trace32 for rt-thread support
-
1.概述
-
2.trace32的基本使用
-
3.trace32系統插件原理
-
4.離線trace32得到rt-thread狀態信息
-
4.1 trace32上的rt-thread插件及菜單欄
-
4.2 trace32 加載dump以及elf文件
-
-
5.總結
1.概述
Lauterbach是全球最大的、完整的、模塊化和可升級微處理器開發工具的生產商,自1979年以來,在制造世界一流的調試器和實時跟蹤方面擁有豐富經驗。其中產品線中的TRACE32為大眾廣為所知,是眾多手機廠商、芯片廠商的必備工具。
在嵌入式底層開發來說,不使用一下trace32,絕對想不到開發調試的便利及其功能的強大。
有幸在對某個芯片的支持上學習使用了trace32工具,并寫了一些trace32 for rt-thread的插件,現在梳理一下心得體會以及實現的相關細節。
2.trace32的基本使用
關于trace32的使用,Lauterbach已經提供了相當完善的文檔支持,對于芯片的架構分析、軟件的重入分析、數據的觀測、操作系統的狀態以及各種符號信息等等都非常容易的觀察到。其調試功能的強大,非常的好用,但是由于其硬件設備的昂貴,能夠長時間的使用trace32也是非常有難度的。
可以直接選擇,也可輸入命令
首先選擇CPU的型號
可以直接選擇下面的提示框,也可以直接輸入sys.cpu
進行選擇,這里選擇Cortex-A9
。
接著就可以輸入system.up
,啟動了。
導入elf符號
可以看到符號文件對應的地址及其代碼。直接通過elf符號就能得到程序的源代碼。
此時只需要結合dump文件,結合elf符號,則可以定位到當前程序執行的狀態。
從上述功能分析來看,主要是兩部分構成:
1.菜單欄(menu bar)
2.顯示信息窗口
無論是點擊菜單欄還是在命令行輸入命令,達到的效果其實一樣。菜單欄只是一個簡單的插件,系統可以調用命令。
3.trace32系統插件原理
trace32是一個工具,其提供了各種各樣的芯片及操作系統插件,同時也可以根據這些插件來展示需要的信息。
在操作系統層面,RTOS這部分,國外的許多操作系統都得到了很好的支持,例如Linux、freertos或者ucosii等等,所以我在此基礎上做了rt-thread的支持。
要想做其支持,首先需要得到Lauterbach的官方的支持,提供EDK,也需要對rt-thread系統底層有著非常深刻的理解,尤其對于系統的全局容器對象、線程、IPC的結構體數組的布局都十分的清楚后,就可以進行插件的擴展開發了。
其底層原理可以概述如下:
TRACE32在進行程序分析的時候,可以通過ELF獲取到符號表信息,可以查詢到系統的全局變量和函數地址信息的。當程序在動態運行的時候,根據符號表對應的地址讀取數據,可以得到當前程序的狀態信息。
而在rt-thread中,有個核心的全局靜態變量,對象容器(rt_object_container)
。記錄著當前系統中所有的線程、IPC等鏈表的掛載點,而根據這個線索,又可以尋找到每個鏈表地址對應的結構體,根據符號信息從而找到對應的對象的狀態結構體的數據。
而TRACE32插件基本的原理也就是利用了符號以及地址的對應關系,從而得到了系統的信息以及當前的狀態。
4.離線trace32得到rt-thread狀態信息
在離線分析這部分,dump方案根據具體的硬件變化而變化,所以這里不多敘述,只采用qemu來dump在程序動態運行時的數據信息。
為了簡單起見,這里采用樹莓派2b的rt-thread bsp來做演示。
raspi2在qemu上啟動,須在啟動之前的匯編加上一句話。
/*Suspendtheothercpucores*/
mrcp15,0,r0,c0,c0,5
andsr0,#3
bne_halt
其中_halt
的實現如下:
_halt:
wfe
b_halt
此處掛起其他的核。
而后在env工具下輸入scons
進行編譯,并且輸入下面的命令測試qemu的執行
qemu-system-arm-Mraspi2-m1024M-serialnull-serialstdio-kernelrtthread.elf
可以看到如下的效果:
接著進入調試階段
qemu-system-arm-Mraspi2-m1024M-serialnull-serialstdio-kernelrtthread.elf-s-S
接著,另外開啟一個env終端。
依次輸入下面的命令,其中dump到的文件是
dumpbinarymemoryrtt_dump0x80000x1000000
可以得到rtt_dump
的dump的文件,大小為16MB。
4.1 trace32上的rt-thread插件及菜單欄
其中rtthread.t32
為可以加載的t32文件,而rtthread.men
為菜單文件。
task.configD:work
t-threadsp
aspberry-pi
aspi2
tthread.t32
menu.reprogramD:work
t-threadsp
aspberry-pi
aspi2
tthread.men
4.2 trace32 加載dump以及elf文件
可以通過如下的命令進行加載dump文件以及elf文件。
Data.LOAD.BinaryD:work
t-threadsp
aspberry-pi
aspi2
tt_dump0x8000
Data.LOAD.ElfD:work
t-threadsp
aspberry-pi
aspi2
tthread.elf
加載了符號文件與dump文件后,可以加載插件文件了。
此時,即可看到系統相關的信息了。
這樣即使在離線的情況下,也能能夠根據需要看到信息了。
5.總結
rt-thread在trace32上的擴展插件使用,可以非常方便的分析系統的狀態。在實際的使用場合中,往往在測試階段,不會用到在線的調試工具,此時當系統crash發生后,采用一些dump方案將內存dump出來,接著將dump文件與elf文件加載到trace32,并且利用一些系統級別的插件功能,即可完成系統的分析,非常的簡潔和高效,文章中只描述了基礎功能,一些復雜信息的分析需要根據需求進行挖掘。
責任編輯:xj
原文標題:trace32 for rt-thread support
文章出處:【微信公眾號:嵌入式IoT】歡迎添加關注!文章轉載請注明出處。
-
嵌入式
+關注
關注
5082文章
19126瀏覽量
305198 -
trace32
+關注
關注
0文章
12瀏覽量
13033 -
RT-Thread
+關注
關注
31文章
1289瀏覽量
40129
原文標題:trace32 for rt-thread support
文章出處:【微信號:Embeded_IoT,微信公眾號:嵌入式IoT】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論