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文章
19107浏览量
304835 -
trace32
+关注
关注
0文章
12浏览量
13029 -
RT-Thread
+关注
关注
31文章
1285浏览量
40089
原文标题:trace32 for rt-thread support
文章出处:【微信号:Embeded_IoT,微信公众号:嵌入式IoT】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
评论