RM新时代网站-首页

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

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

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

AT32講堂009 | 基于CmBacktrace庫,如何快速追蹤和定位產(chǎn)生HardFault的原因

雅特力 AT32 MCU ? 2022-06-15 10:44 ? 次閱讀

概述

在使用ARM Cortex-M系列MCU時(如AT32 MCU),有時會出現(xiàn)程序運行異常。當(dāng)通過編譯器在debug模式查原因時,會發(fā)現(xiàn)程序跑到HardFault_Handler函數(shù)中,產(chǎn)生HardFault,即硬件錯誤。

圖1. HardFault_Handler函數(shù)

7dc45b7c-e6f7-11ec-aa96-dac502259ad0.png

本文檔主要介紹一種基于CmBacktrace庫,快速追蹤和定位產(chǎn)生HardFault原因的方法。


HardFault產(chǎn)生原因

常見產(chǎn)生HardFault產(chǎn)生的原因大概有如下幾類:

數(shù)組越界操作;

內(nèi)存溢出,訪問越界;

堆棧溢出,程序跑飛;

中斷處理錯誤。

數(shù)組越界

程序中使用了靜態(tài)數(shù)組,而在動態(tài)傳參時數(shù)組賦值溢出。或者動態(tài)分配內(nèi)存太小,導(dǎo)致程序異常。

內(nèi)存溢出

重點檢查RAM區(qū)域,程序編譯后執(zhí)行的RAM數(shù)據(jù)量大小為多少是否可能越界。一般不要設(shè)置到極致的情況,程序中的一些動態(tài)數(shù)組傳參時會導(dǎo)致異常。

堆棧溢出

這在使用操作系統(tǒng)的代碼中尤其容易發(fā)生,在操作系統(tǒng)中,任務(wù)的變量均分配放置在任務(wù)所申請的堆棧空間中。

例如FreeRTOS中調(diào)用xTaskCreate來創(chuàng)建任務(wù),該函數(shù)以參數(shù)usStackDepth指定任務(wù)堆棧的大小,如果指定的堆棧太小,則會堆棧申請不足,進(jìn)入HardFault。

中斷處理異常

程序中開啟了某些中斷,例如USART,TIMER,RTC等。

但在程序執(zhí)行中,滿足中斷條件,但并未能查找到該部分對應(yīng)的中斷服務(wù)函數(shù),則可能會出現(xiàn)該異常。


HardFault分析方法

常見的分析方法是:發(fā)生異常之后可首先查看LR寄存器中的值,確定當(dāng)前使用堆棧為MSP或PSP,然后找到相應(yīng)堆棧的指針,并在內(nèi)存中查看相應(yīng)堆棧里的內(nèi)容。由于異常發(fā)生時,內(nèi)核將R0~R3、R12 Returnaddress、PSR、LR寄存器依次入棧,其中Return address即為發(fā)生異常前PC將要執(zhí)行的下一條指令地址。

但以上方法要求對ARM內(nèi)核比較熟悉,且操作較為繁瑣。

以下重點介紹采用開源庫CmBacktrace作為快速分析的方法。

基于CmBacktrace庫分析方法

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

支持的錯誤包括:

1) 斷言(Assert)

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

故障原因自動診斷:可在故障發(fā)生時,自動分析出故障的原因,定位發(fā)生故障的代碼位置,而無需再手動分析繁雜的故障寄存器;

適配Cortex-M0/M3/M4/M7 MCU;

支持IAR、KEIL、GCC編譯器;

支持FreeRTOS、UCOSII、UCOSIII、RT-Thread等OS;

基于MDK的CmBacktrace庫使用流程

基于MDK的移植方法按如下步驟進(jìn)行:

步驟一 添加cm_backtrace庫文件到MDK中

圖2. cm_backtrace庫文件夾

7df7f1d0-e6f7-11ec-aa96-dac502259ad0.png

把cm_backtrace文件夾復(fù)制到我們的工程目錄下,并添加至keil工程中。

圖3. 添加cm_backtrace后keil工程目錄

7e294604-e6f7-11ec-aa96-dac502259ad0.png

步驟二 添加頭文件、勾選C99模式

圖4. Keil中配置C99和頭文件

7e554998-e6f7-11ec-aa96-dac502259ad0.png

步驟三 編譯和調(diào)試

首先,cmb_cfg.h文件按以下提示配置修改。

圖5. cmb_cfg.h文件配置

7eb24972-e6f7-11ec-aa96-dac502259ad0.png

這時候編譯有一個錯誤,這是因為cmb_fault.c與at32f4xx_int.c中的HardFault_Handler函數(shù)重復(fù)定義:

圖6. at32f4xx_it.c編譯報錯

7ee724a8-e6f7-11ec-aa96-dac502259ad0.png

需要把at32f4xx_int.c中的HardFault_Handler函數(shù)屏蔽掉。

圖7. HardFault_Handler函數(shù)屏蔽

7f3febba-e6f7-11ec-aa96-dac502259ad0.png

步驟四 測試與查看

這時候就可以編譯通過了。下面測試這個庫的功能。

測試函數(shù)如下:

圖8. 編寫除零錯誤函數(shù)

7f5c8a7c-e6f7-11ec-aa96-dac502259ad0.png

然后在主函數(shù)中調(diào)用cm_backtrace_init();來初始化cm_backtrace,并調(diào)用該測試函數(shù):

圖9. main函數(shù)調(diào)用除零錯誤函數(shù)

7f89afc0-e6f7-11ec-aa96-dac502259ad0.png

下載運行程序,PC端接收串口信息

圖10. 串口助手輸出錯誤信息

7fb45a54-e6f7-11ec-aa96-dac502259ad0.png

可以看到,列出了出錯原因(除0)和一條命令。運行這個命令需要用到addr2line.exe工具,該工具在tools文件夾中:

圖11. 定位addr2line.exe位置

7fe6473a-e6f7-11ec-aa96-dac502259ad0.png

有32bit和64bit兩個版本,根據(jù)環(huán)境選擇,并拷貝到keil工程目錄下的.axf文件所在的文件夾中,如demo中所附工程,則拷貝到如下目錄:

AN0028_SourceCode_V2.0.0\utilities\AN0028_demo\non_os\mdk_v5\objects

圖12. 拷貝addr2line.exe工具

7fff5964-e6f7-11ec-aa96-dac502259ad0.png

進(jìn)入到cmd窗口,轉(zhuǎn)到上述文件夾位置,運行串口助手中的那條命令:

addr2line -e CmBacktrace(此處要依據(jù)用戶的工程名修改).axf -a -f 080019c6 08001ae9

如demo中工程名為printf,命令則應(yīng)修改為addr2line -e printf.axf -a -f 080019c6 08001ae9

圖13. 調(diào)用CMD運行addr2line.exe工具

800b4f6c-e6f7-11ec-aa96-dac502259ad0.png

可以看到addr2line.exe工具定位出了錯誤相關(guān)的代碼行號,查看對應(yīng)行的代碼:

圖14. 確認(rèn)錯誤代碼區(qū)域

可以看到addr2line.exe工具定位出了錯誤相關(guān)的代碼行號,main.c的第60行,fault_test.c的第38行,查看對應(yīng)行的代碼:

801f3ec8-e6f7-11ec-aa96-dac502259ad0.png

可見,對應(yīng)的行號正是出錯的地方,使用這個CmBacktrace庫能幫助用戶有效、快速地定位到HardFault之類的錯誤。

案例展示

案例一 無OS除零錯誤

工程位置:AN0028_SourceCode_V2.0.0\utilities\AN0028_demo\non_os

測試內(nèi)容:在裸機(jī)上除零錯誤

案例二 FreeRTOS上除零錯誤

工程位置:AN0028_SourceCode_V2.0.0\utilities\AN0028_demo\os\freertos

測試內(nèi)容:在FreeROTOS上除零錯誤,需注意tasks.c中有注釋/**/的三處為針對CmBacktrace做出的修改

案例三 USOCⅢ上非對齊訪問錯誤

工程位置:AN0028_SourceCode_V2.0.0\utilities\AN0028_demo\os\ucosiii

測試內(nèi)容:在UCOSⅢ上非對齊訪問錯誤,需注意os_cfg.h中#define OS_CFG_DBG_EN為1u

關(guān)于雅特力雅特力科技于2016年成立,是一家致力于推動全球市場32位微控制器(MCU)創(chuàng)新趨勢的芯片設(shè)計公司,專注于ARM Cortex-M4/M0+的32位微控制器研發(fā)與創(chuàng)新,全系列采用55nm先進(jìn)工藝及ARM Cortex-M4高效能或M0+低功耗內(nèi)核,締造M4業(yè)界最高主頻288MHz運算效能,并支持工業(yè)級別芯片工作溫度范圍(-40°~105°)。雅特力目前已累積相當(dāng)多元的終端產(chǎn)品成功案例:如微型打印機(jī)、掃地機(jī)、光流無人機(jī)、熱成像儀、激光雷達(dá)、工業(yè)縫紉機(jī)、伺服驅(qū)控、電競周邊市場、斷路器、ADAS、T-BOX、數(shù)字電源、電動工具等終端設(shè)備應(yīng)用,廣泛地覆蓋5G物聯(lián)網(wǎng)、消費、商務(wù)及工控等領(lǐng)域。

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

    關(guān)注

    146

    文章

    17123

    瀏覽量

    350980
收藏 人收藏

    評論

    相關(guān)推薦

    IP定位離線的特點以及作用

    很多人知道IP定位,但是對離線不是很理解。這篇文章會和大家闡述離線的概念、特點以及具體有什么作用。 IP定位路徑https://www.ipdatacloud.com/?utm-s
    的頭像 發(fā)表于 12-06 09:56 ?154次閱讀

    園區(qū)封閉化管理之人員和車輛定位及軌跡追蹤

    如今園區(qū)封閉化管理的需求越來越普遍,特別是化工類的園區(qū),為了實現(xiàn)對園區(qū)內(nèi)人員和車輛的準(zhǔn)確高效管控,人車定位及軌跡追蹤技術(shù)應(yīng)運而生。本文將介紹這一技術(shù)在園區(qū)封閉化管理中的重要作用。 一、 什么是人車
    的頭像 發(fā)表于 10-11 11:20 ?378次閱讀
    園區(qū)封閉化管理之人員和車輛<b class='flag-5'>定位</b>及軌跡<b class='flag-5'>追蹤</b>

    無線定位追蹤器跟手機(jī)怎么連接

    無線定位追蹤器與手機(jī)的連接方法主要取決于追蹤器的類型和功能。以下是一些常見的連接方式: 一、藍(lán)牙連接 確保兼容性 :首先,確保你的定位追蹤
    的頭像 發(fā)表于 09-29 10:01 ?4187次閱讀

    說明增強現(xiàn)實技術(shù)的產(chǎn)生原因

    增強現(xiàn)實技術(shù)(Augmented Reality, AR)的產(chǎn)生,主要源于人類對信息獲取和交互方式的不斷追求與探索,以及計算機(jī)技術(shù)、圖像處理、傳感器技術(shù)、網(wǎng)絡(luò)通信等多領(lǐng)域技術(shù)的快速發(fā)展。以下是增強現(xiàn)實技術(shù)產(chǎn)生的主要
    的頭像 發(fā)表于 09-15 14:44 ?656次閱讀

    AT32講堂087 | 雅特力AT32 IDE快速入門指南

    新建項目新項目向?qū)T32ID提供支持雅特力MCU的C語言項目模板,方便用戶快速創(chuàng)建項目。菜單欄【File】>【New】>【CProject】。新建項目向?qū)У膶υ捒驅(qū)⒊霈F(xiàn)。在對
    的頭像 發(fā)表于 09-15 08:08 ?434次閱讀
    <b class='flag-5'>AT32</b><b class='flag-5'>講堂</b>087 | 雅特力<b class='flag-5'>AT32</b> IDE<b class='flag-5'>快速</b>入門指南

    儀表溫度異常的產(chǎn)生原因

    電子發(fā)燒友網(wǎng)站提供《儀表溫度異常的產(chǎn)生原因.docx》資料免費下載
    發(fā)表于 09-12 14:09 ?0次下載

    簡述自激振蕩產(chǎn)生原因

    自激振蕩是指在沒有外部驅(qū)動信號的情況下,系統(tǒng)內(nèi)部由于某種機(jī)制自發(fā)產(chǎn)生的振蕩現(xiàn)象。這種現(xiàn)象在電子、機(jī)械、聲學(xué)等多個領(lǐng)域中廣泛存在,其產(chǎn)生原因復(fù)雜多樣。以下是對自激振蕩產(chǎn)生
    的頭像 發(fā)表于 09-03 10:59 ?749次閱讀

    AT32講堂085 | 雅特力AT32 MCU HICK時鐘校準(zhǔn)

    簡介AT32系列MCU內(nèi)部都有提供適合運行的內(nèi)部高速時鐘(HICK),其本質(zhì)就是內(nèi)置于芯片的RC振蕩器。在25℃下,其典型值頻率8MHz的精度由工廠校準(zhǔn)到±1%,在-40到105℃,該內(nèi)部高速時鐘
    的頭像 發(fā)表于 08-30 12:26 ?608次閱讀
    <b class='flag-5'>AT32</b><b class='flag-5'>講堂</b>085 | 雅特力<b class='flag-5'>AT32</b> MCU HICK時鐘校準(zhǔn)

    IP定位技術(shù)追蹤網(wǎng)絡(luò)攻擊源的方法

    如今,網(wǎng)絡(luò)安全受到黑客威脅和病毒攻擊越來越頻繁,追蹤攻擊源頭對于維護(hù)網(wǎng)絡(luò)安全變得尤為重要。當(dāng)我們遭受網(wǎng)絡(luò)攻擊時,通過IP地址追蹤技術(shù)結(jié)合各種技術(shù)手段和算法,可以逐步還原出攻擊者的IP地址路徑,隨著
    的頭像 發(fā)表于 08-29 16:14 ?403次閱讀

    智慧園區(qū)人員定位及軌跡追蹤技術(shù)探討

    智慧園區(qū)是指利用先進(jìn)的信息技術(shù)和物聯(lián)網(wǎng)技術(shù),將各種設(shè)備、系統(tǒng)和人員進(jìn)行互聯(lián)互通,實現(xiàn)智能化管理和服務(wù)的園區(qū)。在這樣的園區(qū)中,人員定位和軌跡追蹤是極其重要的功能之一。本文將探討智慧園區(qū)人員定位及軌跡
    的頭像 發(fā)表于 08-28 11:31 ?420次閱讀

    STM32G0 FLASH快速寫入發(fā)生HardFault原因

    32的,成員是64bit的數(shù)組。 調(diào)用第3步寫入函數(shù)就會發(fā)生hardfault,查了很多資料沒有找到原因,求指導(dǎo)
    發(fā)表于 07-23 07:44

    stm32F429zg主頻設(shè)置為180M全速運行有概率進(jìn)入HardFault_Handler的原因?

    調(diào)試很容進(jìn)HardFault_Handler。 我嘗試尋跳轉(zhuǎn)到HardFault_Handler的原因,但找到的造成HardFault_Handler的地址全是無規(guī)律的,后續(xù)我將主頻降
    發(fā)表于 05-29 06:02

    STM32H7在設(shè)置MPU時為什么會進(jìn)入hardfault?

    MPU配置截圖 這樣配置會進(jìn)入hardfault,這么配置的原因是這段里某些地址我用做了ETH和LWIP的緩存 標(biāo)識符啥的 不知道這么配置為什么就會進(jìn)入Hardfault,但是如果我把MPU Cacheable Permiss
    發(fā)表于 05-17 15:02

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

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

    開關(guān)電源產(chǎn)生電磁干擾的原因有哪些

    開關(guān)電源產(chǎn)生電磁干擾(EMI)的原因主要與其工作方式有關(guān)。開關(guān)電源通過高頻開關(guān)來控制能量的轉(zhuǎn)換和傳輸,這種快速切換會在電源內(nèi)部和周圍空間產(chǎn)生電磁場,從而引起電磁干擾。以下是一些詳細(xì)的
    的頭像 發(fā)表于 02-16 17:11 ?2805次閱讀
    RM新时代网站-首页