ARM Coresight 系列文章 7 - ARM Coresight 通过 AHB-AP 访问 cpu 内部 coresight 组件

文章目录

上篇文章:ARM Coresight 系列文章 6 - ARM Coresight ROM Table
下篇文章:ARM Coresight 系列文章 8 - ARM Coresight 通过 APBIC 级联使用

如下图所示,如果A78想去访问M33的内部 coresight 组件 ETM,需要要怎么做?

答案也正是在图中,首先A78 通过AXI 互联,接入到 APBIC 的 slave port,再通过APBIC 的 master 送出,而APBIC中的master port 可以 master 的身份来访问对应的 AHB-AP上,至于为何要是使用AHB-AP连接M33? 前面的文章已经介绍过了。

AHB-AP中的 BASE 寄存器存有 M33 的 ROM Table 的地址,通过SOC-600 SPEC 可以找到 AHB-AP 中的 BASE 寄存器的偏移地址,如下图所示 BASE 寄存器在SOC-600 AHB-AP中有两个,偏移地址分别为:0x0DFB和0x1DFB, 那么为何会出现两个BASE寄存器呢?

答案 在SOC-600的SPEC中,如下面截取SOC-600的部分说明,
看了之后其实还是不明白为何要分为两组,其实前面的文章已经介绍过,对于AHB-AP(APB-AP) 的访问可以有两种,一种是通过外部 debugger 工具,另外一种就是通过系统总线来访问,这里的两组寄存器其实就是这个作用,在0x00001000之后的是留给系统总线使用的,另外一组是给外部debugger 使用的。

如下图所示通过读取0x1df8 偏移之后,读到的值为 0xe00ff003, 这个值也就是 M33 ROM TABLE的地址。

读出来的值最后 2 bit 为何是0x3,可以查看前面文章找到原因。

通过查询 M33 的 SPEC 可以看到 0xE00FF000 正是 ROM Table 的地址。

上篇文章:ARM Coresight 系列文章 6 - ARM Coresight ROM Table
下篇文章:ARM Coresight 系列文章 8 - ARM Coresight 通过 APBIC 级联使用

相关推荐
IAR Systems10 小时前
使用IAR Arm工具链开发和调试Zephyr RTOS
arm开发·嵌入式·iar·zephyr
l'm coming1 天前
[linux]内核启动加载驱动文件的流程
linux·arm开发·驱动开发·嵌入式
Code-keys1 天前
ARM NEON SIMD 编程实战:从音频信号处理到AI算子研发实战
arm开发·音视频·信号处理
有什么事1 天前
云手机多开哪个强?ARM架构:云手机多开的信任基石与性能核心
arm开发·智能手机·架构
头枝1 天前
ARM Cortex-M DWT CYCCNT 必须显式初始化,jlink调试时正常,使用时异常的问题
arm开发·stm32·单片机·问题·cyccnt
咖喱年糕1 天前
KEIL5 编译错误解决:MDK 5.37 及以上版本添加 AC5(ARM Compiler 5)编译器
arm开发·单片机·keil·嵌入式软件·ac5
振南的单片机世界1 天前
中央对齐PWM:边沿对齐EMI大,中央对齐更安静
arm开发·stm32·单片机·嵌入式硬件
三佛科技-187366133971 天前
GD32F103VDT6是什么芯片?GD32 ARM Cortex-M3微控制器MCU解析
arm开发·单片机·嵌入式硬件
都在酒里1 天前
【极致低延时】香橙派部署 MediaMTX 实现 WebRTC 推流,延时仅 500-800ms,比局域网 ffmpeg 拉流快近 10 倍!(附踩坑全记录)
linux·arm开发·ffmpeg·webrtc·orangepi·嵌入式软件
XINVRY-FPGA1 天前
XC7A100T-2CSG324I AMD Xilinx Artix-7 FPGA
arm开发·人工智能·嵌入式硬件·神经网络·fpga开发·硬件工程·fpga