[求助] 关于LPC1788在线升级程序无法从IAP跳到APP

Heguoyao   2015-11-23 09:55 楼主
悬赏 10 分 芯积分未解决
我在做LPC1788在线上升级系统,我的方案是:自己开发一个上位机将keil编译好的APP的.hex文件读出来,并通过usb转CAN发到LPC1788的CAN上,然后调用芯片自带的IAP将数据写到Flash上,可是无法从IAP跳到APP,我的跳转方法是1、SCB->VTOR = APP_START_ADDR & 0x1FFFFF80;        2、 (*app)();      可是没有跳过去成功执行APP(APP里面在让调试灯闪烁),谁来帮我解决这问题,赏金给谁了,我的qq:1223237156 邮箱:1223237156@qq.com 万分感谢

回复评论 (11)

我看大家都是都是用bin文件,难道不能用hex文件吗
点赞  2015-11-23 09:59
为啥没人来,是不是赏金不够?可是最大值也就是10呀
点赞  2015-11-23 10:04
顶一个
点赞  2015-11-23 10:04
先仿真看看,是没有跳转,还是跳转后没有执行。
我的博客
点赞  2015-11-23 10:14
引用: zhaojun_xf 发表于 2015-11-23 10:14
先仿真看看,是没有跳转,还是跳转后没有执行。

没有仿真器,我整个IAP程序基本都是和你一样的,只是我用can来获取这个要升级程序
点赞  2015-11-23 10:23
引用: Heguoyao 发表于 2015-11-23 10:23
没有仿真器,我整个IAP程序基本都是和你一样的,只是我用can来获取这个要升级程序

最好仿真一下,确定问题所在,你现在并不能说明是没有跳转,有可能是跳转了没有运行,也可能是中断向量映射有问题。
我的博客
点赞  2015-11-23 10:51
引用: zhaojun_xf 发表于 2015-11-23 10:14
先仿真看看,是没有跳转,还是跳转后没有执行。

执行跳转,可是程序跑去复位了
点赞  2015-11-23 14:18
引用: Heguoyao 发表于 2015-11-23 14:18
执行跳转,可是程序跑去复位了

跳转后到复位,并不一定是因为跳转后复位,有可能是跳转后,执行某些代码导致复位,所以最好仿真看看,是那些代码导致复位的
我的博客
点赞  2015-11-23 15:05
已经成功解决问题了,原因就是我的APP编译前没有在keil编译器设置工程的入口地址为APP的地址,由于工程里面所有的函数的在flash真实入口地址、以及所有的变量在flash真实地址都是其相对工程入口地址的偏移量加上工程入口地址,这一点可以在keil设置工程两个入口地址,然后编译,在比较两个编译后的hex文件的数据,你就发现,代表地址的数据是不一样
点赞  2015-11-24 09:24
引用: Heguoyao 发表于 2015-11-23 09:59
我看大家都是都是用bin文件,难道不能用hex文件吗

可以用hex文件,hex文件按照hex文件的协议将数据读出来,这些数据就是bin文件的数据,也就是说hex文件有数据的地址信息、该行数据长度信息、数据类型信息、数据偏移地址信息、校检信息、以及用ascll表示的数据(bin中是用2进制表示),把hex文件的用ascll表示的数据转化为二进制,就是bin文件
点赞  2015-11-24 09:35
引用: zhaojun_xf 发表于 2015-11-23 15:05
跳转后到复位,并不一定是因为跳转后复位,有可能是跳转后,执行某些代码导致复位,所以最好仿真看看,是 ...

谢谢版主,已经找到问题了,就是app编译前工程入口地址设置为零,结果程序跳过去后执行启动代码,而启动代码里面装着的复位中断函数入口地址刚好就是IAP的复位中断函数地址(是由入口地址设置为零造成的,如果设为APP的地址,那么这里装着的地址就是APP启动代码中正确的复位中断函数),如果不去认真剖析启动代码,就无法理解整个工程编译完后第一个数据(4byte)是栈的入口地址,第二个数据是复位中断入口地址,后面的是其他中断入口地址,程序都首先去执行复位中断入口地址,这个复位中断会执行一些系统性的函数(SystemInit),然后执行编译器自带的_main函数,_main函数会自动引导到我们写main()函数,这几天被这个跳转问题折腾的要命,但也令我学到了很多东西
点赞  2015-11-24 13:58
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复