HardFault_Handler问题查找方法

一 问题出现

1.1 出现的问题

应用环境:MDK 4.72a

目标芯片:STM32F103VE

错误情况:按键时偶尔死机。

错误详情:在程序进入界面之后,按住“向下键”数次后出现死机,经调试发现程序死在HardFault_Handler函数中。

HardFault_Handler问题查找方法

1.2 关于HardFault

Cortex-M3/4的Fault异常是由于非法的存储器访问(比如访问0地址、写只读存储位置等)和非法的程序行为(比如除以0等)等造成的。常见的4种异常及产生异常的情况如下:

Bus Fault在fetch指令、数据读写、fetch中断向量或中断时存储恢复寄存器栈情况下,检测到内存访问错误则产生Bus Fault。

Memory Management Fault访问了内存管理单元(MPU)定义的不合法的内存区域,比如向只读区域写入数据。

Usage Fault检测到未定义指令或在存取内存时有未对齐。

Hard Fault在调试程序过程中,这种异常最常见。上面三种异常发生任何一种异常都会引起Hard Fault,在上面的三种异常未使能的情况下,默认发生异常时进入Hard Fault中断服务程序。

需要注意的是,在默认复位初始化时,Hard Fault使能,其它三者不使能,因此当程序中出现不合法内存访问(一般是指针错误引起)或非法的程序行为(一般就是数学里面常见的除0)时都将产生Hard Fault中断。

二 问题分析

在网上查找相关资料,发现这种问题主要有以下原因:

1 内存溢出或者访问越界,通常为数组或结构体访问越界。这个需要自己写程序的时候规范代码,遇到了需要慢慢排查。

2 堆栈溢出。增加堆栈的大小。

3 在uCos-III系统中,任务切换时要关中断。

4 没有打开相应的硬件模块但操作了相应的硬件而导致了错误

5 Jlink的问题,禁止用Jlink供电就可以了。在Jlink commander中输入power off,

6程序在添加全局变量的时候会出现sprintf 输出的浮点数不正常,因此尽量不用sprintf函数。

根据大家经验,第一个原因,也就是数组或结构体越界产生的问题的概率最大。

三 问题查找

1 在stm32f10x_it.c中,添加软件断点,一旦调试时出现Hard Fault则会在停在__breakpoint(0)处。

 HardFault_Handler问题查找方法

2 打开Call Stack窗口,在HardFault_Handler中的右键选择“Show Caller Code”

HardFault_Handler问题查找方法

3 程序定位到出错的代码行段。

HardFault_Handler问题查找方法

4 分析出错代码。这段代码是用于字符串复制的。因此可以判断是字符串操作过程中出现错误。HardFault_Handler问题查找方法

继续查找问题,使用Ctrl + F查找“copystr”函数。查找到如下代码。
HardFault_Handler问题查找方法

这是一个结构体的成员进行操作,非常有可能是这个结构体或其成员出现越界。分析出现问题时MenuDisplayIndex值。鼠标选中MenuDisplayIndex,然后右键点击,选择Add to  Watch1.

发现值为102。

HardFault_Handler问题查找方法

而定义MenuData的代码为,可见只有10个成员,是此处发生的结构体越界!

HardFault_Handler问题查找方法

四 问题小结

       问题代码编写调试与问题发现有近两周时间,这段时间里,调试没发现问题,Keil也无任何error或warning。因此很难怀疑之前代码。因此以前写程序时一定要注意书写规范。

 

百度文库地址

http://wenku.baidu.com/view/085b6fbe5022aaea988f0f48.html

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 首先,hardfault_handler 通常是由于程序运行中出现错误或异常导致的。在 ARM Cortex-M 处理器中,当程序访问了未定义的内存地址、执行了无效指令、栈溢出等非法操作时,就会触发 hardfault_handler。 为了查找 hardfault_handler 的原因,可以采取以下步骤: 1. 首先,查看硬件和软件方面是否存在问题。检查硬件连接是否正确,是否有电源不足、多余的设备等。同时,检查程序中是否有语法错误、语义错误、数据异常等问题。 2. 如果硬件和软件方面都没有问题,可以使用调试工具来定位问题。例如,使用 J-Link 调试器等工具,通过读取处理器状态寄存器和堆栈信息来分析 hardfault_handler 的原因。可以查看堆栈信息,查找最后一次正常的函数调用,以及查看函数调用栈。还可以查看错误代码,了解硬件错误类型和原因。 3. 如果无法定位问题,可以通过修改代码进行调试。例如,添加断点、日志、调试信息等等。同时,也可以通过在程序中使用硬件浮点数(FPU)单精度浮点数和双精度浮点数来支持硬件浮点数运算,以防止硬件浮点单元在软件中触发 hardfault_handler。 总之,查找 hardfault_handler 的原因需要通过多种方法和工具来协同完成。只有综合使用各种方法,才能准确定位问题并解决它。 ### 回答2: 在嵌入式系统中,常见的处理器异常是硬件故障(hardfault)。当程序在执行过程中遇到未知的错误或非法操作时,处理器将会抛出一个硬件故障异常。这时,系统会转到硬件故障处理程序(hardfault_handler)中,以便排查并解决问题。 硬件故障处理程序主要用于查找和修复系统中各种硬件及软件故障导致的异常。硬件故障通常指处理器、存储器或其他外部设备的故障。而软件故障通常由程序逻辑错误、内存管理错误等导致。 硬件故障处理程序一般通过记录异常信息来定位问题。处理器会把当前的程序状态保存在堆栈中,并生成一个包含错误类型、错误地址和错误状态等信息的异常记录。我们可以使用调试工具或编写代码,在硬件故障处理程序中读取这些信息,并确定故障的精确原因。 在硬件故障处理程序中,开发人员需要遵循一定的规范和流程。首先是保证程序安全性和效率,然后是尽量减少代码所占用的空间,并且要注意使用可重入函数和非阻塞式代码,避免阻塞整个系统。此外,应尽量优化硬件故障处理程序的执行速度,以迅速恢复系统正常运行。 总之,硬件故障处理程序是嵌入式系统中必不可少的一部分。通过正确的处理,我们能够及时检测和修复系统中各种硬件及软件故障,提高系统的稳定性和可靠性。 ### 回答3: 在嵌入式系统开发中,可能会出现“hardfault”错误,这种错误通常是硬件或软件错误导致的。硬件错误可能包括RAM故障、ROM故障和芯片损坏等,而软件错误可能包括指针错误、数组越界、调用空指针等。这些错误可能会导致程序崩溃或死循环。为了定位这些错误,我们需要用到“hardfault_handler”功能,这个功能通常在ARM Cortex-M处理器中实现。 “hardfault_handler”是一种异常处理程序,用于处理系统中出现的硬件或软件错误。当系统出现错误时,“hardfault_handler”会自动执行,然后可以通过查看系统错误日志来定位错误。这个错误日志通常包括错误原因、错误源、PC值等相关信息。 在实际开发中,我们通常通过以下步骤来查找并定位硬件或软件错误: 1. 启用“hardfault_handler”功能,并记录错误日志 在代码中启用“hardfault_handler”功能,使系统出现错误时可以自动执行并记录错误日志。这个过程通常需要修改系统的相关配置文件或调试工具。 2. 分析错误日志并确定错误源 通过查看错误日志,我们可以确定系统出现错误的原因和源头。例如,如果是RAM故障导致的错误,我们需要检查系统中的内存芯片及其驱动电路;如果是指针错误导致的错误,我们需要检查指针指向的内存地址以及指针的使用方式等。 3. 修复错误源并测试 根据错误日志确定错误源后,我们需要修改相应的代码,修复错误,并进行测试。测试过程需要尽可能地覆盖系统的各个功能模块,以确保系统的稳定性和可靠性。 总之,“hardfault_handler”是一种非常有用的工具,可以帮助我们定位和修复系统中的硬件和软件错误,提高系统的可靠性和稳定性,保证系统的正常运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值