本文为CSDN引用,过来给大家看看,很有帮助的!!!!- y: u6 m6 q# Q 原文地址如下:连接 , u! k* h% x! Y0 B$ Z; { 在用Keil对STM32的程序进行仿真时程序有时会跑飞,停止仿真程序会停在HardFault_Handler函数里的死循环while(1)中。这说明STM32出现了硬件错误。 STM32出现硬件错误可能有以下原因:) J+ r5 d8 ]5 J0 ]. c4 [ ( L; N4 X) O, p% S5 \8 D% i' y* o (1)数组越界操作;! S; V# g5 ]0 Z8 j X0 [7 f p, }" H# m, a9 h (2)内存溢出,访问越界; (3)堆栈溢出,程序跑飞;+ U6 o# r' e1 X9 x5 B ' Y. K9 u& y* |6 b (4)中断处理错误;" ?/ i9 B R5 { h+ Q5 U# T 6 k3 I0 a$ Y& G4 {, O 遇到这种情况,可以通过以下2种方式来定位到出错代码段。 2 b7 Y6 q, ]9 t$ j% a6 X, e 方法1: 1.1在硬件中断函数HardFault_Handler里的while(1)处打调试断点,程序执行到断点处时点击“STOP”停止仿真。" W9 a1 \6 {8 U 3 c" q+ H0 X4 C 1.2 在Keil菜单栏点击“View”——“Registers Window”,在寄存器查看窗口查找R14(LR)的值。如果R14(LR) = 0xFFFFFFE9,继续查看MSP(主堆栈指针)的值,如果R14(LR) = 0xFFFFFFFD,继续查看PSP(进程栈指针)的值。我的程序R14(LR) = 0xFFFFFFF9,接下来以此为例。5 B$ W; y T+ z S 9 ~& n4 c$ k, C4 s 1.3 在Keil菜单栏点击“View”——“Memory Windows”——“Memory1”,在“Address”地址栏中输入MSP的值:0x20001288,然后在对应的行里找到地址。地址一般以0x08开头的32位数。本例中,地址为0x08003CB9。 & }& n9 M# n$ l& S4 }5 y 0 [" X$ \9 z* v I 5 p6 x9 k( D, E8 l 1.4 在Keil菜单栏点击“View”——“Disassembly Window”,在“Disassembly”窗口中右击,在下拉菜单中选择“Show Disassemblyat Address...”。在弹出框“Show Code atAdress”的地址框中输入地址0x08003CB9进行搜索,然后就会找到相对应的代码。这里的代码就是进入循环中断之前的情况。仔细查看附近区域的相关代码来排查错误具体原因。1 C; y, X1 ?# F0 F' `) U$ ?2 N, U 1 G4 o6 o' \1 h# c6 T 1 s$ v$ l2 Q' q- ~7 m 方法2:9 q$ l+ C @6 Y- D+ S $ w4 U8 I" B2 F$ O/ y 2.1在硬件中断函数HardFault_Handler里的while(1)处打调试断点,程序执行到断点处时点击“STOP”停止仿真。- F# A) b' f R! @2 L& Y 3 H# S. h5 l- z; V / V$ q3 G; N2 u: H0 Q/ i 2.2 在Keil菜单栏点击“View”——“Call Stack Window”弹出“Call Stack + Locals”对话框。然后在对话框中右键选择“Show Caller Code”,就会跳转到出错之前的函数处,仔细查看这部分函数被调用或者数组内存使用情况。1 D+ `" W' D1 |% A3 v) u5 B --------------------- 作者:electrocrazy 来源:CSDN 原文:http://blog.csdn.net/electrocrazy/article/details/78173558 版权声明:本文为博主原创文章,转载请附上博文链接!$ }; E! o4 N# E7 U u |
我也是遇到这个问题去网上找的,哈哈哈