侵入式調(diào)試和非侵入式調(diào)試
在嵌入式應(yīng)用的開發(fā)過程中,需要通過調(diào)試來解決程序運行過程中出現(xiàn)的問題,根據(jù)是否會打斷程序的“全速運行狀態(tài)”,調(diào)試方式可以分為侵入式調(diào)試和非侵入式調(diào)試兩類。
侵入式調(diào)試手段如下:
? 停機以及單步執(zhí)行程序
? 硬件斷點和斷點指令(BKPT)
? 變量數(shù)據(jù)觀察點(Watch觀察窗口)
? 訪問寄存器的值
? 調(diào)試監(jiān)視器異常
非侵入式調(diào)試手段如下:
? 在內(nèi)核運行的時候訪問存儲器
? 指令跟蹤,需要硬件包含指令跟蹤單元(ETM)
通常情況下,我們采用的是侵入式調(diào)試,但這種調(diào)試會打破程序的全速運行狀態(tài)。非侵入式調(diào)試則可以在保證程序全速運行的情況下,了解程序運行的情況。在調(diào)試大型軟件和RTOS多任務(wù)系統(tǒng),或者與通信時序相關(guān)的應(yīng)用時(非侵入式調(diào)試會破壞通信時序),應(yīng)用代碼可能突然跑飛或者產(chǎn)生異常中斷,而導(dǎo)致問題的原因可能難以發(fā)現(xiàn)。
此時非侵入式調(diào)試如指令跟蹤這樣的功能就有著不可比擬的作用。指令跟蹤能夠記錄問題發(fā)生之前MCU內(nèi)部的指令執(zhí)行歷史記錄,這些信息可以幫助開發(fā)者回溯問題現(xiàn)場來準(zhǔn)確定位問題發(fā)生的原因。
指令跟蹤的實現(xiàn)方式
在嵌入式MCU調(diào)試中指令跟蹤存在多種實現(xiàn)方式,通過對比我們將能夠更清楚的了解Segger J-Trace Pro產(chǎn)品流模式指令跟蹤功能的強大之處。
(1)使用MCU片上緩存實現(xiàn)指令跟蹤
一些MCU內(nèi)部包含指令緩存區(qū)域,緩存區(qū)域依據(jù)不同芯片型號命名可能有所不同,例如Embedded Trace Buffer(ETB),Micro Trace Buffer(MTB),Embedded Trace FIFO(ETF)等。指令跟蹤記錄被保存在該片上區(qū)域,當(dāng)程序停止運行時,PC端調(diào)試軟件讀取該區(qū)域內(nèi)數(shù)據(jù)以獲取指令跟蹤數(shù)據(jù)。
使用該方式實現(xiàn)指令跟蹤存在的限制:
? 片上的緩存空間很小,通常緩存空間大小只有kb級別
? 只能記錄非常有限的指令執(zhí)行歷史記錄
(2)使用調(diào)試器內(nèi)部緩存進(jìn)行指令跟蹤
另外一種實現(xiàn)指令跟蹤的方式是調(diào)試器內(nèi)部提供指令緩存空間,緩存空間大小可能為MB到GB級別,但受限于調(diào)試器本身的硬件實現(xiàn)成本,調(diào)試器內(nèi)部所能夠提供的緩存空間同樣不會很大。
該方式實現(xiàn)指令跟蹤存在的限制:
? 片上的緩存空間為MB到GB范圍
? 能記錄有限的指令執(zhí)行歷史,但無法記錄從應(yīng)用開始執(zhí)行到出現(xiàn)異常的全過程指令記錄
? 通常需要暫停應(yīng)用運行后,PC端軟件才會讀取緩存在調(diào)試器中的Trace數(shù)據(jù)
Segger J-Trace Pro流模式指令跟蹤
前面的兩種實現(xiàn)方式都因為緩存空間大小的影響而有其使用局限性,Segger J-Trace Pro產(chǎn)品則使用流模式的方式解決了前面兩種方式存在的問題,能夠給開發(fā)者帶來成熟的指令跟蹤解決方案。J-Trace Pro在SWD/JTAG調(diào)試接口引腳之外,與芯片通過額外的跟蹤功能引腳連接,包括Trace時鐘和數(shù)據(jù)傳輸引腳,MCU內(nèi)部ETM模塊中記錄的指令通過J-Trace Pro以流模式的方式實時傳輸?shù)絇C端,此時指令的緩存空間在PC電腦端,因此最大的緩存空間甚至可以達(dá)到TB級別,徹底解決了前面兩種實現(xiàn)方式所存在的局限性。
J-Trace Pro支持通過流模式實時的將指令跟蹤數(shù)據(jù)傳輸?shù)诫娔X端,該方案還帶來了如下優(yōu)勢:
? 指令緩存空間大小取決于電腦硬盤大小(TB級別)
? 能夠記錄應(yīng)用從開始執(zhí)行到出現(xiàn)異常的完整指令過程
? 能夠記錄用戶與應(yīng)用程序發(fā)生交互行為中的指令執(zhí)行過程
? 提供的其他高級調(diào)試功能:
實時代碼覆蓋率分析
實時的代碼執(zhí)行情況分析
本文介紹了嵌入式MCU調(diào)試過程中幾種指令跟蹤調(diào)試功能的實現(xiàn)方式,對比可以發(fā)現(xiàn)Segger J-Trace Pro產(chǎn)品的解決方案具有明顯優(yōu)勢,此外Segger還提供了配套的調(diào)試軟件Ozone,能夠提供強大的指令跟蹤調(diào)試功能
審核編輯 :李倩
-
mcu
+關(guān)注
關(guān)注
146文章
17358瀏覽量
352817 -
嵌入式
+關(guān)注
關(guān)注
5096文章
19189瀏覽量
308028 -
寄存器
+關(guān)注
關(guān)注
31文章
5372瀏覽量
121294
原文標(biāo)題:如何使用SEGGER J-Trace Pro流模式實現(xiàn)指令跟蹤功能?
文章出處:【微信號:麥克泰技術(shù),微信公眾號:麥克泰技術(shù)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
加速調(diào)試嵌入式軟件的五個技巧
嵌入式硬件調(diào)試和軟件調(diào)試
嵌入式系統(tǒng)的Proteus仿真中源碼調(diào)試方式介紹
初步掌握嵌入式程序的編譯和調(diào)試過程
嵌入式開發(fā)調(diào)試經(jīng)驗分享
如何調(diào)試嵌入式代碼?
如何使用SEGGER J-Trace Pro流模式實現(xiàn)指令跟蹤功能?
嵌入式系統(tǒng)的遠(yuǎn)程調(diào)試
![<b class='flag-5'>嵌入式</b>系統(tǒng)的遠(yuǎn)程<b class='flag-5'>調(diào)試</b>](https://file1.elecfans.com//web2/M00/A5/B1/wKgZomUMOaGAb5TxAAAqCU-05J0248.jpg)
淺析STM32調(diào)試過程中的幾個相關(guān)問題
嵌入式軟件的打印調(diào)試信息的方法
如何實現(xiàn)嵌入式系統(tǒng)遠(yuǎn)程調(diào)試
![如何<b class='flag-5'>實現(xiàn)</b><b class='flag-5'>嵌入式</b>系統(tǒng)遠(yuǎn)程<b class='flag-5'>調(diào)試</b>](https://file.elecfans.com/web1/M00/D0/B2/pIYBAF-54uKAUjN5AACS2DO0R-M016.png)
嵌入式開發(fā)過程中的一點調(diào)試經(jīng)驗
![<b class='flag-5'>嵌入式開發(fā)過程中</b>的一點<b class='flag-5'>調(diào)試</b>經(jīng)驗](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
評論