scan cell
scan cell有两种不同的input:
1)data input:由电路的combinational logic驱动;
2)scan input:由另一个scan cell驱动,从而形成scan chain;
在normal/capture mode下,data input来驱动output;
在shift mode下,scan input来驱动output;
几种scan_cell:muxed-D scan,clockd-scan,level-sensitive scan design(LSSD);
muxed-D Scan cell:多指edge_triggered muxed-D scan cell,由一个D flip-flop和一个multiplexer组成,
scan enable(SE)用来选择data input和scan input的输入。
一个level-sensitive的muxed-D scan cell,由一个multiplexer,一个D Latch,一个D FF。
来用替代一个普通的latch
Clocked-scan cell:
也主要用来替代D-FF,不过是通过两个独立的clk来进行选择,
一个data clock DCK;一个shift clock SCK;
主要的优势是不会对data path的timing造成影响,但是要求多一个clock的routing。
LSSD scan cell:
主要是应用在level_sensitive,latch-based design中。
cell包含两个latch,一个master latch,一个slave latch。
其中A/B/D均为clock,D为data input,I为scan input。
优点是可以保证race-free,但是同样会增加clock的routing。
scan architecture
1)full-scan design:所有的storage element都转变为scan cell,combinational ATPG来生成test;
主要的优点是将sequential的ATPG转变为简单的combinational ATPG;
almost full-scan design:在某些critical path和insignificant path上不加入scan。
Muxed-D Full-Scan Design:
Clocked Full-Scan Design:与Muxed-D类似,只是不再使用SE,分别使用两个clock。
LSSD Full-Scan Design:两个时钟C1/C2,A/B来控制shift和capture两种mode。
在full-scan的logic中,输入由两种:
primary input(PI),电路的external input;
pseudo primary input(PPI),scan cell的output
两种输出:
primary output(PO),电路的external output;
pseudo primary output(PPO),scan cell的input;
2)partial-scan design:部分的storage element转变为scan cell,combination和sequential ATPG来生成test;
在test的生成过程中,sequential的ATPG必须包含non-scan的FF的control和observe,这会增加test generation的
复杂性,所以一般将逻辑分开,可以根据functional partition,pipeline/feed_forward partial design.
Full-scan,partitial-scan都被定义为serial scan design,优点是routing的成本会比较低,缺点是每一个单独的scan-cell不能
在不影响本scan chain的其他cell的前提下,完成shift mode,造成high switchingde power消耗。
Random-access scan通过类似RAM似的地址寻址的方式来完成一个cell的shift mode。
3)random-access scan design:不用serial scan chain,使用random addressing的机制;
Scan cell的Q端与下一级的Scan cell的SI端直接连接起来。同时另一个load到combinational logic中。
在capture过程中,必须控制clock的个数,保证ATPG生成的reponse是正确的。
每一条scan chain中的激励和响应的reg的位置并不是对应的。根据ATPG生成的为准。
scan cell的更多相关文章
- scan design flow(二)
在scan stitch之后,scan synthesis就已经完成, Scan extraction主要用来从scan design中extracing所有的instance,来保证scan cha ...
- scan design flow(一)
一个典型的scan实现的flow: clock mux和一些rst,在Scan中都被bypass掉,是不能测到的.所以DFT的test coverage一般就在97%或98%. scan design ...
- scan & ATPG
Testability用来表征一个manufactured design的quality. 将testability放在ASIC前端来做,成为DFT(Design For Test),用可控(cont ...
- INTEST/EXTEST SCAN
INTEST scan指的是对IP 内部的scan cell的扫描测试,针对IP内部的flip-flop进行shift/capture的操作.和INTEST SCAN 对应的就是EXTEST SCAN ...
- INTEST/EXTEST SCAN 的学习
intest scan的一些基本知识.INTEST scan指的是对IP 内部的scan cell的扫描测试,针对IP内部的flip-flop进行shift/capture的操作.和INTEST SC ...
- JTAG
JTAG是JOINT TEST ACTION GROUP的简称,JTAG的两个标准IEEE 1149.1(2001)和IEEE 1149.7(2009). JTAG中主要包含两部分内容:TAP(TES ...
- fault coverage enhancement
在pseudo-random test中,由于random pattern resistant的特性,fault coverage不是sufficient的, 所以会有一些办法来进行coverage的 ...
- DFT basics
DFT测试中,最重要的部分还是sequential circuit的内部状态的测试. 起初ad hoc的方法用来提高testability,可以提高局部的coverage,但并不是一个系统性的方法. ...
- iwinfo 的使用
以前使用iwconfig来配置和获取wireless的信息,目前openwrt已经废弃这种方式,采用 iwinfo 和 iw 命令来进行替代. iwinfo的使用方法如下: root@hbg:/# i ...
随机推荐
- C++字符数字的编码(Encode)与解码(Decode)
在日常应用中,我们常用结构体或者类来存储一条信息,这种方式很方便,但是不利于数据的传输.例如在网络编程中,我们需要将结构中的数据转化为字节流才能进行传输,我们可以利用memcpy强行将结构化的数据转化 ...
- 强调语气<strong>和<em>标签,文字设置单独样式<span>
区别:1,<em> 表示强调,<strong> 表示更强烈的强调. 2,并且在浏览器中<em> 默认用斜体表示,<strong> 用粗体表示. 3,两个 ...
- HttpPost发送Json
1.public static JSONObject post(String url,JSONObject json){ 2. HttpClient client = new DefaultHttpC ...
- Swift-10--错误处理
如何优雅地抛出错误-- 抛出错误使用throw关键字. 某个错误被抛出时,那个地方的某部分代码必要要负责处理这个错误,比如纠正这个问题.尝试另外一种方式.或是给用户提示这个错误. ***4种处理错误的 ...
- 【转】Android性能优化之布局优化篇
转自:http://blog.csdn.net/feiduclear_up/article/details/46670433 Android性能优化之布局优化篇 分类: andorid 开发2015 ...
- http://blog.csdn.net/yangyuhan156/article/details/48899439
http://blog.csdn.net/yangyuhan156/article/details/48899439
- iOS开发中(null)与<null>的判断
判断(null): if(m_result==nil) { NSLog(@"KDA!"); } 判断<null>: if([m_result isEqual: ...
- jquery 日历插件datepicker格式调整
<script> $(function() { $("#datepicker").datepicker({ dateFormat: "yy/mm/dd&quo ...
- C++ version the delaunay triangulation
https://github.com/Bl4ckb0ne/delaunay-triangulation
- Theano学习笔记:Theano的艰辛安装体验
http://www.cnblogs.com/hanahimi/p/4127026.html