ARM Cortex-M CoreSight调试技术简单记录

2024-02-27 23:18

本文主要是介绍ARM Cortex-M CoreSight调试技术简单记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简述

嵌入式系统开发中,调试与测试是非常重要的,ARM Cortex M也针对于不同场景和需求,提供了专门的调试技术,一般在ARM Cortex M架构的IC内都会集成CoreSight模块专用于调试。像ARM 7/9/11之类的是更早一类调试技术,ARM CortexA应该有更高速的调试技术了。这些都是和应用需求(速率、系统等)相关的。
在这里插入图片描述

CoreSight相关技术

列表如下:

名称详细说明备注
JTAG可接入IC内部CoreSight模块协议
SWDSerial Wire Debug,和JTAG类似,只是pin脚占用要少协议
DAPDebug Access Port,可通过JTAG或SWD接入,观察memory情况内部模块
SWVSerial Wire Viewer,跟踪的功能,包括数据读写, 代码执行, 程序计数器状态以及log输出
SWOSerial Wire Output,使用SWD时用于输出的一根pin
ITMInstrumentation Trace Macrocell, 这是一个32bit的内存地址,往该地址写数据时会从SWO(用SWD)或Trace Port(用ETM)输出该数据
Trace Port4-bit的端口,ULINKpro调试器会通过该端口来收集ETM数据帧和SWV相关输出
ETMEmbedded Trace Macrocell,可以显示所有执行指令,ULINKpro提供了ETM跟踪,ETM需要特殊的20-pin的Cortex Debug + ETM 连接器,ETM还提供Code Coverage和Performance Analysis功能
ETBEmbedded Trace Buffer,ETM跟踪buffer,需要小部分内部RAM
MTBMicro Trace Buffer,使用设备的内部RAM用作指令跟踪buffer
Hardware Breakpoints断点,这个调试中常见,CortexM0/M0+可多达4个,CortexM3/M4/M7可多达6个
WatchpointsCortexM框架的可多达2个,用作条件断点,比如可以监测某处内存发生改变时触发断点

调试器or仿真器

ARM官方提供的请移步至 http://www2.keil.com/mdk5/ulink

另外就是各家IC厂商,使用了ARM的IP,但是自己出了对应的调试器,这里列出比较常见些的:

  • Freescale PE-Micro
  • Nuvoton Nu-Link
  • CMSIS-DAP based adapters
  • Segger J-LINK, J-Trace
  • STMicroelectronics ST-LINK
  • TI XDS

更多精彩内容请关注“技塑未来”微信公众号。

这篇关于ARM Cortex-M CoreSight调试技术简单记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/753864

相关文章

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

使用PyQt5编写一个简单的取色器

《使用PyQt5编写一个简单的取色器》:本文主要介绍PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16进制颜色编码,一款跟随鼠标刷新图像的RGB和16... 目录取色器1取色器2PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16

四种简单方法 轻松进入电脑主板 BIOS 或 UEFI 固件设置

《四种简单方法轻松进入电脑主板BIOS或UEFI固件设置》设置BIOS/UEFI是计算机维护和管理中的一项重要任务,它允许用户配置计算机的启动选项、硬件设置和其他关键参数,该怎么进入呢?下面... 随着计算机技术的发展,大多数主流 PC 和笔记本已经从传统 BIOS 转向了 UEFI 固件。很多时候,我们也

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

Servlet中配置和使用过滤器的步骤记录

《Servlet中配置和使用过滤器的步骤记录》:本文主要介绍在Servlet中配置和使用过滤器的方法,包括创建过滤器类、配置过滤器以及在Web应用中使用过滤器等步骤,文中通过代码介绍的非常详细,需... 目录创建过滤器类配置过滤器使用过滤器总结在Servlet中配置和使用过滤器主要包括创建过滤器类、配置过滤

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho