对于独立的嵌入式系统,需要把程序存入non-volitale存储单元中,常用的也就是flash。但是程序在flash中运行相对在ram中行,速度会变慢很多,具体有多慢,拿28335来说吧,假设系统时钟为150MHz,在ram中运行时频率还是150Mhz,而放在flash中,频率会降到90-95Mhz,参照Ti手册SPRA958L,这对于有些对实时性要求较高的函数功能,是不可接受的。所以在系统上电时,把对实时性要求高的函数转移到ram中去。
下面以initflash函数为例具体步骤如下:
(1)、将函数定位到section:
#pragma CODE_SECTION(InitFlash, "secureRamFuncs")
当遇到InitFlash(),就到段secureRamFuncs去运行。
当有多个函数需要转移时,重复使用#pragma CODE_SECTION(“函数名",
"secureRamFuncs")即可。
即使有多个#pragma CODE_SECTION,后面的步骤只需要一次。
(2)、section分配到memory(红 {MOD}为memory)。
意思是到FLASH去下载InitFlash(),下载到SECURE_RAM,然后要到SECURE_RAM去运行程序,这个过程给出了下载地址和目标地址。注意此时SECURE_RAM中还没有代码。
SECTIONS
{
/*** User Defined Sections ***/
secureRamFuncs: LOAD = FLASH,PAGE = 0
RUN =SECURE_RAM, PAGE = 0
//定义FLASH和SECURE_RAM的首地址secureRamFuncs_loadstart和secureRamFuncs_loadstart以代替绝对地址
LOAD_START(_secureRamFuncs_loadstart),
LOAD_SIZE(_secureRamFuncs_loadsize),
RUN_START(_secureRamFuncs_runstart),
}
(3)、用memcpy()将经过#pragmaCODE_SECTION设定的函数从FLASH弄到SECURE_RAM中去。注意不是将FLASH的东西全部弄到SECURE_RAM中。
#include
//实际应用中这一部分声明可有可无
extern unsigned intsecureRamFuncs_loadstart;
extern unsigned intsecureRamFuncs_loadsize;
extern unsigned intsecureRamFuncs_runstart;
void main(void)
{
/* Copy the secureRamFuncs section */
memcpy(&secureRamFuncs_runstart,&secureRamFuncs_loadstart,(Uint32)&secureRamFuncs_loadsize);
/* Initialize the on-chip flash registers*/
InitFlash();
}