vhdl时钟的testbench怎么写(如何编写testbench来仿真VHDL程序)

1.如何编写 test bench来仿真VHDL程序

本文介绍如何写testbench来仿真VHDL程序。

通常testbench完成如下的任务:1. 实例化需要测试的设计(DUT);2. 通过对DUT模型加载测试向量来仿真设计;3. 将输出结果到终端或波形窗口中加以视觉检视;4. 另外,将实际结果和预期结果进行比较。 一、构建Testbench 本文用VHDL来写,由于testbench只用来进行仿真,它们没有那些适用于综合的RTL语言子集的语法约束限制,而是所有的行为结构都可以使用。

所有testbench包含了以下的基本程序段:Entity and Architecture Declaration ;Signal Declaration ;Instantiation of Top-level Design ;Provide Stimulus. 在ISE工程中添加source:VHDL Test Bench到顶层文件,在source for 选项中选择Behavioral Simulation。你会发现Test Bench中有很多已经自动写好,可根据自己的设计需要改写程序。

其中Entity是空的,由于是仿真,不必有管脚的输入输出,只要写好激励信号就可以了。 二、双击Simulate Behavioral Model进行Modelsim仿真 我们在modelsim仿真的过程中,如果想改写激励程序,点击environment back(图中向左的箭头),回到激励程序的编写环境。

可以利用其提供的模板直接改写testbench,点source->show language template,需要将read only取消掉,否则无法改写。本人建议,在这个环境中可以看到模板,你可以根据需要将相应的语句拷到VHDL Testbench中去。

这里只是简单介绍如何用test bench来仿真VHDL程序,其中各种激励信号的编写、时序的安排要依靠设计的需要,这些只能靠平时不断的积累。 这里介绍的是从ISE中直接调用modelsim进行仿真,因此关于ISE和modelsim的关联也是大家经常遇到的问题。

这个下次再总结。

2.怎样写testbench

如何编写testbench的总结?1.激励的设置相应于被测试模块的输入激励设置为reg型,输出相应设置为wire类型,双向端口inout在测试中需要进行处理。

方法1:为双向端口设置中间变量inout_reg作为该inout的输出寄存,inout口在testbench中要定义为wire型变量,然后用输出使能控制传输方向。eg:inout [0:0] bi_dir_port;wire [0:0] bi_dir_port;reg [0:0] bi_dir_port_reg;reg bi_dir_port_oe;assign bi_dir_port=bi_dir_port_oe?bi_dir_port_reg:1'bz;用bi_dir_port_oe控制端口数据方向,并利用中间变量寄存器改变其值。

等于两个模块之间用inout双向口互连。往端口写(就是往模块里面输入)方法2:使用force和release语句,这种方法不能准确反映双向端口的信号变化,但这种方法可以反映块内信号的变化。

具体如示:module test();wire data_inout;reg data_reg;reg link;#xx; //延时force data_inout=1'bx; //强制作为输入端口。

#xx;release data_inout; //释放输入端口endmodule从文本文件中读取和写入向量1)读取文本文件:用 $readmemb系统任务从文本文件中读取二进制向量(可以包含输入激励和输出期望值)。

$readmemh 用于读取十六进制文件。例如:reg [7:0] mem[1:256] // a 8-bit, 256-word 定义存储器meminitial $readmemh ( "mem.data", mem ) // 将.dat文件读入寄存器mem中initial $readmemh ( "mem.data", mem, 128, 1 ) // 参数为寄存器加载数据的地址始终2)输出文本文件:打开输出文件用?$fopen 例如:integer out_file; // out_file 是一个文件描述,需要定义为 integer类型out_file = $fopen ( " cpu.data " ); // cpu.data 是需要打开的文件,也就是最终的输出文本设计中的信号值可以通过$fmonitor, $fdisplay,2. Verilog和Ncverilog命令使用库文件或库目录ex). ncverilog -f run.f -v lib/lib.v -y lib2 +libext+.v //一般编译文件在run.f中, 库文件在lib.v中,lib2目录中的.v文件系统自动搜索使用库文件或库目录,只编译需要的模块而不必全部编译3.Verilog Testbench信号记录的系统任务:1). SHM数据库可以记录在设计仿真过程中信号的变化. 它只在probes有效的时间内记录你set probe on的信号的变化.ex). $shm_open("waves.shm"); //打开波形数据库$shm_probe(top, "AS"); // set probe on "top",第二个参数: A -- signals of the specific scrope S -- Ports of the specified scope and below, excluding library cellsC -- Ports of the specified scope and below, including library cellsAS -- Signals of the specified scope and below, excluding library cellsAC -- Signals of the specified scope and below, including library cells还有一个 M ,表示当前scope的memories, 可以跟上面的结合使用, "AM" "AMS" "AMC"什么都不加表示当前scope的ports;$shm_close //关闭数据库2). VCD数据库也可以记录在设计仿真过程中信号的变化. 它只记录你选择的信号的变化.ex). $dumpfile("filename"); //打开数据库$dumpvars(1, top.u1); //scope = top.u1, depth = 1第一个参数表示深度, 为0时记录所有深度; 第二个参数表示scope,省略时表当前的scope.$dumpvars; //depth = all scope = all$dumpvars(0); //depth = all scope = current$dumpvars(1, top.u1); //depth = 1 scope = top.u1$dumpoff //暂停记录数据改变,信号变化不写入库文件中$dumpon //重新恢复记录3). Debussy fsdb数据库也可以记录信号的变化,它的优势是可以跟debussy结合,方便调试.如果要在ncverilog仿真时,记录信号, 首先要设置debussy:a. setenv LD_LIBRARY_PATH :$LD_LIBRARY_PATH(path for debpli.so file (/share/PLI/nc_xl//nc_loadpli1))b. while invoking ncverilog use the +ncloadpli1 option.ncverilog -f run.f +debug +ncloadpli1=debpli:deb_PLIPtrfsdb数据库文件的记录方法,是使用$fsdbDumpfile和$fsdbDumpvars系统函数,使用方法参见VCD注意: 在用ncverilog的时候,为了正确地记录波形,要使用参数: "+access+rw", 否则没有读写权限在记录信号或者波形时需要指出被记录信号的路径,如:tb.module.u1.clk.………………………………………………………………………………………………………关于信号记录的系统任务的说明:在testbench中使用信号记录的系统任务,就可以将自己需要的部分的结果以及波形文件记录下来(可采用sigalscan工具查看),适用于对较大的系统进行仿真,速度快,优于全局仿真。

使用简单,在testbench中添加:initial begin$shm_open("waves.shm");$shm_probe("要记录信号的路径“,”AS“);#10000$shm_close; 即可。4. ncverilog编译的顺序: ncverilog file1 file2 。

.有时候这些文件存在依存关系,如在file2中要用到在file1中定义的变量,这时候就要注意其编译的顺序是从后到前,就先编译file2然后才是file2.5. 信号的强制赋值force首先, force语句只能在过程语句中出现,即要在initial 或者 always 中间. 去除force 用 release 语句.initial begin force sig1 = 1'b1; 。 ; release sig1; endforce可以对wire赋值,这时整个net都被赋值; 也可以对reg赋值.6.加载测试向量时,避免在时钟的上下沿变化为了模。

3.如何写TESTBENCH, 给个教程吧

一、基本概念和基础知识Testbench 不仅要产生激励也就是输入,还要验证响应也就是输出。

当然也可以只产生激励,然后通过波形窗口通过人工的方法去验证波形,这种方法只能适用于小规模的设计。在ISE 环境中,当前资源操作窗显示了资源管理窗口中选中的资源文件能进行的相关操作。

在资源管理窗口选中了testbench 文件后,在当前资源操作窗显示的ModelSimSimulator 中显示了4 种能进行的模拟操作,分别是:Simulator Behavioral Model(功能仿真)、Simulator Post-translate VHDL Model(翻译后仿真)、Simulator Post-Map VHDLModel(映射后仿真)、Simulator Post-Place & Route VHDL Model(布局布线后仿真)。如图1 所示:图1l Simulator Behavioral Model 也就是所说的功能仿真、行为仿真、前仿真。

验证功能是否正确,这是设计的第一步。功能仿真正确的程序不一定能被正确综合,也就是硬件实现。

有的在综合时报错误,有的虽然能综合但结果并不正确。当然,功能仿真如果都不能通过,以后的步骤也就无法进行。

这是必做的仿真。l Simulator Post-translate VHDL Model 也就是翻译后仿真。

对源程序进行编译后首先排除了语法错误,对一些像类属命令(Generic)、生成语句(Generate)等进行了展开。不是必做的仿真。

l Simulator Post-Map VHDL Model也就是映射后仿真。不同的器件内部结构也不尽相同,映射的作用就是将综合后产生的网表文件对应到实际的器件上去。

由于映射不包含布线,也就是要用什么类型的逻辑单元虽然已经确定但要用哪个位置的还没有确定,因此,映射后仿真不包含布线延时。不是必做的仿真。

l Simulator Post-Place & Route VHDL Model 也就是所说的布局布线后仿真、时序仿真、后仿真。这是最完整的仿真,既包含逻辑延时又包含布线延时。

在做布局布线后仿真时要用到一个叫SDF的文件。SDF文件包含设计中每个单元(Cell)的延时和时序约束数据。

通过加载这个文件就能得到完整的时序情况。它是必做的仿真。

一般必须进行功能仿真和布局布线后仿真。常见问题:为什么有的testbench在进行功能仿真时能正确进行,而在进行布局布线后仿真时就不能运行。

有两点要注意的地方:(1)、在做映射后仿真或布局布线后仿真时,都已经经过了综合工具的综合,源程序中的类属命令(Generic)、生成语句(Generate)等都已经进行展开。例如,如果用Generic 定义了一个参数width,综合工具进行综合时已经按照一个确定的width 值进行了综合。

它生成的电路已经具有一个确定的结构,不能再随意调整。所以在映射后仿真和布局布线后仿真的testbench中,往往不能出现Generic 语句。

(2)映射后仿真和布局布线后仿真都要用到SDF 文件,并且要将SDF文件关联到设计中的实例。所以在映射后仿真和布局布线后仿真的testbench中,第一,要将你的设计声明成一个元件。

第二,实例化你设计的元件并且实例名要取为UUT(默认的,当然也可以改)。关于断言语句在仿真中为了能得到更多信息,经常要用到断言语句(assert)。

其语法如下:Assert<条件>Report<消息>Severity<出错级别>;出错级别共有5 种:l Notel Warningl Errorl Failurel Fatal在VHDL 模型的模拟过程中,一旦断言语句的条件为假,则发送消息并将出错级别发送给模拟器。通常可以设置一个中止模拟器运行的出错级别,一般默认的中止运行的出错级别为Failure。

我们来看一个例子:assert falsereport "********* " & IMAGE(DWIDTH) & "BIT DIVIDER SEQUENCE FINISHEDAT " & IMAGE(now) & " !" & " *********"severity note;断言的条件不是一个条件表达式,而直接是false。这说明只要程序执行到这里断言就一定会成立,送出消息。

出错级别为note,在模拟器的输出窗口将会显示:图2再看一个例子:assert (s_cyi((DWIDTH-1)/4) = '0')and (s_ovi = '0')and (s_qutnt = conv_std_logic_vector(v_quot,DWIDTH))and (s_rmndr = conv_std_logic_vector(v_remd,DWIDTH))report "ERROR in division!"severity failure;断言的条件有4 个并且是与的关系,只要其中一个条件不成立则整个表达式为假,断言成立。如果断言成立将输出“ERROR in division!“这个消息。

并且通知模拟器出错级别为failure,这一般会停止模拟。这个断言实际是在对结果进行验证。

二、实际testbench分析下面将详细分析一个实际的testbench,它是用来测试8051 的ALU单元的除法功能的。8 位的除法器,被除数和除数的组合共有256*256=65536 种。

我们采用的方法是穷举所有的输入组合,这样的代码覆盖率可以达到100%。它的验证必须通过程序自动完成,否则通过人工方法工作量太大。

把要测试的程序当作一个元件,例如想象成一个74 系列数字电路。Testbench 的作用是在被测试电路的输入端加上激励,然后比较被测试电路的输出和计算出来的期望值是否一致。

对我们这个例子来说,在要仿真的ALU 输入端产生65536 种输入组合,然后将ALU产生的对应输出值和testbench 算出的期望值相比较,如果有错误产生则停止模拟并输出信息。ALU 的除法单元的输入有4 个,分别是被除数、除。

vhdl时钟的testbench怎么写

转载请注明出处育才学习网 » vhdl时钟的testbench怎么写(如何编写testbench来仿真VHDL程序)

知识

家谱中个人简历怎么写(家谱简介怎么写)

阅读(925)

本文主要为您介绍家谱中个人简历怎么写,内容包括家谱中如何写个人简历,家谱中个人简历怎么写,家谱中如何写个人简历。家谱族谱网,隶属于北京时代绘谱文化发展公司。家谱族谱网网站策划于2010年2月,历时半年时间,于2010年8月上线,是国内首家集家

知识

名人简介怎么写(名人简介50字左右)

阅读(2231)

本文主要为您介绍名人简介怎么写,内容包括写中国名人简介,如何写名人简介,名人简介50字左右。凿壁偷光匡衡,字稚圭,勤奋学习却没有蜡烛。邻居家有烛光却穿不过来,匡衡就把墙壁凿个洞引来了邻家的烛光,用烛光映着书读。同县人文不识家里有

知识

加班情况说明怎么写(加班证明怎么写)

阅读(4390)

本文主要为您介绍加班情况说明怎么写,内容包括加班情况说明怎样写,加班情况说明怎样写,加班证明怎么写。加班证明范文领导: 兹有XXX在XXX位置加班XX小时,工作内容XXXXX。已完成。参加人有:XX,XXX,证明人:XXX加班人:XXX

知识

自愿加班申请书怎么写(员工自愿加班申请书)

阅读(1244)

本文主要为您介绍自愿加班申请书怎么写,内容包括员工自愿加班申请书,加班申请书怎么写,谁能告诉我保安自愿加班申请书该怎么写模板。去百度文库,查看完整内容>内容来自用户:李鹏亚自愿加班申请书范文【篇一:自愿加班协议书】自愿加班申请协议

知识

加入社团的理由怎么写(社团面试时如何说加入该社团的理由)

阅读(663)

本文主要为您介绍加入社团的理由怎么写,内容包括社团面试时如何说加入该社团的理由,申请加入社团理由,申请加入社团理由。理由可以说是自己有兴趣,希望锻炼自己哪些方面的能力之类的,总而言之要从两方面来讲,一是自己可能为社团带来的益处,二是

知识

地质发展史怎么写(地质学方面描述地质发展历史)

阅读(346)

本文主要为您介绍地质发展史怎么写,内容包括地质学方面描述地质发展历史,地质演化史怎么写,地质发展史。其实这道题并不难分析:图中展示的是一套断层-褶皱-不整合的地层(地层代号的角标我看不清楚),古生界沉积了奥陶、石炭、二叠三个系的地层,奥

知识

服装品牌调研报告的结论怎么写(服装调研报告怎么写)

阅读(361)

本文主要为您介绍服装品牌调研报告的结论怎么写,内容包括服装调研报告怎么写,服装调研报告怎么写,服装的市场调查报告怎么写啊。1 标 题: 三种写法。 ① 标题是文章标题的写法(如:《西部企业生态立旗“一石三鸟”》,《某某市蔬菜的品种结构问题

知识

改变自己日语怎么写(把改变自己4个字翻译成日文)

阅读(333)

本文主要为您介绍改变自己日语怎么写,内容包括“我会试着改变自己”用日文怎么说,我想试着去改变自己日语怎么说,把"改变自己"4个字翻译成日文。如题:改変自己(自分)假名:かいへんじこ(じぶん)罗马音:ka yi he n ji ko(ji bu n)(键盘输入亦可)发音:ka

知识

专利说明书上分类怎么写(多种商品可用的专利说明书怎么写)

阅读(273)

本文主要为您介绍专利说明书上分类怎么写,内容包括专利说明书种类,专利说明书怎么写啊,中国专利说明书采用什么分类中国专利说明书采用什么分类法爱问知。首先根据功能命题为“一种家电保护(节能或其他功能)装置”。然后结合该装置的图纸和结

知识

项目启动邮件怎么写(申请项目奖金邮件如何撰写)

阅读(2010)

本文主要为您介绍项目启动邮件怎么写,内容包括申请项目奖金邮件如何撰写,每周项目汇报,采用邮件形式,怎么写邮件比较好呢,需要写那些东,怎么写offer邮件。首先写明向谁申请,注意礼貌,开头可以说尊敬的XXX,您好2、 写明申请项目奖金的原因,言辞

知识

我的世界时钟怎么用

阅读(233)

本文主要为您介绍我的世界时钟怎么用,内容包括我的世界时钟有什么用,我的世界手机版时钟怎么用闹钟使用方法,clock我的世界怎么用。钟(Clock)的使用方法有点象指南针,意味着你不能直接使用它,只能通过观察上面的图案的变化来辨别时间。时钟上的

知识

我的时钟用英语怎么说

阅读(264)

本文主要为您介绍我的时钟用英语怎么说,内容包括我的钟表用英语怎么说,我有个时钟用英语怎么说,我的钟表用英语怎么写。钟表:Clocks and watches例句:石英钟表走时非常准,年误差仅为一两分钟。Quartz timepieces are ve

知识

八路抢答器怎么写vhdl

阅读(216)

本文主要为您介绍八路抢答器怎么写vhdl,内容包括八人抢答器:怎么将vhdl编写的代码和平台联系起来,就是怎么在平台,您好.我想问一下如果用FPGA来做八路抢答器.那该怎么做源程序该,八路抢答器设计开题报告怎么写。题目名称:八路抢答器 XXXXX学

知识

易语言怎么写多线程替代时钟

阅读(692)

本文主要为您介绍易语言怎么写多线程替代时钟,内容包括易语言线程和时钟的区别,易语言延时如何用时钟代替,易语言线程和时钟的区别。.支持库 EThread.支持库 iext5库 spec.程序集 窗口程序集1.程序集变量 热键_, 整数型.子程序 __启动窗口_

知识

怎么用VHDL写变频器

阅读(226)

本文主要为您介绍怎么用VHDL写变频器,内容包括VHDL实现变频,请问怎么用VHDL写个程序把频率从50MHz转换成40MHz啊,变频器控制程序用哪种语言写比较好。library ieee;use ieee.std_logic_arith.all;use ieee.std_logic_1164.al

知识

时钟的两种方式怎么写

阅读(3158)

本文主要为您介绍时钟的两种方式怎么写,内容包括钟面上的时间有两种写法,你知道吗,用两种方法写时间,时钟指四点怎么用两种方法写。数字加汉字表示。例:11时30分;11点整(11时);11时33分46秒。2、数字加符号表示。例:11:30;11:00;11:33:4

知识

制作时钟作文怎么写

阅读(262)

本文主要为您介绍制作时钟作文怎么写,内容包括制作小闹钟作文怎么写,生命时钟的作文怎么写,急求《时钟的故事》作文如何写。今天,少年宫的手工课要制作小闹钟。老师给我们看了一些创意脑钟的图片,其中我最喜欢高爆手雷版闹钟了,那个闹钟的介绍

知识

vhdl右移怎么写

阅读(183)

本文主要为您介绍vhdl右移怎么写,内容包括vhdl怎么用算术左移,求高手,帮我看看VHDL描述八位右移移位寄存器哪里错了,用VHDL描述异步复位,同步置数和移位使能8位右移移位寄存器。library ieee;use ieee.std_logic_1164.all;use ieee.std_log

[/e:loop]