OpenEdv-开源电子网

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

STM32硬件错误HardFault_Handler的处理方法

[复制链接]

9

主题

50

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
488
金钱
488
注册时间
2017-7-5
在线时间
102 小时
发表于 2018-5-4 16:08:41 | 显示全部楼层 |阅读模式

      之前调程序,发现一会就跑死,刚开始我创建三个任务,其中一个程序运行指示灯,一个任务处理通信,一个上传板卡报警值,一切正常,但我添加了几个功能后,之后程序异常,仿真发现程序停在configASSERT( ( portNVIC_INT_CTRL_REG & portVECTACTIVE_MASK ) == 0 ); 由于是刚学FreeRTOS,经验不足,对堆栈、内存等不很了解,不知道问题出在哪,边找解决方案边修改,最终发现是HardFault_Handler问题,由于水平不高,在参考网上解决方案时,觉得是内存溢出,改了半天没反应,后来一想会不会是堆栈溢出,于是把任务堆栈改大,几乎没效果,最后尝试把数组改大,发现程序多运行了一会,还是跑飞,继续改大,没效果,于是判定是数组越界,至此有了解决方向,查找数组相关程序,问题解决。

  下面附上解决方案,说一下出现HardFault_Handler,我觉得应该首先查看堆栈大小和数组越界,十有八九就是这两个问题。




在用Keil对STM32的程序进行仿真时程序有时会跑飞,停止仿真程序会停在HardFault_Handler函数里的死循环while(1)中。这说明STM32出现了硬件错误。



        STM32出现硬件错误可能有以下原因:

        (1)数组越界操作;

        (2)内存溢出,访问越界;

        (3)堆栈溢出,程序跑飞;

        (4)中断处理错误;

        遇到这种情况,可以通过以下2种方式来定位到出错代码段。


方法1:

      1.1在硬件中断函数HardFault_Handler里的while(1)处打调试断点,程序执行到断点处时点击“STOP”停止仿真。



      1.2 在Keil菜单栏点击“View”——“Registers Window”,在寄存器查看窗口查找R14(LR)的值。如果R14(LR) = 0xFFFFFFE9,继续查看MSP(主堆栈指针)的值,如果R14(LR) = 0xFFFFFFFD,继续查看PSP(进程栈指针)的值。我的程序R14(LR) = 0xFFFFFFF9,接下来以此为例。



      1.3 在Keil菜单栏点击“View”——“Memory Windows”——“Memory1”,在“Address”地址栏中输入MSP的值:0x20001288,然后在对应的行里找到地址。地址一般以0x08开头的32位数。本例中,地址为0x08003CB9。



      1.4 在Keil菜单栏点击“View”——“Disassembly Window”,在“Disassembly”窗口中右击,在下拉菜单中选择“Show Disassemblyat Address...”。在弹出框“Show Code atAdress”的地址框中输入地址0x08003CB9进行搜索,然后就会找到相对应的代码。这里的代码就是进入循环中断之前的情况。仔细查看附近区域的相关代码来排查错误具体原因。



方法2:

      2.1在硬件中断函数HardFault_Handler里的while(1)处打调试断点,程序执行到断点处时点击“STOP”停止仿真。

      2.2 在Keil菜单栏点击“View”——“Call Stack Window”弹出“Call Stack + Locals”对话框。然后在对话框中右键选择“Show Caller Code”,就会跳转到出错之前的函数处,仔细查看这部分函数被调用或者数组内存使用情况。



版权声明:本文为博主原创文章,转载请注明转载地址。http://blog.csdn.net/electrocrazy        https://blog.csdn.net/electrocrazy/article/details/78173558

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

使用道具 举报

11

主题

200

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1154
金钱
1154
注册时间
2014-11-9
在线时间
228 小时
发表于 2018-5-4 17:00:19 | 显示全部楼层
在我看来、出现硬件错误很多都是数组越界。
回复 支持 反对

使用道具 举报

9

主题

50

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
488
金钱
488
注册时间
2017-7-5
在线时间
102 小时
 楼主| 发表于 2018-5-7 11:19:32 | 显示全部楼层
黄伟达 发表于 2018-5-4 17:00
在我看来、出现硬件错误很多都是数组越界。

我也是这样觉得。别的情况几乎遇不到
回复 支持 反对

使用道具 举报

10

主题

81

帖子

0

精华

初级会员

Rank: 2

积分
149
金钱
149
注册时间
2018-5-8
在线时间
27 小时
发表于 2018-5-8 10:22:21 | 显示全部楼层
HardFault_Handler
回复 支持 反对

使用道具 举报

20

主题

38

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
272
金钱
272
注册时间
2019-4-28
在线时间
80 小时
发表于 2020-8-17 10:09:17 | 显示全部楼层
各位大佬,我有个问题,我进入HardFault_Handler调试发现并未用到数组,只是用到了HAL_Delay(1000);,没有这行代码就没有问题,用了就进入死机了。HAL_Delay用在主函数中,程序中使用了串口中断,中断中没有使用HAL_Delay
详情:http://www.openedv.com/forum.php ... d=315509&extra=
回复 支持 反对

使用道具 举报

6

主题

35

帖子

1

精华

中级会员

Rank: 3Rank: 3

积分
421
金钱
421
注册时间
2014-4-1
在线时间
11 小时
发表于 2020-11-7 16:11:53 | 显示全部楼层
宇我所有 发表于 2018-5-7 11:19
我也是这样觉得。别的情况几乎遇不到

我只想说,you are too young too simple.
回复 支持 反对

使用道具 举报

5

主题

63

帖子

0

精华

初级会员

Rank: 2

积分
182
金钱
182
注册时间
2019-10-7
在线时间
36 小时
发表于 2020-12-18 10:50:36 | 显示全部楼层
感谢分享,请问如果是数组越界,如何查找是哪个数组越界了呢?
回复 支持 反对

使用道具 举报

0

主题

21

帖子

0

精华

初级会员

Rank: 2

积分
101
金钱
101
注册时间
2019-5-9
在线时间
22 小时
发表于 2020-12-25 09:40:06 | 显示全部楼层
加看门狗管用吗? 我加了看门狗, 好像不顶用
回复 支持 反对

使用道具 举报

5

主题

133

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1775
金钱
1775
注册时间
2015-3-13
在线时间
270 小时
发表于 2022-8-2 20:21:33 来自手机 | 显示全部楼层
两个方法都没用
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-22 17:57

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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