【笔记------coremark】单片机上的跑分库coremark移植

coremark的官方仓库:https://github.com/eembc/coremark

官方收录了很多单片机的跑分情况:https://www.eembc.org/coremark/scores.php

这个是我建立的一个仓库,用来收集自己用到的一些单片机的跑分情况:https://gitee.com/wild_coder/coremark_test,欢迎共建(现在还没两个,后面遇到新的会慢慢添加。。。)

  1. 文件添加,代码下载好是这样的,把如下部分的头文件和源文件添加到自己的工程:
  2. 把自己的main()函数注释掉,因为core_main.c中已经有一个了。然后打开core_portme.h,搜索COMPILER_FLAGS,根据自己的编译器优化选项填上去,不同优化等级分数差距会非常大:
  1. core_portme.h最上面定义这个常量 ITERATIONS ,这个常量是运算的次数,不是固定的,因为这个跑分需要算法运行10秒以上才有效,跑的快的就大点,慢的就小点,填错的话后面打印也会提示你运行时间不足,再调整就好了
c 复制代码
	#define ITERATIONS 1000
  1. 修改下main函数参数类型

  2. core_portme.c中添加自己的系统初始化,时钟和打印初始化这些,我这里初始化了时钟和打印接口,然后再coremark.h文件中搜索HAS_PRINTF,按需映射下ee_printf

  3. core_portme.c中适配自己的定时器,EE_TICKS_PER_SEC=1000即使用1ms的定时器中断:

    主要是四个函数,start_time(),stop_time(),get_time(),和自己平台的一个定时器函数如Tim1_IRQHandler()

c 复制代码
uint32_t gTick = 0;
void
start_time(void)
{
//    GETMYTIME(&start_time_val);
	gTick = 0;
	Bt_M0_Run(TIM1); 
}

void
stop_time(void)
{
//    GETMYTIME(&stop_time_val);
	Bt_M0_Stop(TIM1); 
}

CORE_TICKS
get_time(void)
{
//    CORE_TICKS elapsed
//        = (CORE_TICKS)(MYTIMEDIFF(stop_time_val, start_time_val));
    return (CORE_TICKS)gTick;
}

//在对应中断文件中修改
extern uint32_t gTick;
void Tim1_IRQHandler(void)               //1ms
{
	static uint8_t cnt_5ms_flag = 0;
	static uint16_t cnt_1s_flag = 0;
    if(TRUE == Bt_GetIntFlag(TIM1, BtUevIrq))
    {
		gTick++;
        Bt_ClearIntFlag(TIM1,BtUevIrq);  //Timer3模式0 中断标志清除
    }
}

没了,,,跑个分试试,这个是华大的hc32l136:

  • 其他注意

    • ITERATIONS 值太大而运行速度太慢的时候是要等很久的,此时是没有任何输出的,所以可以先设小点,如果报错再加大
    • 对堆栈有很少量的需求,简单测试的最小测试通过的配置:
    • 在main函数的最后可以加一句方便的打印CoreMarks/MHz,这里48是系统运行频率
    • 如果出现时间相关参数没打印出来,如下图,先测试下浮点数打印正常,比如打印个3.14试试,很多平台的printf默认是不支持浮点数的,需要想办法实现下,这里贴个RTTview的浮点实现备忘(原文链接:https://blog.csdn.net/jiayujiang/article/details/119216304)。。
    c 复制代码
        case 'f':
        case 'F':
        {
         float fv;
         fv = (float)va_arg(*pParamList, double);    //取出输入的浮点数值
        
         v = (int)fv;                                //取整数部分
        
         _PrintInt(&BufferDesc, v, 10u, NumDigits, FieldWidth, FormatFlags); //显示整数,支持负数
        _StoreChar(&BufferDesc, '.');                                        //显示小数点
        
         v = abs((int)(fv * 100));               
         v = v % 100;
        _PrintInt(&BufferDesc, v, 10u, 2, FieldWidth, FormatFlags);          //显示小数点后两位
        }
        break;
相关推荐
之歆9 分钟前
Python-封装和解构-set及操作-字典及操作-解析式生成器-内建函数迭代器-学习笔记
笔记·python·学习
天天爱吃肉82181 小时前
ZigBee通信技术全解析:从协议栈到底层实现,全方位解读物联网核心无线技术
python·嵌入式硬件·物联网·servlet
东风点点吹1 小时前
STM32F103的boot跳转APP不成功问题排除
stm32·单片机·嵌入式硬件
DKPT2 小时前
Java组合模式实现方式与测试方法
java·笔记·学习·设计模式·组合模式
受之以蒙2 小时前
Rust & WASM 之 wasm-bindgen 基础:让 Rust 与 JavaScript 无缝对话
前端·笔记·rust
茫忙然3 小时前
【WEB】Polar靶场 6-10题 详细笔记
笔记
eric*16883 小时前
尚硅谷张天禹老师课程配套笔记
前端·vue.js·笔记·vue·尚硅谷·张天禹·尚硅谷张天禹
猫猫的小茶馆3 小时前
【STM32】预分频因子(Prescaler)和重装载值(Reload Value)
c语言·stm32·单片机·嵌入式硬件·mcu·51单片机
Allen_LVyingbo4 小时前
数智读书笔记系列035《未来医疗:医疗4.0引领第四次医疗产业变革》
人工智能·经验分享·笔记·健康医疗
岑梓铭4 小时前
考研408《计算机组成原理》复习笔记,第三章(3)——多模块存储器
笔记·考研·408·计算机组成原理