CoreMark移植过程记录

以Cortex M0为例

1. 下载CoreMark

官网地址:http://www.eembc.org/coremark/index.php

代码在github上:https://github.com/eembc/coremark

2. 拷贝对应的文件到自己的工程文件夹,注意main函数已经在core_main.c中。

core_list_join.c
core_main.c
core_matrix.c
core_state.c
core_util.c
coremark.h
simple/core_portme.c
simple/core_portme.h

其中core_portme.c和core_portme.h是和MCU相关的,主要移植这个文件

3. 将coremark.h所在文件夹位置设为include的路径

4. 修改core_portme.c中的portable_init,加入平台的初始化代码

5. 在core_portme.h里面添加宏定义,数字根据具体的MCU填写。

#define ITERATIONS      2000

这个宏定义表示迭代次数,CoreMark要求程序运行的最短时间至少是10s, 根据使用的系统时钟等情况设置这个参数。

6. 根据编译环境和配置修改宏定义COMPILER_FLAGS

#ifndef COMPILER_FLAGS
#define COMPILER_FLAGS \
    "-O"/* "Please put compiler flags here (e.g. -o3)" */
#endif

7. 如不使用标准的printf函数,需要定义ee_printf,在里面去掉HAS_PRINTF的定义,然后增加ee_printf的定义

/*
#ifndef HAS_PRINTF
#define HAS_PRINTF 1
#endif
*/
#define ee_printf Printf

8. 修改Timer部分的代码,使用SysTick计数

void
start_time(void)
{
    //GETMYTIME(&start_time_val);
    gTick = 0;
    SysTick_Config(((SystemCoreClock / 1000) * 1));
}

void
stop_time(void)
{
    //GETMYTIME(&stop_time_val);
    SysTick->CTRL &= 0xFFFFFFFE;
}

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

9. 添加Systick中断函数

uint32_t gTick = 0;
void SysTick_Handler(void)
{
    gTick++;
}

10. 修改宏定义EE_TICKS_PER_SEC,改为Systick的中断时间修改,表示每秒多少个Tick。

#define EE_TICKS_PER_SEC           1000

一些MCU的CoreMark得分:

1. MM32L073: 44.44

2. FT900: 142.85

3. STM32F103:86.95

C906 E203 CoreMark是一种基准测试程序,用于评估处理器内核的性能。移植这个程序意味着将其从一个处理器平台移植到另一个处理器平台,以测试新平台的性能。 移植C906 E203 CoreMark可以通过以下步骤实现: 首先,需要了解目标处理器的架构和指令集。这是因为不同的处理器平台具有不同的指令集和架构,而程序必须根据特定的架构和指令集进行适当的修改和优化。 其次,需要对C906 E203 CoreMark程序进行源代码分析,理解其工作原理和核心算法。这将有助于正确理解程序的逻辑和数据流,并为移植过程中的代码修改和优化提供指导。 然后,根据目标处理器的架构和指令集,对源代码进行相应的修改和优化。这可能涉及到调整代码结构、使用处理器特定的指令和优化算法,以提高性能和效率。 最后,编译和链接修改后的源代码,生成可在目标处理器上运行的可执行文件。确保编译选项正确设置,以充分利用处理器的所有功能和优化。 在移植完成后,需要进行测试和评估,以验证程序在新平台上的正确性和性能。可以使用C906 E203 CoreMark程序自身的性能评估功能来比较不同处理器平台之间的性能差异。 总的来说,移植C906 E203 CoreMark需要深入了解目标处理器的架构和指令集,进行代码分析和修改,以及测试和评估。这样可以确保在新平台上获得准确的性能评估结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值