- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
芯驿电子科技(上海)有限公司
021
编写testbench 及仿真
黑金动力社区 2017-12-21
1 文档简介
本章节主要了解如何编写激励文件,常用的系统任务和系统函数,并实现在 Modelsim 软件
里仿真。
2 新建 Modelsim 工程
(1 ) 新建文件夹,利用 01_led_test 实验文件进行仿真,将 verilog 文件及激励文件拷贝到新建
文件夹中 。注意路径不要出现中文或空格等非法字符。
(2 ) 打开 Modelsim 软件,新建项目工程指定到所建的文件夹,并将两个文件导入到项目中。
(3 ) 后面讲到的例子都放在了 demo/testbench 文件夹下,如果遇到问题可以点击“点我仿
真.bat “自动运行仿真测试。但建议按照下面的步骤学习。
黑金FPGA 版权所有 1 / 14
3 分析激励文件
打开激励文件 led_test_tb.v 可以看到,激励文件主要由模块定义、信号初始化、执行模块、
例化等几部分组成。下面对 testbench 逐条进行了解释:
`timescale 1ns/1ns //timescale是verilog中的一种时间尺度预编译指令,用来定义
//仿真时的时间单位和时间精度,/左边是时间单位,右边是时间精
//度,时间单位是用于编写激励文件,时间精度是显示时的刻度,比
//如#100也就是100ns。时间精度不能大于时间单位,
//比如`timescale 1 ns/1 ps是正确的,
//而`timescale 1 ps/1 ns是错误的。
module led_test_tb(); //端口定义,激励文件不需要声明输入输出端口
reg clk; //对于例化文件的输入端口,需要定义寄存器类型的信号
reg rst_n;
wire [3:0] led; //对于例化文件的输出端口,需要定义wire类型的信号
//每个initial或always模块之间是并行执行的
initial //需要对输入信号进行初始化处理
begin
clk = 1b0;
rst_n = 1b0;
#100 rst_n = 1b1; //# 代表延时,如时间单位是1ns , 那么#100代表延迟100ns
end
always#10 clk = ~clk; //根据时钟频率,如50MHz,每个周期是20ns,那么每10ns翻转
//产生出时钟信号
led_test dut
(
.clk (clk), // 开发板上输入时钟: 50Mhz
.rst_n (rst_n), // 开发板上输入复位按键
.led (led) // 输出LED灯,用于控制开发板上四个LED(LED0~LED3)
);
endmodule
经过仿真,即可查看波形界面:
黑金动力社区 2 / 14
4 系统任务和系统函数
下面介绍几个激励文件中常用 的系统任务和系统函数。
4.1 显示任务
4.
您可能关注的文档
- (草稿2)FPGA系统设计与验证实战指南_V1.2.pdf
- 04.verilog基础模块指南.pdf
- 02.安装Modelsim及仿真指南.pdf
- 《轴对称与坐标变化》word教案 (公开课获奖)2022北师版 整理版 .pdf
- 【可行性报告】2023年飞行管理系统相关项目可行性研究报告 .pdf
- 七年级数学竞赛(初赛)试题(含答案) .pdf
- 【可行性报告】2023年软件产业园相关项目可行性研究报告 .pdf
- 《济南的冬天》的读后感6篇 .pdf
- 《2021谈心谈话记录范文 [2021最新工作谈心谈话记录内容范文大全精选.pdf
- 七年级上册 第2章 第3讲 生物体的结构层次(解析版) .pdf
文档评论(0)