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

2024-01-10 17:36

本文主要是介绍【笔记------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秒以上才有效,跑的快的就大点,慢的就小点,填错的话后面打印也会提示你运行时间不足,再调整就好了
	#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()

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 值太大而运行速度太慢的时候是要等很久的,此时是没有任何输出的,所以可以先设小点,如果报错再加大
    • 对堆栈有很少量的需求,简单测试的最小测试通过的配置:
      ITERATIONS
    • 在main函数的最后可以加一句方便的打印CoreMarks/MHz,这里48是系统运行频率
      在这里插入图片描述
    • 如果出现时间相关参数没打印出来,如下图,先测试下浮点数打印正常,比如打印个3.14试试,很多平台的printf默认是不支持浮点数的,需要想办法实现下,这里贴个RTTview的浮点实现备忘(原文链接:https://blog.csdn.net/jiayujiang/article/details/119216304)。。
      在这里插入图片描述
        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;
    

这篇关于【笔记------coremark】单片机上的跑分库coremark移植的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/591553

相关文章

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

论文阅读笔记: Segment Anything

文章目录 Segment Anything摘要引言任务模型数据引擎数据集负责任的人工智能 Segment Anything Model图像编码器提示编码器mask解码器解决歧义损失和训练 Segment Anything 论文地址: https://arxiv.org/abs/2304.02643 代码地址:https://github.com/facebookresear

数学建模笔记—— 非线性规划

数学建模笔记—— 非线性规划 非线性规划1. 模型原理1.1 非线性规划的标准型1.2 非线性规划求解的Matlab函数 2. 典型例题3. matlab代码求解3.1 例1 一个简单示例3.2 例2 选址问题1. 第一问 线性规划2. 第二问 非线性规划 非线性规划 非线性规划是一种求解目标函数或约束条件中有一个或几个非线性函数的最优化问题的方法。运筹学的一个重要分支。2

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

查看提交历史 —— Git 学习笔记 11

查看提交历史 查看提交历史 不带任何选项的git log-p选项--stat 选项--pretty=oneline选项--pretty=format选项git log常用选项列表参考资料 在提交了若干更新,又或者克隆了某个项目之后,你也许想回顾下提交历史。 完成这个任务最简单而又有效的 工具是 git log 命令。 接下来的例子会用一个用于演示的 simplegit

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

忽略某些文件 —— Git 学习笔记 05

忽略某些文件 忽略某些文件 通过.gitignore文件其他规则源如何选择规则源参考资料 对于某些文件,我们不希望把它们纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。通常它们都是些自动生成的文件,比如日志文件、编译过程中创建的临时文件等。 通过.gitignore文件 假设我们要忽略 lib.a 文件,那我们可以在 lib.a 所在目录下创建一个名为 .gi

取得 Git 仓库 —— Git 学习笔记 04

取得 Git 仓库 —— Git 学习笔记 04 我认为, Git 的学习分为两大块:一是工作区、索引、本地版本库之间的交互;二是本地版本库和远程版本库之间的交互。第一块是基础,第二块是难点。 下面,我们就围绕着第一部分内容来学习,先不考虑远程仓库,只考虑本地仓库。 怎样取得项目的 Git 仓库? 有两种取得 Git 项目仓库的方法。第一种是在本地创建一个新的仓库,第二种是把其他地方的某个