如何用SystemView分析AliOS Things

 

1、SystemView简介

SystemView 是一个用于分析嵌入式系统性能的工具。SystemView可以分析系统中有哪些中断、任务执行了,以及它们的先后关系。 可以完整的深入观察一个应用程序运行时的行为,它揭示了在任务运行中发生了什么,哪个中断触发了任务切换,中断和任务调用了哪个底层系统的API函数。
SystemView 可以实时分析和展示数据,帮助用户进行系统调试和问题诊断,尤其是在开发和处理具有多个任务的复杂系统时。

 

SystemView效果展示:

 

2、基础知识

 

SystemView 由两个部分组成:

SystemView 的PC端程序,用于收集目标板上传的数据信息,并在不同的窗口中显示这些信息。这些记录可以保存到文件中,用于以后的分析。

 

SystemView 嵌入式端程序可以分析嵌入式系统的行为。它记录嵌入式系统产生的监视数据,它包含了SYSTEMVIEW和RTT。SYSTEMVIEW模块用于收集和格式化监视数据,并将数据传送给RTT。RTT模块可以将数据保存在目标板的buffer中,使用J-Link可以实现连续的记录数据。

 

如果想用SystemView分析我们OS的性能,我们需要把SystemView相关的代码加到我们的代码工程中一起编译。
在我们的OS代码需要记录的地方添加hook函数,用SystemView的 API代码实现这些hook函数。
当这些函数被运行时SystemView相关的代码会把数据通过Jlink发送到PC机上,PC机上的SystemView 软件会解析这些数据并通过图形化的方式展示出来。

 

下图展示的是SystemView的工作原理:

 

3、物料清单

 

3.1、HaaS100 硬件

HaaS100 硬件简介

 

3.2、J-Link 仿真器

J-Link是德国SEGGER公司推出基于JTAG的仿真器。操作方便、连接方便、简单易学,是学习开发嵌入式开发最好最实用的开发工具。

 

4、案例实现

4.1、硬件连接

将HaaS100 SWDIO、SWCLK和地GND共3根线与J-Link仿真器连接。

HaaS引脚编号

HaaS引脚说明

J-link引脚说明

J-link引脚编号

41

SWCLK

CLK

9

42

SWDIO

TMS

7

40

GND

GND

8

 

硬件连接图:

 

 

4.2、编译AliOS Things

AliOS Things最新代码中默认集成了SystemView的功能,默认是关闭的,只需要打开Trace工具配置开关就可以使用。

 

打开方式:

在应用package.yaml 文件 depends下添加一行- trace: master。

 

 

参考 helloworld简单示例 中的4.3 编译下载章节,完成helloworld_demo应用的编译和下载。

 

5、使用SystemView

 

5.1、下载安装SystemView

 

下载地址

根据你所用的操作系统下载对应版本的SystemView,然后进行安装。

 

5.2、配置SystemView

拷贝SYSVIEW_AliOSThings.txt 文件到PC机SystemView软件安装目录 C:\Program Files\SEGGER\SystemView\Description下。

SYSVIEW_AliOSThings.txt 文件路径:

components/trace/Config/SYSVIEW_AliOSThings.txt

 

5.3、打开SystemView PC软件

 

点击菜单栏Target打开 Recorder Configuration。

 

参考下图配置参数信息,其中 Address 信息可以从开机串口log 中获取:
例如开机串口log中显示:_SEGGER_RTT:0x34683a1c。

 

 

5.4、开始采集

 

点击菜单栏Target打开 Start Recording

 

界面显示效果如下:

 

6、总结

通过上面的操作,相信你已经学会了使用AliOS Things上的SystemView分析工具了。我们可以通过SystemView看到OS内部的运行情况。

无论是对于学习操作系统知识,还是对操作系统进行性能分析,使用SystemView分析工具都是最好的选择。借助SystemView 这款工具能够缩短调试时间,提高开发效率。

 

开发者支持

如需更多技术支持,可加入钉钉开发者群,或者关注微信公众号。

 

更多技术与解决方案介绍,请访问HaaS官方网站https://haas.iot.aliyun.com

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值