初级会员

- 积分
- 54
- 金钱
- 54
- 注册时间
- 2014-4-3
- 在线时间
- 2 小时
|
1金钱
原子老师:
您好!我在看您的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后清除显示
}
FLASH_APP1_ADDR被宏定义成了“#define FLASH_APP1_ADDR 0x08010000 //第一个应用程序起始地址(存放在FLASH)”
而iap_load_app()函数原型如下:
//跳转到应用程序段
//appxaddr:用户代码起始地址.
void iap_load_app(u32 appxaddr)
{
if(((*(vu32*)appxaddr)&0x2FFE0000)==0x20000000) //检查栈顶地址是否合法.
{
jump2app=(iapfun)*(vu32*)(appxaddr+4); //用户代码区第二个字为程序开始地址(复位地址)
MSR_MSP(*(vu32*)appxaddr); //初始化APP堆栈指针(用户代码区的第一个字用于存放栈顶地址)
jump2app(); //跳转到APP.
}
}
如此,函数怎么会执行到jump2app()处呢???
|
|