RISCVDEBUG系列之一:JTAG简介

原创 嵌入式Lee 2024-12-02 16:20

一. 前言

RISCV前期验证和驱动开发阶段比较依赖DEBUG,甚至第一步就是要调通DEBUG使其能工作,否则早期都无法进行程序下载与调试验证。规格书RISC-V Debug Specification Version 1.0-STABLE 中介绍了RISCVDEBUG实现,我们就分几篇来分享相关内容。其中Chapter 6 Debug Transport Module (DTM), non-ISA这一章节介绍了基于JTAGDTM实现,我们这一篇就来分享下JTAG相关的基本知识。通过本文应该要能通过逻辑分析仪抓取JTAG信号,确认JTAG信号是否正常,知道JTAG正在进行什么操作,有了这部分基础知识才能为进一步调试做准备。

二. JTAG基本知识

2.1.术语

Joint Test Action Group (JTAG):联合测试行动小组.

boundary-scan test (BST):边界扫描测试

Boundary-scan cells(BSC):边界扫描单元

BST可以在不使用物理测试探针的情况下测试引脚连接,并在设备正常运行时捕获功能数据。设备中的边界扫描单元可以将信号施加到引脚上,或者从引脚或核心逻辑信号中捕获数据,即测试数据串行地移入边界扫描单元, 捕获的数据连续移出,这样就可以实现测试数据输入输出,输入控制行为,然后对输出与预期结果进行外部比较即可进行功能测试

以下是一个简单的图示,

抽象一下即内部使用边界扫描寄存器和外部TDITDO交互,边界扫描寄存器即一个很长的串行移位寄存器,使用TDI引脚作为输入,TDO引脚作为输出。

示意如下,类似一个环形结构,TDI->边界扫描寄存器->TDO

2.2.JTAG信号

从信号角度看JTAG是类似于SPI的同步串行接口。

高位在前,TCK下降沿发送端输出数据,上升沿接收端采集数据。

其中只有TDITDOTMSTCK四个信号是必需的。

具体的时序参数参考如下示意图,对应的参数可以参考JTAG标准,这里其实无需详细了解,除非需要去确认临界的时序参数是否有问题。平常只需要知道TCK下降沿发送端输出数据,上升沿接收端采集数据即可。

TDI:测试数据输入(输入输出是以TARGET的角度而言),TARGET内部弱上拉(如果没有则PCB上添加),TCK的上升沿被TARGET采集。

比如如下波形,我们在TCK的上升沿看TDI的数据,传输的是10001,0x11.

所以对于发送端,需要在TCK上升沿准备好数据。

TDO:测试数据输出(输入输出是以TARGET的角度而言),TCK下降沿TARGET输出数据。在没有数据输出时,应该处于tri-stated状态。接收端在上升沿采集数据。

比如如下波形,我们在TCK的上升沿看TDO的数据,传输的是10001,即0x11

注意我们不能在TCK下降沿去读数据,因为TCK下降沿只是理论上的开始输出数据,到数据输出到线上可能还有延迟,所以我们要等数据稳定,到TCK上升沿再去读数据,如下图所示,即要考虑数据的setup建立时间。

TDO引脚在除SHIFT_IRSHIFT_DR状态之外的所有状态下都是三态的。TDO引脚在进入任一移位状态后,在TCK的第一个下降沿被激活,在离开任一移位状态时,在TCK的第一个x降沿被三态化。

SHIFT_IR状态被激活时,TDO不再是三态,指令寄存器的初始状态在TCK的下降沿被移出。只要shift_IR状态处于活动状态,TDO就会继续移出指令寄存器的内容。只要TMS保持低电平,TAP控制器就保持在SHIFT_IR状态。

SHIFT_IR状态下,通过移动TCK上升沿TDI引脚上的数据来输入指令代码。操作码的最后一位必须与下一个状态EXIT1_IR激活的同时计时;EXIT1_IR是通过在TMS上设置逻辑高来输入的。一旦处于EXIT1_IR状态,TDO再次变为三态。

TMS:测试模式选择,TARGET的输入信号,TARGET内部弱上拉(如果没有则PCB上添加),用于决定状态机的状态流转。同样的发送端在TCK的下降沿输出数据,TARGET在上升沿采集数据。

比如如下波形:

开始位于状态TEST_LOGIC/RESET

TCK的上升沿看TMS, 如下0->1->1

即对应状态

TEST_LOGIC/RESET->RUN_TEST/IDLE->SELECT_DR_SCAN->SELECT_IR_SCAN

TCK:测试时钟输入,TARGET的输入信号.TARGET内部弱下拉(如果没有则PCB上添加)。上升沿发送端输出数据,上升沿接收端采样数据。

以上几个引脚是必须的,还有一些引脚不是必须的,比如

nRESET: 仿真器的开漏输出,输出低复位目标系统(SOC,PCB上各种外设等)。该信号不能复位TARGETDEBUG模块本身,这样才能保证在DEBUG模块本身不复位情况下复位SOCDEBUG模块能捕获SOC复位后从开始执行第一条指令的过程。如果仅仅是复位SOC可以直接通过JTAG读写寄存器的方式进行配置复位,所以不是必须的。但是如果要复位PCB板上其他外设等,则建议最好加上这个信号。

nTRST: 仿真器的输出,输出低复位TARGETDEBUG模块本身,让DEBUG模块处于复位正常状态。这个信号也不是必须的,也可以通过JTAG进行复位。

还有一些其他的引脚都不是必须的一般也很少用,可以参考具体的规格书。很多JTAG仿真器还会带一些扩展功能,比如虚拟串口等这个就要参考实际的产品的说明。

2.3.JTAG状态机

以上说明了JTAG的信号的基本内容,有了以上内容就可以直接根据信号解析对应的数据,虽然一般不需要手动解析。一般逻辑分析仪都会带JTAG的解码,可以直接查看。但是有了以上知识可以在调试阶段确认信号是否正确合理,帮助排查问题。

现在来看JTAG的最重要的内容,即其状态机。JTAG通过TMS来决定内部状态机的流转,

对应如下的状态图。在TCK的上升沿采集TMS的状态是0还是1,然后决定一个状态是什么。

首先状态机肯定要有一个最初始状态,这里即TEST_LOGIC/RESET,并且要能方便的回到初始状态,否则需要持续记录状态,且任意记录错误一次状态机器就会跑着跑着就乱了,这样容错性不高。

从上面状态机看到,每次只要TMS始终保持1,最终总是会回到TEST_LOGIC/RESET,且TEST_LOGIC/RESETTMS1时依旧是TEST_LOGIC/RESET。这个路径最深为5,也就是只要连续发5TMS=1,最终肯定会回到TEST_LOGIC/RESET,这就是状态机复位的操作。

当处于TEST_LOGIC/RESET状态时,BST电路被禁用,设备正常运行,指令寄存器以IDCODE作为初始指令。上电时,TAP控制器初始化为该状态。

如下从SHIFT_IR发送5TMS=1回到初始状态。

所以在不确定当前状态是,可以发至少5TMS=1,进入TEST_LOGIC/RESET这个初始状态。

比如如下抓到的波形,就是复位状态机的操作,发了一长串TMS=1,多发是为了确保复位成功,避免偶尔的干扰。

平时操作并不需要回到TEST_LOGIC/RESET状态,因为该状态会默认重新选择指令寄存器为IDCODE了。如果每操作一次都回到该状态,又需要重新设置指令寄存器等,效率就低了。所以只有确实异常了才会回到该状态。

平时操作完一次只需要回到RUN_TEST/IDLE状态,该状态相当于空闲但是指令寄存器等不变。

如下所抓到波形所示

2.4.JTAG数据流

JTAG提供了IRDR寄存器的概念,IR即需要进行操作的类别,DR则为对应的数据。

所以一个操作包括,设置IR和读写DR的过程。

其中IR寄存器需要至少实现以下寄存器

l指令寄存器,用于确定要执行的动作和要访问的数据寄存器

l旁路寄存器一个1位长的数据寄存器,用于在TDITDO之间提供最小长度的串行路径

l边界扫描寄存器器件的所有边界扫描单元组成的移位寄存器。

对应RISCV中的定义如下,主要选择的IR就是0x100x11,然后对应的DR就是分别对应的是dtmcsdmi的数据寄存器。其中选择IDCODEDRTDO输出的是32位厂商代码。

在这里其实可以理解为只是使用了JTAG的这种硬件的数据链路,即选择IR对应不同的DR内容的操作形式。规格书中介绍了基于JTAGDTM实现,实际上也不可以不用JTAG,可以任意设计一种接口比如基于USB等都可以,使用JTAG只是因为它已经成为了行业标准,有大量的硬件设备可以直接拿来就用。

示意如下:

读写IR寄存器即先进入CAPTURE_IR状态,通过TDI将数据移入IR寄存器(SHIFT_IR),同时TDO会移出TARGET中原来的IR寄存器内容(相当于是环形结构,一边IN,一边OUT)

类似的读写DR寄存器则先进入CAPTURE_DR状态,通过TDI将数据移入DR寄存器(SHIFT_DR),同时TDO会移出TARGET中原来的DR寄存器内容(相当于是环形结构,一边IN,一边OUT)

IRDR的长度根据实现不同,完成IRDR的移动,EXIT1_IR/UPDATE_IR,EXIT_DR/UPDATE_DR更新生效即可。

所以JTAG操作就是分解为IRDR的交换,全双工模式,不需要区分是读还是写。

即写入的同时有读出(即交换), 即TDI->IR->TDO, TDI->DR->TDO

设置IR过程为

对应状态转移如下

实测波形如下

RUN_TEST/IDLE->SELECT_DR_SCAN->SELECT_IR_SCAN->CAPTURE_IR->

SHIFT_IR(5)->EXIT1_IR->UPDATE_IR->RUN_TEST/IDLE

最终又回到了RUN_TEST/IDLE以便继续操作DR

以上操作完IR后,会进入RUN_TEST/IDLE,以便操作DR

操作DR的流程如下

对应状态转移如下

实测波形如下

RUN_TEST/IDLE->SELECT_DR_SCAN->CAPTURE_DR->

SHIFT_DR(44)->EXIT1_DR->UPDATE_DR->RUN_TEST/IDLE

以上操作完DR后,会进入RUN_TEST/IDLE,以便继续操作

.参考

IEEE Std 1149.1-2001 (Revision of IEEE Std 1149.1-1990) 

IEEE Standard Test Access Port andBoundary-Scan Architecture

13. IEEE 1149.1 (JTAG) Boundary-Scan Testing for MAX II Devices

.推荐阅读

https://mp.weixin.qq.com/s/fZohshp5bhtEhpC8DrmJNg?token=176082340&lang=zh_CN 使用JTAG边界扫描快速进行FPGA引脚对应关系逆向

https://mp.weixin.qq.com/s/biR6j9wt7YxQ2GSXs-UpbQ?token=176082340&lang=zh_CN

《基于矿板低成本学习FPGA》逆向扫描插座所有IO引脚映射

五. 总结

本文主要分享了JTAG的基本知识,为后续调试RISCVDEBUG做准备,对照实际抓取的波形来看JTAGIRDR的操作。


























评论 (0)
  •         信创产业含义的“信息技术应用创新”一词,最早公开信息见于2019年3月26日,在江苏南京召开的信息技术应用创新研讨会。本次大会主办单位为江苏省工业和信息化厅和中国电子工业标准化技术协会安全可靠工作委员会。        2019年5月16日,美国将华为列入实体清单,在未获得美国商务部许可的情况下,美国企业将无法向华为供应产品。       2019年6
    天涯书生 2025-05-11 10:41 139浏览
  • 【拆解】+CamFi卡菲单反无线传输器拆解 对于单反爱好者,想要通过远程控制自拍怎么办呢。一个远程连接,远程控制相机拍摄的工具再合适不过了。今天给大伙介绍的是CamFi卡菲单反无线传输器。 CamFi 是专为数码单反相机打造的无线传输控制器,自带的 WiFi 功能(无需手机流量),不但可通过手机、平板、电脑等设备远程连接操作单反相机进行拍摄,而且还可实时传输相机拍摄的照片到 iPad 和电视等大屏设备进行查看和分享。 CamFi 支持大部分佳能和尼康单反相机,内置可充电锂离子电池,无需相机供电。
    zhusx123 2025-05-11 14:14 123浏览
  • 行车记录仪是长这个样子的,如下图。从前面拆去玻璃挡板,可以清晰的看见里面的部件,5个按键电路板,液晶显示屏,摄像头,喇叭,电池包,还有一块主电路板。液晶显示屏正面,如下图。液晶显示屏背面,如下图。喇叭,如下图。5个按键的电路板,MENU,DOWN,POWER,UP,OK总共5个按键功能,导线连接到主电路板上,如下图。电池包,303040聚合物锂电池,3.7V,300mAH,如下图。如下图。摄像头,如下图。拿去摄像头外壳,如下图。分离广角聚集镜头和PCB板,如下图。广角聚焦镜头,具体结构如下图。P
    liweicheng 2025-05-09 22:50 41浏览
  • 在 AI 浪潮席卷下,厨电行业正经历着深刻变革。AWE 2025期间,万得厨对外首次发布了wan AiOS 1.0组织体超智能系统——通过AI技术能够帮助全球家庭实现从健康检测、膳食推荐,到食材即时配送,再到一步烹饪、营养总结的个性化健康膳食管理。这一创新之举并非偶然的个案,而是整个厨电行业大步迈向智能化、数字化转型浪潮的一个关键注脚,折射出全行业对 AI 赋能的热切渴求。前有标兵后有追兵,万得厨面临着高昂的研发成本与技术迭代压力,稍有懈怠便可能被后来者赶
    用户1742991715177 2025-05-11 22:44 84浏览
  • 递交招股书近一年后,曹操出行 IPO 进程终于迎来关键节点。从 2024 年 4 月首次递表,到 2025 年 4 月顺利通过中国证监会境外发行上市备案,并迅速更新招股书。而通过上市备案也标志着其赴港IPO进程进入实质性推进阶段,曹操出行最快有望于2025年内完成港股上市,成为李书福商业版图中又一关键落子。行路至此,曹操出行面临的挑战依然不容忽视。当下的网约车赛道,早已不是当年群雄逐鹿的草莽时代,市场渐趋饱和,竞争近乎白热化。曹操出行此时冲刺上市,既是背水一战,也是谋篇布局。其招股书中披露的资金
    用户1742991715177 2025-05-10 21:18 65浏览
  •   基于 2025 年行业权威性与时效性,以下梳理国内知名软件定制开发企业,涵盖综合型、垂直领域及特色技术服务商:   华盛恒辉科技有限公司:是一家专注于高端软件定制开发服务和高端建设的服务机构,致力于为企业提供全面、系统的开发制作方案。在部队政企开发、建设到运营推广领域拥有丰富经验,在教育,工业,医疗,APP,管理,商城,人工智能,部队软件、工业软件、数字化转型、新能源软件、光伏软件、汽车软件,ERP,系统二次开发,CRM等领域有很多成功案例。   五木恒润科技有限公司:是一家专业的部队信
    华盛恒辉l58ll334744 2025-05-12 16:13 100浏览
  • 体积大小:14*11*2.6CM,电气参数:输入100V-240V/10A,输出16V24A。PCB 正面如下图。PCB 背面如下图。根据实际功能可以将PCB分成几部分:EMI滤波,PFC电路,LLC电路。EMI滤波区域,两级共模电感,LN各用了保险丝加压敏电阻,继电器(HF32FV-G)用来切除NTC的,为了提高效率点,如下图。PFC电路区域,如下图。LLC电路区域,如下图。详细分析一下该电源用的主要IC还有功率器件。AC侧采用了两颗整流桥进行并联,器件增加电流应力,如下图。共模电感都有放电针
    liweicheng 2025-05-10 20:03 49浏览
  • 蓝牙耳机是长这个样子,如下图。背部图,如下图。拆开L耳的一侧,有NFC和电池包(501230 3.7V 150mAh)如下图。电池包(501230 3.7V 150mAh)如下图。NFC正面,如下图。NFC背面,如下图。如何理解NFC的工作原理呢,搜集一下相关的资料,如下图。拆开R耳的一侧,PCB正面,如下图。PCB背面,如下图。有两组红黑的线,一组连接到了喇叭,另一组连接到了MIC头上,MIC头参数如下图。蓝牙模块(CSR 8635),有蛇形PCB走线做成天线,节约了天线成本,如下图。该IC介
    liweicheng 2025-05-10 00:45 53浏览
  • 【拆解】+自动喷香机拆解 家里之前买了从PDD买了一个小型自动喷香机放在厕所里。来增加家里的温馨感,这东西看着确实小巧,精致。可是这东西吧,耗电就是快,没过几天就没电了。今个就让我拆开看看什么在捣鬼。如下是产品的实物和宣传图: 由于螺丝孔太小和限位很深。对于我的螺丝刀套装没用。只能使用那种螺丝刀细头,同时又长的小螺丝刀进行拆解 拧下三颗螺丝钉,用一字螺丝刀撬开外壳,内部结构就呈现在眼前。 内部构造相当简单,部件没多少。就是锂电池供电,通过MCU实现按键控制,段码屏控制,LE
    zhusx123 2025-05-10 19:55 82浏览
  • 文/Leon编辑/cc孙聪颖‍在新能源汽车赛道的残酷洗牌中,威马、爱驰等数十个品牌黯然退场,极越、哪吒汽车也深陷经营困局,“跨界造车” 早已褪去曾经的光环,成为吞噬企业资金与精力的风险泥潭,尤其对上市公司而言,稍有不慎便会被拖入业绩泥沼。当行业共识已清晰显现 —— 新能源汽车市场这片红海正上演着惨烈的生存之战,石头科技创始人昌敬却逆势入局,掌舵极石汽车,其押注造车的抉择,正让本就面临挑战的石头科技主业雪上加霜。2025 年 4 月中旬,昌敬突然清空微博、抖音等社交媒体账号的举动,迅速引爆舆论场。
    华尔街科技眼 2025-05-09 20:53 36浏览
  • 在印度与巴基斯坦的军事对峙情境下,歼10C的出色表现如同一颗投入平静湖面的巨石,激起层层涟漪,深刻印证了“质量大于数量”这一铁律。军事领域,技术优势就是决定胜负的关键钥匙。歼10C凭借先进的航电系统、强大的武器挂载能力以及卓越的机动性能,在战场上大放异彩。它能够精准捕捉目标,迅速发动攻击,以一敌多却毫不逊色。与之形成鲜明对比的是,单纯依靠数量堆砌的军事力量,在面对先进技术装备时,往往显得力不从心。这一现象绝非局限于军事范畴,在当今社会的各个领域,“质量大于数量”都已成为不可逆转的趋势。在科技行业
    curton 2025-05-11 19:09 184浏览
  • ‌磁光克尔效应(Magneto-Optic Kerr Effect, MOKE)‌ 是指当线偏振光入射到磁性材料表面并反射后,其偏振状态(偏振面旋转角度和椭偏率)因材料的磁化强度或方向发生改变的现象。具体表现为:1、‌偏振面旋转‌:反射光的偏振方向相对于入射光发生偏转(克尔旋转角 θK)。2、‌椭偏率变化‌:反射光由线偏振变为椭圆偏振(克尔椭偏率 εK)。这一效应直接关联材料的磁化状态,是表征磁性材料(如铁磁体、反铁磁体)磁学性质的重要非接触式光学探测手段,广泛用于
    锦正茂科技 2025-05-12 11:02 138浏览
  • 1.概述MYD-YG2LX采用瑞萨RZ/G2L作为核心处理器,该处理器搭载双核Cortex-A55@1.2GHz+Cortex-M33@200MHz处理器,其内部集成高性能3D加速引擎Mail-G31 GPU(500MHz)和视频处理单元(支持H.264硬件编解码),16位的DDR4-1600 / DDR3L-1333内存控制器、千兆以太网控制器、USB、CAN、SD卡、MIPI-CSI等外设接口,在工业、医疗、电力等行业都得到广泛的应用。米尔基于瑞萨RZ/G2L开发板本文主要介绍基于MYD-Y
    米尔电子嵌入式 2025-05-09 17:38 27浏览
  •   定制软件开发公司推荐清单   在企业数字化转型加速的2025年,定制软件开发需求愈发多元复杂。不同行业、技术偏好与服务模式的企业,对开发公司的要求大相径庭。以下从技术赛道、服务模式及行业场景出发,为您提供适配的定制软件开发公司推荐及选择建议。   华盛恒辉科技有限公司:是一家专注于高端软件定制开发服务和高端建设的服务机构,致力于为企业提供全面、系统的开发制作方案。在部队政企开发、建设到运营推广领域拥有丰富经验,在教育,工业,医疗,APP,管理,商城,人工智能,部队软件、工业软件、数字化转
    华盛恒辉l58ll334744 2025-05-12 15:55 146浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦