众所周知,芯片主要由三大部分构成.

芯片示例-可见下图

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使用MentorTestKompress
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 工程师三大法宝的使用的更多相关文章

  1. Java工程师三大框架面试题汇总

    1. Hibernate3 提供了属性的延迟加载功能? 当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内 ...

  2. 图像特征提取三大法宝:HOG特征,LBP特征,Haar特征(转载)

    (一)HOG特征 1.HOG特征: 方向梯度直方图(Histogram of Oriented Gradient, HOG)特征是一种在计算机视觉和图像处理中用来进行物体检测的特征描述子.它通过计算和 ...

  3. 图像特征提取三大法宝:HOG特征,LBP特征,Haar特征

    (一)HOG特征 1.HOG特征: 方向梯度直方图(Histogram of Oriented Gradient, HOG)特征是一种在计算机视觉和图像处理中用来进行物体检测的特征描述子.它通过计算和 ...

  4. [CV笔记]图像特征提取三大法宝:HOG特征,LBP特征,Haar特征

    (一)HOG特征 1.HOG特征: 方向梯度直方图(Histogram of Oriented Gradient, HOG)特征是一种在计算机视觉和图像处理中用来进行物体检测的特征描述子.它通过计算和 ...

  5. 集成学习的不二法门bagging、boosting和三大法宝<结合策略>平均法,投票法和学习法(stacking)

    单个学习器要么容易欠拟合要么容易过拟合,为了获得泛化性能优良的学习器,可以训练多个个体学习器,通过一定的结合策略,最终形成一个强学习器.这种集成多个个体学习器的方法称为集成学习(ensemble le ...

  6. DFT设计绪论

    DFT设计的主要目的是为了将defect-free的芯片交给客户. 产品质量,通常使用Parts Per million(PPM)来衡量. 但是随着IC从SSI到VLSI的发展,在test上花销的时间 ...

  7. DFT,可测试性设计--概念理解

    工程会接触DFT.需要了解DFT知识,但不需要深入. 三种基本的测试(概念来自参考文档): 1. 边界扫描测试:Boundary Scan Test: 测试目标是IO-PAD,利用JTAG接口互连以方 ...

  8. STIL文件(DFT/IC测试方向)

    相信很多工程师,特别是刚入行或准备入行的兄弟们或多或少听过测试相关的东西.如果你想做DFT工程师的,测试工程师的,而对于设计/验证工程师们如果能了解下STIL文件的原理,在和DFT/测试工程师聊技术聊 ...

  9. DFT 问答 I

    Q: Boundary Scan是什么?应用场景是什么?实现的方法是什么?挑战是什么? A: Boundary Scan就是边界扫描,是由Joint Test action Group起草的规范,最初 ...

随机推荐

  1. Hibernate 之HQL数据查询

    1. HQL简介 HQL是面向对象的查询语言,与SQL查询语言相比,虽然在语法上类似,都是运行时进行解析,但HQL并不像SQL那样操作的是数据表,列等数据库对象,HQL所操作的对象是类,对象,属性等. ...

  2. cesium编程入门(四)界面介绍及小控件隐藏

    感性认识 界面介绍,viewer Geocoder : 查找位置工具,查找到之后会将镜头对准找到的地址,默认使用bing地图 Home Button :视角返回初始位置. Scene Mode Pic ...

  3. Sql语法高级应用之一:使用sql语句如何实现不同的角色看到不同的数据

    前言 在常见的管理系统中,通常都有这样的需求,管理员可以看到所有数据,部门可以看到本部门的数据,组长可以看到自己组的数据,组员只能看到自己相关的数据. 一般人的做法是,根据不同的角色通过if...el ...

  4. Fiddler4无法抓取HttpWebRequest本地请求的解决办法

    网上很多解决案例是如下方代码设置代理,但在我的Fiddler4环境下无效,后寻得官方处理方法证实与代理无关. HttpWebRequest request= WebRequest.Create(&qu ...

  5. RabbitMq初探——发布与订阅

    publish and subscribe 前言 前面的例子 我们都是用到的都是消息单一消费,即一条消息被单个消费者消费.像微博系统的消息推送,是一条消息推送给所有订阅到该频道的用户. 这里我们就需要 ...

  6. sql server中的 trimtrailingblanks

    使用sp_help 查出 发现有个这个属性, 如何修改呢? SET ANSI_PADDING ONAlter Table Sys_users_History Alter   column PveSit ...

  7. 关于字典的几个类--defaultdict,OrderedDict, zip()

    一.  1个键对应多个值 比如:d = {'a' : [1, 2, 3],  'b' : [4, 5]},可以使用 collections 模块中的 defaultdict 来构造这样的字典 from ...

  8. vscode 本地调试nodejs

    1.首先通过node-inspect插件可以debug   nodejs ,先起nodejs服务,再启用node-inpector服务 安装调试器 npm install -g node-inspec ...

  9. mysql 查询小技巧

    数据字段中存放的是id集,形如  1,2,15,35   也可类推json格式 查询时不用拆分了, 用上 instr.concat搜索和连接字符串 查询fids中包含15的 select * from ...

  10. 1059 C语言竞赛 (20 分)

    #include <iostream> #include <iomanip> #include <cmath> using namespace std; <& ...