STM32强大的调试和跟踪CoreSight技术

关注、星标公众,不错过精彩内容

作者:黄工

微信公众号:strongerHuang

如今调试STM32能这么方便,在于有一项基于Arm Cortex-M处理器设备的CoreSight技术,该技术引入了强大的新调试(Debug)和跟踪(Trace)功能。

下面就来重点讲讲关于CoreSight中调试和跟踪的相关内容。

一、调试和跟踪功能

CoreSight两个主要功能就是调试和跟踪功能。

1.调试功能

  • 运行处理器的控制,允许启动和停止程序

  • 单步调试源码和汇编代码

  • 在处理器运行时设置断点

  • 即时读取/写入存储器内容和外设寄存器

  • 编程内部和外部FLASH存储器

2.跟踪功能

  • 串行线查看器(SWV)提供程序计数器(PC)采样,数据跟踪,事件跟踪和仪器跟踪信息

  • 指令(ETM)跟踪直接流式传输到您的PC,从而实现历史序列的调试,软件性能分析和代码覆盖率分析

一张图了解整体内容:


二、JTAG

JTAG是行业标准的接口,用于下载和调试目标处理器上的程序以及许多其他功能。它提供了连接设备的简便方法,并且在所有基于Arm处理器的设备上都可用。JTAG接口可与基于Cortex-M的设备一起使用,以访问CoreSight调试功能。

1.JTAG历史

JTAG是联合测试工作组(Joint Test Action Group)的简称,是在名为标准测试访问端口和边界扫描结构的IEEE的标准1149.1的常用名称。此标准用于验证设计与测试生产出的印刷电路板功能。

1990年JTAG正式由IEEE的1149.1-1990号文档标准化,在1994年,加入了补充文档对边界扫描描述语言(BSDL)进行了说明。从那时开始,这个标准被全球的电子企业广泛采用,边界扫描几乎成为了JTAG的同义词。

---引用维基百科

2.JTAG接口

JTAG的接口通常是4/5个接脚接口连到芯片上:

  • TDI(测试数据输入)

  • TDO(测试数据输出)

  • TCK(测试时钟)

  • TMS(测试模式选择)

  • TRST(测试复位)可选

三、SWD串行线调试

SWD,Serial Wire Debug(串行线调试)模式是标准JTAG接口的替代方法,它仅使用两个引脚即可提供与JTAG相同的调试功能,而不会降低性能,并通过串行线查看器(SWV)引入了数据跟踪功能。

在JTAG引脚中包含SWD接口引脚,从而允许标准目标连接器中使用。引脚包含:

  • TCLK-SWCLK(串行时钟)

  • TMS-SWDIO(串行数据输入/输出)

  • TDO-SWO(串行线输出-SWV使用)

关于SWV

SWV:Serial Wire Viewer,串行线查看器

基于Cortex-M3、 M4、 M7的设备能够根据所需信息或分析的类型,以多种方式提供高速数据跟踪信息。当系统处理器继续全速运行时,它通过SWO引脚传输。

可从ITM(仪器跟踪宏单元)和DWT(数据观察点和跟踪)单元获得信息,其中包括:

  • PC(程序计数器)采样

  • 显示CPU周期统计信息的事件计数器

  • 具有定时统计信息的异常和中断执行

  • 跟踪数据-用于时序分析的数据读取和写入

  • 用于简单printf样式调试的ITM跟踪信息

可参看我之前的文章《printf系列教程》,后台回复【printf系列教程】查看更多。

四、拓展:下载调试器

支持JTAG和SWD模式的下载调试器很多,J-Link、 ST-LINK、 ULINK这些大众化的工具都支持,还有很多小众的下载调试器同样也支持。

如果你看过我之前的文章《CMSIS-DAP和J-Link、ST-Link是什么关系?》,就应该知道为什么这些都是基本的功能。

那么,我们该选择哪一种呢? 哪一种更香呢?

支持全面的一点的算J-Link了,但正版的价格,对于普通个人来说,有压力。

有多种版本,算下来好几千一个。

同样,正版ULINK也和J-Link一样,价格上千。当然,很多人买到的ULINK和J-Link都是盗版。

相比ULINK和J-Link而言,正版的ST-Link价格就很划算,一个正版ST-Link V2才两三百,但缺点就是只能针对STM8/32使用。

最后,我想说,我五六年前某宝上十几元买的ST-Link至今还能用,你说哪个香?

免责声明:本文部分素材来源网络,版权归原作者所有。如涉及作品版权问题,请与我联系删除。

‧  END  

推荐阅读:

精选汇总 | 目录 | 搜索

TIOBE 4 月榜单 C 和 JAVA 几乎持平

盘点国产操作系统,能否对抗 Windows ?

关注微信公众号『strongerHuang』,后台回复“1024”查看更多内容,回复“微信”添加我微信。

长按前往图中包含的公众号关注

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

strongerHuang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值