Rocket - jtag - JtagTap
https://mp.weixin.qq.com/s/0u9jM2u-FkTlrk3QNuZaBw
简单介绍JtagTap的实现。
1. 简单介绍
定义TAP(Test Access Port)所需要的相关模块,并实现一个生成TAP的方法。
2. JTAGIO
定义JTAG模块的输入输出接口,输入输出方向是从master side的视角出发决定:
其中,TDO是一个三态值:
3. JtagOutput
定义JTAG模块的输出信号:
a. state:JTAG的当前状态;
b. instruction:当前执行的指令;
c. reset:在Test-Logic-Reset状态输出的复位信号;
4. JtagControl
输入Jtag模块的控制信号,这里是复位信号:
5. JtagBlockIO
聚合在一起的Jtag模块的输入输出接口:
其中:
a. jtag:从slave侧看的TCK/TMS/TDI/TDO等接口;
b. control:Jtag模块控制信号,这里是复位信号;
c. output:Jtag模块的输出信号;
d. idcode:根据类参数决定是否包含JTAGIdcodeBundle数据,用以支持IDCODE指令:
e. irLength:指令寄存器的宽度;
6. JtagControllerIO
定义Jtag控制器的输入输出接口:
a. dataChainOut:数据串出接口;
b. dataChainIn:数据串入接口;
7. JtagTapController
定义Jtag TAP控制器:
1) 类参数
a. irLength:指令寄存器宽度;
b. initialInstruction:初始指令;
2) io
Jtag控制器输入输出接口:
3) stateMachine
stateMachine是JtagTapController的状态机:
a. 创建状态机;
b. suggestName:为stateMachine命名;
c. 灌入tms信号:stateMachine.io.tms := io.jtag.TMS;
d. 输出状态机的状态到currState和io.output.state;
4) stateMachine.io.currState/currState/io.output.state
a. stateMachine.io.currState是状态机中使用的状态,也是最原始(最先变化)的状态;
b. currState:JtagTapController中使用的状态,使用Wire挂在stateMachine.io.currState上作为下游,所以其值与stateMachine.io.currState一致;
c. io.output.state:JtagTapController将stateMachine.io.currState输出到io.output.state,以把状态机的状态作为JtagTapController的状态输出;
5) dataChain
A. 串入串出
data chain使用的是JtagControllerIO,只能串入串出;不像irChain是CaptureUpdateChain,可以并入并出(parallel-in/parallel-out)。
B. 交叉
a. io.jtag.TDI输出到io.dataChainOut.data:
b. io.dataChainIn.data输出到TDO:
c. 为什么不是TDI到io.dataChainIn.data,而io.dataChainOut.data到TDO?
如果与指令寄存器(IR)相比较,指令寄存器只有一个,只是其中存放的指令不同,并不会有多个指令同时存在。
而数据寄存器(DR)则包括很多,TAP控制器需要根据指令的不同,把不同的数据寄存器连接到TDI和TDO之间。
6) irChain
a. CaptureUpdateChain
irChain是一个CaptureUpdateChain,可以并入并出。并且irChain的io.chainIn与io.chainOut中间以移位寄存器链相连接。
b. io.jtag.TDI输出到irChain.io.chainIn.data;
c. irChain.io.chainOut.data输出到TDO:
7) tdo
tdo输出到io.jtag.TDO,tdo_driven用于控制TDO是否active:
8) activeInstruction
A. activeInstruction来自于nextActiveInstruction和updateInstruction;
B. 取值
a. reset为真
当模块处于复位状态时,使用initialInstruction;
b. 如果当前状态为UpdateIR,则从irChain.io.update.bits获取更新后的指令;
c. 其他情况下,则不更新指令;
C. 输出activeInstruction到io.output.instruction:
9) io.output.reset
当状态为TestLogicReset时,输出复位信号:
8. JtagTapGenerator
JtagTapGenerator用于使用JtagTapController生成一个JtagTap。
1) internalIo
internalIo是一个JtagBlockIO:
相比较之下,JtagTapController模块的io接口也继承自JtagBlockIO,并且添加了dataChainIn/dataChainOut。
2) allInstructions
A. instructions
instructions是一个Map,key是指令,value是data register chain:
B. idcode
如果idcode定义了,那么也要生成一个IDCODE指令和data register chain的映射:
a. instructions中不能已经包含一个IDCODE指令
b. 生成一个idcodeChain,作为IDCODE指令使用的data chain:
c. capture
从internalIo.idcode中捕获数据:
d. 把IDCODE指令及idcodeChain的映射加入到instructions中
C. allInstructions
allInstructions中需要加入IDCODE指令,如果instructions中没有,那就把创建一个加入进去。
3) 生成initialInstruction
如果没有提供idcode,则使用BYPASS指令:
4) 创建JtagTapController
5) 处理bypassChain
a. 创建bypassChain
b. 从controller中接收输出:
c. 输出到controller:
d. 连接图
若controller选择从bypassChain输入,则bypassChain中的数据经io.dataChainIn.data输入,而后从TDO输出;
若controller选择输入到bypassChain,则TDI中的数据经过io.dataChainOut.data保存到bypassChain中;
6) 生成数据寄存器到使用其的指令的映射:chainToInstCodes
__chainToInstCodes是重构之后的代码:
a. sortedMap:把allInstructions排序之后的映射;
b. groupsByChain:按照使用的chain(test data register)分组;
c. chainToInstCodesMap:生成chain到使用这个chain的指令之间的映射;
d. 使用第一个指令进行排序;
总体而言,就是把原本指令到数据移位寄存器链的映射,转换为数据移位寄存器链到指令序列的映射。
7) 根据controller中正在执行的指令,确定使用的是哪一个data chain:
8) 生成逻辑,把选择到的chain,输出到controller中:
若没有选择到任何一个data chain,则使用bypassChain。
9) 生成逻辑,让选择到的chain,从controller接收数据:
没有选择到的data chain,从unusedChainOut中获取数据:
因为shift/capture/update都是false,所以没有选择到的data chain内容不会发生变化。
10) data chain连接图
11) 连接与controller的jtag/control/output接口:
12) 返回internalIo供外部使用
实际上可以把这个Generator定义为JtagTap类,而internalIo就是JtagTap模块的io。
Rocket - jtag - JtagTap的更多相关文章
- Rocket - jtag - JtagStateMachine
https://mp.weixin.qq.com/s/cFXVOBHayV2w27jpT5RglA 简单介绍JtagStateMachine的实现. 1. 简单介绍 根据IEEE 1149.1-200 ...
- Rocket - jtag - JtagShifter
https://mp.weixin.qq.com/s/pHtrlmSCPqzlDdfj3qkNPQ 简单介绍JtagShifter的实现. 1. 简单介绍 实现移位寄存器链,包含并行Capture和U ...
- Rocket - debug - DebugTransport
https://mp.weixin.qq.com/s/EcsuTjb4hFF9Ncig9Gfhew 简单介绍DebugTransport的实现. 1. JtagDTMConfig 1) JtagDTM ...
- STM32C8T6 JTAG使用到PB3|PB4|PA13|PA14|PB15端口做普通IO时,需禁止JTAG!
GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIO ...
- STM32用JLINK 烧写程序时出现NO Cortex-m device found in JTAG chain现象和解决方案
现象 CPU: STM32107VC 用JLINK 烧写程序时出现NO Cortex-m device found in JTAG chain 如图无法查找到硬件就是CPU 提示1:NO Cortex ...
- 偶遇STM32 JTAG和SWD口(调试)被禁用无法下载,已经粗暴解决!
处女座,为了板子走线美观,拉线方便,在项目量产前,还更改了原来外设的IO口,埋头苦干一天,移植ok,发现PB3一直不听使唤,好,加班检查代码,检查初始化,时钟,IO对应,然后试PCB板,是否短路,断路 ...
- (转)小心FPGA的JTAG口(上电和下电顺序)
同志们,根据ALTERA官方FAE(现场应用工程师)的强烈建议,请注意不要随意带电插拔你的JTAG下载接口,否则会损坏FPGA芯片的JTAG口信号管脚.现象:在排除了下载线的问题后,还是不能访问FPG ...
- JTAG 学习 -SVF格式
yxr注: 主要zt,附上自己的心得如下: 1)反观SVF文件,除了设置必要的条件之外(初始条件和TIR等四条命令),真正的运行命令就两条,SIR向JTAG TAP状态机的IR寄存器送命令,SDR往J ...
- [异常解决] JTAG 与STM32的SWD连接接线方式
如果我们的板子上只留了4个接口:V3.3,SWDIO,SWDCLK,GND.那么和JTAG的连接关系参见下图: dd400cf22b5c01e57a6c9e198d5383a0_189.jpg (0 ...
随机推荐
- react——key值的理解
key不是给开发者使用的,是给react在diff算法中使用的,diff算法会比较新旧虚拟dom,并且是同层比较,当同一层中有多个元素的时候,会比较这一层的key值, 如果key相同,属性改变积极更新 ...
- 王颖奇 201771010129《面向对象程序设计(java)》第四周学习总结
实验四 类与对象的定义及使用 实验时间 2018-9-20 1.目的与要求 学习目标 掌握类与对象的基础概念,理解类与对象的关系: 掌握对象与对象变量的关系: 掌握预定义类的基本使用方法,熟悉Math ...
- 推荐算法_CIKM-2019-AnalytiCup 冠军源码解读
最近在帮一初创app写推荐系统,顺便学习一波用户兴趣高速检索的冠军算法. 写总结前贴出冠军代码的git地址:https://github.com/ChuanyuXue/CIKM-2019-Analyt ...
- Day_08【面向对象】扩展案例2_测试旧手机新手机类,并给新手机实现玩游戏功能
分析以下需求,并用代码实现 1.定义手机类 行为: 打电话,发短信 2.定义接口IPlay 行为: 玩游戏 3.定义旧手机类继承手机类 行为: 继承父类的行为 4.定义新手机继承手机类实现IPlay接 ...
- 【Hadoop离线基础总结】Hadoop的架构模型
Hadoop的架构模型 1.x的版本架构模型介绍 架构图 HDFS分布式文件存储系统(典型的主从架构) NameNode:集群当中的主节点,主要用于维护集群当中的元数据信息,以及接受用户的请求,处理用 ...
- vue项目-打印页面中指定区域的内容(亲测有效!)
关于打印整个页面的,没什么好说的.今天我给大家分享一个打印指定区域的方法,你想打印哪里,就打印哪里! 我也是刚刚开始接触打印这一块功能的,然后当然是找度娘深入了解了一番啦,期间试了网上的各种方法,有的 ...
- 关于redis,你需要了解的几点!
一.关于 redis key: 1.是二进制安全的,也就是说,你可以使用任何形式的二进制序列来作为key,比如一个string,或者一个jpg图片的数据,需要说明的是,空字符串也是一个有效的key. ...
- java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized的报错问题
url的问题 这个是根据使用的数据库版本不同而出现的错误,mysql8.0以上版本在使用URL时如果使用的语句是 url=jdbc:mysql://localhost:3306/book 是会报错的, ...
- 10JAVA基础-常用类02
Arrays 工具类,构造方法私有 //将数组转变为字符串 String str = Arrays.toString(int[] value); //对于原数组进行排序,升序 Arrays.sort( ...
- Rabbitmq 整合Spring,SpringBoot与Docker
SpringBootLearning是对Springboot与其他框架学习与研究项目,是根据实际项目的形式对进行配置与处理,欢迎star与fork. [oschina 地址] http://git.o ...