【软件使用】Icarus Verilog仿真

复制代码
发音:/ˈaikərəs/: n. [希神]伊卡洛斯(代达罗斯的儿子)
安装

iverilog安装时,默认会把GTKWave一起安装,用于查看生成的波形图。安装地址:https://bleyer.org/icarus/

全平台可装,本文Win平台,随后在CMD中直接查阅iverilog, vvp, gtkwave是否安装成功

bash 复制代码
C:\Users\wpyoung>where iverilog
C:\Users\wpyoung\AppData\Roaming\iverilog\bin\iverilog.exe

C:\Users\wpyoung>where vvp
C:\Users\wpyoung\AppData\Roaming\iverilog\bin\vvp.exe

C:\Users\wpyoung>where gtkwave
C:\Users\wpyoung\AppData\Roaming\iverilog\gtkwave\bin\gtkwave.exe

iverilog:用于编译verilog和vhdl文件,进行语法检查,生成可执行文件

vvp:根据可执行文件,生成仿真波形文件

gtkwave:用于打开仿真波形文件,图形化显示波形

Icarus参数
  1. -o,指定生成文件的名称。如不指定,默认生成为a.out。如:iverilog -o test test.v
  2. -y,包含指定文件夹,iverilog -y E:/pro/demo demo_tb.v
  3. -I,(大写i)头文件包含(`include),用法与-y同

用法查询,输入iverilog即可

shelll 复制代码
C:\Users\wpyoung>iverilog
iverilog: no source files.

Usage: iverilog [-EiSuvV] [-B base] [-c cmdfile|-f cmdfile]
                [-g1995|-g2001|-g2005|-g2005-sv|-g2009|-g2012] [-g<feature>]
                [-D macro[=defn]] [-I includedir] [-L moduledir]
                [-M [mode=]depfile] [-m module]
                [-N file] [-o filename] [-p flag=value]
                [-s topmodule] [-t target] [-T min|typ|max]
                [-W class] [-y dir] [-Y suf] [-l file] source_file(s)

See the man page for details.
Verilog文件格式和函数
  1. VCD文件是记录各种信号取值变化情况的信息记录文件。EDA工具通过读取VCD格式的文件,显示图形化的仿真波形,所以,可以把VCD文件简单地视为波形记录文件。
  2. $dumpfile ("wave.vcd"); //仿真信息将记录到wave.vcd
  3. $dumpvar(level, module_name); level用于指定层次数,module则指定要记录的模块。对于指定的模块,包括其下各个层次的信号,都需要记录到VCD文件中去。$dumpvar表示记录所有的信号文件。
仿真
  1. iverilog -o wave led_demo_tb.v得到wave
shell 复制代码
PS E:\weip_vgg_Noc\pro_hdl_icarus> iverilog -o wave led_demo_tb.v led_demo.v
  1. vvp -n wave -lxt2得到vcd文件
shell 复制代码
PS E:\weip_vgg_Noc\pro_hdl_icarus> vvp -n wave -lxt2
LXT2 info: dumpfile wave.vcd opened for output.
led_demo_tb.v:29: $stop called at 11000 (100ps)
  1. gtkwave打开仿真文件gtkwave wave.vcd
脚本

Windows系统保存为.bat文件,Linux系统保存为.sh文件。Windows直接双击运行,Linux在终端执行

shell 复制代码
echo "开始编译"
iverilog -o wave led_demo.v led_demo_tb.v
echo "编译完成"
vvp -n wave -lxt2
echo "生成波形文件"
cp wave.vcd wave.lxt
echo "打开波形文件"
gtkwave wave.lxt

参考资料:https://zhuanlan.zhihu.com/p/95081329

相关推荐
FPGA小迷弟2 小时前
FPGA 时序约束基础:从时钟定义到输入输出延迟的完整设置
前端·学习·fpga开发·verilog·fpga
daxi1507 小时前
Verilog入门实战——第3讲:流程控制语句(if-else / case / 循环结构)
fpga开发·fpga
biubiuibiu9 小时前
工业机器人编程语言详解:多样化选择与应用
fpga开发·机器人
lf28248143110 小时前
04 DDS信号发生器
fpga开发
szxinmai主板定制专家11 小时前
基于 STM32 + FPGA 船舶电站控制器设计与实现
arm开发·人工智能·stm32·嵌入式硬件·fpga开发·架构
ARM+FPGA+AI工业主板定制专家21 小时前
基于ARM+FPGA+AI的船舶状态智能监测系统(二)软硬件设计,模拟量,温度等采集与分析
arm开发·人工智能·目标检测·fpga开发
szxinmai主板定制专家1 天前
基于ZYNQ MPSOC船舶数据采集仪器设计(一)总体设计方案,包括振动、压力、温度、流量等参数
arm开发·人工智能·嵌入式硬件·fpga开发
FPGA小迷弟1 天前
高频时钟设计:FPGA 多时钟域同步与时序收敛实战方案
前端·学习·fpga开发·verilog·fpga
szxinmai主板定制专家1 天前
基于ZYNQ MPSOC船舶数据采集仪器设计(三)振动,流量,功耗,EMC,可靠性测试
arm开发·人工智能·嵌入式硬件·fpga开发
hoiii1871 天前
Vivado下Verilog交通灯控制器设计
fpga开发