OpenEdv-开源电子网

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

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

[复制链接]

5

主题

36

帖子

0

精华

初级会员

Rank: 2

积分
84
金钱
84
注册时间
2012-11-4
在线时间
1 小时
发表于 2014-10-7 00:43:31 | 显示全部楼层 |阅读模式
5金钱
调试程序的过程中遇到了硬件中断,进入了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的值?真心不懂,虚心求解。

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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165475
金钱
165475
注册时间
2010-12-1
在线时间
2115 小时
发表于 2014-10-7 01:03:10 | 显示全部楼层
帮顶下。
硬件fault一部分是堆栈少了,还有一部分是指针乱指,或者数组越界。
如果不是堆栈问题,那就查查指针和数组。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

5

主题

36

帖子

0

精华

初级会员

Rank: 2

积分
84
金钱
84
注册时间
2012-11-4
在线时间
1 小时
 楼主| 发表于 2014-10-7 01:36:58 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
原子哥,我的堆栈大概有4K,足够用了。我做的是LWIP实验,每次发送644个字节的数据,但是发送19458个字节的后,stm32就进入硬件中断了,如果是数组越界了我想也不会等到发送19458个字节后才进入HardFault_Handler吧,因为每发送644字节后,就又重新从头发送了,
我想查出PC指针在进入HardFault_Handler之前指向何处,以便知道确切的出错地址。我想通过SP倒推出出错前PC所指的位置,然后通过反汇编栏知道是那条语句出错了,但是却发现经过stm32自动压栈后,SP所指的位置的值居然不是R0的值,难道是压栈出错?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165475
金钱
165475
注册时间
2010-12-1
在线时间
2115 小时
发表于 2014-10-7 10:25:37 | 显示全部楼层
回复【3楼】lzw520:
---------------------------------
这个逆向查没有研究过。
我都是顺向查问题的,比如你说的19458字节,既然知道这个地方会出错,我就写一些辅助性的代码,到这个时候,才进入断点调试,然后就是一步步看代码,到底死在哪里了。。。。然后观察各个用到的变量、数组、指针,是否正常,从而排除问题。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

5

主题

36

帖子

0

精华

初级会员

Rank: 2

积分
84
金钱
84
注册时间
2012-11-4
在线时间
1 小时
 楼主| 发表于 2014-10-7 14:02:52 | 显示全部楼层
回复【4楼】正点原子:
---------------------------------
确实是堆栈出了问题,(确切的说应该是堆内存用完了)
找到原因了,改了一下程序,每次发送数据前,动态申请一块内存,发完数据后立马释放掉,下次发数据前再重新申请一块内存,然后程序就正常了。
为什么我不能动态申请一块内存,然后反复利用这块内存,直到不需要这块内存时再释放它?
回复

使用道具 举报

28

主题

1489

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1656
金钱
1656
注册时间
2013-7-24
在线时间
1 小时
发表于 2014-10-7 17:53:16 | 显示全部楼层
看了楼主的帖,寄存器压栈顺序是正确的。给以下思路:
M3的SP有Bank,需要你了解PSP/MSP的使用方式;
判断栈空间地址范围有没有越界(4楼堆越界,可以从栈未使用区域值看出)。
于20150522停用该账号:http://www.microstar.club
回复

使用道具 举报

0

主题

2

帖子

0

精华

新手入门

积分
3
金钱
3
注册时间
2019-5-5
在线时间
0 小时
发表于 2019-5-5 23:13:15 | 显示全部楼层
mark一下
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-4-30 09:08

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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