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.

最新文章

  1. ThreadLocal原理及其实际应用
  2. Navicat 11使用技巧
  3. QUI操作超时弹出登录窗口登录的处理方式
  4. gulp入门
  5. eclipse同时开两个tomcat
  6. core文件找不到了
  7. AndroidPullToRefresh拉动效果配置
  8. 用free -m查看的结果:
  9. Swift去除两边的特定字符(空格或其它)
  10. Android Studio 字体和字号调整
  11. android与c#之间scoket获取数据进行赋值显示的问题
  12. 使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据
  13. vue-webpack项目本地开发环境设置代理解决跨域问题
  14. python数据类型4
  15. LaTeX自定义宏包、类文件的默认搜索路径设置方法
  16. 10 The Go Programming Language Specification go语言规范 重点
  17. 【ARC066】F - Contest with Drinks Hard
  18. Oracle数据库学习(一):虚拟机下Oracle Linux的安装与配置
  19. 记一次服务器迁移SVN客户端更换IP
  20. 002——vue小结

热门文章

  1. Minimum Euler Cycle(找规律+模拟)
  2. WCF(一)
  3. js上传文件过大导致上传失败原因以及解决办法
  4. leetCode刷题 | 两数之和
  5. 【MySQL基础总结】索引的使用
  6. Adobe Reader XI 打开后“已停止工作”的解决办法
  7. 在ef core中使用postgres数据库的全文检索功能实战之中文支持
  8. 🏃‍♀️点亮你的Vue技术栈,万字Nuxt.js实践笔记来了~
  9. box-sizing 可以使border padding不影响设置的盒子尺寸
  10. 简单而面试中又常见的知识点:JS执行机制