OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3039|回复: 0

stm32旗舰版IAP例程求助。。。

[复制链接]

4

主题

13

帖子

0

精华

初级会员

Rank: 2

积分
54
金钱
54
注册时间
2014-4-3
在线时间
2 小时
发表于 2016-6-6 11:46:12 | 显示全部楼层 |阅读模式
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()处呢???

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-11 08:50

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表