本帖最后由 freeelectron 于 2023-5-24 10:29 编辑
#申请原创#
CoreMark是一项测试处理器性能的基准测试。代码使用C语言写成,包含:列举,数学矩阵操作和状态及CRC等运算法则;
目前CoreMark已迅速成为测量与比较处理器性能的业界标准基准测试。CoreMark的得分越高,意味着性能更高;
CoreMark官网的连接地址:http://www.eembc.org/coremark;
本文将一步步来介绍如何将下载的CoreMark测试代码移植到SWDM-QFP100-34SVEA3开发板上进行测试。
源码地址 https://github.com/eembc/coremark
1、源码结构
主要分为两部分,源码和接口代码,其中接口代码针对不同的平台,有不同的文件夹,针对单片机,我们使用simple文件夹中的即可。
2、将代码添加进工程
3、编译报错处理
FLAGS STR:优化等级,需要替换,这里要与编译器的优化等级一致,本次移植设置为:
#define COMPILER_FLAGS "-o3" ;
ITERATIONS:算法运行的次数,这个值的设置必须确保,运行的时间大于10s,否则,会报错,本次移植设置为:
4、main函数重复定义
在core_main.c文件中的main函数与原来工程中的重复,修改为core_main:
5、启动时间、停止时间、获取当前时间函数接口
使用定时器4实现了一个1ms中断一次的计数器
start_time(void):启动时间
void
start_time(void)
{
// GETMYTIME(&start_time_val);
start_time_val=(CORETIMETYPE)GetSystemTick();
}
stop_time:结束时间
void
stop_time(void)
{
// GETMYTIME(&stop_time_val);
stop_time_val=(CORETIMETYPE)GetSystemTick();
}
get_time:运行时间,停止时间计数减去启动时间,两个的差就是运行时间
CORE_TICKS
get_time(void)
{
CORE_TICKS elapsed
= (CORE_TICKS)(MYTIMEDIFF(stop_time_val, start_time_val));
return elapsed;
}
6、时间颗粒度定义
由于我们是1ms中断一次,即就是1ms计数一次,那么1s就需要1000次计数,所以有如下定义:
#define EE_TICKS_PER_SEC 1000
7、主函数
int main(void)
{
int argc;
char *argv[]={"1","2"};
SystemInit();
TimerInit();
LedInit();
SerialInit();
DelayInit();
printf("SystemCoreClock=%d\r\n",SystemCoreClock);
core_main(argc,argv);
while(1)
{
SystemRun();
}
}
8、下载运行
可以看出,使用mdk编译,优化等级设置为3,在120MHZ的时候跑分为315。
|