【ARM Trace32(劳特巴赫) 使用介绍 3 - trace32 访问运行时的内存】

这篇具有很好参考价值的文章主要介绍了【ARM Trace32(劳特巴赫) 使用介绍 3 - trace32 访问运行时的内存】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


请阅读【ARM Coresight SoC-400/SoC-600 专栏导读】


上篇文章:【ARM Trace32(劳特巴赫) 使用介绍 2.2 – TRACE32 进阶命令之 DIAG 弹框命令】
下篇文章:【ARM Trace32(劳特巴赫) 使用介绍 4 - Trace32 Discovery 详细介绍】
文章来源地址https://www.toymoban.com/news/detail-780273.html

1.1 trace32 访问运行时的内存

1.1.1 侵入式 运行时内存访问

侵入式意思是CPU周期性的停止和启动,这样外部debugger才可以使用CPU的 load/store指令访问内存内容。
trace32 trace功能,# 【劳特巴赫 Trace32 系列】,arm开发,Trace 运行时访问,runt-time,Trace32 snoop
这种方式下,debugger和cpu看待内存的方式是一样的,但是这样方式限制了“运行时”的特点。

1.1.2 非侵入式运行时访问

非侵入式就意味着 CPU不用停止下来 当进行memory访问的时候。所以外部debugger就不能使用cpu来进行内存的访问了,所以debugger 必须使用 DAP的方式来进行访问,例如 通过 AHB 和 AXI 总线进行访问,前提是 AHB或者AXI 口必须映射到 memory上。
trace32 trace功能,# 【劳特巴赫 Trace32 系列】,arm开发,Trace 运行时访问,runt-time,Trace32 snoop

1.1.3 缓存一致性的非侵入式运行时访问

这种访问指的是 AHB/AXI 总线绕过 cache 进行访问,在下面的例子中 变量 myVar 只会在 cache 中更新并没有写入到memory中,它的当前状态对外部 debugger是不可见的。
trace32 trace功能,# 【劳特巴赫 Trace32 系列】,arm开发,Trace 运行时访问,runt-time,Trace32 snoop
下面的例子则不同,它的 cache 策略使用的是write-back 方式,当外部 debugger来读取这个变量时会通过 SCU(Snoop Control Unit) 告知 cache 先将其刷到 memory中,所以 debugger读到的数据和cache中的数是一样的。
trace32 trace功能,# 【劳特巴赫 Trace32 系列】,arm开发,Trace 运行时访问,runt-time,Trace32 snoop
上面这个例子中,cache的维护是通过 SCU进行的,在 AXI 访问的过程中,SCU会触发 cache将数据写入memory中。需要注意AHB没有这种功能。

1.2 Trace32 侵入式和非侵入式 运行时访问

使用Trace32 进行运行时访问的时候需要加上个前缀 E 类, E 表示运行访问,E 可以和其他访问类一块使用,如:Data.dump NSD:<address> 可修改成 Data.dump ENSD:<address>

1.2.1 侵入式访问

可以使用功下面的命令:

SYStem.MemAccess.StopAndGo
Data.dump E:0x100
Var.view %E myVar

1.2.2 非侵入式运行时访问

该访问方式也就是直接DAP访问,可以直接通过AHB或者 AXI来访问,并指定访问“类”。这种访问方式需要硬件定义好 AP(access port)。如果使用了一个常用的芯片,在 Trace32 的脚本中使用 SYStem.CPU 命令之后,Trace 就会将 AP 配置好。

SYStem.CONFIG MEMORYACCESSPORT 1 	; Define memory access port and AXI
SYStem.CONFIG AXIACCESSPORT 1.   	; access port (e.g. port number 1)
Data.dump EAXI:<address> 			; Run-time access via AXI. Prefix “E”
Data.dump EAXI:myVar 				; is optional but recommended to read myVarn via the DAP

在 SoC-400 中可以存在 0-255 个 AP port, 所以需要使用 “AXIAPn.Port <port number>” 来指定是哪个 AP PORT。
在 SoC-600 使用的不是 port number 而是地址,如:sys.config.axiap1.base dp:0x2b170000, 如果 soc 中有三个 AXI-AP port 最好是按照顺序进行设置。

使用 DAP的非侵入是运行时访问的例子如下:

SYStem.CONFIG MEMORYACCESSPORT 1. ; Define memory access port and AHB
// SYStem.CONFIG AHBACCESSPORT 1. ; or AXI access port
SYStem.CONFIG AXIACCESSPORT 1.

SYStem.MemAccess DAP ; Non-intrusive access via AHB / AXI

Data.dump E:0x100 ; Run-time access via DAP. Prefix “E”
Var.view %E myVar ; is required to read 0x100 or myVar

1.3 Trace32 缓存一致性的运行时访问

使用命令: SYStem.Option.AXIACEEnable ON

SYStem.CONFIG.MEMORYACCESSPORT 1. ; Define memory access port and AXI
SYStem.CONFIG.AXIACCESSPORT 1. ; access port (e.g. port number 1)

SYStem.Option.AXIACEEnable ON ; Enable cache coherent transactions
SYStem.MemAccess DAP ; Non-intrusive access via AXI

Data.dump E:0x100 ; Run-time access via AXI. Prefix “E”
Var.view %E myVar ; is required to read 0x100 or myVar

如果想通过Trace32 来访问下图中 VPU或者 NPU上的寄存器,那么需要怎么做?
trace32 trace功能,# 【劳特巴赫 Trace32 系列】,arm开发,Trace 运行时访问,runt-time,Trace32 snoop

  • sys.config.axiap1.base dp:0xxxxxxxxx
  • sys.up
  • d.dump eaxi1:0xxxxxxxxx // 读 NI-700里的地址

详细分析见:【ARM Trace32(劳特巴赫) 使用介绍 4 - Trace32 Discovery 详细介绍】

system.attach 与 system.up 命令不同,system.attach 不会对目标系统进行复位。

1.4 Trace32 run bin file

在 fpga/emu上可以使用 trace32使 bin 文件 从sram 中启动:

  • 首先需要将strap pin 设置为从sram 启动;
  • 连接 Trace32,并适应system.prepare 命令进入 prepare 模式;
  • 通过Trace 配置core 进入 wait,比如使用命令Data.Set DP 0x80000B20 %LE %Long 1
  • 通过AHB-AP或者 AXI-AP 将bin 文件写入 sram中,这里以 AXI-AP为例:
sys.config.axiap1.base dp:0x6b200000
d.load.binary /home/sam/test.bin eaxi1:0x90000000
d.dump eaxi1:0x90000000
  • 通过命令释放cpu wait,然后系统将会从sram 中重启:Data.Set DP:x80000B20 %LE %Long 0

命令介绍

  • data.set: 这是 TRACE32 命令,其作用是设定(set)数据(data)。
  • dp: 指定访问数据的方式,这里 dp 代表数据访问点(Data Access Point),通常与特定的存储器或寄存器接口相关。
  • %LE: 这个参数指定了数据的字节顺序。%LE 表示使用小端(Little-Endian)格式。
  • %LONG: 这个参数指定了数据的类型和大小。%long 表示32位长整型数。

1.4.1 CPU 复位与解复位

ARM CPU的复位(Reset)和解复位(Deassert Reset)状态是指处理器从停机状态开始执行指令的过程。这些状态被设计来确保处理器在开机或者需要重新同步时能够以一个已知的、一致的状态开始执行。

1.4.2 复位状态 (Reset State)

当ARM CPU接收到一个复位信号时,它进入复位状态。这通常发生在以下几种情况下:

  • 上电复位:当系统电源首次打开时,处理器会自动进行复位。
  • 外部复位:一个外部信号(例如来自复位按钮或其他硬件组件的信号)可以触发复位。
  • 看门狗复位:如果配置了看门狗计时器并且系统未能在预定时间内响应,看门狗将发出复位信号。
  • 软件复位:软件可以编程性地请求一个复位事件,通常作为异常处理或系统重启的一部分。

在复位状态中,处理器会执行以下动作:

  • 停止执行指令:CPU停止当前的活动并放弃正在执行的指令。
  • 清除寄存器:大多数寄存器,包括程序计数器(PC)、状态寄存器和其他工作寄存器,会被设置为初始状态。
  • 初始化状态机:CPU内部的状态机和控制逻辑会被重置。
  • 清除缓存和流水线:指令和数据缓存可能被清空,流水线被清除。
  • 设置启动地址:程序计数器(PC)被设置为预定的启动地址,通常是一个内存中的固定位置,如0x00000000或0xFFFF0000,取决于具体的ARM架构和实现。

1.4.3 解复位状态 (Deassert Reset State)

解复位状态是指复位信号被释放,CPU开始正常操作的状态。在这个状态,CPU开始从指定的启动地址执行指令。这一过程包括:

  • 执行启动代码:通常是引导加载程序(Bootloader)或初始程序加载器,负责初始化硬件和加载操作系统。
  • 初始化内存和外设:设置堆栈、初始化内存控制器、配置外设接口等。
  • 加载操作系统:如果设备上有操作系统,引导加载程序将负责将其从存储介质(比如闪存)加载到RAM中,并将控制权交给操作系统。

在解复位过程中,CPU开始正常运行,按照启动代码的指示进行操作。这段时间是非常关键的,因为它设置了系统随后运行的基础环境。


上篇文章:【ARM Trace32(劳特巴赫) 使用介绍 2.2 – TRACE32 进阶命令之 DIAG 弹框命令】
下篇文章:【ARM Trace32(劳特巴赫) 使用介绍 4 - Trace32 Discovery 详细介绍】

到了这里,关于【ARM Trace32(劳特巴赫) 使用介绍 3 - trace32 访问运行时的内存】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【ARM Trace32(劳特巴赫) 使用介绍 1.1 - Veloce 环境中使用trace32 连接 Cortex-M33】

    请阅读 【ARM Coresight SoC-400/SoC-600 专栏导读】 上篇文章:【ARM Trace32(劳特巴赫) 使用介绍 1 - Veloce 环境中使用 Trace32】 下篇文章:【ARM Trace32(劳特巴赫) 使用介绍 2.1 – TRACE32 Practice 脚本 cmm 脚本学习】

    2024年02月04日
    浏览(42)
  • 【ARM Trace32(劳特巴赫) 使用介绍 15 -- 通过 nRESE从CPU第一条指令开始Debug】

    请阅读 【嵌入式开发学习必备专栏 】 在 TRACE32 系统中, nRESET 是一个非常重要的概念,它直接关联到目标系统(通常是一个微处理器或微控制器)的硬件复位信号。 nRESET 通常表示为负逻辑(即 “n” 前缀通常表示负逻辑,“RESET” 表示复位信号),意味着当信号为低电平时

    2024年04月28日
    浏览(33)
  • 劳特巴赫仿真测试工具Trace32的基本使用(cmm文件)

    使用PRACTICE 脚本(.cmm) 在TRACE32 中使用PRACTICE 脚本(*.cmm)将帮助你: 在调试器启动时立即执行命令 根据您的项目需求自定义TRACE32PowerView用户界面 加载应用程序或符号 使调试操作具有可重复性, 并可用于验证目的和回归测试 自动启动脚本 安装 TRACE32 软件后,脚本 autostart.cmm 将

    2024年02月02日
    浏览(59)
  • Debug工具Trace32的ARM内存访问类型详解

    关于Trace32的访问类型的基本概念可以参考博文: Trace32使用教程-访问类型(Access Class)_SOC罗三炮的博客-CSDN博客 本文将以ARMv8为基础,详解Trace32的内存访问类型。 内存访问类型 描述 A 绝对寻址(物理地址),即绕过MMU E 运行时访问。(可以由 SYStem.CpuAccess 和SYStem.MemAccess命令来

    2024年02月16日
    浏览(41)
  • [飞腾]Trace32使用概述

     视频教程: B站:【教程11】飞腾CPU JTAG Trace32使用概述 https://www.bilibili.com/video/BV1pG411c77F/?vd_source=6b0aeb756259b17f1846941ff75f37c6 根据飞腾demo图trace32的接法图如下图所示(新一些的demo图jtag的接法已经删除了,可以看比较老点儿的demo才会有这部分原理图,这里参考FT-2000_4core_demo_

    2023年04月18日
    浏览(51)
  • 【ARM Coresight 系列文章 10.2 - ARM Coresight STM Trace packets】

    上篇文章:ARM Coresight 系列文章 10.1 - ARM Coresight STM 介绍及使用 下篇文章:ARM Coresight 系列文章 10.3 - ARM Coresight STM 寄存器介绍 及STM DMA 传输介绍 STM 产生的trace的是遵守 MIPI System Trace Protocol version 2 (STPv2) 规范的,STM 提供 65536(64K) 个 STMv2 chan

    2024年02月16日
    浏览(39)
  • Trace32 部分命令

    以下命令可用于对FLASH进行刷写 FLASH.ReProgram ALL 启用所有声明的FLASH设备进行编程 FLASH.ReProgram off 对FLASH设备进行编程,然后禁用FLASH编程 Data.LOAD.auto 加载刷写文件(在大多数情况下,可以自动检测文件格式) Data.LOAD.file_format 有关支持的文件格式,请参阅《处理器体系结构支

    2024年02月10日
    浏览(42)
  • 【ARM Coresight 系列文章 22 -- linux frace 与 trace-cmd】

    ftrace 是 Linux 内核中的一个跟踪工具,主要用于帮助开发者分析和调试内核的行为。ftrace 的名字来源于 “ function tracer ”,它最初是用于跟踪内核函数调用的,但现在已经发展成一个功能强大的通用跟踪框架,可以跟踪函数调用、调度事件、中断、定时器、内存映射等各种内

    2024年02月11日
    浏览(51)
  • 虚拟ECU:基于SkyEye的TRACE32嵌入式调试

    ​ 随着通信技术、智能终端、云计算等基础支撑技术的发展,嵌入式软件功能的丰富程度日益上升,已不再局限于21世纪初的基础功能,在航空航天、工业控制、医疗设备、消费电子、汽车电子、信息家电、网络通信等领域得到大规模应用,为加快经济发展、提升生活便利水

    2024年04月12日
    浏览(49)
  • Trace32 SRST和TRST、system.attach 和 system.up的区别

    目录 TRST-Resets the JTAG TAP controller and the CPU internal debug logic SRST- Resets the CPU core and peripherals SYStem.Mode Down SYStem.Mode Nodebug SYStem.Mode Prepare SYStem.Mode Go SYStem.Mode Attach SYStem.Mode StandBy SYStem.Mode Up 下图为Trace32工具为ARM debug设计的 JTAG pin 脚图:  其中,TRST和SRST信号是可选的。 Test Res

    2024年02月06日
    浏览(70)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包