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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

剖析Cortex-M3發(fā)生Fault故障類(lèi)型及產(chǎn)生原因

strongerHuang ? 來(lái)源:strongerHuang ? 作者:strongerHuang ? 2021-05-08 15:59 ? 次閱讀

我們平時(shí)的項(xiàng)目,可能會(huì)遇到死機(jī)的情況,通過(guò)在線(xiàn)調(diào)試,或者打印消息,可能會(huì)發(fā)現(xiàn),怎么進(jìn)入了 HardFault_Handler 中斷呢? 這種“硬故障”是我們常見(jiàn)的一種故障,導(dǎo)致硬故障的原因也有很多。本文針對(duì) Cortex-M3 說(shuō)說(shuō)Fault故障相關(guān)的內(nèi)容。

1

Fault故障種類(lèi)

Fault故障的種類(lèi)有很多,拿本文Cortex-M3來(lái)說(shuō),主要有:

HardFault:硬故障

MemManage:存儲(chǔ)器管理故障

BusFault:總線(xiàn)故障

UsageFault:用法故障

3af924d0-ac42-11eb-9728-12bb97331649.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) { }}

2

Fault故障描述

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

1.HardFault:硬故障

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

3af924d0-ac42-11eb-9728-12bb97331649.png

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

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

3b7d6de4-ac42-11eb-9728-12bb97331649.png

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

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

往只讀 region 寫(xiě)數(shù)據(jù)

用戶(hù)級(jí)下訪問(wèn)了只允許在特權(quán)級(jí)下訪問(wèn)的地址

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

3b8febae-ac42-11eb-9728-12bb97331649.png

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

取指,通常被稱(chēng)作“預(yù)取流產(chǎn)”

數(shù)據(jù)讀/寫(xiě),通常被稱(chēng)作“數(shù)據(jù)流產(chǎn)”

觸發(fā)總線(xiàn)故障的動(dòng)作:

中斷處理起始階段的堆棧 PUSH 動(dòng)作。稱(chēng)為“入棧錯(cuò)誤”

中斷處理收尾階段的堆棧 POP 動(dòng)作。稱(chēng)為“出棧錯(cuò)誤”

3ba59ad0-ac42-11eb-9728-12bb97331649.png

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

3bb8ed56-ac42-11eb-9728-12bb97331649.png

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

3bc89de6-ac42-11eb-9728-12bb97331649.png

3

應(yīng)對(duì)故障

不知道大家平時(shí)有沒(méi)有對(duì)這些進(jìn)行有效避免?

這里簡(jiǎn)單說(shuō)幾點(diǎn)應(yīng)對(duì)故障的措施:

1.通過(guò)故障狀態(tài)寄存器的值來(lái)判定程序錯(cuò)誤

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

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

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

2.提前對(duì)代碼進(jìn)行分析、預(yù)判

比如:通過(guò)代碼靜態(tài)分析工具,對(duì)代碼進(jìn)行分析、查找bug。

前不久才分享過(guò)一篇文章:推薦幾個(gè)代碼靜態(tài)分析工具

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5295

    瀏覽量

    119823
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    6817

    瀏覽量

    88743
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4723

    瀏覽量

    68236
  • 編譯器
    +關(guān)注

    關(guān)注

    1

    文章

    1617

    瀏覽量

    49016

原文標(biāo)題:Cortex-M3發(fā)生Fault故障類(lèi)型及產(chǎn)生原因

文章出處:【微信號(hào):strongerHuang,微信公眾號(hào):strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    變頻器故障類(lèi)型產(chǎn)生原因

    模塊是變頻器的指揮中心,主要由運(yùn)算電路、檢測(cè)電路、控制信號(hào)的輸入、輸出電路和驅(qū)動(dòng)電路等構(gòu)成,主要完成對(duì)逆變器的開(kāi)關(guān)控制、對(duì)整流器的電壓控制及完成各種保護(hù)功能,也是經(jīng)常出故障的環(huán)節(jié)。一、故障類(lèi)型
    的頭像 發(fā)表于 10-23 15:52 ?89次閱讀

    TAS6421-Q1產(chǎn)生負(fù)載短路故障,功放fault腳不置位是怎么回事?

    產(chǎn)生負(fù)載短路故障,檢測(cè)到AMP fault腳拉低,讀取0x0C, 0x0D寄存器確認(rèn)故障類(lèi)型后,操作0x21寄存器清除
    發(fā)表于 10-09 06:04

    基于ARM Cortex-M3單片機(jī)研發(fā)的國(guó)產(chǎn)指紋芯片 - P1032BF1

    指紋芯片 - P1032BF1是一款基于ARM Cortex-M3的單片機(jī),專(zhuān)為Wi-Fi /藍(lán)牙通信控制而設(shè)計(jì);可應(yīng)用于智能鎖;支持大型程序代碼和擁有大型嵌入式SRAM,也可用于一般的MCU應(yīng)用。
    的頭像 發(fā)表于 07-10 09:22 ?508次閱讀
    基于ARM <b class='flag-5'>Cortex-M3</b>單片機(jī)研發(fā)的國(guó)產(chǎn)指紋芯片 - P1032BF1

    變頻器故障類(lèi)型產(chǎn)生原因詳解

    變頻器作為現(xiàn)代工業(yè)自動(dòng)化控制中的核心設(shè)備,其穩(wěn)定運(yùn)行對(duì)于生產(chǎn)效率和設(shè)備安全至關(guān)重要。然而,由于工作環(huán)境、操作方式、設(shè)備質(zhì)量等多種因素的影響,變頻器在運(yùn)行過(guò)程中可能會(huì)出現(xiàn)各種故障。本文將對(duì)變頻器的故障類(lèi)型
    的頭像 發(fā)表于 06-11 11:52 ?774次閱讀

    求助,關(guān)于cortex-M3的壓棧問(wèn)題求解

    我們都知道cortex-m3中斷時(shí)是硬件自動(dòng)壓棧的,這樣可以減少中斷響應(yīng)和恢復(fù)時(shí)間。中斷硬件壓棧的寄存器為xPSR, PC, LR, R12, R0-R3,為什么其他寄存器不需要壓棧呢?
    發(fā)表于 04-28 08:18

    STM32F103VE添加DSP庫(kù)報(bào)錯(cuò)ld.exe: cannot find -l-mcpu=cortex-m3是什么原因呢?

    使用STM32F103VE芯片,在STM32cubeide里添加DSP庫(kù)后,編譯報(bào)錯(cuò)ld.exe: cannot find -l-mcpu=cortex-m3,請(qǐng)問(wèn)是什么原因呢?文件目錄以及配置如下
    發(fā)表于 03-15 08:14

    Cortex-M3芯片有哪些

    Cortex-M3芯片是一款基于ARM架構(gòu)的低功耗、高性能的嵌入式處理器。目前市面上有眾多廠商生產(chǎn)了基于Cortex-M3內(nèi)核的芯片,如意法半導(dǎo)體的STM32F系列、恩智浦半導(dǎo)體的LPC1800系列等。這些芯片廣泛應(yīng)用于工業(yè)控制、智能家居、物聯(lián)網(wǎng)等領(lǐng)域。
    的頭像 發(fā)表于 03-11 17:07 ?1492次閱讀

    Cortex-M3芯片怎么樣

    Cortex-M3芯片是一款高性能、低功耗的32位RISC處理器,特別適用于嵌入式系統(tǒng)和實(shí)時(shí)控制領(lǐng)域。其架構(gòu)采用哈佛結(jié)構(gòu),實(shí)現(xiàn)指令和數(shù)據(jù)存儲(chǔ)器的獨(dú)立訪問(wèn),提高了系統(tǒng)效率。Cortex-M3支持內(nèi)部和外部總線(xiàn)接口,提供了廣泛的外設(shè)連接和擴(kuò)展性支持。
    的頭像 發(fā)表于 03-08 16:00 ?1176次閱讀

    光纜故障的主要產(chǎn)生原因及解決方案

    光纜故障的主要產(chǎn)生原因及解決方案 光纜是現(xiàn)代通信領(lǐng)域中重要的傳輸介質(zhì),其穩(wěn)定可靠的運(yùn)行對(duì)于現(xiàn)代社會(huì)的信息傳輸和通信起著至關(guān)重要的作用。然而,光纜在使用過(guò)程中,也存在著各種故障問(wèn)題,這些
    的頭像 發(fā)表于 02-04 10:11 ?3804次閱讀

    強(qiáng)大的Arm? Cortex?-M3內(nèi)核(下)

    經(jīng)過(guò)前一期的芝識(shí)課堂,我們了解了東芝MCU產(chǎn)品所基于Arm Cortex-M3內(nèi)核的基本結(jié)構(gòu)和寄存器分配的細(xì)節(jié)。
    的頭像 發(fā)表于 01-25 09:25 ?1080次閱讀
    強(qiáng)大的Arm? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>M3</b>內(nèi)核(下)

    如何實(shí)現(xiàn)Cortex-M3與ADuC7061之間用IIC通訊?

    我想實(shí)現(xiàn)Cortex-M3與ADuC7061之間用IIC通訊,Cortex-M3用做主機(jī),ADuC7061用做從機(jī) 。我要實(shí)現(xiàn)收發(fā)數(shù)據(jù),ADuC7061應(yīng)該怎樣配置呢,思路是什么?
    發(fā)表于 01-15 06:13

    Cortex-M3 技術(shù)參考手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《Cortex-M3 技術(shù)參考手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 12-25 09:18 ?3次下載

    光纜故障的主要產(chǎn)生原因

    光纜故障的主要產(chǎn)生原因 光纜是現(xiàn)代通信和互聯(lián)網(wǎng)領(lǐng)域的重要基礎(chǔ)設(shè)施之一,其承載著海量的信息傳輸任務(wù)。然而,由于各種原因,光纜故障時(shí)有
    的頭像 發(fā)表于 12-07 10:10 ?1083次閱讀

    集成電源管理的超低功耗ARM Cortex-M3 MCU數(shù)據(jù)手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《集成電源管理的超低功耗ARM Cortex-M3 MCU數(shù)據(jù)手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 11-28 10:49 ?0次下載
    集成電源管理的超低功耗ARM <b class='flag-5'>Cortex-M3</b> MCU數(shù)據(jù)手冊(cè)

    基于Cortex-M3的全自動(dòng)焊接機(jī)設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《基于Cortex-M3的全自動(dòng)焊接機(jī)設(shè)計(jì).doc》資料免費(fèi)下載
    發(fā)表于 11-14 10:46 ?0次下載
    基于<b class='flag-5'>Cortex-M3</b>的全自動(dòng)焊接機(jī)設(shè)計(jì)