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

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

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

如何使用Ozone的調(diào)試功能

我快閉嘴 ? 來源:麥克泰技術(shù) ? 作者:麥克泰技術(shù) ? 2022-09-06 11:26 ? 次閱讀

Ozone是用于J-link和J-Trace的多平臺調(diào)試,分析工具。獨(dú)立的圖形化界面,可加載IAR,Keil,Gcc,Clang/LLVM等工具鏈生成的Elf/Dwarf可執(zhí)行文件,進(jìn)行C/C++源代碼調(diào)試和匯編指令調(diào)試。可直接使用J-Link和J-Trace內(nèi)置功能,如無限flash斷點(diǎn),flash下載,指令跟蹤等。在Cortex-M架構(gòu)上,Ozone可以幫助用戶快速發(fā)現(xiàn)和分析導(dǎo)致CPU故障的軟件錯誤。本文將介紹如何使用Ozone的調(diào)試功能,深入了解這些類型的錯誤。

分析故障工作流程

我們首先在一個示例的基礎(chǔ)上演示Ozone 的分析故障工作流程。示例應(yīng)用程序可以生成不同類型的 Cortex-M 故障,示例可以在此處(https://wiki.segger.com/File:CortexM_FaultTest.zip)下載。在下圖中,示例應(yīng)用程序已下載到SEGGER Cortex-M Trace開發(fā)板板。使用的仿真器是 J-Trace PRO V2。程序已運(yùn)行至_NoThumbFunc()中,當(dāng)前PC位于跳轉(zhuǎn)地址0的分支上。由于地址 0 處為一條 Thumb 指令,因此恢復(fù)程序執(zhí)行將導(dǎo)致 Cortex-M CPU 故障。我們繼續(xù)執(zhí)行程序,看看 Ozone 如何處理故障。

71a0b520-2d92-11ed-ba43-dac502259ad0.png

一、目標(biāo)異常窗口

菜單欄點(diǎn)擊 GO 后,程序執(zhí)行立即中斷,并彈出 Ozone 的目標(biāo)異常對話框:

71b53428-2d92-11ed-ba43-dac502259ad0.png

目標(biāo)異常窗口顯示 CPU 故障描述及其系統(tǒng)寄存器的內(nèi)容。在此示例中,SHCSR 寄存器 USGFAULTACT 指示發(fā)生了Cortex-M UsageFault 異常。UFSR寄存器提供已發(fā)生的UsageFault 異常; INVSTATE被置位,表示在無效的 CPU 狀態(tài)下執(zhí)行指令。USGFAULTENA 表示已啟用 UsageFault 處理程序,如果沒有使能改位,異常將升級為HardFault。異常寄存器上下文的解釋特定于體系結(jié)構(gòu)。因此,Ozone在異常描述中盡可能多的顯示處理過的信息。當(dāng)程序執(zhí)行暫停且目標(biāo)處于異常狀態(tài)時,都會顯示目標(biāo)異常窗口。

二、向量捕獲

71c53b34-2d92-11ed-ba43-dac502259ad0.png

開始調(diào)試時,Ozone 會啟用 Cortex-M 故障向量捕獲。這會導(dǎo)致程序執(zhí)行在進(jìn)入故障處理程序時立即中止。Ozone 將顯示目標(biāo)異常窗口。如上圖所示,可以使用 Ozone 的 Break & Tracepoints 窗口設(shè)置或清除單個向量捕獲。Ozone還提供命令Break.SetVectorCatch以編程方式編輯目標(biāo)的矢量捕獲狀態(tài)。例如,此命令可用于在調(diào)試啟動時修改 Ozone 的默認(rèn)向量捕獲初始化行為。該命令在項(xiàng)目腳本函數(shù)OnProjectLoad中使用。

三、調(diào)試窗口

現(xiàn)在我們使用Ozone的調(diào)試窗口來進(jìn)一步了解故障。

71cf3044-2d92-11ed-ba43-dac502259ad0.png

Call Stack窗口顯示目標(biāo)處于UsageFault異常狀態(tài)。該窗口顯示故障源自函數(shù)_NoThumbFunc。我們在Call Stack窗口中選擇_NoThumbFunc。在Call Stack窗口中選擇調(diào)用幀時,Ozone 的調(diào)用幀感知調(diào)試窗口會將輸出切換到所選幀的執(zhí)行上下文(請參閱上圖)。Local Data窗口指示在函數(shù)_NoThumbFunc中執(zhí)行了地址 0 分支。這導(dǎo)致 CPU 在 ARM 狀態(tài)下執(zhí)行 Thumb 指令。查看Ozone的寄存器窗口,寄存器UFSR確認(rèn)CPU已發(fā)出INVSTATE UsageFault。

使用跟蹤功能分析故障

在不確定的故障情況下,Cortex-M 內(nèi)核無法提供故障指令的準(zhǔn)確 PC,可以使用 Ozone 的跟蹤窗口來快速識別故障指令。

71a0b520-2d92-11ed-ba43-dac502259ad0.png

如上例所示,使用 Ozone 的 Backtrace Highlighting 功能可以輕松地將不精確的 BusFault 異常追溯到錯誤的存儲指令。

總結(jié)

Cortex-M處理器異常包含:

(1)HardFault異常,是缺省異常,固定優(yōu)先級為-1,優(yōu)先級比除NMI之外的所有中斷和異常更高。

(2)MemManage異常,可通過使用內(nèi)存保護(hù)單元(MPU)引起內(nèi)存訪問沖突異常。

(3)BusFault異常,在任一內(nèi)存訪問錯誤時觸發(fā),例如通過非法讀/寫,向量捕獲。

(4)UsageFault異常,在執(zhí)行錯誤時觸發(fā)。UsageFault異常在向量表第6位,IRQ為-11,具有可配置優(yōu)先級。如果未啟用UsageFault,則會改為觸發(fā)HardFault。

在任一異常中,都會從向量表中調(diào)用異常處理程序,類似于中斷處理過程。Ozone檢測到目標(biāo)系統(tǒng)崩潰時,會自動分析目標(biāo)狀態(tài)并提供所必要的信息。異常窗口指示崩潰的原因,位置以及NVIC寄存器;Call Stack窗口可以從異常中展開,以便導(dǎo)航到錯誤位置,即使跨過多個異常( The Call Stack Window can also unwind from an exception to enable easy navigation to the location of error, even across multiple exceptions.)。

審核編輯:湯梓紅

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

    關(guān)注

    68

    文章

    18926

    瀏覽量

    227214
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10698

    瀏覽量

    209347
  • Cortex-M
    +關(guān)注

    關(guān)注

    2

    文章

    227

    瀏覽量

    29659

原文標(biāo)題:如何使用Ozone分析Cortex-M故障?

文章出處:【微信號:麥克泰技術(shù),微信公眾號:麥克泰技術(shù)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    如何調(diào)用Ozone支持的腳本函數(shù)來實(shí)現(xiàn)自動化的調(diào)試工作

    Ozone是一個跨平臺支持的代碼調(diào)試軟件,支持Segger J-link和J-Trace調(diào)試器。可以加載IAR、keil、GCC、clang/LLVM等工具鏈編譯生成的Elf/Dwarf可執(zhí)行文件,進(jìn)行C/C++源碼
    的頭像 發(fā)表于 09-30 11:14 ?1498次閱讀

    在 PSoC? Creator中使用調(diào)試實(shí)用程序,為什么無法“實(shí)時”看到監(jiān)視變量?

    KIT_A2G_TC387_MOTORCTR一起使用,我可以在其中實(shí)時查看監(jiān)視的變量和流跟蹤數(shù)據(jù)? 我附上了Segger Ozone調(diào)試器的屏幕截圖,只是為了顯示我正在尋找的功能(例如流媒體數(shù)據(jù))。 [我不確定
    發(fā)表于 01-18 10:44

    靈動微課堂 (第161講) | MM32F013x——巧用Ozone調(diào)試MM32 MCU

    在上周的《基于Embedded Studio搭建MM32開發(fā)環(huán)境》的章節(jié)中,我們使用了Ozone這款工具進(jìn)行調(diào)試,今天我們來向大家詳細(xì)地介紹如何使用Ozone調(diào)試MM32 MCU,以及
    發(fā)表于 03-26 09:27

    SEGGER Ozone調(diào)試器使用攻略!

    源碼調(diào)試和匯編指令調(diào)試。通過J-Link實(shí)現(xiàn)高速下載和無限Flash斷點(diǎn)功能(需J-Link型號支持)。本文將介紹如何使用Ozone調(diào)試器。
    發(fā)表于 08-11 17:10

    Ozone調(diào)試步驟

    ??首先說一下,我之前的開發(fā)流程是:VSCode 編輯代碼 + Keil 編譯及調(diào)試。Keil 的調(diào)試功能雖然很強(qiáng)大,但是多數(shù)功能需要配合 ARM 自家的 ULINKpro才可以用,例
    發(fā)表于 11-04 08:19

    如何使用Ozone分析Cortex-M故障?

    源代碼調(diào)試和匯編指令調(diào)試??芍苯邮褂肑-Link和J-Trace內(nèi)置功能,如無限flash斷點(diǎn),flash下載,指令跟蹤等。在Cortex-M架構(gòu)上,Ozone可以幫助用戶快速發(fā)現(xiàn)和分
    發(fā)表于 09-23 11:26

    如何實(shí)現(xiàn)Ozone項(xiàng)目可移植?

    SEGGER Ozone是用于J-link和J-Trace的多平臺調(diào)試、分析工具??杉虞dIAR,Keil,Gcc,Clang/LLVM等工具鏈生成的Elf/Dwarf可執(zhí)行文件,進(jìn)行C/C++源代碼
    發(fā)表于 01-05 13:56

    如何使用ozone調(diào)試雙核應(yīng)用?

    在第二個core的ozone中, 點(diǎn)擊開始調(diào)試, 就不正常了
    發(fā)表于 05-26 08:11

    如何在芯片被JTAG保護(hù)后用Ozone調(diào)試?

    一般使用Jlink連接S32K312是可以的,但是我們已經(jīng)通過寫ADKP key實(shí)現(xiàn)了JTAG保護(hù),芯片生命周期從CUST_DEL提前到IN_FIELD,我們想在芯片被JTAG保護(hù)后用Ozone調(diào)試
    發(fā)表于 05-29 06:44

    華大 MCU 之六 SEGGER Embedded Studio 及 Ozone 使用 Jlink 調(diào)試

    ??首先說一下,我之前的開發(fā)流程是:VSCode 編輯代碼 + Keil 編譯及調(diào)試。Keil 的調(diào)試功能雖然很強(qiáng)大,但是多數(shù)功能需要配合 ARM 自家的 ULINKpro 才可以用
    發(fā)表于 10-29 09:36 ?9次下載
    華大 MCU 之六 SEGGER Embedded Studio 及 <b class='flag-5'>Ozone</b> 使用 Jlink <b class='flag-5'>調(diào)試</b>

    MM32F013x——巧用Ozone調(diào)試MM32 MCU

    在上周的《基于Embedded Studio搭建MM32開發(fā)環(huán)境》的章節(jié)中,我們使用了Ozone這款工具進(jìn)行調(diào)試,今天我們來向大家詳細(xì)地介紹如何使用Ozo...
    發(fā)表于 01-25 18:41 ?2次下載
    MM32F013x——巧用<b class='flag-5'>Ozone</b><b class='flag-5'>調(diào)試</b>MM32 MCU

    MM32F013x——巧用Ozone調(diào)試MM32

    本文將向大家詳細(xì)地介紹如何使用Ozone調(diào)試MM32 MCU,以及Ozone能給大家?guī)砟男┍憷裕w驗(yàn)這款工具的強(qiáng)大之處。
    發(fā)表于 02-08 16:23 ?0次下載
    MM32F013x——巧用<b class='flag-5'>Ozone</b><b class='flag-5'>調(diào)試</b>MM32

    如何實(shí)現(xiàn)Ozone項(xiàng)目可移植?

    SEGGER Ozone是用于J-link和J-Trace的多平臺調(diào)試、分析工具??杉虞dIAR,Keil,Gcc,Clang/LLVM等工具鏈生成的Elf/Dwarf可執(zhí)行文件,進(jìn)行C/C++源代碼調(diào)試和匯編指令
    的頭像 發(fā)表于 12-16 11:20 ?904次閱讀

    SEGGER的Ozone現(xiàn)可支持用于M1/M2(ARM內(nèi)核)上的macOS

    SEGGER的市場經(jīng)理Dirk Akemann說:“基于客戶的大量要求和Apple 處理器產(chǎn)品的流行,我們決定推出一款新的Ozone?!薄疤O果架構(gòu)系統(tǒng)對我們的J-Link調(diào)試仿真器和開發(fā)工具Embedded Studio及SystemView的需求一直很高,所以我們決定將
    的頭像 發(fā)表于 04-07 11:10 ?809次閱讀

    Ozone的3.30版本——J-Link調(diào)試器發(fā)布

    SEGGER宣布最新的Ozone的3.30版本——J-Link調(diào)試器發(fā)布。此更新帶來了許多新功能和改進(jìn),將增強(qiáng)您的調(diào)試體驗(yàn)。
    的頭像 發(fā)表于 06-13 11:37 ?926次閱讀