怎样调试STM32硬件错误HardFault
2024-08-09 来源:elecfans
在用 Keil 对STM32的程序进行仿真时程序有时会跑飞,停止仿真程序会停在HardFault_Handler 函数里的死循环while(1)中。
这说明 STM32 出现了硬件错误。
硬件错误中断
STM32出现硬件错误可能有以下原因:
数组越界操作;
内存溢出,访问越界;
堆栈溢出,程序跑飞;
中断处理错误;
遇到这种情况,可以通过以下2种方式来定位到出错代码段。
方法1:
在硬件中断函数HardFault_Handler里的while(1)处打调试断点,程序执行到断点处时点击STOP停止仿真。
示例
在Keil菜单栏点击View——Registers Window,在寄存器查看窗口查找R14(LR)的值。
如果R14(LR) = 0xFFFFFFE9,继续查看MSP(主堆栈指针)的值;如果R14(LR) = 0xFFFFFFFD,继续查看PSP(进程栈指针)的值;
我的程序R14(LR) = 0xFFFFFFF9,接下来以此为例。
寄存器信息
在Keil菜单栏点击“View”——“Memory Windows”——“Memory1”;
在“Address”地址栏中输入MSP的值:0x20001288,然后在对应的行里找到地址。
地址一般以 0x08 开头的32位数。本例中,地址为0x08003CB9。
内存信息
在Keil菜单栏点击View——Disassembly Window,在Disassembly窗口中右击,在下拉菜单中选择Show Disassemblyat Address...。
在弹出框Show Code atAdress的地址框中输入地址0x08003CB9进行搜索,然后就会找到相对应的代码。这里的代码就是进入循环中断之前的情况。
仔细查看附近区域的相关代码来排查错误具体原因。

方法2:
在硬件中断函数HardFault_Handler里的while(1)处打调试断点,程序执行到断点处时点击“STOP”停止仿真。
CallStack
在Keil菜单栏点击View——Call Stack Window弹出Call Stack + Locals对话框。
然后在对话框中右键选择Show Caller Code,就会跳转到出错之前的函数处,仔细查看这部分函数被调用或者数组内存使用情况。
- RK3568开发板的JTAG仿真方案:突破AMP架构调试瓶颈
- IAR与英飞凌共同推出DRIVECORE软件包及AURIX™ RISC‑V调试方案,全面加速SDV开发进程
- M4-R1 开源鸿蒙(OpenHarmony)开发板:串口调试助手实战案例
- 工业现场CCLink至以太网网关调试:实现KUKA机器人与三菱PLC通讯
- 嵌入式C开发环境构建指南:工具链配置、Makefile编写与调试实战
- M4-R1 OpenHarmony开发板串口调试助手实现教程
- STM32CubeIDE使用说明_3 —— 实时调试
- vofa+ : 优雅のSTM32串口调试
- STM32调试诊断工具 | STM32CubeMonitor介绍、下载、安装和使用教程
- STM32开发之VSCode+GDB下载调试
- 六大全新产品系列推出,MCX A微控制器家族迎来创新
- 意法半导体全新STM32C5系列,重新定义入门级微控制器性能与价值,赋能万千智能设备
- 从控制到系统:TI利用边缘AI重塑嵌入式MCU的边界
- 模组复用与整机重测在SRRC、CCC、CTA/NAL认证中的实践操作指南
- 有源晶振与无源晶振的六大区别详解
- 英飞凌持续巩固全球微控制器市场领导地位
- 使用 Keil Studio for Visual Studio Code开发 STM32 设备
- 蓝牙信道探测技术原理与开发套件实践
- LoRa、LoRaWAN、NB-IoT与4G DTU技术对比及工业无线方案选型分析
- Microchip 推出生产就绪型全栈边缘 AI 解决方案,赋能MCU和MPU实现 智能实时决策




