https://mp.weixin.qq.com/s/9nMo6IYmDCz7S-ALFx824g

简单介绍TLDebugModuleOuter的实现。

1. DebugModuleAccessType

定义调试模块访问宽度:

2. DebugAbstractCommandError

定义抽象命令访问错误:

3. DebugAbstractCommandType

定义抽象命令类型:

4. DebugModuleParams

定义调试模块参数:

其中:

a. nDMIAddrSize:调试总线地址宽度;

b. nProgramBufferWords:Program Buffer中包含的字数,每个字包含4个字节;

c. nAbstractDataWords: 抽象命令数据的字数,每个字包含4个字节;

d. nScratch:

e. hasBusMaster:是否包含SBToTL模块;

f. clockGate: 是否使用门控时钟;

g. maxSupportedSBAccess: 支持访问系统总线的最大宽度;

h. supportQuickAccess: 是否支持快速访问抽象命令;

i. supportHartArray: 是否支持核心数组;

j. hasImplicitEbreak: Program Buffer最后是否包含一个隐含的ebreak命令;

限定条件:

a. DMIAddrSize在7-32之间;

b. nAbstractDataWords在0-16之间;

c. nProgramBufferWords在0-16之间;

5. DefaultDebugModuleParams

默认调试模块参数:

除了已有的默认值外:

a. nAbstractDataWords: 根据总线宽度来决定支持的抽象命令数据字数;

b. maxSupportedSBAccess: 根据总线宽度确定;

6. DebugModuleParams

定义用于获取配置的Key:

7. DebugModuleHartSelFuncs

定义hartid和hartsel之间的映射函数:

8. DebugModuleHartSelKey

定义用于获取配置的Key:

9. DebugInternalBundle

用于传递hartsel等信息的结构:

10. DebugCtrlBundle

调试模块顶层信号:

11. WNotifyWire

生成一个只写的寄存器域:

其中:

a. 宽度为n;

b. 读出的数值为0;

c. 值写入value变量,并以set作为写入标志;

12. RWNotify

生成一个读写寄存器域:

其中:

a. 宽度为n;

b. 从rVal中读出值,并以rNotify作为读取标志;

c. 值写入wVal中,并以wNotify作为写入标志;

13. TLDebugModuleOuter

1) 引入全局配置

2) 多个diplomacy node

A. intnode

包含一个中断节点:

B. dmiNode

包含一个DMI节点,这是一个寄存器节点:

3) lazy module

A. 输出中断,但不接收中断

B. 支持的核心数量:

如果只有一个核心,则不需要支持核心数组;

C. 定义模块IO:

D. dmcontrol使用dmiClock时钟:

E. dmcontrol寄存器

a. 复位值:

b. 更新值:

c. 异步复位寄存器:

d. 寄存器读取时使用的数据源:

e. 接收写寄存器时写入的32位值:

f. 把32位值解析成为带结构值:

g. 读写使能标志:

h. 根据dmactive的值,更新dmcontrol的值:

如果不支持核心数组,则hasel=0;

i. 写使能时更新dmactive的值:

j. dmcontrol是一个可读写寄存器:

其中:DMCONTROLRdEn, DMCONTROLWrEn指示正在读和正在写。

F. hawindowsel & hawindow寄存器

a. 每个核心一个掩码位,窗口宽度为32位:

b. 读取hawindowsel寄存器时使用的数据源:

c. 接收写寄存器时写入的值:

- HAWINDOWSELWrDataVal接收写入的32位值;

- HAWINDOWSELWrData把这个32位的值解析成带结构信息的值;

d. hawindowsel寄存器的读写标志:

e. hawindow寄存器相关变量:

f. 如果支持核心窗口,hawindowsel等于当前选择的32个核心的窗口:

为了防止写入值超过支持的值,需要一个掩码进行限定。这里使用的是:log2Up(nComponents) - 5。这个应该是有问题的,需要再取一次对数,如log2Up(log2Up(nComponents) - 5)。

g. 支持的核心数量需要多少个32位窗口:

h. 生成每个窗口的掩码:

- 如果不是最后一个窗口,则32个核心都支持;如果是最后一个窗口,则根据数量计算包含多少个掩码位;

- HAWINDOWRdData:读取时返回的值需要使用掩码进行限定;

- 如果dmactive为假,则使用复位值;

- 否则如果选择的是当前窗口,则把掩码值写入到hamask寄存器中;

i. 更新包含全部掩码的hamask:

- 把写入的新值更新到当前窗口;

- 非当前窗口使用原值;

G. 生成dmcontrol/hawindowsel/hawindow寄存器:

H. Interrupt Registers

每个核心对应一个中断线,通过intnode连接到每一个核心:

中断的值等于haltreq的值:

I. inner & ctrl

把信号向inner传递:

这里只使用了harsello,没有使用hartselhi,也就是支持1024个以内的核心,hartselhi默认为0.

Rocket - debug - TLDebugModuleOuter的更多相关文章

  1. Rocket - debug - TLDebugModuleInner - Hart Bus Access

    https://mp.weixin.qq.com/s/deNMEyJ1idJDVoZwwo0A1A 简单介绍TLDebugModuleInner中核心总线访问(Hart Bus Access). 参考 ...

  2. Rocket - debug - Periphery

    https://mp.weixin.qq.com/s/uGxn-Xec0LkwdaSsCtQBvw 简单介绍Periphery的实现. 1. ExportDebugDMI/ExportDebugJTA ...

  3. Rocket - debug - DebugTransport

    https://mp.weixin.qq.com/s/EcsuTjb4hFF9Ncig9Gfhew 简单介绍DebugTransport的实现. 1. JtagDTMConfig 1) JtagDTM ...

  4. Rocket - debug - TLDebugModule

    https://mp.weixin.qq.com/s/EhUb1z5oiIw6dJ-90ifDJA 简单介绍TLDebugModule中的实现. 1. device device是一个设备描述符,包含 ...

  5. Rocket - debug - TLDebugModuleOuterAsync

    https://mp.weixin.qq.com/s/PSeMVZjSjEFHJgCYZzfa9Q 简单介绍TLDebugModuleOuterAsync的实现. 1. dmi2tl dmi2tl是T ...

  6. Rocket - debug - TLDebugModuleInner - ROM Generation

    https://mp.weixin.qq.com/s/j_CgHU4PnY82NMwJzOqHYg 简单介绍Variable ROM Generation. 1. jalAbstract jalAbs ...

  7. Rocket - debug - TLDebugModuleInner

    https://mp.weixin.qq.com/s/jkiHceU0HaJbHGvHiU-QOA 简单介绍TLDebugModuleInner的实现. 1. 引入全局配置 1) cfg 引入Debu ...

  8. Rocket - debug - Example: DMI

    https://mp.weixin.qq.com/s/7suuJ7m2BKCpsHk1K2FzJQ 介绍riscv-debug的使用实例:如何使用DMI. 1. dm Debug Module实现了调 ...

  9. Rocket - debug - Example: Triggers

    https://mp.weixin.qq.com/s/zPNyrBOhsytkRrZTDTEvpw 介绍riscv-debug的使用实例:配置Triggers功能. 1. Trigger Trigge ...

随机推荐

  1. tp5中提示错误A non well formed numeric value encountered

    问题因为自动完成时间导致的 原来我的数据库是这样的 修改成下面这样就好了

  2. JAVA知识总结(三):继承和访问修饰符

    今天乘着还有一些时间,把上次拖欠的面向对象编程三大特性中遗留的继承和多态给简单说明一下.这一部分还是非常重要的,需要仔细思考. 继承 继承:它是一种类与类之间的关系,通过使用已存在的类作为基础来建立新 ...

  3. 从浅入深——理解JSONP的实现原理

    由于浏览器的安全性限制,不允许AJAX访问 协议不同.域名不同.端口号不同的 数据接口,浏览器认为这种访问不安全: 可以通过动态创建script标签的形式,把script标签的src属性,指向数据接口 ...

  4. Kitty Cloud(HTTP_RPC)的全局异常处理

    项目地址 https://github.com/yinjihuan/kitty-cloud 异常处理不用我讲,大家都清楚.单独的异常处理太繁琐,全局异常处理可以在一个应用中统一进行异常的处理,非常方便 ...

  5. 02JAVA基础-运算符及选择语句

    一.运算符 1.算数运算符 算数运算符 备注 + 可以用作拼接 - * / 整数相除得整数,需要获得小数,需一方为浮点数 % 取余数 ++ 自增 -- 自减 扩展(1) 对于++和--的扩展(以++为 ...

  6. java ->IO流_字节流

    字节流 在前面的学习过程中,我们一直都是在操作文件或者文件夹,并没有给文件中写任何数据.现在我们就要开始给文件中写数据,或者读取文件中的数据. 字节输出流OutputStream OutputStre ...

  7. 基于 abp vNext 和 .NET Core 开发博客项目 - 完善与美化,Swagger登场

    上一篇文章(https://www.cnblogs.com/meowv/p/12896898.html)已经成功将博客项目跑起来了,那么本篇主要是将之前遗留的问题解决,现在的代码看起来可能还是比较混乱 ...

  8. 「雕爷学编程」Arduino动手做(39)——DS18B20温度传感器

    37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器和模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里 ...

  9. 重学 Java 设计模式:实战工厂方法模式

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获!

  10. mysql小白系列_11 MHA补充

    1.ssh_user 使用VIP方式需要在新的master主机上对网卡启alias并设置IP,普通用户没权限 2.VIP问题 配置以后主从后,在MHA管理节点启动masterha_manager,VI ...