Logic and Fault simulation
fault simulation是指对fault circuit的simulation,来locate manufacturing defects并且进行fault diagnosis。
logic simulation针对logic circuit model的simulation,主要有compiled-code和event-driven两种techniques。
Logic simulation针对design verification的:
一般design verificaiton起始于behavioral level或者elcetronic system(ESL),一般的描述语言有C/C++。
一旦behavior model被验证为acceptable,开始进行register-transfer level(RTL)的验证,描述语言有verilog/SV。
ESL和RTL级别的verification被称为functional verification。
经过logic/scan synthesis之后,进行gate-level的verification,检查timing-critical的部分。
之后可以进行更精确的transistor-level的仿真,得到更精确的power,timing等信息。

ESL code---------------------------behavioral design;
HDL code------------------------------RTL design;
netlist----------------------------------gate-level design;
SPICE model---------------------------transistor-level design;
Logic simulation通过对比给出的spec和作为ref的good design来identifying design error。
fault simualtion主要针对fabricated circuit。fault simulation注重fault coverage,保证chip的quality。
logic simulation的model:
组合电路:

时序电路:

logic symbol有:1,0,x,z,还有strength level。
当一个circuit上电时,storage element的初始值为X,在simulator中的x是悲观的,实际上,只会是1或0的有限值。

tristate gate拥有high-impedance state,Tristate gates允许一个time-share的wire(BUS).
实际中,在bus上要添加pull-up/pull-down逻辑,因为tristate不允许有多个gate同时打开,而且打开的gate关掉之后,
bus会维持之前的state,而pull-up/down可以打破这种关系。
intermediate logic states,不仅会建模signal的value还包括strength,包括strong,weak,floating 1/0。
strong 1和0,就像我们使用的1和0,weak 1和0,会被strong的信号所覆盖。
floating signal作为最weak的signal。
Logic element evaluation:
1)truth table,最straightforward的方式。
2)input scanning,根据门电路的control bit进行控制,AND由"0"控制,OR由"1"控制。
3)Parallel gate evaluation,通过计算机32Bit或64bit的多位计算,来进行bitwise parallel simulation。
Timing model:
1)transport delay,指gate input输出到gate output上的延时,norminal delay表示这个延时对于rise和fall相同。
对于rising time和falling timing不同的情况,需要rise/fall delay model。
如果transport delay不能被唯一的决定,需要使用min-max delay model。
2)inertial delay,指通过门电路的最小pulse duration。
3)wire delay,由于wire内在的resistive和capacitive,以及neighboring conductors mutual capacitance。
也被称作propagation delay,在PR之前只能通过WLM进行评估。
4)Functional Element Delay Model,像FF,有更负责的时序模型,D-Q的delay以及setup/fold等。
Compiled-Code simulation
将logic network转换为一系列的machine instruction,来对gate和他们之间的interconnect进行建模。
在这个过程中,会进行logic optimization,主要是进行逻辑简化的一些操作。
logic levelization,logic gate只有在它的所有driving gate都evaluated之后,才会进行evaluated。
经过simulator之后,可以产生的三种code:
1)high-level的code,像C语言。
2)Native-machine code,不需要经过compilation的代码。
3)Interpreted code,在进行simulation的过程中,指令便被interpreted和executed。
Compiled-Code的主要问题:不能加入timing model和很低的simulation efficiency。
Event-Driven simulation
event-driven simulation拥有很高的efficiency,因为只在必要的时候,才进行gate evaluation。
并且可以加入delay model。

compiled-code更适用于cycle-based simualtion,并且DUT用model来代替的时候。
输入变化引起的不必要的pulse和glitch,称为hazards。
其中包括static hazard(static 1-hazard, static 0-hazard),和dynamic hazards。

Logic and Fault simulation的更多相关文章
- fault coverage enhancement
在pseudo-random test中,由于random pattern resistant的特性,fault coverage不是sufficient的, 所以会有一些办法来进行coverage的 ...
- EDA简介
Electronic design automation (EDA), also referred to as electronic computer-aided design (ECAD),[1] ...
- scan & ATPG
Testability用来表征一个manufactured design的quality. 将testability放在ASIC前端来做,成为DFT(Design For Test),用可控(cont ...
- [置顶] Oracle 11g Data Guard Role Transitions: Failover
Role TransitionsInvolving Physical Standby Databases A database operates in one of the following mut ...
- 对仿真glbl.v文件的理解
Simulation, UniSim, SimPrim - How do I use the "glbl.v" module in a Verilog simulation? De ...
- Gate level Simulation(门级仿真)
1 什么是后仿真? 后仿真也成为时序仿真,门级仿真,在芯片布局布线后将时序文件SDF反标到网标文件上,针对带有时序信息的网标仿真称为后仿真. 2 后仿真是用来干嘛的? 检查电路中的timing vio ...
- Logic BIST
Logic BIST is crucial for many applications, in particular for life-critical and mission-critical ap ...
- what is delta simulation time
In digital logic simulation, a delta cycles are evaluation of expressions, followed by value updates ...
- delta simulation time[(delta cycle), (delta delay)]
"Delta cycles are an HDL concept used to order events that occur in zero physical time."si ...
随机推荐
- C/C++ 获取汉字拼音
参考文章:http://blog.csdn.net/thenile/article/details/6318521 在参考文章的基础上,去掉了代码中C++特有的语法和数据类型,用纯C语言实现了获取汉字 ...
- Maven实战(三)Eclipse构建Maven项目
1. 安装m2eclipse插件 要用Eclipse构建Maven项目,我们需要先安装meeclipse插件 点击eclipse菜单栏Help->Eclipse Marketplac ...
- [LeetCode] Simplify Path(可以不用看)
Given an absolute path for a file (Unix-style), simplify it. For example, path = "/home/", ...
- Asset Store
Asset Store 是用来供Unity开发者将自己的插件拿出来供大家有偿使用的一个平台. 报错信息: failed to import package with error cannot impo ...
- js引入img标签和图片
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 使用openvswitch实现跨主机docker容器互联
安装openvswitch的步骤请参考上一篇文章:http://www.cnblogs.com/xkops/p/5568167.html 环境:192.168.3.201 node1192.168.3 ...
- linux sed命令参数及用法详解
linux sed命令参数及用法详解 http://blog.csdn.net/namecyf/article/details/7336308 1. Sed简介 sed 是一种在线编辑器,它一次处理一 ...
- 分享一下一款直播App开发的过程
听说有人声称开发一款直播App不仅耗时还非常昂贵,今天跟大家说道一下,开发一款直播App到底分几步走? 第一步:分解直播App的功能,我们以X客为例 视频直播功能,这是一款直播App最主要的功能,要能 ...
- 01 viewport
<meta name="viewport" content="width=device-width,initial-scale=1.0">
- 设计模式之 -- 单例模式(Singleton)
单例模式是一种常用的软件设计模式,通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问. 使用说明 1.使用时机 在某些系统中某些对象最多只能存在一个,例如Windows中只能打开一个 ...