目录
1149.1协议定义了可包含在集成电路中的测试逻辑,以提供标准化的方法,其主要包含以下两点:
1.测试板级(PCB)或其他基层上的不同芯片间的互联;
2.测试芯片内部自身逻辑,可用于控制信号,也可用于观测信号。
如下图所示,1149.1测试逻辑主要由边界扫描寄存器(boundary-scan register,BSR)、其他内建的控制或观测寄存器(Test Data Register,TDR)组成,并通过测试访问端口(Test Access Port,TAP)访问。JTAG内部逻辑寄存器的访问一般由两步组成:1.选择指令寄存器(选择地址);2.指令寄存器使能后即选中了对应的数据寄存器。此外,一般BSR,IDCODE,BYPASS是必须的,TDR是可选的(根据用户需求定义)。

JTAG信号引脚一共有4个或者5个(其中一个可选)。这些引脚仅用于测试目的,控制JTAG完成1149.1协议的操作。引脚信息如下:
Test clock input(TCK):该引脚为测试逻辑提供时钟,由于受板级以及芯片pad限制,一般频率为10MHz,频率占空比一般为50%。
Test mode select input(TMS):用于控制JTAG内部状态机跳转,切换到指定,该信号在TCK上升沿时被采样。
Test data input(TDI):串行输入指令/数据,该信号在TCK上升沿时被采样。
Test data output(TDO):串行输出指令/数据,该信号在TCK下降沿时被采样输出,外部指令以及数据在TDI和TDO之间传输。
Test reset input(TRST*):JTAG 内部逻辑全局异步复位信号,一般低电平有效。该信号时可选信号,原因是可以通过TMS shift 5拍1使状态机处于Test-Logic-Reset状态,也可以复位内部逻辑,所以不一定需要该信号。
如下图所示,所有的JTAG操作的源头都是由一个具有16个状态的同步状态机控制的。该控制器使用TCK为时钟,使用TMS为其输入,如果需要复位时使用TRSTN。状态的跳转是由TMS输入1或者0决定的。状态机分为如下两列,左边绿色的是控制数据寄存器,右边蓝色的是控制指令寄存器。
常用状态:
Test-Logic-Reset : 控制器的第一个状态是复位状态。通过发出TRSTN或者在五个连续时钟内一直把TMS置为1可进入这种状态。在这种状态下,一个复位信号会被发送到所有寄存器组件,以将其重设为它们的初始状态。
Run-Test/Idle:如果TMS为0,TAP控制器能进入的下一个状态是Idle状态,即空闲状态。当TMS为1时,退出该状态并进入下一个状态。IR状态走完进入DR状态时,可以走Run-Test/Idle状态,也可以不走。
Select-DR-Scan/Select-IR-Scan:该状态是一个暂时状态。
Capture-DR/Capture-IR:在该状态下,系统会发出指令寄存器ClockDR/ClockIR,并使其执行捕获操作。
Shift-DR/Shift-IR:在该状态下,数据寄存器以及指令寄存器会被置于TDI和TDO之间,并且时钟上升沿时进行串行移位,TDO只在该状态下有效,其他状态TDO为High-Z。
Update-DR/Update-IR:在该状态下,系统会更新对应的指令寄存器或数据寄存器。

如下图所示,一般指令寄存器结构。当TAP状态处于Capture-IR时,系统发出CaptureEn信号,将Din信号捕获进Capture寄存器。当TAP处于Shift-IR时,系统发出ShiftEn信号,SI到SO通路被打通,可以进行移位操作。当TAP处于Update-IR时,系统发出UpdateIR信号,Update寄存器值更新到Capture 寄存器出输出值。

指令寄存器的长度最短位2,目前业界一般使用4位或者8位。常用的指令寄存器如下
(以8位IR宽度举例):
BYPASS:一般指令为8‘hFF
IDCODE: 一般指令为8’h01,指明器件可识别ID
EXTEST:外测试指令,BSD指令集
INTEST:内测试指令,BSD指令集
PROLOAD:预加载指令,BSD指令集
等等。
数据寄存器结构类似于上面的指令寄存器,在这里就不重复描述了。除了上述描述的指令对应的数据寄存器外,还有可用户自定义的寄存器。
如下图所示,在芯片pad和内核逻辑之间插入BSR寄存器实现PAD可控测试目的。当BSR指令被选中时,data可以从TDI shift进8个BSR中,并从TDO口依次shift出对应的值。

最基本的BSR类型是BC_4,只有1个mux和1个寄存器,不过它的使用也很局限,只可以用作观测信号,不可作为控制信号。

实用性更高的cell如BC_1 cell,可用于观测也可用于控制。 支持capture、shift、update功能,可用于输入或输出BSR cells。
BC_2和BC_1有点类似,不同的是两个cell capture的行为不一样,BC_1捕获的是data_in的值,而BC_2捕获的是update寄存器。

BC_7最为复杂,支持双向port。
如下图所示,当前芯片设计中一般有多组TAP,多组TAP的解决方案有如下几种方式:
1.第一种多个TAP相互独立,互不干扰,但是需要分别拉信号到PAD,这种方式浪费pad资源,一般很少用;
2.第二种方案如下图所示,将所有的TAP 串联起来,TDI进TDO出,中间的TAP TDI/TDO首尾相接,其他信号TMS/TCK/TRSTN 共享。这样的好处是只用一组JTAG 引脚可以访问芯片内所有TAP。使用时,如果只操作其中一个TAP,其他TAP处于bypass状态,读到这里是否注意到这种方式的缺点:操作不同的TAP需要计算其他TAP BYAPSS占用的1bit,对于读出的数据不太友好,当然也可以通过软件处理得到想要的数据。

3.第三种多个TAP用1到2组PAD控制,可以onehot控制,这涉及到TAP间如何切换,后续有空讲解这部分。
最近在学习CAN,记录一下,也供大家参考交流。推荐几个我觉得很好的CAN学习,本文也是在看了他们的好文之后做的笔记首先是瑞萨的CAN入门,真的通透;秀!靠这篇我竟然2天理解了CAN协议!实战STM32F4CAN!原文链接:https://blog.csdn.net/XiaoXiaoPengBo/article/details/116206252CAN详解(小白教程)原文链接:https://blog.csdn.net/xwwwj/article/details/105372234一篇易懂的CAN通讯协议指南1一篇易懂的CAN通讯协议指南1-知乎(zhihu.com)视频推荐CAN总线个人知识总
尝试通过SSL连接到ImgurAPI时出现错误。这是代码和错误:API_URI=URI.parse('https://api.imgur.com')API_PUBLIC_KEY='Client-ID--'ENDPOINTS={:image=>'/3/image',:gallery=>'/3/gallery'}#Public:Uploadanimage##args-Theimagepathfortheimagetoupload#defupload(image_path)http=Net::HTTP.new(API_URI.host)http.use_ssl=truehttp.verify
一、什么是MQTT协议MessageQueuingTelemetryTransport:消息队列遥测传输协议。是一种基于客户端-服务端的发布/订阅模式。与HTTP一样,基于TCP/IP协议之上的通讯协议,提供有序、无损、双向连接,由IBM(蓝色巨人)发布。原理:(1)MQTT协议身份和消息格式有三种身份:发布者(Publish)、代理(Broker)(服务器)、订阅者(Subscribe)。其中,消息的发布者和订阅者都是客户端,消息代理是服务器,消息发布者可以同时是订阅者。MQTT传输的消息分为:主题(Topic)和负载(payload)两部分Topic,可以理解为消息的类型,订阅者订阅(Su
TCL脚本语言简介•TCL(ToolCommandLanguage)是一种解释执行的脚本语言(ScriptingLanguage),它提供了通用的编程能力:支持变量、过程和控制结构;同时TCL还拥有一个功能强大的固有的核心命令集。TCL经常被用于快速原型开发,脚本编程,GUI和测试等方面。•实际上包含了两个部分:一个语言和一个库。首先,Tcl是一种简单的脚本语言,主要使用于发布命令给一些互交程序如文本编辑器、调试器和shell。由于TCL的解释器是用C\C++语言的过程库实现的,因此在某种意义上我们又可以把TCL看作C库,这个库中有丰富的用于扩展TCL命令的C\C++过程和函数,所以,Tcl是
一、RIPV2协议简介 RIP(RoutingInformationProtocol)路由协议是一种相对古老,在小型以及同介质网络中得到了广泛应用的一种路由协议。RIP采用距离向量算法,是一种距离向量协议。RIP-1是有类别路由协议(ClassfulRoutingProtocol),它只支持以广播方式发布协议报文。RIP-1的协议报文无法携带掩码信息,它只能识别A、B、C类这样的自然网段的路由,因此RIP-1不支持非连续子网(DiscontiguousSubnet)。RIP-2是一种无类别路由协议(ClasslessRoutingProtocol),支持路由标记,在路由策略中可根据路由标记对
开门见山|拉取镜像dockerpullelasticsearch:7.16.1|配置存放的目录#存放配置文件的文件夹mkdir-p/opt/docker/elasticsearch/node-1/config#存放数据的文件夹mkdir-p/opt/docker/elasticsearch/node-1/data#存放运行日志的文件夹mkdir-p/opt/docker/elasticsearch/node-1/log#存放IK分词插件的文件夹mkdir-p/opt/docker/elasticsearch/node-1/plugins若你使用了moba,直接右键新建即可如上图所示依次类推创建
文章目录概念索引相关操作创建索引更新副本查看索引删除索引索引的打开与关闭收缩索引索引别名查询索引别名文档相关操作新建文档查询文档更新文档删除文档映射相关操作查询文档映射创建静态映射创建索引并添加映射概念es中有三个概念要清楚,分别为索引、映射和文档(不用死记硬背,大概有个印象就可以)索引可理解为MySQL数据库;映射可理解为MySQL的表结构;文档可理解为MySQL表中的每行数据静态映射和动态映射上面已经介绍了,映射可理解为MySQL的表结构,在MySQL中,向表中插入数据是需要先创建表结构的;但在es中不必这样,可以直接插入文档,es可以根据插入的文档(数据),动态的创建映射(表结构),这就
HTTP缓存是指浏览器或者代理服务器将已经请求过的资源保存到本地,以便下次请求时能够直接从缓存中获取资源,从而减少网络请求次数,提高网页的加载速度和用户体验。缓存分为强缓存和协商缓存两种模式。一.强缓存强缓存是指浏览器直接从本地缓存中获取资源,而不需要向web服务器发出网络请求。这是因为浏览器在第一次请求资源时,服务器会在响应头中添加相关缓存的响应头,以表明该资源的缓存策略。常见的强缓存响应头如下所述:Cache-ControlCache-Control响应头是用于控制强制缓存和协商缓存的缓存策略。该响应头中的指令如下:max-age:指定该资源在本地缓存的最长有效时间,以秒为单位。例如:Ca
如何用IDEA2022创建并初始化一个SpringBoot项目?目录如何用IDEA2022创建并初始化一个SpringBoot项目?0. 环境说明1. 创建SpringBoot项目 2.编写初始化代码0. 环境说明IDEA2022.3.1JDK1.8SpringBoot1. 创建SpringBoot项目 打开IDEA,选择NewProject创建项目。 填写项目名称、项目构建方式、jdk版本,按需要修改项目文件路径等信息。 选择springboot版本以及需要的包,此处只选择了springweb。 此处需特别注意,若你使用的是jdk1
前言上一篇我们简要讲述了粒子系统是什么,如何添加,以及基本模块的介绍,以及对于曲线和颜色编辑器的讲解。从本篇开始,我们将按照模块结构讲解下去,本篇主要讲粒子系统的主模块,该模块主要是控制粒子的初始状态和全局属性的,以下是关于该模块的介绍,请大家指正。目录前言本系列提要一、粒子系统主模块1.阅读前注意事项2.参考图3.参数讲解DurationLoopingPrewarmStartDelayStartLifetimeStartSpeed3DStartSizeStartSize3DStartRotationStartRotationFlipRotationStartColorGravityModif