大规模集成电路验证.ppt
《大规模集成电路验证.ppt》由会员分享,可在线阅读,更多相关《大规模集成电路验证.ppt(120页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、VLSI Design and Verification大规模集成电路设计与验证VLSI Verfication大规模集成电路验证验证部分的授课内容除VLSI设计之外的全部内容均是验证设计 vs.验证(design vs.Verification)验证 vs.测试 (Verification vs.Test)投片前验证 vs.投片后验证(Pre-Silicon vs.Post-Silicon)Verfication,Validation,Testing参考资料课程教材集成电路计算机辅助设计与验证实践/算法Hardware Design Verification:Simulation and F
2、ormal Method-Based Approaches.Prentice Hall PTR.ISBN:0131433474全面的功能验证:完整的工业流程 Comprehensive Functional Verification:The Complete Industry CycleProceedings:DAC,DATE,HLDVT,ITC验证部分课程学习组成课程讲授|HOME实验作业 考试掌握原理的基础上强调实践验证原理,工具算法原理工具Synopsys VCS,Cadence IUS/IES,Mentor ModelSIMIFV,ZeroIn,SpyGlass,Conformal,F
3、omalityDC,RC,ICC,Encounter,TessentOffice Hour唐遇星,副研究员yuxing.微电子与微处理器研究所微处理器研究室619Monday Tuesday:20:00 22:00 and weekend302 计算机工厂停车场北楼AgendaPart 0.WelcomePart 1.Verfication IntroductionPart 2.Testbench Simulation ToolPart 3.Testbench Construction and OpenSPARCPart.0 WelcomeWelcome 领域Welcome 校园Welcome
4、 课程Part.1 IntroductionWhat?什么是验证?Why?为什么要验证?How?如何开展验证?验证包括哪些内容主要的验证方法验证的困境What is Design Verification什么是验证The Opposite of DesignDesign:Make/Implement sth that you wantVerification:Make sure that sth is what you want(correct)确保设计符合原始设计需求与目标功能正确,性能达标,功耗、良率和成本符合要求VLSI团队分工 Design Team&Verification Team
5、At least 1:1,Now 1:3 1:4Time Statistic:30%Design,70%VerficationHint:设计人员必须完成初始验证才能提交设计;但一个设计的必须由额外的验证人员审核Design,Verification and TestingDesign Synthesis设计综合根据设定的输入输出功能,使用现有的方法、技术、材料和工艺制造设备的过程Verification验证预测并保证设计与综合在制造过程乎能够根据输入输出完成功能Test 测试用于保证按照设计综合结果来生产的器件,不受制造错误影响Verification vs.TestingVerificati
6、on检验设计的正确性主要方法为模拟、硬件仿真和形式化方法在设备制造之前多次重复,但对一个设计仅一次完整正确验证为设计的质量负责Testing检测生产结果的正确性分两个步骤:设计期间产生测试;生产后应用测试对生产出来的每个产品均完成一次测试对器件的质量负责Why we need VerificationExample 1 1980北美防空司令部误报遭受导弹袭击检测反馈电路故障检测反馈软件对故障未处理,直接报告预警Possible World War IIIExample 2 1996年阿丽亚娜5火箭爆炸64位双精度浮点操作转换为16位整数时产生的例外重新设计的计算节点板完全重用阿丽亚娜4软件代价
7、$800M 4颗Cluster卫星Why we need VerficationExample 3 Intel Pentium处理器FDIV除法错误Pentium处理器在双精度运算时有时会返回单精度的结果代价$400M 所有产品召回如何展开验证设计的每个步骤都对应着验证只有描述转换的过程就对应着验证系统级设计RTL设计概念设计逻辑综合可测性设计物 理设计signoff投片系统级模拟功能模拟验证概念检测 验证计划网表模拟 反 标模拟 一致性检查一致性检查门级模拟 物 理验证超 标量?Pipeline,FP,L2C 多核?异构?综 合后结果功能、时序正确性增加DFT MBIS是否影响功能是否符合设
8、计和工艺规则DRC LVS Antenna 主要的验证方法Functional verificationSimulationHardware emulationFormal methodsArithmetic verificationProperty checkingEquivalence checkingTheorem proverLanguage containmentSymbolic model checkingSymbolic trajectory evaluation两种主要的验证方法基于模拟的方法,适用于所有设计层次circuit simulation(e.g.Spice)swit
9、ch and transistor level simulation(e.g.Cos-mos)gate level simulation(e.g.IUS/VCS)register transfer level simulation(e.g.IUS/VCS)behavioral or system level simulation(e.g.Ptolemy,PD).Architecture or conception(e.g.systemC,PD)形式化方法理论上最佳的验证方法,数学方法受限于问题规模模拟验证与形式化验证模式模拟验证平均对待每一种可能和输入时间受限可能不完备输入驱动形式化验证将系统
10、和属性分类分隔子系统内必定完备输出驱动模拟验证的主要流程模拟方法:正确的输入得到正确的输出根据设计描述获得验证计划,构造激励,预测预测结果构建测试平台TestBench实例化待测设计DUT用激励驱动DUT运行检查DUT是否获得正确结果模拟运行,反馈设计修改回归测试,固定设计版本形式化验证的流程从设计中获得待验证特性抽象或者描述特性特性检查或者等价性检查可能的人工指导或模拟增加、修订或删除限定条件调试调整设计或抽象描述模拟验证方法最常用的验证方法,输入驱动Input vectorDirected伪随机模拟器事件驱动基于周期的硬件模拟器:使用硬件对电路建模Simulation-based Veri
11、fication Execute the system in parallel with a reference modelwith respect to some input sequences.test suiteas exhaustive as possible模拟Find bugs by executing the implementation and checking its behavior四要素:circuit,test pattern,reference output,comparison mechanismRequirementsSimulateRTL ModelGate-l
12、evelModelSynthesizeSimulateTest BenchASIC or FPGAPlace&RouteTimingModelSimulate“You can prove the presence of bugs,but you cannot prove their absence.”如果找到一个 不一致,就可以证明设计有错不能证明没 有不一致(没人可以证明UFO不存在)基于形式方法的验证形 式验证等价性检查模型检验定 理证 明等价性检查Compare two models Mathematically prove that the origin and output are
13、logically equivalent and the transformation preserved its functionalityIt can compare two netlists to ensure that some netlist post-processing,such as scan-chain insertion,clock-tree synthesis,or manual modification,did not change the functionality of the circuit.等价性检查:两个实现是否等价为 缩小搜索空间,用户可以定义等价点两种方法
14、SAT:系统搜索输入空间将两种电路转化为唯一表示,并进行比较常用场合:Scan insertion前 后Layout与RTL的 一致性ECO前 后模型检验Look for generic problems or violation of user-defined rules about the behavior of the design.Assertions or characteristics of a design are formally proven or disproved.All state machines in a design could be checked for un
15、reachable or isolated states.To determine if deadlock conditions can occur模型检验System A mathematical model MDesired behavior A formal specification The system has the required behaviorM satisfies Model checking模型检验形式地证明设计的断言和特征,如状态机是否可达、是否死锁、接口的断言搜索整个状态空间,找到属性不满足的点,如果找到,则失败隐式枚举状态空间:符号遍历算法,一次访问一组点,提高效
16、率Unbound propertyBound property两种方法的比较SimulationSimulate the design with test stimuli and check the resultsInput output compare expected resultOnly a small part of the space can be exploredHard to tell if testing is sufficientFormalProving facts about the designModel checking,Equivalence checkingExp
17、ected behavior property proveTime and space issuesHard to tell if properties are complete例 1:4位加法器adder4ba3:0b3:0sum3:0c_out44c_in4module adder4b(sum,c_out,a,b,c_in);input 3:0 a,b;inputc_in;output3:0 sum;outputc_out;assign c_out,sum=a+b+c_in;endmoduleSimulation Exampleadder4b(DUT)a3:0b3:0sum3:0c_out
18、44c_in4t_adder4bTestbenchtimescale 1ns/1ns /time_unit/time_precisionmodule t_adder4b;reg8:0 stim;/inputs to DUT are regswire3:0 S;/outputs of DUT are wires wire C4;/instantiate DUTadder4b(S,C4,stim8:5,stim4:1,stim0);/stimulus generationinitial begin stim=9b000000000;/at 0 ns#10 stim=9b111100001;/at
19、10 ns#10 stim=9b000011111;/at 20 ns#10 stim=9b111100010;/at 30 ns#10 stim=9b000111110;/at 40 ns#10$stop;/at 50 ns stops simulationendendmodulesee“response”to each of these input vectorsUUTBehav.Verilog:“do this once”timing control for simulationTestbench RequirementsInstantiate the Design Under Test
20、(DUT)Provide input to that unitUsually a number of different input combinations!Watch the“results”(outputs of DUT)Can watch Wave windowCan print out information to the screen or to a filetimescale 1ns/1ns /time_unit/time_precisionmodule t_adder4b;reg8:0 stim;/inputs to DUT are regswire3:0 S;/outputs
21、 of DUT are wires wire C4;/instantiate DUTadder4b(S,C4,stim8:5,stim4:1,stim0);/monitor statementinitial$monitor($time,C4,S,stim8:5,stim4:1,stim0);/stimulus generationinitial begin stim=9b000000000;/at 0 ns#10 stim=9b111100001;/at 10 ns#10 stim=9b000011111;/at 20 ns#10 stim=9b111100010;/at 30 ns#10 s
22、tim=9b000111110;/at 40 ns#10$stop;/at 50 ns stops simulationendendmoduleExhaustive Simulation综综 合后合后module adder4b(sum,c_out,a,b,c_in);output 3:0 sum;input 3:0 a,b;input c_in;output c_out;wire carry1,carry2,carry3;ADD32 U1_0 (.A(a0),.B(b0),.CI(c_in),.CO(carry1),.S(sum0);ADD32 U1_1 (.A(a1),.B(b1),.CI
23、(carry1),.CO(carry2),.S(sum1);ADD32 U1_2 (.A(a2),.B(b2),.CI(carry2),.CO(carry3),.S(sum2);ADD32 U1_3 (.A(a3),.B(b3),.CI(carry3),.CO(c_out),.S(sum3);endmodulemodule ADD32(A,B,CI,CO,S);input A,B,CI;output CO,S;and(net_1,CI,B);and(net_2,CI,A);and(net_3,B,A);or(CO,net_1,net_2,net_3);xor(S,CI,B,A);endmodu
24、le如何验证综合后网表的正确性?Consistency:same testbench at each level of abstractionBehavioralGate-level Design(Post-layout)Gate-level Design(Pre-layout)RTL DesignTestbenchSimulation方法 1:Gate-level simulationGiven two designs,prove that for all possible input stimuli their corresponding outputs are equivalentDes
25、ign ADesign B=?InputYes/NoProduct Machine 方法 2:Equivalence Checking例 2:交 通灯控制器Guarantee no collisions:It is never possible that all traffic lights are greenGuarantee eventual serviceEventually,each traffic light will become greenESNVerilog programmodule main(N_SENSE,S_SENSE,E_SENSE,N_GO,S_GO,E_GO);i
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 大规模集成电路 验证
限制150内