版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Chapter15:IntroductiontoVerilogTestbenchesObjectivesInthissection,youwilllearnaboutdesigningatestbench:CreatingclocksIncludingfilesStrategicuseoftasksandconcurrentstatementsControllingandobservingthedesignReportingwarningsanderrorsTheSimulationEnvironmentThisisasimplifiedpictureoftheoverallsimulationenvironment.Thissectionconcentratesontestbenchdevelopmentstrategies.designsourcemodellibrariestestbenchsourcefileinput:stimulus,responsesimulatorcompilesimulatefileoutput:testpats,reportsCreatingClocksExample1Youcandefinetheclockineitherthedesignoritstestbench.Youcandefinetheclockeitherbehaviorallyorstructurally.Hereareexamplesofasymmetricclock:0103050clkregclk;alwaysbegin#10clk=1;#10clk=0;endregstart;nand#10(clk,clk,start);initialbeginstart=0;#10start=1;endCreatingClocksExample2Hereareexamplesofasymmetricclockwithdelayedstartup:0204060clkregclk;initialbegin#20clk=1;foreverbegin
#10clk=0;
#10clk=1;endendregstart;nand#10(clk,clk,start);initialbegin#10start=0;#10start=1;endCreatingClocksExample3Hereareexamplesofanasymmetricclockwithdelayedstartup:0204060clkregclk;initialbegin#20clk=1;foreverbegin
#5
clk=0;
#15clk=1;endendregstart;nand#(15,5)(clk,clk,start);initialbegin#5
start=0;#15start=1;endDesigningYourTestbenchYoucanmakeyourtestbenchassimpleorascomolexasyouwant.Acomolextestbenchwouldperformresponseberifivation“on-the-fly”.controldesigncontrolobservedesignsophisticatedtestbenchsimpletestbenchUsingIncludeFilesUse`includefilestoensureproject-wideconsistencyofcommonsource.`include“defines.inc”moduleclkgen(clk);outputclk;reg
clk;alwaysbegin#(`PERIOD/2)clk=0;
#(`PERIOD/2)clk=1;endinitialbegin#(`TIMEOUT)$display(“TIMEOUTERROR”);$finish;endendmodule//defines.inc`timescale1ns/10ps`definePERIOD20`defineTIMEOUT10000000UsingVerilogTasksUseVerilogtasksinyourtestbenchtoencapsulaterepeatedoperations.clkdata_validdata_readdata_readtaskcpu_read;begin#30data_valid=1;wait(data_read==1);#20cpu_data=data_in;wait(data_read==0);#20cpu_data=8`hzz;#30data_valid=0;endendtaskUsingConcurrentStatementsUsefork-joinblocksinyourtestbenchtoconcurrentlyactivateparalleltasks.initializemonitorexecuteforkjoinmoduleinline_tb;//declarevariables//instantiatedesignsinitialbegininitialize_design;forkmonitor_data;monitor_error;monitor_timeout;run_test;joinendendmoduleApplyingStimulusSomecommonstimulusapplicationtechniquesinclude:In-linestimulus,appliedfromaninitialblockStimulusappliedfromalooporalwaysblockStimulusappliedfromanarrayofvectorsorintegersStimulusthatisrecordedduringonesimulationandplayedbackinanothersimulationIn-LineStimulusIn-linestimulushasthefollowingcharacteristics:YoulistthevariablesonlywhentheirvalueschangeYoucaneasilydefinecomplextimingrelationshipsbetweensignalsThetestbenchcanbecomeverylongfortestsofrealdesignsmoduleinline_tb;wire[7:0]results;
reg[7:0]data_bus,addr;DUTu1(results,data_bus,addr);initialfork#10addr=8`h01;#10data_bus=8`h23;#20data_bus=8`h45;#30addr=8`h67;#30data_bus=8`h89;#40data_bus=8`hAB;#45$finish;joinendmoduleStimulusFromLoopsStimulusappliedfromaloophasthefollowingcharacteristics:ForeachiterationyouassignanewstimulusvectorThetimingrelationshipsbetweensignalsareregularinnatureThetestbenchiscompactmoduleloop_tb;
wrie[7:0]response;
reg[7:0]stimulus;
regclk;integeri;DUTu1(response,stimulus);
inititialclk=0;alwaysbegin#10clk=1;#10clk=0;endinitialbeginfor(i=0;i<=255;i=i+1)@(negedgeclk)stimulus=i;#20$finish;endendmoduleStimulusFromArraysStimulusappliedfromanarrayhasthefollowingcharacteristics:YoucanloadthestimulusfromadatafiledirectlyintothearrayForeachiterationyoureadanewstimulusvectorfromthearraymodulearray_tb;wire[7:0]response;
reg[7:0]stimulus,stim_array[0:15];integeri;DUTu1(response,stimulus);initialbegin$readmemb(“datafile”,stim_array);for(i=0;i<=15;i=i+1);#20stimulus=stim_array[i];#20$finish;endendmoduleVectorCaptureandPlaybackYoucancapturemanufacturingtestvectorsattheboundaryofadevicemodel.parameterperiod=20wire[7:0]response;reg[7:0]stimulus;DUTu1(response,stimulus);alwaysapply(stimulus);alwaysverify(response);taskcapture_tb;integerMCDR,MCDS;beginMCDR=$fopen(“response.dat”);if(!MCDR)$finish;MCDS=$fopen(“stimulus.dat”);if(!MCDS)$finish;forever@(posedgeclk)#(period-1)begin$fdisplayb(MCDR,“%b”,response);$fdisplayb(MCDS,“%b”,stimulus);end
endendtaskVectorCaptureandPlaybackYoucanplaybackthesavedstimulusandresponsevectors.parameterMAX_VECTOR=255;wire[7:0]response;reg[7:0]stimulus,stim_array[0:255],resp_arry[0:255];DUTu1(response,stimulus);taskplayback_tb;integerMCDR,MCDS,i;begin$readmemb(“response.dat”,resp_array);
$readmemb(“stimulus.dat”,stim_array);@(negedgeclk)//synchronizetoinactiveclockstimulus=stim_array[0];//apply1ststimulusfor(i=0;i<=MAX_VECTOR;i=i+1)@(negedgeclk)beginif(response!==resp_array[i])begin//checkresponse$display(“ERROR:responseis%b,shouldbe%b”,response,resp_array[i],“\nTESTFALLED”);$finish;endif(i==MAX_VECTOR)begin$display(“TESTPASSED”);$finish;endstimulus=stim_array[i+1];//applynextstimulusendendendtaskForcingStimulusYoucanmaketwotypesofproceduralcontinuousassignments:Youcanassignanddeassign
aregister
assign<lvalue>=<expression>
Thisoverridesanyproceduralassignmenttotheregisterinitialbegin
#10assigntop.dut.fsm1.state_reg=`init_state;
#20deassigntop.dut.fsm1.state_reg;
endYoucanforceandreleasearegisterornet
Thisoverridesalldriversofthesignalinitialbegin
#10forcetop.dut.counter.scan_reg.q=0;
#20releasetop.dut.counter.scan_reg.q;
endReportingWarningsandErrorsUsefileoutputsystemtaskstoreporterrorsandwarnings.Amoresophisticatedtestbenchwould:ReportanerrortoacentralizederrorhandlerModifythetestflow,dependingupontheerrorsencounteredMaintainerrorstatistics,andreportthemattheendofthetesttaskpar_err_task;forever@(posedgepar_err)err_handle_task(`NONFATAL,`PARITY);endtasktaskcor_err_task;forever@(posedgecor_err)err_handle_task(`NONFATAL,`CORRECTABLE);endtaskSummaryInthissection,youlearnedaboutdesigningatestbench:CreatingclocksIncludingfilesStrategicuseoftas
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 防控疫情的安全教案8篇
- 福建省宁德市福鼎市2024-2025学年高二上学期第一次月考(10月)数学试题含答案
- 2022师德师风个人自查报告(5篇)
- 2024年传统银饰项目资金需求报告代可行性研究报告
- DB12-T 1116-2021 控制性详细规划技术规程
- 海南省海口市(2024年-2025年小学五年级语文)统编版竞赛题((上下)学期)试卷及答案
- 江西省赣州市(2024年-2025年小学五年级语文)统编版质量测试(上学期)试卷及答案
- 2024年非晶、微晶合金项目资金筹措计划书代可行性研究报告
- 2023年动叶可调轴流电站用风机资金申请报告
- 三年级数学计算题专项练习汇编及答案
- 辛弃疾词《青玉案·元夕》
- T-HNKCSJ 002-2023 河南省地源热泵系统工程技术规范
- 《无人机驾驶基础》课件-项目四 无人机结构及性能
- XX公司安全生产风险管控与隐患排查双重预防管理体系手册
- 心血管内科试题库+答案
- 2024年保密知识测试有解析答案
- 酒店住宿水单模板-皇冠假日
- 成都麓湖生态城案例详解
- 2024年小升初数学模拟试卷
- 员工工伤事故报告(2篇)
- 广东省深圳市2023年中考英语试题(含答案与解析)
评论
0/150
提交评论