[原创] IAR EWARM的SWO Trace调试功能

MamoYU   2020-11-10 13:47 楼主

SWD调试接口是ARM公司提出的一种调试接口,相对于传统的JTAG接口,使用更少的信号引脚。SWD调试接口信号定义如下图红线所示:

图片1.png

图 1

一些Cortex- M3/M4/M7等架构的芯片支持SWO Trace功能,其内置了DWT,ITM((Instrument Trace Macrocell)等单元。ITM的一个主要的用途,就是支持信息的输出。此外DWT还会跟踪中断的进入和退出,对PC计数器进行采样。

IAR支持SWO Trace调试这一强大的调试功能,利用SWD接口中的SWO串行线输出调试时产生的跟踪信息。使用SWO调试需要将调试器的SWO引脚连接到芯片的SWO。

 

本文将简单介绍几种SWO Trace调试的实用功能。

使用SWO Trace的硬件要求:

1.使用的仿真器支持SWD调试接口和SWO串行通信。

2.芯片支持SWD调试接口。M3/M4/M7等主流内核的芯片大多都支持,且芯片上SWO引脚应与硬件调试接口的SWO引脚连接。

使用SWO Trace的软件设置:

调试器配置中选择使用SWD接口连接。

图片2.png

图 2

SWO调试功能举例:

(1). 使用Terminal I/O打印调试信息

IAR提供的Terminal I/O功能可以将函数内printf语句输出的信息在Terminal I/O窗口中显示出来,printf信息的输出有两种方式,半主机模式和SWO模式.半主机模式时信息的输出速率较慢,当使用SWO模式进行信息输出时,速度很快,适用于有大量信息需要输出的时候。可以在General Options->Library Configuration选项中勾选使用SWO模式,Terminal I/O窗口在进入调试环境后从View菜单打开。

图片3.png

 

图 3

(2). 实时显示变量值的变化

借助SWO调试,可以实时监测全局变量的数值变化,并以图形化的方式进行显示。下图中的TestPoint为全局变量,在该变量处右键选择设置“Data Log”数据记录断点。

图片4.png

图 4

通过view->breakpoint选项打开breakpoint断点窗口,在断点处右键点击Edit选项进行编辑,选择当该变量被Write改写时触发数据记录断点。

图片5.png

图 5

图片6.png

图 6

从所使用的仿真器如I-jet调试菜单下打开Data Log和Timeline窗口,在窗口处右键选择“Enable”使能后,点击“Go”全速运行程序,在Data log窗口中将会实时显示全局变量TestPoint变量值的跟踪记录。显示的数据中包含时间戳、变量值和变量地址等信息。

图片7.png

图 7

在Timeline 窗口Data Log一栏再次右键选择“Enable”使能图形化显示,可获得如下TestPoint变量值的实时变化视图。

图片8.png

图 8

(3). 测量代码执行时间

因为Data Log窗口中显示的信息包含了变量值变化时的时间戳,这可用于测量函数的执行时间。如下图所示在排序函数 NumberSorting()执行前后添加了一个全局变量TimeStamp作为测量运行时间的监控变量。 

图片9.png

图 9

图片10.png

图 10

NumberSorting这个函数执行前后修改了TimeStamp变量的值,根据Data Log窗口中TimeStamp值的变化时间可计算出函数的执行时间,TimeStamp 从 0x05 变化到 0x0A 所用的时间为:

t = 21576.23 - 20992.01 = 584.22us

由此可以知道排序函数 NumberSorting()执行所用的时间为 584.22us。

欢迎关注“麦克泰技术”

回复评论 (4)

有意思,收藏了,还真没用过SWO,没想法这么多功能。

默认摸鱼,再摸鱼。2022、9、28
点赞  2020-11-10 22:47
引用: freebsder 发表于 2020-11-10 22:47 有意思,收藏了,还真没用过SWO,没想法这么多功能。

欢迎关注“麦克泰技术”
点赞  2020-11-11 14:23

再多搞点,你搞的文章都很不错。

默认摸鱼,再摸鱼。2022、9、28
点赞  2020-11-11 22:36
引用: freebsder 发表于 2020-11-11 22:36 再多搞点,你搞的文章都很不错。

好滴,谢谢赞赏,你的眼光也不错

欢迎关注“麦克泰技术”
点赞  2020-11-12 09:38
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复