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

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

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

專治MCU各種HardFault問(wèn)題的開(kāi)源庫(kù)

MCU開(kāi)發(fā)加油站 ? 來(lái)源:strongerHuang ? 作者:armink ? 2021-03-10 11:49 ? 次閱讀

相信有不少讀者都遇到過(guò) “HardFault”的問(wèn)題,而且不止一次,有時(shí)候可能因?yàn)樗B續(xù)幾日加班,甚至通宵。 那么今天就來(lái)分享一個(gè)由armink(也就是現(xiàn)在RTT里面的那位朱大神)整理的開(kāi)源庫(kù),借花獻(xiàn)佛分享給大家。一、CmBacktrace 是什么

CmBacktrace (Cortex Microcontroller Backtrace)是一款針對(duì) ARM Cortex-M 系列 MCU 的錯(cuò)誤代碼自動(dòng)追蹤、定位,錯(cuò)誤原因自動(dòng)分析的開(kāi)源庫(kù)。主要特性如下:

1. 支持的錯(cuò)誤包括

斷言(assert)

故障(Hard Fault, Memory Management Fault, Bus Fault, Usage Fault, Debug Fault)

2. 故障原因自動(dòng)診斷可在故障發(fā)生時(shí),自動(dòng)分析出故障的原因,定位發(fā)生故障的代碼位置,而無(wú)需再手動(dòng)分析繁雜的故障寄存器;3. 輸出錯(cuò)誤現(xiàn)場(chǎng)的函數(shù)調(diào)用棧(需配合 addr2line 工具進(jìn)行精確定位),還原發(fā)生錯(cuò)誤時(shí)的現(xiàn)場(chǎng)信息,定位問(wèn)題代碼位置、邏輯更加快捷、精準(zhǔn)。也可以在正常狀態(tài)下使用該庫(kù),獲取當(dāng)前的函數(shù)調(diào)用棧;4. 支持 裸機(jī) 及以下操作系統(tǒng)平臺(tái):

RT-Thread

UCOS

FreeRTOS(需修改源碼)

5. 根據(jù)錯(cuò)誤現(xiàn)場(chǎng)狀態(tài),輸出對(duì)應(yīng)的 線程棧 或 C 主棧;6.故障診斷信息支持多國(guó)語(yǔ)言(目前:簡(jiǎn)體中文、英文);7.適配Cortex-M0/M3/M4/M7 MCU;

8.支持IAR、KEIL、GCC 編譯器;

二、為什么選擇 CmBacktrace入門新人:對(duì)于從 C51 、MSP430 等簡(jiǎn)單單片機(jī)轉(zhuǎn)而使用更加復(fù)雜的 ARM 新人來(lái)說(shuō),時(shí)不時(shí)出現(xiàn)的 "hard falut" 死機(jī)會(huì)讓新人瞬間懵掉。定位錯(cuò)誤的方法也往往是連接上仿真器,一步步 F10/F11 單步,定位到具體的錯(cuò)誤代碼,再去猜測(cè)、排除、推敲錯(cuò)誤原因,這種過(guò)程十分痛苦。

熟練老手:慢慢的大家知道可以通過(guò)故障寄存器信息來(lái)定位故障原因及故障代碼地址,雖然這樣能解決一小部分問(wèn)題,但是重復(fù)的、繁瑣的分析過(guò)程也會(huì)耽誤很多時(shí)間。而且對(duì)于一些復(fù)雜問(wèn)題,只依靠代碼地址是無(wú)法解決的,必須得還原錯(cuò)誤現(xiàn)場(chǎng)的函數(shù)調(diào)用邏輯關(guān)系。雖然連接仿真器可以查看到的函數(shù)調(diào)用棧,但故障狀態(tài)下是無(wú)法顯示的,所以還是得一步步 F10/F11 單步去定位錯(cuò)誤代碼的位置。

另外,還有兩種場(chǎng)景:1、很多產(chǎn)品真機(jī)調(diào)試時(shí)必須斷開(kāi)仿真器2、問(wèn)題確實(shí)存在,但是極難被重現(xiàn)

所以定位這類問(wèn)題就顯得難上加難。

使用本庫(kù):上述所有問(wèn)題都迎刃而解,可以將錯(cuò)誤信息輸出到控制臺(tái)上,還可以將錯(cuò)誤信息使用 EasyFlash 的 Log 功能保存至 Flash 中,設(shè)備死機(jī)后重啟依然能夠讀取上次的錯(cuò)誤信息。CmBacktrace 輸出的信息包括函數(shù)調(diào)用棧、故障診斷結(jié)果、堆棧、故障寄存器及產(chǎn)品固件信息,極大的提升了錯(cuò)誤定位的效率及準(zhǔn)確性。

俗話說(shuō),工欲善其事,必先利其器。所以有時(shí)候做事效率低的原因也許是,你會(huì)用的工具種類太少。

三、CmBacktrace 如何使用

本文就簡(jiǎn)單演示一下,演示分如下幾個(gè)步驟:1、制造除零異常(IAR 工程,點(diǎn)擊查看源碼)2、查看錯(cuò)誤診斷信息3、查看函數(shù)調(diào)用棧基本信息4、通過(guò)命令行工具進(jìn)入項(xiàng)目工程存放可執(zhí)行文件的路徑

5、使用 addr2line 命令,查看函數(shù)調(diào)用棧詳細(xì)信息,并定位錯(cuò)誤代碼

具體的使用方法,請(qǐng)見(jiàn)原始說(shuō)明文檔,里面描述了很多細(xì)節(jié)內(nèi)容。

原文標(biāo)題:專治MCU各種 HardFault 的庫(kù):CmBacktrace(錯(cuò)誤追蹤庫(kù))

文章出處:【微信公眾號(hào):MCU開(kāi)發(fā)加油站】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(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)投訴
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    17148

    瀏覽量

    351212
  • 開(kāi)源
    +關(guān)注

    關(guān)注

    3

    文章

    3349

    瀏覽量

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

    關(guān)注

    1

    文章

    1634

    瀏覽量

    49133

原文標(biāo)題:專治MCU各種 HardFault 的庫(kù):CmBacktrace(錯(cuò)誤追蹤庫(kù))

文章出處:【微信號(hào):mcugeek,微信公眾號(hào):MCU開(kāi)發(fā)加油站】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    鴻蒙原生開(kāi)源庫(kù)ViewPool在OpenHarmony社區(qū)正式上線

    近日,由伙伴參與共建的鴻蒙原生開(kāi)源庫(kù)“ViewPool”在OpenHarmony社區(qū)正式上線。這個(gè)開(kāi)發(fā)庫(kù)是基于OpenHarmony技術(shù)孵化的成果,充分發(fā)揮了平臺(tái)的技術(shù)特性,同時(shí)融入了伙伴在應(yīng)用開(kāi)發(fā)
    的頭像 發(fā)表于 12-20 14:44 ?220次閱讀

    開(kāi)源AI模型庫(kù)是干嘛的

    開(kāi)源AI模型庫(kù)是指那些公開(kāi)源代碼、允許自由訪問(wèn)和使用的AI模型集合。這些模型通常經(jīng)過(guò)訓(xùn)練,能夠執(zhí)行特定的任務(wù)。以下,是對(duì)開(kāi)源AI模型庫(kù)的詳細(xì)
    的頭像 發(fā)表于 12-14 10:33 ?175次閱讀

    芯原股份與開(kāi)源圖形庫(kù)LVGL達(dá)成戰(zhàn)略合作

    芯原股份 (芯原,股票代碼:688521.SH) 今日宣布與嵌入式系統(tǒng)領(lǐng)域領(lǐng)先的開(kāi)源圖形庫(kù)LVGL達(dá)成戰(zhàn)略合作,在LVGL庫(kù)中支持芯原的低功耗3D和VGLite 2.5D GPU技術(shù)。此次合作旨在
    的頭像 發(fā)表于 11-29 09:20 ?339次閱讀

    開(kāi)放原子開(kāi)源數(shù)據(jù)庫(kù)生態(tài)論壇成功舉辦

    以“開(kāi)源生態(tài)筑基礎(chǔ),數(shù)字經(jīng)濟(jì)鑄未來(lái)”為主題的2024全球數(shù)字經(jīng)濟(jì)大會(huì)——開(kāi)放原子開(kāi)源數(shù)據(jù)庫(kù)生態(tài)論壇在北京成功舉辦。開(kāi)放原子開(kāi)源基金會(huì)副秘書長(zhǎng)辛?xí)匀A出席并致辭,北京市經(jīng)濟(jì)和信息化局信息化
    的頭像 發(fā)表于 09-24 10:36 ?464次閱讀

    使用Arm KleidiCV開(kāi)源庫(kù)加速圖像處理性能

    針對(duì) Arm CPU 優(yōu)化的性能關(guān)鍵型例程的開(kāi)源庫(kù)。該軟件庫(kù)專為集成到各種計(jì)算機(jī)視覺(jué)框架而設(shè)計(jì),能夠?yàn)?Arm 平臺(tái)上的計(jì)算機(jī)視覺(jué)工作負(fù)載提供最佳性能,并且無(wú)需應(yīng)用開(kāi)發(fā)者進(jìn)行額外編程或
    的頭像 發(fā)表于 09-03 11:32 ?1826次閱讀
    使用Arm KleidiCV<b class='flag-5'>開(kāi)源</b><b class='flag-5'>庫(kù)</b>加速圖像處理性能

    運(yùn)行ble_hello_sensor時(shí)出現(xiàn)了HardFault_Handler,為什么?

    當(dāng)我運(yùn)行 ble_hello_sensor 時(shí),出現(xiàn)了 HardFault_Handler。 我認(rèn)為 cy_rtos_create_thread(cybt_platform_task.c) 用于
    發(fā)表于 05-21 07:35

    阿里云與中興通訊達(dá)成開(kāi)源數(shù)據(jù)庫(kù)合作

    近日,阿里云與中興通訊宣布達(dá)成開(kāi)源數(shù)據(jù)庫(kù)領(lǐng)域的深度合作。中興通訊正式加入PolarDB開(kāi)源社區(qū),并榮任首屆理事會(huì)成員單位,這一舉措標(biāo)志著兩大科技巨頭在數(shù)據(jù)庫(kù)領(lǐng)域的合作邁向新的高度。
    的頭像 發(fā)表于 05-17 10:47 ?570次閱讀

    阿里云與中興通訊達(dá)成開(kāi)源數(shù)據(jù)庫(kù)合作,助推國(guó)產(chǎn)數(shù)據(jù)庫(kù)發(fā)展

    據(jù)悉,阿里云與中興通訊于5月16日公布了開(kāi)源數(shù)據(jù)庫(kù)合作事宜。中興通訊正式宣布加入PolarDB開(kāi)源社區(qū),并擔(dān)任首屆理事會(huì)成員單位。
    的頭像 發(fā)表于 05-16 16:34 ?462次閱讀

    FOC4.3 MTPA創(chuàng)建時(shí),為什么觸發(fā)了HardFault_Handler中斷?

    最近想用ST的FOC 4.3 庫(kù)做一個(gè)空調(diào)壓縮機(jī)的驅(qū)動(dòng)控制。當(dāng)選擇MTPA控制時(shí),當(dāng)執(zhí)行到“oMTPA[M1] = MTPA_NewObject( MTPAParamsM1); ”這個(gè)語(yǔ)句時(shí)(在MCTasks.c的MCboot函數(shù)中調(diào)用),觸發(fā)了HardFault_Han
    發(fā)表于 04-25 07:33

    SDK5開(kāi)源庫(kù)高頻注入的頭文件怎么沒(méi)有?

    ST SDK5開(kāi)源庫(kù),高頻注入的頭文件怎么沒(méi)有?只有。c文件。怎么能夠獲得?
    發(fā)表于 04-17 07:37

    工程里在keil設(shè)置界面,只要把微庫(kù)勾選的去掉,則程序運(yùn)行就會(huì)進(jìn)入hardfault為什么?

    我的工程里在keil設(shè)置界面,只要把微庫(kù)勾選的去掉,則程序運(yùn)行就會(huì)進(jìn)入hardfault,選中就沒(méi)事了,這是為什么呢?
    發(fā)表于 04-17 06:11

    STM32程序運(yùn)行時(shí)會(huì)莫名的進(jìn)入HardFault硬件中斷中,為什么?

    程序運(yùn)行時(shí)會(huì)莫名的進(jìn)入HardFault硬件中斷中,嘗試了一周的時(shí)間,試過(guò)以下方法始終不能找到問(wèn)題出在哪里,希望有人能指導(dǎo)下: 1.換硬件,依然出現(xiàn),可以排除硬件自身原因; 2.在代碼中加入nop
    發(fā)表于 04-10 06:29

    使用STSPIN32F0的MCU時(shí)遇到的疑問(wèn)求解

    最近使用STSPIN32F0的MCU時(shí),出現(xiàn)有如下兩個(gè)問(wèn)題: 1、在使用SDK5.4.6的FOC庫(kù),電機(jī)在大負(fù)載啟動(dòng)時(shí),會(huì)出現(xiàn)實(shí)際轉(zhuǎn)動(dòng)方向與設(shè)置的方向相反;而且最高速運(yùn)行。請(qǐng)問(wèn)這問(wèn)題有誰(shuí)遇到過(guò)
    發(fā)表于 04-02 07:06

    STM32將MCU驅(qū)動(dòng)和應(yīng)用進(jìn)行分離,生成一個(gè)drv.a然后主工程引用drv.a,程序會(huì)進(jìn)入HardFault的原因?

    編譯器:GCC MCU:STM32H563 問(wèn)題:將MCU驅(qū)動(dòng)和應(yīng)用進(jìn)行分離,生成一個(gè)drv.a,然后主工程引用drv.a,這將會(huì)導(dǎo)致程序異常進(jìn)入 HardFault。 解決辦法:將中斷相關(guān)的函數(shù)
    發(fā)表于 03-07 06:08

    深耕文檔型數(shù)據(jù)庫(kù)12載,SequoiaDB再開(kāi)源

    1月15日,巨杉數(shù)據(jù)庫(kù)舉行SequoiaDB新特性及開(kāi)源項(xiàng)目發(fā)布活動(dòng)。本次活動(dòng)回顧了巨杉數(shù)據(jù)庫(kù)深耕JSON文檔型數(shù)據(jù)庫(kù)12年的發(fā)展歷程與技術(shù)演進(jìn),全面解讀了SequoiaDB包括在高可
    的頭像 發(fā)表于 01-16 13:06 ?292次閱讀