經驗教訓 | STM32 異常之BFARVALID,PRECISERR,INVSTATE

最近有一個項目基於STM32F446ZE MCU使用FREERTOS操作系統開發,之前有部分功能代碼是基於MCU裸機開發的,移植過程種發現程序老出錯,DEBUG模式條件發現程序停在了HardFault_Handler中斷服務程序中:

查看對應的錯誤報告顯示BFARVALID和PRECISERR錯:

查看了兩個錯誤的對應說明(感覺還是不知道是什麼原因):

通過將任務逐個屏蔽,然後代碼塊逐個屏蔽方式最終定位到了一下函數,函數中對一個結構體對像進行了賦值操作後就會觸發該錯誤,這些代碼都是之前要無FREERTOS時運行好好的,現在就會出現這個錯:

思考好久,可以是任務堆棧太小導致,於試償試將任務堆棧從128增加到512,

編譯下載運行OK,果然不再出錯了。

 

長了教訓!記錄一下問題分析過程,也爲後續類似的問題提供思路。

 

順便記錄了一下在調試過程中遇到的另一個硬件錯INVSTATE,對應的解釋如下,

我是因爲數組越界超作也產生該錯誤,如下圖,當message->len > 8 時,如果沒有下面紅框中的長度限制,就有可能在memcpy函數中引起數組越界產生INVSTATE硬件錯!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章