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 ...
随机推荐
- php--group_concat()函数总结
group_concat(),手册上说明:该函数返回带有来自一个组的连接的非NULL值的字符串结果. 比较抽象,难以理解. 通俗点理解,其实是这样的:group_concat()会计算哪些行属于同一组 ...
- Object C语法学习
#synthesize关键字: 根据@property设置,自动生成成员变量相应的存取方法,从而可以使用点操作符来方便的存取该成员变量 . @implementation 关键字,表明类的实现 @en ...
- 【转载】拒绝平庸——浅谈WEB登录页面设计
用户活跃度是检验产品成功与否的重要指标之一,传统行业的商家极为重视门面的装潢,因为一个好的门面可以聚集人气,招揽更多的顾客.古时候的大户人家院子门口的石狮子或其他的摆件的摆放极为讲究,有一定的风水学说 ...
- 使用jQuery基本过滤选择器
<script type="text/javascript"> $(function(){ //增加第一个元素的类别 $("li:first").a ...
- Java学习-012-文件删除实例及源代码
此文源码主要为应用 Java 创建文件的源代码.若有不足之处,敬请大神指正,不胜感激! 文件删除源代码如下: /** * @function 文件操作:删除文件.若文件存在且未被占用,则删除文件:若文 ...
- http请求及模拟浏览器发送http请求
/** *测试新增图片 * @throws IOException * @throws HttpException * @throws SAXException * @th ...
- java时间戳转date(转)
1.时间戳的定义 时间戳(timestamp),通常是一个数字序列,唯一地标识某一刻的时间,指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起 ...
- C#线程系列讲座(1):BeginInvoke和EndInvoke方法
一.C#线程概述 在操作系统中一个进程至少要包含一个线程,然后,在某些时候需要在同一个进程中同时执行多项任务,或是为了提供程序的性能,将要执行的任务分解成多个子任务执行.这就需要在同一个进程中开启多个 ...
- 解决download.msdn.microsoft.com无法正确解析而无法下载的问题
不知何时,微软 MSDN 订阅软件下载服务IP解析有问题,总是在点击“下载”按钮之后无法打开. 想必又跟“国情”有关,我是使用联通宽带,没测试过电信的. 我是可以通过指定hosts entry来解决: ...
- [gerrit] Auto Add Reviewer When Push Code
1. ${PROJECT_ROOT}/.git/config 加入如下代码 [remote "review"] url = ssh://${username}@codeserver ...