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的更多相关文章

  1. Rocket - jtag - JtagStateMachine

    https://mp.weixin.qq.com/s/cFXVOBHayV2w27jpT5RglA 简单介绍JtagStateMachine的实现. 1. 简单介绍 根据IEEE 1149.1-200 ...

  2. Rocket - jtag - JtagShifter

    https://mp.weixin.qq.com/s/pHtrlmSCPqzlDdfj3qkNPQ 简单介绍JtagShifter的实现. 1. 简单介绍 实现移位寄存器链,包含并行Capture和U ...

  3. Rocket - debug - DebugTransport

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

  4. STM32C8T6 JTAG使用到PB3|PB4|PA13|PA14|PB15端口做普通IO时,需禁止JTAG!

    GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIO ...

  5. 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 ...

  6. 偶遇STM32 JTAG和SWD口(调试)被禁用无法下载,已经粗暴解决!

    处女座,为了板子走线美观,拉线方便,在项目量产前,还更改了原来外设的IO口,埋头苦干一天,移植ok,发现PB3一直不听使唤,好,加班检查代码,检查初始化,时钟,IO对应,然后试PCB板,是否短路,断路 ...

  7. (转)小心FPGA的JTAG口(上电和下电顺序)

    同志们,根据ALTERA官方FAE(现场应用工程师)的强烈建议,请注意不要随意带电插拔你的JTAG下载接口,否则会损坏FPGA芯片的JTAG口信号管脚.现象:在排除了下载线的问题后,还是不能访问FPG ...

  8. JTAG 学习 -SVF格式

    yxr注: 主要zt,附上自己的心得如下: 1)反观SVF文件,除了设置必要的条件之外(初始条件和TIR等四条命令),真正的运行命令就两条,SIR向JTAG TAP状态机的IR寄存器送命令,SDR往J ...

  9. [异常解决] JTAG 与STM32的SWD连接接线方式

    如果我们的板子上只留了4个接口:V3.3,SWDIO,SWDCLK,GND.那么和JTAG的连接关系参见下图: dd400cf22b5c01e57a6c9e198d5383a0_189.jpg (0 ...

随机推荐

  1. TD-LTE华为 DBS3900数据配置实践 典型案例

    案例:华为 DBS3900 双基站二扇区配置(同频切换) 一.数据配置前的硬件准备: HW-DBS3900: (1#基站名称) FAN (风扇),安装在 16#槽位: LBBP (基带处理单板),安装 ...

  2. 201771010113 李婷华 《面向对象程序设计(Java)》第八周总结

    一.理论知识部分 1.Java为了克服单继承的缺点,Java使用了接口,一个类可以实现一个或多个接口. 2.在Java程序设计语言中,接口不是类,而是对类的一组需求描述,由常量和一组抽象方法组成.接口 ...

  3. Code::Blocks无法调试 Starting the debuggee failed: No executable specified, use `target exec'

    1.必须建立工程 2.工程名不可有特殊字符或空格,可以有字母.数字.下划线 2.编译器设置里勾选-g(产生调试符号) 3.重新编译项目(如果之前编译过了) 4.调试器设置 > Default & ...

  4. Linux内核驱动学习(十)Input子系统详解

    文章目录 前言 框架 如何实现`input device` 设备驱动? 头文件 注册input_dev设备 上报按键值 dev->open()和dev->close() 其他事件类型,处理 ...

  5. 关于前后端写入Cookie时domain的一个问题

    1.1. 前端 先假设有如下setCookie方法: function setCookie(name, value, day, path, domain) { day = day || 30; pat ...

  6. python 基础应用1

    1.使用while循环输入1 2 3 4 5 6 8 9 10 n = 0 while n < 11: n = n + 1 if n == 7: continue print(n) n = 0 ...

  7. 【漫画】互斥锁ReentrantLock不好用?试试读写锁ReadWriteLock

    ReentrantLock完美实现了互斥,完美解决了并发问题.但是却意外发现它对于读多写少的场景效率实在不行.此时ReentrantReadWriteLock来救场了!一种适用于读多写少场景的锁,可以 ...

  8. 学习docker的一点记录

    0x00 docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化 ...

  9. android 百度地图v3.2.0获取实际地址

    百度地图升级到v3.2.0后,api发生挺大的变化的,但是下载的Demo却不是最新版本的. 在v3.2.0之前获取详细地址只要:option.setIsNeedAddress(true); 但是升级后 ...

  10. 基于Memcached的Nginx服务器集群session共享

    原料:jdk1.8,tomcat7,nginx1.16,memcached-1.2.6,Mem-Tomcat需要的jar包,基于windows7.所有的点击以下链接可下载 链接:https://pan ...