IAP实现,程序跳转疑问

2019-07-21 01:35发布

最近在实现无线(WIFI)升级程序功能,看了相关资料后,发现程序跳转是通过获取并调用ResetHandler的函数指针来实现的,这样调用是属于中断调用还是普通调用,这里是简单的函数调用还是说有一系列其他隐含操作?从bootloader程序跳转到app程序时,栈和堆会不会被初始化,会的话是在什么时候,是怎么进行的?
谢谢您的解答!
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
7条回答
zc123
2019-07-21 02:49
这不是栈和堆初始化的问题,而是跳到应用代码后,栈和堆指向的就不是同一个地址。
我这正好有升级代码和应用代码,可以详细的举例
bootloder:
生成的二进制文件


小端模式,所以偏移0x00位的数据为0x020010B0,对比map表


就知道这儿放的是主堆栈顶地址(0x200010b0)。
在参考跳转后的application:


.map文件


可以知道跳转后的主堆栈顶地址是(0x20013000)
跳转代码里__set_MSP(*(__IO uint32_t*)USER_APPLICATION_FIRST_ADDRESS);
重新定义了栈顶地址,就已经修改了堆栈。
M3权威指南里说过,M3的堆栈是向下生长的满栈,那么就可以很清晰的明了,bootloader和application的栈顶地址不一样,也就是说用的堆栈根本就在内存的不同区域,也就没有什么初始化一说。
因为这个问题,我还想到既然bootloader也建立的堆栈,会不会这部分无法使用造成内存泄漏呢?
还是.map文件解决了这个问题:


这是应用代码的内存占用,也就是说和bootloder重叠的部分仍然被分配了数据。所以当跳转的application时,bootloder的那部分内存就被application的数据覆盖了,也就是原有堆栈已经没有意义,作为application的普通内存使用了。

一周热门 更多>