1.3.2 仿真验证平台介绍
通常情况下,在完成相关的RTL设计之后,接下来要做的事情就是对设计功能进行仿真,验证它是否满足我们的设计需求。本节基于ModelSim,搭建了一个简易的仿真验证平台,用于本书中RTL设计的功能仿真。
该平台是基于批处理脚本、do脚本、一键化可运行图形界面或命令形式的仿真机制的。图1.18所示为仿真验证平台的文件组织架构,下面分别对各文件夹和文件的作用进行介绍。
图1.18 仿真验证平台的文件组织架构
(1)sim_log:存放ModelSim仿真过程中产生的文件,包括编译文件、仿真波形文件等。
(2)source_files:存放ModelSim仿真用的数据源。
(3)print_files:存放ModelSim仿真的打印结果。
(4)design_ver.f:存放Verilog设计文件列表。
(5)read_wave.bat:用于打开仿真波形文件的批处理脚本。
(6)run.bat:启动ModelSim仿真的批处理脚本。
(7)run.do:执行ModelSim仿真的相关指令,包括建立库、映射库、编译、启动仿真。
(8)testbench.sv:存放ModelSim仿真的顶层文件。
仿真验证平台的运行机制,如图1.19所示。通过批处理脚本和do脚本文件之间的调用来启动仿真验证平台。运行run.bat时,启动ModelSim对run.do进行编译(包括design_ver.f和testbench.sv)和仿真。
图1.19 仿真验证平台的运行机制
接下来对批处理脚本和do脚本的内容进行介绍。
1.3.2.1 read_wave.bat
关闭显示信息,代码如下所示。
将当前路径作为cmd窗口的标题显示,代码如下所示。
进入sim_log目录,代码如下所示。
打开仿真波形文件vsim.wlf,代码如下所示。
1.3.2.2 run.bat
关闭显示信息,代码如下所示。
将当前路径作为cmd窗口的标题显示,代码如下所示。
删除sim_log目录下的内容,代码如下所示。
删除print_files目录下的内容,代码如下所示。
进入sim_log目录,代码如下所示。
后台模式启动ModelSim软件执行run.do进行仿真,代码如下所示。
终止cmd窗口并退出,代码如下所示。
1.3.2.3 run.do
将ModelSim的配置文件ModelSim.ini拷贝到当前目录,代码如下所示。
建立库目录和映射库,代码如下所示。
编译testbench.sv和design_ver.f,代码如下所示。
启动仿真并使用相关的器件库,代码如下所示。
添加波形;记录波形;设置仿真时间,代码如下所示。
关于仿真验证平台的具体使用流程,请参考第2章2.4.2节仿真流程的详解。