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

相关文章

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Web技术与Nginx网站环境部署教程

《Web技术与Nginx网站环境部署教程》:本文主要介绍Web技术与Nginx网站环境部署教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Web基础1.域名系统DNS2.Hosts文件3.DNS4.域名注册二.网页与html1.网页概述2.HTML概述3.

使用nohup和--remove-source-files在后台运行rsync并记录日志方式

《使用nohup和--remove-source-files在后台运行rsync并记录日志方式》:本文主要介绍使用nohup和--remove-source-files在后台运行rsync并记录日... 目录一、什么是 --remove-source-files?二、示例命令三、命令详解1. nohup2.

Python MCPInspector调试思路详解

《PythonMCPInspector调试思路详解》:本文主要介绍PythonMCPInspector调试思路详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录python-MCPInspector调试1-核心知识点2-思路整理1-核心思路2-核心代码3-参考网址

Java使用WebView实现桌面程序的技术指南

《Java使用WebView实现桌面程序的技术指南》在现代软件开发中,许多应用需要在桌面程序中嵌入Web页面,例如,你可能需要在Java桌面应用中嵌入一部分Web前端,或者加载一个HTML5界面以增强... 目录1、简述2、WebView 特点3、搭建 WebView 示例3.1 添加 JavaFX 依赖3

Linux系统调试之ltrace工具使用与调试过程

《Linux系统调试之ltrace工具使用与调试过程》:本文主要介绍Linux系统调试之ltrace工具使用与调试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、ltrace 定义与作用二、ltrace 工作原理1. 劫持进程的 PLT/GOT 表2. 重定

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模