0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

單片機Fault遇到故障了應該怎么辦

Q4MP_gh_c472c21 ? 來源:strongerHuang ? 作者:strongerHuang ? 2021-11-08 16:59 ? 次閱讀

我們平時的項目,可能會遇到死機的情況,通過在線調試,或者打印消息,可能會發(fā)現(xiàn),怎么進入了 HardFault_Handler 中斷呢?

這種“硬故障”是我們常見的一種故障,導致硬故障的原因也有很多。本文針對 Cortex-M3 說說Fault故障相關的內容。

Fault故障種類

Fault故障的種類有很多,拿本文Cortex-M3來說,主要有:

HardFault:硬故障

MemManage:存儲器管理故障

BusFault:總線故障

UsageFault:用法故障

7f9cb336-3f77-11ec-9195-dac502259ad0.png

比如,在stm32f10x_it.c源代碼中,有這樣的中斷入口:

void HardFault_Handler(void){ /* Go to infinite loop when Hard Fault exception occurs */ while (1) { }} void MemManage_Handler(void){ /* Go to infinite loop when Memory Manage exception occurs */ while (1) { }} void BusFault_Handler(void){ /* Go to infinite loop when Bus Fault exception occurs */ while (1) { }} void UsageFault_Handler(void){ /* Go to infinite loop when Usage Fault exception occurs */ while (1) { }}

Fault故障描述

每一種Fault故障的產生,都肯定是有一定原因的,如果你代碼產生了Fault故障中斷,說明代碼某些地方引起了Fault故障。

1、HardFault:硬故障

通過截圖的描述,你會發(fā)現(xiàn)硬故障是一種“不可編程”的故障,因為存儲器管理故障、總線故障、用法故障如果不能得到執(zhí)行,就為上訪為硬故障。

7f9cb336-3f77-11ec-9195-dac502259ad0.png

比如:比如在取向量時產生的總線故障也按會硬故障進行處理。所以,你會發(fā)現(xiàn)出現(xiàn)故障,很多時候都是硬故障。

硬故障狀態(tài)寄存器描述:

804ec274-3f77-11ec-9195-dac502259ad0.png

通過狀態(tài)寄存器,你會發(fā)現(xiàn)產生硬故障的原因有以上幾種。 2、MemManage:存儲器管理故障 存儲器管理故障通常與MPU(內存保護單元)有關,之前給大家分享過MPU相關的文章《什么是Cortex-M內核的MPU?》。 通常就是我們說的“內存越界”就會導致存儲器管理故障,細說引起該故障的誘因有:

訪問了 MPU 設置區(qū)域覆蓋范圍之外的地址

往只讀 region 寫數(shù)據

用戶級下訪問了只允許在特權級下訪問的地址

存儲器管理故障狀態(tài)寄存器:

8084ce00-3f77-11ec-9195-dac502259ad0.png

通過狀態(tài)寄存器,你會發(fā)現(xiàn)引起該故障的一些原因。 3、BusFault:總線故障 總線故障,顧名思義就是對“總線”操作出現(xiàn)問題,導致的故障。 比如:當 AHB 接口上正在傳送數(shù)據時,如果回復了一個錯誤信號(error response),則會產生總線故障。 產生總線故障的場合:

取指,通常被稱作“預取流產”

數(shù)據讀/寫,通常被稱作“數(shù)據流產”

觸發(fā)總線故障的動作:

中斷處理起始階段的堆棧 PUSH 動作。稱為“入棧錯誤”

中斷處理收尾階段的堆棧 POP 動作。稱為“出棧錯誤”

80c00c04-3f77-11ec-9195-dac502259ad0.png

同樣,通過總線故障狀態(tài)寄存器了解產生的原因:

8104de60-3f77-11ec-9195-dac502259ad0.png

4、UsageFault:用法故障 用法故障相對不常見,出現(xiàn)該故障通常是進行了“未對齊訪問操作”,其他導致該故障問題很少見。 比如:執(zhí)行了未定義的指令、除數(shù)為0(編譯器都會避免)、無效的中斷返回等這些情況比較少見。 用法故障狀態(tài)寄存器:

8190f256-3f77-11ec-9195-dac502259ad0.png

如何應對故障

不知道大家平時有沒有對這些進行有效避免?這里簡單說幾點應對故障的措施:

1、通過故障狀態(tài)寄存器的值來判定程序錯誤

在故障中斷函數(shù)中,讀取故障的狀態(tài)(上面描述了狀態(tài)寄存器),比如硬故障:

void HardFault_Handler(void){//讀取狀態(tài)寄存器,打印狀態(tài)寄存器,判斷什么原因引起故障printf("狀態(tài)x信息"); while (1) { }}

如果不想系統(tǒng)處于死機狀態(tài),可以在中斷里面做軟復位。

2、提前對代碼進行分析、預判

比如:通過代碼靜態(tài)分析工具,對代碼進行分析、查找bug。前不久才分享過一篇文章:推薦幾個代碼靜態(tài)分析工具

3、其他診斷方法

之前給大家分享過一篇文章《針對Cortex-M調試診斷 HardFault 的錯誤追蹤庫》可以有效診斷本文說的這種“硬故障”。 先寫到這里,還有更多更好的方法,歡迎大家留言補充。

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 單片機
    +關注

    關注

    6037

    文章

    44569

    瀏覽量

    636152
  • CAN總線
    +關注

    關注

    145

    文章

    1952

    瀏覽量

    130840

原文標題:超實用!單片機Fault故障常見應對辦法

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    單片機出現(xiàn)故障怎么維修

    單片機出現(xiàn)故障時,維修過程需要系統(tǒng)地檢查和診斷,以確定故障的根本原因,并采取相應的修復措施。以下是一個詳細的單片機維修指南,旨在幫助技術人員或愛好者有效地解決
    的頭像 發(fā)表于 10-17 17:57 ?1252次閱讀

    我用的是multisim14.0,因為是初學者,仿真電路的時候找不到合適的模型,應該怎么辦?

    我用的是multisim14.0,因為是初學者,仿真電路的時候找不到合適的模型,應該怎么辦? 比如我電路用的是AO3400的NMOS,但是在multisim14.0軟件自帶的元件庫里面沒找到類似的,開啟電壓是1.5v的nmos,請教大家,
    發(fā)表于 08-23 10:59

    大電流一體成型電感有噪音怎么辦

    電子發(fā)燒友網站提供《大電流一體成型電感有噪音怎么辦.docx》資料免費下載
    發(fā)表于 07-30 12:30 ?0次下載

    如何入門嵌入式?怎么才算是掌握單片機

    大一應該學習最重要的 C 語言,51 單片機,大二學 51 單片機也可以,高數(shù)也應該好好學下,考研或者以后的工作中會有用的。
    的頭像 發(fā)表于 04-28 14:45 ?669次閱讀

    stm8系列單片機在IAR環(huán)境下怎樣配置G口?

    stm8系列單片機,在IAR環(huán)境下,怎樣配置G口? 例如:不小心把外斷的紅外接收或按鍵的引腳接到G口,比如STM8S105或207(48腳封裝的),P35、P36腳(PG0、PG1),但IAR的環(huán)境里沒有G口的設置,怎么辦?
    發(fā)表于 04-23 07:02

    工控主板發(fā)生故障怎么辦

    工控主板發(fā)生故障怎么辦?前幾天有個客戶問了我這個問題,大部分情況下出現(xiàn)的故障并不可怕,主要是用戶粗心大意造成的。那今天小編就來講解一下工控主板一般會出現(xiàn)故障的主要原因及判斷方法:
    的頭像 發(fā)表于 04-11 18:19 ?893次閱讀

    電容負極熔斷怎么辦

    在現(xiàn)代科技發(fā)展的時代,電容器在各個領域都扮演著重要的角色。然而,由于各種原因,電容器的負極可能會發(fā)生熔斷的情況。那么,當電容器的負極熔斷時,我們應該怎么辦呢?
    的頭像 發(fā)表于 04-10 14:15 ?537次閱讀
    電容負極熔斷<b class='flag-5'>怎么辦</b>

    單片機RAM不夠用怎么解決?

    來自一位用戶的咨詢,麻煩幫忙解答。越詳細越好,有圖有真相。如有相關的視頻、文檔也可以輔助說明,謝謝。 單片機RAM不夠用怎么辦? 單片機都有RAM,如果我們一下子定義一大堆的變量,使
    發(fā)表于 02-02 07:35

    linux用gdb調試遇到函數(shù)調用怎么辦?

    linux用gdb調試遇到函數(shù)調用怎么辦? 在Linux上使用GDB調試時,遇到函數(shù)調用是一個常見的情況。函數(shù)調用可能涉及到多個函數(shù)、多個文件,這就需要我們仔細審查代碼,理解函數(shù)之間的關系和參數(shù)傳遞
    的頭像 發(fā)表于 01-31 10:33 ?728次閱讀

    怎么辦?晶振沒有信號輸出

    怎么辦?晶振沒有信號輸出? 晶振作為電子設備中常見的元器件之一,在電子系統(tǒng)中起到時鐘信號供應的重要作用。然而,有時我們可能會遇到晶振沒有信號輸出的問題,這會嚴重影響設備的正常運行。本文將針對這一
    的頭像 發(fā)表于 01-25 13:51 ?1074次閱讀

    修復輥壓機軸承位磨損怎么辦

    電子發(fā)燒友網站提供《修復輥壓機軸承位磨損怎么辦.docx》資料免費下載
    發(fā)表于 01-23 09:52 ?0次下載

    wifi無互聯(lián)網連接怎么辦?解決wifi無法訪問互聯(lián)網怎么辦的方法

    wifi無互聯(lián)網連接怎么辦?解決wifi無法訪問互聯(lián)網怎么辦的方法? 在現(xiàn)代社會中,WiFi已經成為了我們生活中必不可少的一部分。然而,有時我們可能會遇到WiFi無法訪問互聯(lián)網的問題,這給我們的學習
    的頭像 發(fā)表于 01-17 11:17 ?3.4w次閱讀

    變頻器輸出的直流24V電源輸出了故障怎么辦?

    變頻器輸出的直流24V電源輸出了故障,怎么辦? 變頻器是工業(yè)生產中常用的電器設備,它通過改變電力的頻率,控制電機的轉速和運行。然而,變頻器輸出的直流24V電源故障可能會給生產過程帶來嚴重的影響。在
    的頭像 發(fā)表于 01-15 16:15 ?3615次閱讀

    ADuC824正弦波轉方波時頻帶要比較寬時怎么辦?

    正弦波轉方波時頻帶要比較寬時怎么辦呢!我用lm393做了一個過零比較器給單片機(aduc824)識別(頻率計)但是在低頻時監(jiān)測不到。在小于200hz的時候不可以,到300khz又不行了。不知道是在
    發(fā)表于 01-15 06:42

    風機軸磨損怎么辦

    電子發(fā)燒友網站提供《風機軸磨損怎么辦.docx》資料免費下載
    發(fā)表于 01-07 11:04 ?0次下載