$dumpfile() $ dumpvars()的用法

$dumpfile() $ dumpvars()的用法,第1张

分类: 教育/科学 >>外语学习

问题描述:

initial

begin

$dumpfile("???")

$dumpvars(0,?)

end

?处怎么填,有什么意义???

解析:

$dumpfile和$dumpvar是verilog语言中的两个系统任务,可以调用这两个系统任务来创建和将指定信息导入VCD文件. (什么是VCD文件? 答:VCD文件是在对设计进行的仿真过程中,记录各种信号取值变化情况的信息记录文件。EDA工具通过读取VCD格式的文件,显示图形化的仿真波形,所以,可以把VCD文件简单地视为波形记录文件.)下面分别描述它们的用法并举例说明之。

$dumpfile系统任务:为所要创建的VCD文件指定文件名。

举例(""符号后的内容为注释文字):

initial

$dumpfile ("myfile.dump")指定VCD文件的名字为myfile.dump,仿真信息将记录到此文件

$dumpvar系统任务:指定需要记录到VCD文件中的信号,可以指定某一模块层次上的所有信号,也可以单独指定某一个信号。

典型语法为$dumpvar(level, module_name)参数level为一个整数,用于指定层次数,参数module则指定要记录的模块。整句的意思就是,对于指定的伏旦模块,包括其下各个层次(层次数由level指定)的信号掘厅滚,都需要记录到VCD文件中去。

举例:

initial

$dumpvar (0, top)指定层次数为0,则top模块及其下面各层次的所有信号将被记录

initial

$dumpvar (1, top)记录模块实例top以下一层的信号

层次数为1,即记录top模块这一层次的信号

对于top模块中调用的更深层次的模块实例,则不记录其信号变化

initial

$dumpvar (2, top)记录模块实例top以下两层的信号

即top模块及其下一层的信号将被记录

假设模块top中包含有子模块module1,而我们希望记录top.module1模块以下两层的信号,则语法举例如下:

initial

$dumpvar (2, top.module1)模块实例top.module1及其下一层的信号将被记录

假设模块top包含信号signal1和signal2(注意是变量而不是子模块判余), 如我们希望只记录这两个信号,则语法举例如下:

initial

$dumpvar (0, top.signal1, top.signal2)虽然指定了层次数,但层次数是不影响单独指定的信号的

即指定层次数和单独指定的信号无关

我们甚至可以在同一个$dumpvar的调用中,同时指定某些层次上的所有信号和某个单独的信号,假设模块top包含信号signal1,同时包含有子模块module1,如果我们不但希望记录signal1这个独立的信号,而且还希望记录子模块module1以下三层的所有信号,则语法举例如下:

initial

$dumpvar (3, top.signal1, top.module1)指定层次数和单独指定的信号无关

所以层次数3只作用于模块top.module1, 而与信号

top.signal1无关

上面这个例子和下面的语句是等效的:

initial

begin

$dumpvar (0, top.signal1)

$dumpvar (3, top.module1)

end

$dumpvar的特别用法(不带任何参数):

initial

$dumpvar无参数,表示设计中的所有信号都将被记录

最后,我们将$dumpfile和$dumpvar这两个系统任务的使用方法在下面的例子中综合说明,假设我们有一个设计实例,名为 i_design,此设计中包含模块module1,模块module1下面还有很多层次,我们希望对这个设计进行仿真,并将仿真过程中模块module1及其以下所有层次中所有信号的变化情况,记录存储到名为mydesign.dump的VCD文件中去,则例示如下:

initial

begin

$dumpfile ("mydesign.dump")指定VCD文件名为mydesign.dump

$dumpvar (0, i_design.module1)记录i_design.module1模块及其下面层次中所有模块的所有信号

end

Value change dump, 简称VCD,是一种基于ASCII码的文件格式,用于记录由EDA仿真工具产生的信号信息。四值VCD格式由IEEE标准1364-1995在1995年随Verilog硬件描述语言标准制定。扩展的VCD格式在6年后,由IEEE标准1364-2001制定,增加了对信号的强度和方向进行记录的支持。由于VCD格式结构简单紧凑,它被广泛用于其它非Verilog工具中,比如内核追踪等。

2结构/语法

编辑

VCD文件包含了3个段,依次如下排列:头信息(日期,仿真器,时间精度)、变量定义、值变化信息。这些部分通过对应的关键字进行区分。

VCD关键字通过在词首加$标志(不过变量标志也可以用$开始)。通常,相应的关键字开始一个段,而关键字#end将结束这个段。

VCD语句通过空格区分。VCD文件中的数据变化袭键告敏感。

头信息段

VCD文件的头信息段,包含一个亮伍时间戳,一个仿真器版本号,和一个时间精度。时间精度用拍明于表示下面的值在变化的时候,时间增加的单位。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12126866.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-21
下一篇 2023-05-21

发表评论

登录后才能评论

评论列表(0条)

保存