初级会员

- 积分
- 102
- 金钱
- 102
- 注册时间
- 2013-10-29
- 在线时间
- 6 小时
|
原子哥IAP例程中,执行这段程序时:
①:
if(key==KEY_LEFT)
{
printf("开始执行FLASH用户代码!!\r\n");
if(((*(vu32*)(FLASH_APP1_ADDR+4))&0xFF000000)==0x08000000)//判断是否为0X08XXXXXX.
{
iap_load_app(FLASH_APP1_ADDR);//执行FLASH APP代码
}else
{
printf("非FLASH应用程序,无法执行!\r\n");
LCD_ShowString(60,210,200,16,16,"Illegal FLASH APP!");
}
clearflag=7;//标志更新了显示,并且设置7*300ms后清除显示
}
②:
//跳转到应用程序段
//appxaddr:用户代码起始地址.
void iap_load_app(u32 appxaddr)
{
if(((*(vu32*)appxaddr)&0x2FFE0000)==0x20000000) //检查栈顶地址是否合法.
{
jump2app=(iapfun)*(vu32*)(appxaddr+4); //用户代码区第二个字为程序开始地址(复位地址)
MSR_MSP(*(vu32*)appxaddr); //初始化APP堆栈指针(用户代码区的第一个字用于存放栈顶地址)
jump2app(); //跳转到APP.
}
}
在执行FLASH中的APP时,其中的①中iap_load_app(FLASH_APP1_ADDR)这个函数有执行吗?
如果“#define FLASH_APP1_ADDR 0x08010000 //第一个应用程序起始地址(存放在FLASH)”的话,那么((appxaddr)&0x2FFE0000)应该不等于0x20000000吧?
|
|