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

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

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

針對(duì)Cortex-M3談?wù)剢纹瑱C(jī)Fault故障

strongerHuang ? 來源:strongerHuang ? 作者:strongerHuang ? 2021-10-29 10:00 ? 次閱讀

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

這種“硬故障”是我們常見的一種故障,導(dǎo)致硬故障的原因也有很多。本文針對(duì) Cortex-M3 說說 Fault 故障相關(guān)的內(nèi)容。

1

Fault故障種類

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

HardFault:硬故障

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

BusFault:總線故障

UsageFault:用法故障

4a8fa124-383f-11ec-82a8-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) { }}

2

Fault故障描述

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

1.HardFault:硬故障

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

4a8fa124-383f-11ec-82a8-dac502259ad0.png

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

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

4b3a6546-383f-11ec-82a8-dac502259ad0.png

通過狀態(tài)寄存器,你會(huì)發(fā)現(xiàn)產(chǎn)生硬故障的原因有以上幾種。

2.MemManage:存儲(chǔ)器管理故障存儲(chǔ)器管理故障通常與MPU(內(nèi)存保護(hù)單元)有關(guān),之前給大家分享過MPU相關(guān)的文章《什么是Cortex-M內(nèi)核的MPU?》。

通常就是我們說的“內(nèi)存越界”就會(huì)導(dǎo)致存儲(chǔ)器管理故障,細(xì)說引起該故障的誘因有:

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

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

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

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

4b803576-383f-11ec-82a8-dac502259ad0.png

通過狀態(tài)寄存器,你會(huì)發(fā)現(xiàn)引起該故障的一些原因。

3.BusFault:總線故障總線故障,顧名思義就是對(duì)“總線”操作出現(xiàn)問題,導(dǎo)致的故障。

比如:當(dāng) AHB 接口上正在傳送數(shù)據(jù)時(shí),如果回復(fù)了一個(gè)錯(cuò)誤信號(hào)(error response),則會(huì)產(chǎn)生總線故障。

產(chǎn)生總線故障的場(chǎng)合:

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

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

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

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

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

4bbd91dc-383f-11ec-82a8-dac502259ad0.png

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

4c069850-383f-11ec-82a8-dac502259ad0.png

4.UsageFault:用法故障用法故障相對(duì)不常見,出現(xiàn)該故障通常是進(jìn)行了“未對(duì)齊訪問操作”,其他導(dǎo)致該故障問題很少見。

比如:執(zhí)行了未定義的指令、除數(shù)為0(編譯器都會(huì)避免)、無效的中斷返回等這些情況比較少見。

用法故障狀態(tài)寄存器:

4c5be620-383f-11ec-82a8-dac502259ad0.png

3

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

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

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

1.通過故障狀態(tà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ù)判

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

責(zé)任編輯:haq

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

    關(guān)注

    6037

    文章

    44569

    瀏覽量

    636155
  • Fault
    +關(guān)注

    關(guān)注

    0

    文章

    5

    瀏覽量

    7304

原文標(biāo)題:單片機(jī)Fault故障常見應(yīng)對(duì)辦法

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Cortex-M3/M4F指令集技術(shù)用戶手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《Cortex-M3/M4F指令集技術(shù)用戶手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 12-23 16:31 ?3次下載
    <b class='flag-5'>Cortex-M3</b>/<b class='flag-5'>M</b>4F指令集技術(shù)用戶手冊(cè)

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

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

    STM32單片機(jī)的特點(diǎn)介紹

    和易用的工具,再配合強(qiáng)大的功能,在行業(yè)中享有盛譽(yù)。 STM32單片機(jī)的特點(diǎn)主要體現(xiàn)在以下幾個(gè)方面: STM32擁有強(qiáng)大的內(nèi)核。它采用了ARM32位Cortex-M3 CPU,最高工作頻率可達(dá)72MHz,這意味著它能夠以極快的速度處理復(fù)雜的任務(wù)。同時(shí),它還具備1.25DMI
    的頭像 發(fā)表于 09-25 17:19 ?1668次閱讀

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

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

    芯海通用 MCU 應(yīng)用筆記 :CS32F103 系列 MCU IAP 升級(jí)指南

    本應(yīng)用筆記旨在幫助指導(dǎo)用戶針對(duì)芯海 CORTEX-M3 MCU CS32F103 系列單片機(jī) IAP 應(yīng)用的快速開發(fā)。本應(yīng)用筆記實(shí)現(xiàn)了 CAN 和 USART 兩種接口方式來開發(fā) IAP 應(yīng)用,協(xié)議
    發(fā)表于 05-16 11:40

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

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

    請(qǐng)問cortex-M7核單片機(jī)主要應(yīng)用在哪些領(lǐng)域?

    看到st和nxp的M7核單片機(jī),動(dòng)不動(dòng)幾百兆的主頻,有的還要外置DDR,還有的成本低于1刀。想知道這些單片機(jī)的目標(biāo)應(yīng)用場(chǎng)合是哪些? 單片機(jī)發(fā)展,從51過渡到
    發(fā)表于 04-17 07:49

    Holtek新推出Arm? Cortex?-M0+直流無刷電機(jī)控制專用全整合單片機(jī)

    Holtek推出新一代Arm? Cortex?-M0+直流無刷電機(jī)控制專用全整合單片機(jī)HT32F65C32F與HT32F65C40F,針對(duì)低電壓、低功率電機(jī)專門設(shè)計(jì),具有極高的集成度,
    的頭像 發(fā)表于 04-02 17:19 ?909次閱讀

    市面上很火的32位單片機(jī)—PY32F030單片機(jī)的產(chǎn)品特性介紹

    PY32F030 系列單片機(jī)是采用了高性能的 32 位 ARM? Cortex?-M0+ 內(nèi)核,寬電壓工作范圍的 MCU。
    的頭像 發(fā)表于 03-22 15:29 ?1318次閱讀

    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 ?1608次閱讀

    Cortex-M3芯片怎么樣

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

    Cortex-M85內(nèi)核單片機(jī)如何快速上手

    2022年4月,Arm推出了全新的MCU級(jí)內(nèi)核Cortex-M85。截止目前(2024年2月),Cortex-M85是最新、最強(qiáng)的Cortex-M內(nèi)核。
    發(fā)表于 02-29 09:35 ?762次閱讀
    <b class='flag-5'>Cortex-M</b>85內(nèi)核<b class='flag-5'>單片機(jī)</b>如何快速上手

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

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

    PY32C613單片機(jī)簡單介紹

    PY32C613單片機(jī)是普冉新推出的高性能的 32 位 ARM Cortex-M0+ 內(nèi)核,寬電壓工作范圍的 MCU。
    的頭像 發(fā)表于 01-16 18:06 ?1112次閱讀
    PY32C613<b class='flag-5'>單片機(jī)</b>簡單介紹

    如何實(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