stm32进入硬件中断后,SP指针指向的地址所存的值为何不是R0的值?

2019-07-20 02:08发布

调试程序的过程中遇到了硬件中断,进入了HardFault_Handler(void),调试如图,
SP的值为0x200099a0,查出内存0x00099a0处存放着0xe000ed04,该值显然和R0里面的值不一样,不知道为什么?
《CM3权威指南》里第141页说:“响应异常的第一个行动,就是自动保存现场的必要部分:依次把xPSR, PC, LR, R12以及R3-R0由硬件自动压入适当的堆栈中”,如图:


我对调试不太懂,遇到HardFault_Handler我就不知道咋办了,
(   以前增大启动文件里堆栈的大小似乎可以解决一些问题。现在堆栈已经足够大了,并且查了一下output文件夹里的.htm文件,

Maximum Stack Usage = 624 bytes + Unknown(Functions without stacksize, Cycles, Untraceable Function Pointers)

Call chain for Maximum Stack Depth:

最大栈大小>624,我分配了大于2K的栈空间   ),
我只是想说SP所指地址存放的值为何不是R0的值?真心不懂,虚心求解。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
6条回答
lzw520
2019-07-20 05:39
回复【2楼】正点原子:
---------------------------------
原子哥,我的堆栈大概有4K,足够用了。我做的是LWIP实验,每次发送644个字节的数据,但是发送19458个字节的后,stm32就进入硬件中断了,如果是数组越界了我想也不会等到发送19458个字节后才进入HardFault_Handler吧,因为每发送644字节后,就又重新从头发送了,
我想查出PC指针在进入HardFault_Handler之前指向何处,以便知道确切的出错地址。我想通过SP倒推出出错前PC所指的位置,然后通过反汇编栏知道是那条语句出错了,但是却发现经过stm32自动压栈后,SP所指的位置的值居然不是R0的值,难道是压栈出错?

一周热门 更多>