DFT 工程师三大法宝的使用
众所周知,芯片主要由三大部分构成.
芯片示例-可见下图

1.与电路板和其他芯片的接口-IO pad
2.存放程序的空间-RAM和ROM
3.搭建逻辑电路的基本组件 –标准逻辑单元
DFT工程师所有的工作的目的只有一个-设计和插入数字电路,测试整个芯片的制造质量,筛选出没有制造缺陷的芯片。
针对芯片的三大部分,DFT工程师手里有三大法宝
BSCAN技术-- 测试IO PAD,主要实现工具是Mentor-BSDArchit,sysnopsy-BSD
Compiler
MBIST技术-- 测试MEM, 主要实现工具是Mentor的MBISTArchitect 和Tessent
mbist
ATPG 技术-- 测试STD_LOGIC, 主要实现工具是:产生ATPG使用Mentor的 TestKompress
和synopsys TetraMAX;插入SCAN CHAIN主要使用synopsys 的DFT compiler
以上三类工具licenses较贵,特别是ATPG工具,很多IC公司都只有几个,经常run
case时出现拿不到license的情况。
以下对工具的使用原则做一些介绍
ATPG工具
Insert scan:
1.虽然教科书会介绍很多种DFT DRC,但是在实际设计中95%的工作在修复scan_clk和scan_reset的DRC
violation
2.修复clk/reset violation 的方法主要是用DC插入mux
,目的是使在scan_mode下clk和reset被芯片scan_clk和scan_reset
pad控制。同时,scan_clk和scan_reset pad会用于ATE给芯片施加激励
3.插入scan时,DFT Compiler必须修复的DRC violations 类别为D1/D2/D3/D9
4.做全片级的DFT设计时,需要在scan_in,scan_out,scan_reset,scan_clk的IO pad
的OEN/IE/REN端插入mux,控制pad的输入和输出方向
ATPG patterns产生和仿真
1.所有的模拟模块,例如PLL,POR等,一般设置为black-box,无法用ATPG测试其内部
2.芯片clk,power,reset的控制寄存器,一般不会放到scan_chain上,以免在测试时由于寄存器的动作,改变芯片工作状态
3.考虑power domain的开关,一般必须保证在scan测试时,所有power
domain都打开,每个数字标准单元都能测试到。
4.如果有模拟的IO
pad,一般必须在产生pattern时mask掉,因为他们不是数字的,ATPG工具无法控制它们
5.业界一般使用DC插入OCC (on chip clocking)模块,实现at-speed
scan测试电路
MBIST工具
目前使用较多的是MBISTArchitect, 但是Tessent
MBIST以后会成为主流。原因是Mentor公司2013年已经宣布MBISTArchi将不再提供技术支持,而且Tessent
MBIST技术更为先进。
1.所有的MBIST设计应该考虑diagnose,加入diagnose电路,方便诊断mem故障,这会在芯片量产时大大提高成品率。
2.由于ARM与Mentor有合作,Coretex-A9以上的ARM核具有share-bus接口,可以很好支持Tessent
Mbist,就能够实现ARM内核的mem的高速测试和访问,也提高了ARM CPU的性能。
3.Tessent
MBIST会使用JTAG,只占用TCK/TMS/TDO/TDI/TRST五个pad,比MBISTArich使用更少的pad资源
BSCAN 工具
1.所有的模拟IO,一般无法用bscan来测试,不要加上bscan_cells
2.所有需要测试的数字pad的OEN/IE/REN 在bscan_mode下,需要插mux来控制
3.所有需要测试的数字pad的PU/PD
在bscan_mode下,一般需要插mux来控制,保证在bscan_mode下,PU和PD=0,才能使bscan
HIGHZ测试仿真通过
4.所有JTAG的强制要求指令如IDCODE,EXIST必须在bscan电路中实现,特别是BYPASS
问题
1)如何用可测性设计ATPG工具实现at-speed测试?
2)如何使用BSCAN工具中实现PLL测试?
3)使用Tessent MBIST实现at-speed测试?
4)BSCAN工具会在pad的那些端口上连上bscan cell?
关于MBIST/SCAN/BSCAN的技术介绍,我们可以参看《数字系统测试和可测试性设计》一书,书中有更为详细和系统的介绍,该书近期将由机械工业出版社出版。
DFT 工程师三大法宝的使用的更多相关文章
- Java工程师三大框架面试题汇总
1. Hibernate3 提供了属性的延迟加载功能? 当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内 ...
- 图像特征提取三大法宝:HOG特征,LBP特征,Haar特征(转载)
(一)HOG特征 1.HOG特征: 方向梯度直方图(Histogram of Oriented Gradient, HOG)特征是一种在计算机视觉和图像处理中用来进行物体检测的特征描述子.它通过计算和 ...
- 图像特征提取三大法宝:HOG特征,LBP特征,Haar特征
(一)HOG特征 1.HOG特征: 方向梯度直方图(Histogram of Oriented Gradient, HOG)特征是一种在计算机视觉和图像处理中用来进行物体检测的特征描述子.它通过计算和 ...
- [CV笔记]图像特征提取三大法宝:HOG特征,LBP特征,Haar特征
(一)HOG特征 1.HOG特征: 方向梯度直方图(Histogram of Oriented Gradient, HOG)特征是一种在计算机视觉和图像处理中用来进行物体检测的特征描述子.它通过计算和 ...
- 集成学习的不二法门bagging、boosting和三大法宝<结合策略>平均法,投票法和学习法(stacking)
单个学习器要么容易欠拟合要么容易过拟合,为了获得泛化性能优良的学习器,可以训练多个个体学习器,通过一定的结合策略,最终形成一个强学习器.这种集成多个个体学习器的方法称为集成学习(ensemble le ...
- DFT设计绪论
DFT设计的主要目的是为了将defect-free的芯片交给客户. 产品质量,通常使用Parts Per million(PPM)来衡量. 但是随着IC从SSI到VLSI的发展,在test上花销的时间 ...
- DFT,可测试性设计--概念理解
工程会接触DFT.需要了解DFT知识,但不需要深入. 三种基本的测试(概念来自参考文档): 1. 边界扫描测试:Boundary Scan Test: 测试目标是IO-PAD,利用JTAG接口互连以方 ...
- STIL文件(DFT/IC测试方向)
相信很多工程师,特别是刚入行或准备入行的兄弟们或多或少听过测试相关的东西.如果你想做DFT工程师的,测试工程师的,而对于设计/验证工程师们如果能了解下STIL文件的原理,在和DFT/测试工程师聊技术聊 ...
- DFT 问答 I
Q: Boundary Scan是什么?应用场景是什么?实现的方法是什么?挑战是什么? A: Boundary Scan就是边界扫描,是由Joint Test action Group起草的规范,最初 ...
随机推荐
- windows通过命令方式解压zip文件
1.需要下载unzip 地址:http://gnuwin32.sourceforge.net/packages/unzip.htm 下载exe版本 2.安装后将bin目录下的unzip.exe文件放在 ...
- C#发送邮件及注意事项
//参数配置 static readonly string smtpServer = System.Configuration.ConfigurationManager.AppSettings[&qu ...
- WPF制作歌词动画
最近再做一个UWP的音乐播放器,今天实现了歌词动画,不是滚动的,滚动的慢慢研究 思路:在右边放了三个textBlock,设置 textBlock的effect属性 <TextBlock.Effe ...
- poj 2981 Strange Way to Express Integers (中国剩余定理不互质)
http://poj.org/problem?id=2891 Strange Way to Express Integers Time Limit: 1000MS Memory Limit: 13 ...
- 【题解】 AGC029-A Irreversible operation
传送门 定位:思维好题. 考虑无论如何每一个W都会和前面的B在一起交换一次,所以直接求和就好了. 注意long long的使用. #include<stdio.h> #include< ...
- Neutorn LBaaS 原理
Load Balance as a Service(LBaaS)是 Neutron 提供的一项高级网络服务.LBaaS 允许租户在自己的网络中创建和管理 load balancer. load bal ...
- StringBudiler源码简单解析
StringBudiler源码 继承关系树 底层实现 默认容量() 特别的添加方法(append) 1.继承关系树 继承自AbstractStringBuilder与StringBuffer同族 2. ...
- “全栈2019”Java异常第六章:finally代码块作用域详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java异 ...
- “全栈2019”Java第一百零八章:匿名内部类与final关键字
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- Mybatis 动态Sql语句《常用》
MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格,还要注意省掉 ...