STM32硬件錯誤HardFault_Handler的處理方法

       在用KeilSTM32的程序進行仿真時程序有時會跑飛,停止仿真程序會停在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”,就會跳轉到出錯之前的函數處,仔細查看這部分函數被調用或者數組內存使用情況。

發佈了33 篇原創文章 · 獲贊 118 · 訪問量 35萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章