二 vcd dump

由于VCD可以用于做功耗分析,所以需要把其dump出来。另外VCD可以作为结果,也可以作为激励,但是实际看到的少啊!

VCD是verilog的标准,所以有系统函数$dumpvars,$dumpfile(),$dumpon,$dumpoff,$dumpflush.

但是VHDL没有相关函数,所以要使用modelsim的脚本 :

vcd file, vcd add, vcd flush

注意:

a)以上前两句要加在vsim后面,见sample,

b)注意在仿真结束前调用 vcd flush,把buffer中的数据输出给文件,估算buffer可能是2kB大小。如果文件很小且没有运行vcd flush,会看到文件没有内容!

另外如果不运行vcd flush,则最后的约2KB数据不会写进vcd中!

c)另外vcd add只能添加bit, bit_vector,std_logic, and std_logic_vector
vcd add
This command adds the specified objects to a VCD file.
The allowed objects are Verilog nets and variables and VHDL signals of type bit, bit_vector,
std_logic, and std_logic_vector (other types are silently ignored). The command works with
mixed HDL designs.

d) 如果想子模块一起存储VCD,添加-r,但是参数是有顺序的

vcd add /top/* -r 这个是错的

改为

vcd add -r /top/*

e) -----------VCD script sample-------

#    vcd file test.vcd
#    vcd add /top/*

vsim -L work -t ns -novopt -c -pli ./pslse-master/pslse/afu_driver/src/afu_driver.sl +nowarnTSCALE work.top
#注意 -novopt很重要,否则会被优化层次结构,甚至有些模块会不见了!(比如做了D触发器以及其testbench,就能看到这个问题)
    vcd file test.vcd
#  vcd add /top/* -r   这句话是错误的,参数有顺序
    vcd add -r /top/*
为了只计算power,只需要dut的功耗,可以如下

vcd add -r /top/dut/*

f) vcd flush,解释见后

如果在仿真结束后,没有运行vcd flush,会有部分内容,甚至全部内容没有写到vcd的file中,碰到如下问题

在verilog的代码中使用了$stop。

而在do文件中,最后是

run all

这样得到的vcd file是空文件,因为没有flush进去吧?!

即使改为

run all

vcd flush

仍然出错,因为script会pause在run all。

修改的原则,保证确实flush到文件中了!

.)取消$stop,修改run all为run 具体时间(如1ms),添加vcd flush。

.)此法不适合VHDL而适合verilog,在$stop前添加,$dumpflush。仍然run -all

但是不建议脚本和verilog的vcd相关task混合使用,要不全部用脚本,或者全部用task

1) ---------------  如下来自modelsim OEM产生的script

vmap presynth presynth
vmap SmartFusion2 "D:/Microsemi/Libero_SoC_v11.7/Designer/lib/modelsim/precompiled/vlog/SmartFusion2"

vlog -vlog01compat -work presynth "${PROJECT_DIR}/hdl/top.v"
vlog "+incdir+${PROJECT_DIR}/stimulus" -vlog01compat -work presynth "${PROJECT_DIR}/stimulus/tb.v"

vsim -L SmartFusion2 -L presynth  -t 1ps -novopt presynth.tb
add wave /tb/*
add log -r /*
vcd file power.vcd
vcd add -r /tb/top_0/*
run 500ns
vcd flush
echo "VCD file power.vcd was successfully exported under the project simulation/ direct

2) ----------sample 采用verilog函数 dump (注意最后用了和vcd flush一样的作用的function $dumpflush)-------

http://verilog.renerta.com/mobile/source/vrg00056.htm

initial begin
  $dumpfile("test.txt");
  $dumpvars(1,a,y);
  #200;
  $dumpoff;
  #200;
  $dumpon;
  #20;
  $dumpall;
  #10;
  $dumpflush;
end
endmodule

The dumpfile will contain only changes of 'a' and 'y' variables.
After 200 time units, dumping will be suspended for 200 time units.
Next, dumping will start again and after 20 time units, all variables
will be dumped.

问题:实在不知道$dumpall和$dumpflush的区别,如下是查找modelsim的ug得到解释以及相对应的vcd命令

vcd checkpoint
This command dumps the current values of all VCD variables to the specified VCD file. While
simulating, only value changes are dumped.
Related Verilog tasks: $dumpall, $fdumpall

vcd on
This command turns on VCD dumping to the specified file and records the current values of all
VCD variables.
By default, vcd on is automatically performed at the end of the simulation time that the vcd add
command performed.
Related Verilog tasks: $dumpon, $fdumpon
Syntax
vcd on [<filename>]
Arguments
• <filename>
(optional) Specifies the name of the VCD file. If omitted the command is executed on the
file designated by the vcd file command or dump.vcd if vcd file was not invoked.
 
vcd flush
This command flushes the contents of the VCD file buffer to the specified VCD file. This
command is useful if you want to create a complete VCD file without ending your current
simulation.
Related Verilog tasks: $dumpflush, $fdumpflush

-----------------------

三) 要查看以前的仿真,需要先将VCD转为wlf

vcd2wlf xx.vcd xx.wlf

然后用-view参数查看,导入wav.do显示需要看的波形!

vsim -do wav.do(波形文件) -view test=xx.wlf(test是dataset名,可以不要)

四)VCD 格式理解

$date
    Fri Aug 26 15:48:49 2016
$end
$version
    QuestaSim Version 10.3_1
$end
$timescale
    1ps
$end

$scope module dff_tb $end

$scope module dut $end
$var wire 1 ! clk $end    --- shannon:这句话表示用!符号表示clk网络
$var wire 1 " rst $end    --- shannon:这句话表示用"符号表示rst网络
$var wire 1 # d $end
$var reg 1 $ q $end
$upscope $end
$upscope $end
$enddefinitions $end
#0
$dumpvars                --- shannon: dump值
0$          
0#
0!
1"
$end
#5000                         --- shannon :网络clk 值在5000是为1
1!
#10000
0!
#15000
1!
#16000
0"                                     ---shannon:网络rst 值在16000ps时变为0  (1ps 是 vsim -t 1ps -novopt work.dff_tb 定义的单位)
#20000
0!
#25000
1!
#30000
0!
#35000
1!
#40000
0!

modelsim(2) - vcd (dump, 查看,格式理解)的更多相关文章

  1. 【Kindle】pdf转mobi适合kindle查看格式

    pdf转mobi适合kindle查看格式 1.用到软件:福昕风腾PDF套件,切白边,PDF-Viewer,导出png图片ChainLP,图片转换为mobi文件<期间要下载kindlegen.ex ...

  2. YUV主要采样格式理解

    主要的采样格式有YCbCr 4:2:0.YCbCr 4:2:2.YCbCr 4:1:1和 YCbCr 4:4:4.其中YCbCr 4:1:1 比较常用,其含义为:每个点保存一个 8bit 的亮度值(也 ...

  3. Json格式理解

    json格式中共有三个重要符号"[","{",":" 中括号和花括号的唯一区别就是:中括号不需要key,花括号必须有key

  4. 在Modelsim波形中查看值

    在Modelsim的波形中查看值时,可以利用右键选择变量的数据类型.如果变量值为0,可以选择unsigned类型观察,可以1位显示0. 长度较大的数据以十六进制显示时,即使值为0,也依然显示为长度较长 ...

  5. 各种波形文件VCD,VPD,SHM,FSDB生成的方法

    转载---http://www.cnblogs.com/zeushuang/archive/2012/11/14/2769640.html 仿真是IC设计不可或缺的重要步骤,仿真后一般需要记录下波形文 ...

  6. 各种波形文件vcd,vpd,shm,fsdb生成的方法(zz)

    仿真是IC设计不可或缺的重要步骤,仿真后一般需要记录下波形文件,用于做详细分析和研究.说一下几种波形文件WLF(Wave Log File).VCD(Value Change Dump)文件,fsdb ...

  7. vsim仿真VHDL输出fsdb格式文件

    vsim(modelsim)仿真VHDL输出fsdb格式文件 1.Dump准备 (1) 将下列设置放到顶层testbench tb.vhd文件中[注意放置的位置:关系如图] library novas ...

  8. 《深入理解Java虚拟机》(四)虚拟机性能监控与故障处理工具

    虚拟机性能监控与故障处理工具 详解 4.1 概述 本文参考的是周志明的 <深入理解Java虚拟机> 第四章 ,为了整理思路,简单记录一下,方便后期查阅. JDK本身提供了很多方便的JVM性 ...

  9. modelsim 保存波形文件

    1. do文件记录了仿真的过程和加载的各种库. do文件的保存过程: file——>save format——>D:/modeltech_6.5b/examples/run_wave.do ...

随机推荐

  1. SQL视图与触发器

    视图(虚拟的表) select查询出来的结果集可以用as起别名当作虚拟表来使用 视图只能添加使用不能添加修改 视图不能建在其他视图上,只能一其他实体表作为基础 视图表的数据会随实体表的变动而变动 视图 ...

  2. SQL 函数集锦

    ..STUFF()用另一子串替换字符串指定位置.长度的子串.STUFF (<character_expression1>, <start_ position>, <len ...

  3. Extjs控制面板组件

    (1)aoolyTo:(id) renderTo:(id)呈现在哪个html里面,同上  id最好用"" contentEI:() 呈现哪个html元素里面,把eI内的内容呈现 ( ...

  4. Unity3D基础知识梳理

    这段时间在做Unity的项目,这差不多是我的第一次实战啊~然后公司来了实习的童鞋要学Unity,但是我一向不靠谱啊,所以只能帮他们稍微梳理下基础的东西了啊,唉~学长只能帮你们到这里了~顺便就把自己这两 ...

  5. Func<T,T>应用之Elasticsearch查询语句构造器的开发

    前言 之前项目中做Elasticsearch相关开发的时候,虽然借助了第三方的组件PlainElastic.Net,但是由于当时不熟悉用法,而选择了自己拼接查询语句.例如: string queryG ...

  6. Content is not allowed in prolog.解决方法

    将xml配置文件利用记事本另存为Anis编码的文件可以解决.

  7. 也谈谈规范JS代码的几个注意点

    也谈谈规范JS代码的几个注意点 写JS代码差不多也有两年了吧,从刚开始的“初生牛犊不怕虎”乱写一通到后来也慢慢知道去规范一下自己写的代码.这种感觉就像是代码是你的作品,你希望它保持一份不仅干净而且也优 ...

  8. OpenStack nova VM migration (live and cold) call flow

    OpenStack nova compute supports two flavors of Virtual Machine (VM) migration: Cold migration -- mig ...

  9. Android学习笔记(六)

    活动的生命周期 Android中的活动是可以重叠的,每启动一个新的活动,就会覆盖在原活动之上,然后点击Back键就会销毁最上面的活动. Android是使用任务(Task)来管理活动的,一个任务就是一 ...

  10. Storm Topology及分组原理

    Storm的通信机制,需要满足如下一些条件以满足Storm的语义. 1.建立数据传输的缓冲区.在通信连接没有建立之前把发送的数据缓存起来.数据发送方可以在连接建立之前发送消息,而不需要等连接建立起来, ...