Rocket - jtag - JtagShifter
https://mp.weixin.qq.com/s/pHtrlmSCPqzlDdfj3qkNPQ
简单介绍JtagShifter的实现。
1. 简单介绍
实现移位寄存器链,包含并行Capture和Update功能,用于实现从TDI到IR/DR,再到TDO的串行移位路径。
2. ShifterIO
定义Shifter的输入输出接口:
a. data:被移位(移入移出)的数据;
b. shift:控制是否移位(high in the ShiftIR/DR state);
c. capture:控制是否捕获数据(high in CaptureIR/DR state);
d. update:控制是否更新数据(hign in UpdateIR/DR state);
另外:
a. 多个ShifterIO可以组合在一起成为一个shifter chain;
b. chainControlFrom方法只是把控制接口串在一起,并没有串接data;
3. ChainIO
定义包含一个输入移位器接口和一个输出移位器接口的移位器链:
4. Capture
定义CaptureIO:
其中,
a. bits:输入信号,从中输入要捕获的数据(data to capture);
b. capture:输出信号,只是是否在捕获数据;
5. Chain
定义会引入一个ChainIO输入输出接口的特征:
6. JtagBypassChain
定义包含bypass寄存器的移位器链,按照规范中的说法,是select the bypass register to be connected for serial access between TDI and TDO in the Shift-DR controller state:
1) io
输入输出接口是一个ChainIO,用于把数据串行移入移出:
2) reg
reg即是bypass register,只有一个比特:
reg中的数据输出到chainOut这个ShifterIO:
reg中的数据从chainIn中来:
这里同时也考虑到capture的情况,可以参考规范。
3) assert
这个断言后面还会出现,用于断定capture/update/shift这三个值不能同时为真:
7. CaptureChain
包含并行数据捕获功能的移位器链:
1) io
在ChainIO的基础上,添加CaptureIO:
2) n
n是并行捕获数据的宽度,同时也是构造移位器链所需要的单比特寄存器数:
3) regs
regs用于存放并行捕获的数据,同时也支持移位:
4) 移位
regs可以通过移位逐位输入输出。
a. 串出
b. 串入
c. 移位
5) 捕获
regs也可以通过捕获并行输入输出。
a. 并行捕获
并行(一次性)地把io.capture.bits中的数据输入到regs中:
b. io.capture.capture赋值
相较于io.chainIn.shift通过外部输入,io.capture.capture的值根据io.chainIn.capture和io.chainIn.shift来决定:
8. CaptureUpdateChain
包含并行捕获和更新的移位寄存器链:
1) io
在ChainIO的寄存上加入CaptureIO和update相关的数据:
其中,更新相关的数据使用ReadyValid接口;
2) captureWidth/updateWidth/n
a. captureWidth:捕获数据的宽度;
b. updateWidth:更新数据的宽度;
c. n:两者中的较大值;
n取较大值,因为生成的寄存器既要并行输入要捕获的数据,也要并行输出更新的数据:
3) 移位
a. 串出
b. 串入
c. 移位
4) 捕获
把io.capture.bits并行输入到regs中:
这里使用math.min(n, captureWidth)是没有必要的,可以直接使用captureWidth;因为n ≥captureWidth,所以两者中较小的肯定是captureWidth。
5) 更新
在判断到io.chainIn.update为真时,会把io.update.valid值为真:
此时由regs产生的updateBits就并行更新(parallel update)输出到io.update.bits中了:
6) 断言
这个断言的意义在这里就更明确了,用于断定capture/update/shift这三个值不能同时为真:
Rocket - jtag - JtagShifter的更多相关文章
- Rocket - jtag - JtagTap
https://mp.weixin.qq.com/s/0u9jM2u-FkTlrk3QNuZaBw 简单介绍JtagTap的实现. 1. 简单介绍 定义TAP(Test Access Port)所需要 ...
- Rocket - jtag - JtagStateMachine
https://mp.weixin.qq.com/s/cFXVOBHayV2w27jpT5RglA 简单介绍JtagStateMachine的实现. 1. 简单介绍 根据IEEE 1149.1-200 ...
- 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 ...
- Quartus 11.0 的AS 下载方式和JTAG下载jic文件的方式
FPGA下载的三种方式:主动配置方式(AS)和被动配置方式(PS)和最常用的(JTAG)配置方式: AS由FPGA器件引导配置操作过程,它控制着外部存储器和初始化过程,EPCS系列.如EPCS1,EP ...
随机推荐
- 区间dp C - Two Rabbits
C - Two Rabbits 这个题目的意思是,n块石头围一圈.一只兔子顺时针,一只兔子逆时针(限制在一圈的范围内). 这个题目我觉得还比较难,不太好想,不过后来lj大佬给了我一点点提示,因为是需要 ...
- C++中的隐式转换和explicit
隐式转换 c++中的数据类型转换分为隐式转换和显示转换: 显示转换即使用static_cast等方法进行转换,相关内容请参考 <C++数据类型转换>: 隐式转换则是编译器完成的,如,boo ...
- 【Scala】什么是隐式转换?它又能用来干嘛?该怎么用
文章目录 定义 隐式参数 隐式转换 隐式值:给方法提供参数 隐式视图 将Int和Double类型转换为String 狗狗学技能(使用别的类中的方法) 使用规则 定义 隐式参数 隐式参数指在函数或者方法 ...
- Docker知识点整理
目录 1. Docker简介 1.1 Docker是什么 1.2 在隔离的容器中运行软件 1.3 分发容器 2. Docker镜像 2.1 Docker镜像简介 2.2 Docker镜像常见操作 2. ...
- 如何将Altera官方提供的CADENCE.OLB应用于altium Designer中
- Dotnet core使用JWT认证授权最佳实践(一)
最近,团队的小伙伴们在做项目时,需要用到JWT认证.遂根据自己的经验,整理成了这篇文章,用来帮助理清JWT认证的原理和代码编写操作. 一.JWT JSON Web Token (JWT)是一个开放标准 ...
- Windows10系统优化(批处理)
经历过XP.Win7.Vista.Win8之后,Win10有了很大的改变,虽然Win10刚出时,非常糟糕,甚至很长一段时间被认为没有Win7,但是随着Win10的不断优化不断更新,已经慢慢的变得更好了 ...
- Lottery
0x01 修改金币到8位,才能买东西 robots.txt中发现.git泄露 下载附件,得到源码 审计api.php 我们传入的值与随机生成的值进行比较, 按照相同的个数,得到不同的钱 if($num ...
- PHP EOF使用说明
PHP EOF(heredoc) 使用说明 PHP EOF(heredoc)是一种在命令行shell(如sh.csh.ksh.bash.PowerShell和zsh)和程序语言(像Perl.PHP.P ...
- Redis学习笔记(九) AOF持久化
除了RDB持久化功能之外,Redis还提供了AOF持久化功能.与RDB持久化通过保存数据库中的键值对来记录数据库状态不同,AOF持久化是通过保存Redis服务器所执行的写命令来记录数据库状态的. 服务 ...