女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

3天內不再提示

如何在IAR Embedded Workbench for Arm中調試Cortex-M HardFault

電子工程師 ? 來源:IAR愛亞系統 ? 作者:IAR愛亞系統 ? 2022-08-05 11:11 ? 次閱讀

基于Cortex-M的MCU被廣泛應用于各種嵌入式系統中,Cortex-M有很多優點,比如高性能、低功耗、高代碼密度、豐富的調試功能、強大的生態系統等。在錯誤異常處理上,Cortex-M提供了強大的錯誤異常機制,幫助提升系統的穩健性。

本文主要介紹如何在IAR Embedded Workbench for Arm中調試Cortex-M HardFault,幫助開發人員在開發過程中盡早發現代碼中的錯誤異常、提升開發和調試效率、提高代碼質量。

關于 Cortex-M Fault

Cortex-M包含了如下幾種Fault:

HardFault: 在異常處理中發生錯誤導致的Fault,或者是不能被其它異常處理的Fault。

MemManage Fault: 違反內存訪問規則導致的Fault。

BusFault: 內存訪問過程中總線出錯導致的Fault。

UsageFault: 指令執行時出錯導致的Fault,包括:

- 未定義的指令

- 非法未對齊訪問

- 指令執行時非法狀態

- 異常返回錯誤 下面兩個需要額外使能: - 未對齊訪問字和半字內存

- 除零操作

其中,HardFault是永遠使能的,而MemManage Fault,BusFault和UsageFault默認是沒有使能的,對應的Fault發生之后會升級為HardFault。

在IAR Embedded Workbench for Arm中
調試Cortex-M HardFault

下面通過幾個示例介紹如何在IAR Embedded Workbench for Arm中調試Cortex-M HardFault。

示例1除零操作導致UsageFault

這個例子中,通過配置CCR寄存器中的DIV_0_TRP來使能除零操作異常。在Call Stack窗口中,可以看到對應發生除零操作的源代碼行。在Register窗口中,可以看到 CFSR 寄存器中的DIVBYZERO 置位,表示出現了除零操作異常。在Debug Log和Fault exception viewer窗口中,可以看到詳細的錯誤信息:發生了除零操作異常,導致UsageFault,由于UsageFault沒有使能,升級為HardFault,同時給出了除零操作異常發生的PC地址和LR地址。

c67070b2-146b-11ed-ba43-dac502259ad0.png

示例2訪問無效地址導致BusFault

這個例子中,地址0x7000000是MCU中的無效地址,當訪問無效地址時,會產生BusFault。在Call Stack窗口中,可以看到訪問無效地址的源代碼行。在Register窗口中,可以看到CFSR 寄存器的的PRECISERR和BFARVALID置位,表示出現了Precise data bus error,同時BFAR中保存了對應訪問的無效地址。在Debug Log和Fault exception viewer窗口中,可以看到詳細的錯誤信息:發生了precise data access error,導致BusFault,由于BusFault沒有使能,升級為HardFault,同時給出了precise data access error發生時的PC地址和LR地址及對應訪問的無效地址。

c69ec2fa-146b-11ed-ba43-dac502259ad0.png

示例3從XN(Execute Never)內存運行程序導致MemManage Fault

在這個例子中,地址0x4000000在Cortex-M中是屬Peripheral地址空間,對應的內存屬性屬于XN(Execute Never):即如果從XN內存運行程序會造成MemManage Fault。在Call Stack窗口中,可以看到對應的源代碼行。在Register窗口中,可以看到CFSR 寄存器的的IACCVIOL置位,表示發生了instruction access violation。在Debug Log和Fault exception viewer窗口中,可以看到詳細的錯誤信息:XN訪問違反導致MemManage Fault,由于MemManage Fault沒有使能,升級為HardFault,同時給出了XN訪問發生時的PC地址和LR地址, 通過LR地址可以找到之前函數調用的地方(即導致MemManage Fault的地方)。

c6d05b26-146b-11ed-ba43-dac502259ad0.png

注意事項

1. 為了在調試時出現Fault之后程序能夠立即停下來,從而可以更好地分析出現Fault之后的現場,需要使能對應的Vector catch選項(默認是使能的):關于Vector catch的更多信息,請參考ARMv7-M Architecture Reference Manual。

c6e686a8-146b-11ed-ba43-dac502259ad0.png

2. 本文中的示例是基于Cortex-M4,其它Cortex-M的錯誤異常機制可能會有所不同(比如基于ARMv6-M的Cortex-M0/M0+/M1只有HardFault,沒有MemManage Fault,BusFault和UsageFault),對應Register窗口中的信息可能與上面的截圖不同,具體取決于所使用的 Cortex-M 類型。但是本文的方法適用于所有Cortex-M的HardFault調試。

總結

本文以Cortex-M4為例,介紹了如何在IAR Embedded Workbench for Arm中調試Cortex-M HardFault。通過分析Call Stack,Register,Debug Log和Fault exception viewer窗口中的信息,可以快速地找到HardFault的原因,盡早發現代碼中的錯誤異常,從而提升開發和調試效率,提高代碼質量。

審核編輯 :李倩

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

    關注

    10

    文章

    2947

    瀏覽量

    89324
  • IAR
    IAR
    +關注

    關注

    5

    文章

    369

    瀏覽量

    37232
  • Cortex-M
    +關注

    關注

    2

    文章

    230

    瀏覽量

    30213

原文標題:在IAR Embedded Workbench for Arm中調試Cortex-M HardFault

文章出處:【微信號:IAR愛亞系統,微信公眾號:IAR愛亞系統】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    基于 IAR Embedded Workbench 的自研 MCU 芯片軟件函數與變量內存布局優化精控方法

    在嵌入式軟件開發領域,MCU芯片軟件的架構設計與內存布局的精細規劃對系統性能和穩定性起著關鍵作用。本文檔聚焦于IAR Embedded Workbench環境下,為自研MCU芯片軟件提供了一套詳盡
    的頭像 發表于 04-30 16:38 ?175次閱讀
    基于 <b class='flag-5'>IAR</b> <b class='flag-5'>Embedded</b> <b class='flag-5'>Workbench</b> 的自研 MCU 芯片軟件函數與變量內存布局優化精控方法

    IAR全面支持芯馳科技車規MCU芯片E3650

    2025年4月22日,全場景智能車芯引領者芯馳科技與全球嵌入式軟件開發解決方案領導者IAR正式宣布,IAR Embedded Workbench for
    的頭像 發表于 04-23 15:45 ?529次閱讀

    瑞薩RA8快速上手指南:Cortex-M85內核瑞薩RA8開發環境搭建 并點亮一個LED

    因為Cortex-M內核,瑞薩RA8系列單片機支持多種市面上常見的開發環境,像Keil MDK、IAR EWARM等,而本文講述的是瑞薩自家官方的IDE(e2 studio)。
    的頭像 發表于 03-17 14:35 ?798次閱讀
    瑞薩RA8快速上手指南:<b class='flag-5'>Cortex-M</b>85內核瑞薩RA8開發環境搭建 并點亮一個LED

    Arm Cortex-A320 CPU助力嵌入式設備實現高能效AI計算

    ,要確定適合特定 AI 應用的處理器,系統開發者需要通過比較基于 Arm Cortex-A、Arm Cortex-MArm Ethos
    的頭像 發表于 02-27 17:17 ?659次閱讀
    <b class='flag-5'>Arm</b> <b class='flag-5'>Cortex</b>-A320 CPU助力嵌入式設備實現高能效AI計算

    如何將項目從IAR遷移到Embedded Studio

    本文描述如何將IAR EWARM項目遷移到SEGGER Embedded Studio(簡稱SES)
    的頭像 發表于 02-25 17:11 ?448次閱讀
    如何將項目從<b class='flag-5'>IAR</b>遷移到<b class='flag-5'>Embedded</b> Studio

    盤點工程師常用的嵌入式開發工具

    Cortex-M內核的商用IDE,支持調試、編譯和仿真,廣泛用于STM32等開發。 IAR Embedded Workbench 支持多種
    的頭像 發表于 02-07 10:06 ?1571次閱讀

    IAR與紫光同芯合作,全面支持THA6系列汽車芯片

    近日,全球領先的嵌入式系統開發軟件解決方案提供商IAR與業內知名的芯片及解決方案提供商紫光同芯攜手宣布,最新版本的IAR Embedded Workbench for
    的頭像 發表于 12-27 11:46 ?1185次閱讀

    ?IAR C-SPY為VS Code社區樹立調試新標準

    全球領先的嵌入式系統開發軟件解決方案供應商IAR宣布,對VS Code調試擴展IAR C-SPY調試器進行了重大升級。此次升級引入了
    的頭像 發表于 12-06 10:27 ?590次閱讀

    如何使用Ozone分析Cortex-M異常

    Ozone可以幫助用戶快速分析和查找導致CPU故障的軟件bug。本文解釋如何使用Ozone的調試功能,深入了解Cortex-M架構上的這些錯誤。
    的頭像 發表于 11-29 11:14 ?1472次閱讀
    如何使用Ozone分析<b class='flag-5'>Cortex-M</b>異常

    IAR Systems最新版開發環境全面賦能芯海科技32位MCU芯片

    隨著IAR Embedded Workbench for Arm 9.32版本對芯海科技MCU系列的全面支持,雙方將攜手為開發者提供更加高效、便捷的開發體驗,共同推動物聯網、工業控制、
    的頭像 發表于 11-14 14:47 ?829次閱讀
    <b class='flag-5'>IAR</b> Systems最新版開發環境全面賦能芯海科技32位MCU芯片

    IAR支持旗芯微車規級MCU,助力汽車行業智能化發展

    在全球汽車電子產業迅猛發展的背景下,IAR與蘇州旗芯微半導體有限公司(簡稱“旗芯微”)攜手宣布了一項重大合作成果:IAR Embedded Workbench for
    的頭像 發表于 10-23 11:09 ?1084次閱讀

    【GD32 MCU 入門教程】二、GD32 MCU 燒錄說明 (2)SWD/JTAG在線下載

    Cortex-M內核調試系統支持串行(SW)調試和跟蹤功能,部分型號也支持JTAG調試調試
    的頭像 發表于 08-08 17:34 ?1488次閱讀
    【GD32 MCU 入門教程】二、GD32 MCU 燒錄說明 (2)SWD/JTAG在線下載

    IAR全面支持芯馳科技E3系列車規MCU產品E3119/E3118

    IAR與全場景智能車芯引領者芯馳科技宣布進一步擴大合作,最新版IAR Embedded Workbench for Arm已全面支持芯馳科技
    的頭像 發表于 07-15 10:16 ?175次閱讀
    <b class='flag-5'>IAR</b>全面支持芯馳科技E3系列車規MCU產品E3119/E3118

    IAR全面支持矽力杰SA32系列車規MCU

    在全球嵌入式系統開發軟件領域,IAR以其卓越的解決方案而享有盛譽。近日,IAR與矽力杰半導體達成戰略合作,共同宣布即將推出的IAR Embedded
    的頭像 發表于 06-27 17:27 ?1210次閱讀

    IAR通過多架構認證的靜態分析工具加速代碼質量自動化

    公司推出經TüV SüD認證的C-STAT靜態分析工具,適用于最新發布的IAR Embedded Workbench for RISC-V V3.30.2功能安全版。
    的頭像 發表于 06-19 15:49 ?617次閱讀