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

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

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

trace32 for rt-thread support的基本使用及系統(tǒng)插件原理

嵌入式IoT ? 來源:嵌入式IoT ? 作者:嵌入式IoT ? 2021-01-07 10:34 ? 次閱讀

trace32 for rt-thread support

  • 1.概述

  • 2.trace32的基本使用

  • 3.trace32系統(tǒng)插件原理

  • 4.離線trace32得到rt-thread狀態(tài)信息

    • 4.1 trace32上的rt-thread插件及菜單欄

    • 4.2 trace32 加載dump以及elf文件

  • 5.總結(jié)

1.概述

Lauterbach是全球最大的、完整的、模塊化和可升級微處理器開發(fā)工具的生產(chǎn)商,自1979年以來,在制造世界一流的調(diào)試器和實(shí)時跟蹤方面擁有豐富經(jīng)驗。其中產(chǎn)品線中的TRACE32為大眾廣為所知,是眾多手機(jī)廠商、芯片廠商的必備工具。

嵌入式底層開發(fā)來說,不使用一下trace32,絕對想不到開發(fā)調(diào)試的便利及其功能的強(qiáng)大。

有幸在對某個芯片的支持上學(xué)習(xí)使用了trace32工具,并寫了一些trace32 for rt-thread的插件,現(xiàn)在梳理一下心得體會以及實(shí)現(xiàn)的相關(guān)細(xì)節(jié)。

2.trace32的基本使用

關(guān)于trace32的使用,Lauterbach已經(jīng)提供了相當(dāng)完善的文檔支持,對于芯片的架構(gòu)分析、軟件的重入分析、數(shù)據(jù)的觀測、操作系統(tǒng)的狀態(tài)以及各種符號信息等等都非常容易的觀察到。其調(diào)試功能的強(qiáng)大,非常的好用,但是由于其硬件設(shè)備的昂貴,能夠長時間的使用trace32也是非常有難度的。

但是trace32也提供了相關(guān)的模擬版本,所以這里采用TRACE32 Simulator版本進(jìn)行演示離線功能。

2bbed890-5074-11eb-8b86-12bb97331649.png

可以直接選擇,也可輸入命令

首先選擇CPU的型號

2bd78c1e-5074-11eb-8b86-12bb97331649.png

可以直接選擇下面的提示框,也可以直接輸入sys.cpu進(jìn)行選擇,這里選擇Cortex-A9。

接著就可以輸入system.up,啟動了。

導(dǎo)入elf符號

2bea7734-5074-11eb-8b86-12bb97331649.png

可以看到符號文件對應(yīng)的地址及其代碼。直接通過elf符號就能得到程序的源代碼。

此時只需要結(jié)合dump文件,結(jié)合elf符號,則可以定位到當(dāng)前程序執(zhí)行的狀態(tài)。

從上述功能分析來看,主要是兩部分構(gòu)成:

1.菜單欄(menu bar)

2.顯示信息窗口

無論是點(diǎn)擊菜單欄還是在命令行輸入命令,達(dá)到的效果其實(shí)一樣。菜單欄只是一個簡單的插件,系統(tǒng)可以調(diào)用命令。

3.trace32系統(tǒng)插件原理

trace32是一個工具,其提供了各種各樣的芯片及操作系統(tǒng)插件,同時也可以根據(jù)這些插件來展示需要的信息。

2c481786-5074-11eb-8b86-12bb97331649.png

在操作系統(tǒng)層面,RTOS這部分,國外的許多操作系統(tǒng)都得到了很好的支持,例如Linux、freertos或者ucosii等等,所以我在此基礎(chǔ)上做了rt-thread的支持。

要想做其支持,首先需要得到Lauterbach的官方的支持,提供EDK,也需要對rt-thread系統(tǒng)底層有著非常深刻的理解,尤其對于系統(tǒng)的全局容器對象、線程、IPC的結(jié)構(gòu)體數(shù)組的布局都十分的清楚后,就可以進(jìn)行插件的擴(kuò)展開發(fā)了。

2c98c1a4-5074-11eb-8b86-12bb97331649.png

其底層原理可以概述如下:

TRACE32在進(jìn)行程序分析的時候,可以通過ELF獲取到符號表信息,可以查詢到系統(tǒng)的全局變量和函數(shù)地址信息的。當(dāng)程序在動態(tài)運(yùn)行的時候,根據(jù)符號表對應(yīng)的地址讀取數(shù)據(jù),可以得到當(dāng)前程序的狀態(tài)信息。

而在rt-thread中,有個核心的全局靜態(tài)變量,對象容器(rt_object_container)。記錄著當(dāng)前系統(tǒng)中所有的線程、IPC等鏈表的掛載點(diǎn),而根據(jù)這個線索,又可以尋找到每個鏈表地址對應(yīng)的結(jié)構(gòu)體,根據(jù)符號信息從而找到對應(yīng)的對象的狀態(tài)結(jié)構(gòu)體的數(shù)據(jù)。

而TRACE32插件基本的原理也就是利用了符號以及地址的對應(yīng)關(guān)系,從而得到了系統(tǒng)的信息以及當(dāng)前的狀態(tài)。

4.離線trace32得到rt-thread狀態(tài)信息

在離線分析這部分,dump方案根據(jù)具體的硬件變化而變化,所以這里不多敘述,只采用qemu來dump在程序動態(tài)運(yùn)行時的數(shù)據(jù)信息。

為了簡單起見,這里采用樹莓派2b的rt-thread bsp來做演示。

raspi2在qemu上啟動,須在啟動之前的匯編加上一句話。

/*Suspendtheothercpucores*/
mrcp15,0,r0,c0,c0,5
andsr0,#3
bne_halt

其中_halt的實(shí)現(xiàn)如下:

_halt:
wfe
b_halt

此處掛起其他的核。

而后在env工具下輸入scons進(jìn)行編譯,并且輸入下面的命令測試qemu的執(zhí)行

qemu-system-arm-Mraspi2-m1024M-serialnull-serialstdio-kernelrtthread.elf

可以看到如下的效果:

2cececac-5074-11eb-8b86-12bb97331649.png

接著進(jìn)入調(diào)試階段

qemu-system-arm-Mraspi2-m1024M-serialnull-serialstdio-kernelrtthread.elf-s-S

接著,另外開啟一個env終端。

2d3996ce-5074-11eb-8b86-12bb97331649.png

依次輸入下面的命令,其中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文件

可以通過如下的命令進(jìn)行加載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文件后,可以加載插件文件了。

2d8c07ba-5074-11eb-8b86-12bb97331649.png

此時,即可看到系統(tǒng)相關(guān)的信息了。

這樣即使在離線的情況下,也能能夠根據(jù)需要看到信息了。

5.總結(jié)

rt-thread在trace32上的擴(kuò)展插件使用,可以非常方便的分析系統(tǒng)的狀態(tài)。在實(shí)際的使用場合中,往往在測試階段,不會用到在線的調(diào)試工具,此時當(dāng)系統(tǒng)crash發(fā)生后,采用一些dump方案將內(nèi)存dump出來,接著將dump文件與elf文件加載到trace32,并且利用一些系統(tǒng)級別的插件功能,即可完成系統(tǒng)的分析,非常的簡潔和高效,文章中只描述了基礎(chǔ)功能,一些復(fù)雜信息的分析需要根據(jù)需求進(jìn)行挖掘。

責(zé)任編輯:xj

原文標(biāo)題:trace32 for rt-thread support

文章出處:【微信公眾號:嵌入式IoT】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


聲明:本文內(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)注

    5052

    文章

    18912

    瀏覽量

    300813
  • trace32
    +關(guān)注

    關(guān)注

    0

    文章

    12

    瀏覽量

    13007
  • RT-Thread
    +關(guān)注

    關(guān)注

    31

    文章

    1249

    瀏覽量

    39727

原文標(biāo)題:trace32 for rt-thread support

文章出處:【微信號:Embeded_IoT,微信公眾號:嵌入式IoT】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    2024 RT-Thread全球巡回 線下培訓(xùn)火熱來襲!

    親愛的RT-Thread社區(qū)成員們:我們非常高興地宣布,2024年RT-Thread全球開發(fā)者線下培訓(xùn)即將拉開帷幕!24年全球巡回培訓(xùn)將覆蓋超10座城市及國家,為開發(fā)者提供一個深入學(xué)習(xí)RT-Thread嵌入式開發(fā)的絕佳機(jī)會。
    的頭像 發(fā)表于 08-07 08:35 ?698次閱讀
    2024 <b class='flag-5'>RT-Thread</b>全球巡回 線下培訓(xùn)火熱來襲!

    【好書推薦】RT-Thread設(shè)備驅(qū)動開發(fā)指南

    近年來國內(nèi)芯片產(chǎn)業(yè)和物聯(lián)網(wǎng)產(chǎn)業(yè)的快速崛起,行業(yè)發(fā)展迫切需要更多人才,尤其需要掌握嵌入式操作系統(tǒng)等底層技術(shù)的人才。隨著RT-Thread被更廣泛地應(yīng)用于行業(yè)中,開發(fā)者對嵌入式驅(qū)動開發(fā)的需求越來越
    的頭像 發(fā)表于 08-01 08:35 ?411次閱讀
    【好書推薦】<b class='flag-5'>RT-Thread</b>設(shè)備驅(qū)動開發(fā)指南

    RT-Thread 新里程碑達(dá)成——GitHub Star 破萬!

    RT-Thread實(shí)時操作系統(tǒng)開源項目在GitHub上的star數(shù)量突破一萬!截止發(fā)文,RT-Thread作為實(shí)時操作系統(tǒng)在業(yè)界Star數(shù)量排名第一!倉庫地址:https://gith
    的頭像 發(fā)表于 07-04 08:35 ?342次閱讀
    <b class='flag-5'>RT-Thread</b> 新里程碑達(dá)成——GitHub Star 破萬!

    6月6日杭州站RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    嵌入式軟件工程師郭占鑫老師為您講解有關(guān)技術(shù)知識和實(shí)踐經(jīng)驗。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺上提升系統(tǒng)實(shí)時
    的頭像 發(fā)表于 05-28 08:35 ?350次閱讀
    6月6日杭州站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    新書發(fā)布——《實(shí)時操作系統(tǒng)應(yīng)用技術(shù):RT-Thread與ARM編程實(shí)踐》

    RT-Thread又一本新書《實(shí)時操作系統(tǒng)應(yīng)用技術(shù)——基于RT-Thread與ARM的編程實(shí)踐》發(fā)布,標(biāo)志著RT-Thread生態(tài)和實(shí)時操作系統(tǒng)
    的頭像 發(fā)表于 05-11 08:35 ?634次閱讀
    新書發(fā)布——《實(shí)時操作<b class='flag-5'>系統(tǒng)</b>應(yīng)用技術(shù):<b class='flag-5'>RT-Thread</b>與ARM編程實(shí)踐》

    5月16日南京站RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    嵌入式軟件工程師郭占鑫老師為您講解有關(guān)技術(shù)知識和實(shí)踐經(jīng)驗。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺上提升系統(tǒng)實(shí)
    的頭像 發(fā)表于 05-01 08:35 ?279次閱讀
    5月16日南京站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    RT-Thread混合部署Workshop北京站來啦!

    嵌入式軟件工程師郭占鑫老師為您講解有關(guān)技術(shù)知識和實(shí)踐經(jīng)驗。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺上提升系統(tǒng)
    的頭像 發(fā)表于 04-19 08:34 ?360次閱讀
    <b class='flag-5'>RT-Thread</b>混合部署Workshop北京站來啦!

    4月25日北京站RT-Thread線下workshop,探索RT-Thread混合部署新模式

    嵌入式軟件工程師郭占鑫老師為您講解有關(guān)技術(shù)知識和實(shí)踐經(jīng)驗。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺上提升系統(tǒng)
    的頭像 發(fā)表于 04-16 08:35 ?351次閱讀
    4月25日北京站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式

    4月10日深圳場RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    4月10日我們將在深圳福田舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺上實(shí)現(xiàn)同時運(yùn)行RT-Thread和linux,本次workshop邀請到RT-Thread資深嵌入式軟件工程師農(nóng)曉明老師為您講
    的頭像 發(fā)表于 03-27 11:36 ?707次閱讀
    4月10日深圳場<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    4月10日深圳場RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    嵌入式軟件工程師農(nóng)曉明老師為您講解有關(guān)技術(shù)知識和實(shí)踐經(jīng)驗。通過本次workshop能深入理解RT-Thread專業(yè)版與混合部署的潛力,在RK3568平臺上提升系統(tǒng)實(shí)
    的頭像 發(fā)表于 03-27 08:34 ?436次閱讀
    4月10日深圳場<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    恩智浦半導(dǎo)體正式加入RT-Thread全球合作伙伴計劃!

    前不久,恩智浦半導(dǎo)體正式加入RT-Thread全球合作伙伴計劃,成為RT-Thread高級會員合作伙伴。同時,RT-Thread現(xiàn)已成為恩智浦注冊合作伙伴(RT-Thread| 簡介合
    的頭像 發(fā)表于 03-14 10:40 ?519次閱讀
    恩智浦半導(dǎo)體正式加入<b class='flag-5'>RT-Thread</b>全球合作伙伴計劃!

    RT-Thread設(shè)備驅(qū)動開發(fā)指南基礎(chǔ)篇—以先楫bsp的hwtimer設(shè)備為例

    RT-Thread設(shè)備驅(qū)動開發(fā)指南》書籍是RT-thread官方出品撰寫,系統(tǒng)講解RT-thread IO設(shè)備驅(qū)動開發(fā)方法,從三方面進(jìn)行講解。
    的頭像 發(fā)表于 02-20 16:01 ?1505次閱讀
    <b class='flag-5'>RT-Thread</b>設(shè)備驅(qū)動開發(fā)指南基礎(chǔ)篇—以先楫bsp的hwtimer設(shè)備為例

    RT-Thread qemu mps2-an385 bsp移植制作 :系統(tǒng)運(yùn)行篇

    前面已經(jīng)讓 RT-Thread 進(jìn)入了 entry 入口函數(shù),并且 調(diào)整 鏈接腳本,自動初始化與 MSH shell 的符號已經(jīng)預(yù)留, 進(jìn)入了 RT-Thread 的初始化流
    的頭像 發(fā)表于 11-14 12:27 ?718次閱讀
    <b class='flag-5'>RT-Thread</b> qemu mps2-an385 bsp移植制作 :<b class='flag-5'>系統(tǒng)</b>運(yùn)行篇

    i.MX RT1170:VGLite移植RT-Thread Nano過程講解(下)

    上篇介紹了如何移植 RT-Thread Nano 內(nèi)核與 Finsh 控制臺到 RT1170。本篇繼續(xù)介紹如何將 NXP 官方的 VGLite API 移植到 RT-Thread Nano 上。
    的頭像 發(fā)表于 11-09 11:22 ?820次閱讀

    i.MX RT1170:VGLite移植RT-Thread Nano過程講解(上)

    RT-Thread 是國人自主研發(fā)的開源實(shí)時操作系統(tǒng)(RTOS),RT-Thread Nano 是極簡版的硬實(shí)時內(nèi)核,內(nèi)存占用小,移植簡單。VGLite 是 NXP 提供的輕量級 2D 圖形 API,基于 FreeRTOS 實(shí)現(xiàn)
    的頭像 發(fā)表于 11-09 11:20 ?2333次閱讀
    i.MX <b class='flag-5'>RT</b>1170:VGLite移植<b class='flag-5'>RT-Thread</b> Nano過程講解(上)