Rocket - debug - DebugTransport
https://mp.weixin.qq.com/s/EcsuTjb4hFF9Ncig9Gfhew
简单介绍DebugTransport的实现。
1. JtagDTMConfig
1) JtagDTMConfig
这是关于JtagDTM的配置:
其中:
a. idcodeVersion:表示Jtag模块的版本号;
b. idcodePartNum:表示Jtag模块的Part number;
c. idcodeManfId:表示设计者或制造者的编号;
d. debugIdleCycles:表示需要多少个时钟周期DMI能够完成请求的操作:
2) JtagDTMKey
用于查找JtagDTMConfig的关键字:
3) JtagDTMKeyDefault
JtagDTMConfig的默认值:
2. dtmJTAGAddrs
记录JTAGDTM中使用的IR寄存器的地址:
3. DMIAccessUpdate
定义写入dmi寄存器的数据的结构:
各个字段的意义如下:
4. DMIAccessCapture
定义从dmi寄存器中读取数据的结构:
5. DTMInfo
定义dtmcs寄存器的结构:
规范中的定义如下:
注:规范的版本相较于代码实现较新,代码中没有实现dmihardreset。
6. SystemJTAGIO
定义系统JTAG接口:
7. DebugTransportModuleJTAG
用于生成调试传输模块:
1) io
定义调试传输模块的IO接口:
其中:
a. dmi用于与DMI模块相连:
b. jtag是JTAG标准接口,用于与外部连接:
2) DTM Info Chain
a. dtmInfo是一个DTMInfo结构的数据:
其值基本上都是默认值:
其中,dmiStatus是dmi的状态,其定义在规范中为:
dmiStatus使用stickyBusyReg/stickyNonzeroRespReg实现:
b. dtmInfoChain
dtmInfo用于实现dtmInfoChain:
dtmInfoChain是一个CaptureUpdateChain:
所谓Capture就是在Capture-DR状态把dtmcs寄存器的值捕获到移位寄存器中:
所谓Update是指在Update-DR状态把移位寄存器的值并出到dtmcs寄存器中:
在当前的实现中,只有dmireset为可以写:
3) Debug Access Chain
dmiAccessChain用于实现对dmi寄存器的读写:
读取数据的结构为DMIAccessCapture,写入数据的结构为DMIAccessUpdate。
4) busyReg
busyReg是一个寄存器,用于记录busy状态:
当通过DMI接口发起请求时,进入busy状态;当响应返回时,退出busy状态:
5) busy
a. busy
busy是一个布尔值:
表示当前是否busy:
b. stickyBusyReg
stickyBusyReg是一个寄存器:
表示之前是否存在读取dmi寄存器时而结果还没有返回的情况发生:
当写dtmcs.dmireset被写1时,清除stickyBusyReg的值:
6) skipOpReg
当DTM处于busy状态时,跳过操作:
在Update-DR状态,把skipOpReg的值置为false:
在Capture-DR状态,根据是否busy设置skipOpReg的值:
在Update-DR状态,如果skipOpReg为真,则不修改dmiRegReg的值:
也就是跳过操作。
7) downgradeOpReg
当之前的操作有错误时,把请求的操作降级为nop:
在Update-DR状态,把downgradeOpReg的值置为false:
在Capture-DR状态,设置downgradeOpReg的值:
不busy并且有错误返回时,downgradeOpReg置为true。
若downgradeOpReg为真,则向DMI发送的请求为OP_NONE:
8) nonzeroResp
非零响应即是错误响应:
a. nonzeroResp
nonzeroResp是一个标志位:
当返回的相应非零时,或者存在历史非零响应时置位:
b. stickyNonzeroRespReg
stickyNonzeroRespReg用于记录历史非零响应,在Capture-DR状态时置位:
9) dmiResp
Capture-DR状态捕获的值,存在三种情况:
a. 当busy为真时,使用busyResp:
其中:resp=3,规范中定义为:
b. 否则,当响应返回时,为dmiResp:
c. 当响应没返回时,使用nopResp:
10) dmiReqReg
dmiReqReg用于向DMI发送请求:
a. 当skipOpReg为真时,不改变dmiReqReg的值;
b. 当downgradeOpReg为真时,dmiReqReg为全零;
c. 正常情况下,dmiReqReg的值从移位寄存器中更新:
d. 只有正常情况下,才向DMI发送请求:
e. 针对不同的请求,接收响应的时机有所不同:
如果是写请求,则响应返回时即可接收;
如果是读请求,则需要在Capture-DR状态才能接收响应;
11) idcode
idcode是执行IDCODE命令时在Capture-DR状态获取到的值:
这里之所以可以直接调用get,而不用担心返回None,是因为使用JtagTapGenerator时传入的icode是有值的:
12) tapIO
tapIO是使用JtagTapGenerator生成的JtagTap模块的IO:
其类型为JtagBlockIO:
13) io连接
a. io.jtag
io.jtag连接到tap的jtag接口:
b. io.jtag_reset
io.jtag_reset输出到tapIO.control.jtag_reset:
作为Jtag状态机的复位信号:
c. io.fsmReset
当状态为TestLogicReset时,jtagTap输出reset信号:
这个reset信号进而输出到io.fsmReset:
io.fsmReset又被输出到DebugTransportModuleJTAG的复位信号:
Rocket - debug - DebugTransport的更多相关文章
- Rocket - debug - TLDebugModuleInner - Hart Bus Access
https://mp.weixin.qq.com/s/deNMEyJ1idJDVoZwwo0A1A 简单介绍TLDebugModuleInner中核心总线访问(Hart Bus Access). 参考 ...
- Rocket - debug - Periphery
https://mp.weixin.qq.com/s/uGxn-Xec0LkwdaSsCtQBvw 简单介绍Periphery的实现. 1. ExportDebugDMI/ExportDebugJTA ...
- Rocket - debug - TLDebugModule
https://mp.weixin.qq.com/s/EhUb1z5oiIw6dJ-90ifDJA 简单介绍TLDebugModule中的实现. 1. device device是一个设备描述符,包含 ...
- Rocket - debug - TLDebugModuleInner - ROM Generation
https://mp.weixin.qq.com/s/j_CgHU4PnY82NMwJzOqHYg 简单介绍Variable ROM Generation. 1. jalAbstract jalAbs ...
- Rocket - debug - Example: DMI
https://mp.weixin.qq.com/s/7suuJ7m2BKCpsHk1K2FzJQ 介绍riscv-debug的使用实例:如何使用DMI. 1. dm Debug Module实现了调 ...
- Rocket - debug - Example: Triggers
https://mp.weixin.qq.com/s/zPNyrBOhsytkRrZTDTEvpw 介绍riscv-debug的使用实例:配置Triggers功能. 1. Trigger Trigge ...
- Rocket - debug - Example: Accessing Registers Using Program Buffer
https://mp.weixin.qq.com/s/8yYLVg-RXX3XX0T431lxeA 介绍riscv debug接口的使用实例:使用Program Buffer读取寄存器. 1. Wri ...
- Rocket - debug - Example: Accessing Registers Using Abstract Command
https://mp.weixin.qq.com/s/RdJzE06mMkh2x__vVj_fEA 介绍riscv debug接口的使用实例:使用抽象命令读取寄存器. 1. Read s0 using ...
- Rocket - debug - TLDebugModuleInnerAsync
https://mp.weixin.qq.com/s/Xf4VFTHIDFh1NHmfwlTX3w 简单介绍TLDebugModuleInnerAsync的实现. 1. dmInner dmInner ...
随机推荐
- B. Welfare State(RMQ问题的逆向考虑)
\(对于操作1,我们只关心最后一次操作.\) \(对于操作2,我们只关心值最大的一次操作.\) \(也就是说,我们记录每个居民最后一次被修改的位置\) \(然后它的最终答案就是从这个位置起,max(操 ...
- H. Subsequences (hard version) dp
H. Subsequences (hard version) 这个题目好难啊,根本就不知道怎么dp,看了题解,理解了好一会才会的. 首先dp[i][j] 表示前面 i 个字符,形成长度为 j 的不 ...
- 201771010113 李婷华 《面向对象程序设计(Java)》第十七周总结
一.理论知识部分 Java 的线程调度采用优先级策略:优先级高的先执行,优先级低的后执行:多线程系统会自动为每个线程分配一个优先级,缺省时,继承其父类的优先级: 任务紧急的线程,其优先级较高: 同优先 ...
- Java实现栈(链表和线性表两种方法实现)
一.栈的介绍 任何数据结构都是一种规则 栈就是在最基础的结构--线性结构和链式结构上面定义规则形成的 如果对基本数据结构(线性表和链表)有疑问的同学可以看我之前的博客:https://www.cnbl ...
- WEB程序报错Address localhost:1099 is already in use的解决方案(网络端口被占用导致程序无法运行)
首先,这是说明你的本地端口1099已经被占用了,解决的方法有两个: 1.停止本地占用端口 打开cmd 按如下指令进行命令输入,就能找出占用端口的进程并停止啦 2.修改程序运行端口 一个问题,两种解决办 ...
- C++内存管理学习笔记(4)
/****************************************************************/ /* 学习是合作和分享式的! /* Auth ...
- HTML简单的伪装与造假
利用浏览器制止台能简单的修改内容,致使其造成伪装. 打开网页控制台后,不要管那些眼花撩乱的代码,我们直接寻找控制台顶部的 Tab 栏 找到 Console 这个 Tab,点击它,把代码 documen ...
- html中require.config 缓存问题
在html中,require的官方基本用法如下: <!DOCTYPE html> <html> <head> <title>My Sample Proj ...
- Dockerfile-Namespace
Docker核心-Namespaces(命名空间) 1)概念: 命令空间是Linux内核的一个强大的特性.每个容器都有自己单独的命令空间,运行在其中的应用都是独立在操作系用中运行一样.命名空间保证了容 ...
- post请求导出表单。
postExcelFile(params, url) { //params是post请求需要的参数,url是请求url地址 var form = document.createElement(&quo ...