simvision使用
Access Design Source Code:
1)通过file---open来打开,
2)通过send to source viewer来看,
双击信号,进行driver的trace,显示在左侧的driver/load tab或者直接转到下一个scope的source code file
查找:
1)右侧tool bar
2)edit-----search,
signal的选择,
1)单击或者框选,
2)select---scope/port/signal
信号右键的功能:
1) Follow signal,相当于verdi中的connection功能。
2) Trace Driving logic/Trace loading logic
3) send to waveform/watch/Schematic/Design/Design file window
4) Create Probe,
5) Show Value
6) Set Force/Release Force/Deposit Value
在进行trace的时候,如果对象是Verilog的register或者VHDL的 variable,直接进入相应的source code
如果对象是Verilog的net或者VHDL signal,进入左侧的sidebar
在source code中可以直接进行edit,然后revoke来直接进行编译仿真。
Access Design Objects
使用design browser tab,通过filter进行scope的选择。
使用design search tab,主要来选择signal(input,output,inside)/transaction/assertion等
Creating and Managing Probes
通过probe signal,可以在仿真过程中保存signal的值,之后可以直接查看probe的signal的值。
当用户向Waveform window添加signals和scopes时,Simvision自动添加probe。
在创建probe的过程中,需要勾选include task/function,include sub-scope,disable/enable add to waveform
可以在simvision---show---probes中查看已经打开的probe,也可以进行删除操作。
probe不能对在仿真中new的变量添加,不知道probe和watch window的应用区别
Setting and managing Breakpoints
simvision中支持的breakpoint的添加方式,
1) time breakpoint, stop at specify time or time interval(delta cycle)
2) signal breakpoint, stop based on a design object
3) line breakpoint, stop at specified line
4) Condition breakpoint,
通过simulation----Set BreakPoint---time来设置,
使用breakpoint的前提是,在编译时,必须添加-linedebug
Changing and Monitoring the value of an Object during Simulation
在verilog中只有force和deposit两种方式。前提是在elaborate时,必须有-access +w的选项。
不能force的design object:
1) Verilog memory or memory element
2) bit-select或者part-select verilog register/wire
可以通过Simulation----Show-----Forces来显示当前已有的force
不能deposit的object:(memory可以)
1) analog signal
Controlling the Simulation
可以通过simulation bar来进行simulation的控制,

reset simulation:simulation time到0,设置的breakpoint和probe保留,但是force和deposit的动作都被移除。
reinvoking simulation:改变source code之后,通过reinvoke来启动simulator。
Saving and Restarting a simulation checkpoint
simulation的checkpoint可以保存design在某个simulation time的所有状态,包括:已经打开的database,设置的breakpoint
之前某个时间点的force和deposit的信号。
checkpoint的保存对large simulation的debug十分有用。
保存一个simulation check point
选择simulation---save checkpoint,点击Run Clean,为了将当前时间点的sequential code执行完毕。
从check point重新开始:
选择simulation---Restart from checkpoint,
Debugging at the Delta Cycle Level
实际仿真时,并不能做到完全并行,simulator通过将每个时间点分为delta cycle并且先后调用进程来进行模拟。
在波形中,只能反映的是每个time point的最终的信号值。
delta cycle的执行过程:红色表示会发生迭代,蓝色表示最终的跳转。


Simulation Cycle Debugger的打开:
Windows---Tools---Simulation Cycle Debug
打开之后,有一个state diagram表示当前执行的point
另一个window,表示即将执行的point
直接点击某个statement就可以打开Source Browser window
Cycle Debugging的选项,

Debugging API Applications
DPI/PLI这类的API可以在simulator中,调用C/C++/SystemC这样的task。
SimVision提供GDB的环境,来直接debug API application, (环境中的gcc必须与IUS中的一致)
当调用API application时,compiling和elaborate HDL design需要加额外的option,
Eg:API调用DPI task,必须在elaborator中加入 -dpiheader,并指定一个.h文件来declares DPI task。
在simulation---systemc/c++/c debug选项,在console中加入gdb tab,并且Source Browser中加入GDB 控制。
simulator和GDB之间的交叉控制,主要通过breakpoint来设置,
Tracing Paths with the Trace Signals Sidebar
trace signals sidebar可以使能driving/loading logic,并自动的tarce所有的X value的path。
使用simvision进行driver trace操作时,simvision可以显示出force的操作,并给一个较高的grade。
为了在waveform中加入更多的内容,可以
1) probe signal,来加入更新element到波形中。
2) 在进行仿真时,加入-event option,提供更加精确的sequence time。
simvision使用的更多相关文章
- Verification of WISHBONE I2C Master Core(IRUN+Simvision)
一.前言 很久没写技术博客了,有些懈怠,生活还得继续折腾.转眼工作一年多,时间越长越发觉得自己知之甚少,当然这跟IC行业技术密集有关.用空余时间在opencores网站上下载些小的IP看看 验证下,让 ...
- IUS database
仿真中的database主要存放关于signal transition以及时间点的信息. IUS中的的database包括: 1) SHM, Verilog/VHDL/mixed-language的d ...
- simvision1 database和invoke
VCD是一种ASCII码的文件,可以直接用gvim来打开.有两种格式:1)Four-state, 2) Extended, 相比较而言,Extended VCD会多一些strength的信息. VC ...
- IUS tcl cmd
Incisive simulator中的command-line language基于TCL. Ncsim> command [-modifier] [-options] [arguments] ...
- ncsim仿真VHDL
ncsim仿真VHDL 1.文件列表 ctrl.vhd design_io.vhd tb.vhd compile.nc simulate.nc ./shm/shmtb.tcl 2. Compile你的 ...
- How to view assertions in the Verdi waveform viewer
In the Cadence Simvision waveform viewer, I can see every assertions listed as a hierarchical signal ...
- 各种波形文件VCD,VPD,SHM,FSDB生成的方法
转载---http://www.cnblogs.com/zeushuang/archive/2012/11/14/2769640.html 仿真是IC设计不可或缺的重要步骤,仿真后一般需要记录下波形文 ...
- cadence upf低功耗流程的仿真验证
本文是记录项目过程中遇到的奇巧淫技,如有遗漏或者不足,请大家改正和补充,谢谢. 随着深亚微米技术的普及与发展,leakage功耗在整个功耗中的比重越来越大,比如45nm下,已经占到了60%以上,所以低 ...
- 各种波形文件vcd,vpd,shm,fsdb生成的方法(zz)
仿真是IC设计不可或缺的重要步骤,仿真后一般需要记录下波形文件,用于做详细分析和研究.说一下几种波形文件WLF(Wave Log File).VCD(Value Change Dump)文件,fsdb ...
随机推荐
- T4学习资料
网址:http://www.olegsych.com/2007/12/text-template-transformation-toolkit/
- windows环境 andorid JNI开发
1.下载并安装GNUstep 下载地址:http://www.gnustep.org/experience/Windows.html 安装文件 a.GNUstep MSYS System b.GN ...
- 如何记录搜索引擎爬行记录php版
写博客也有一段时间了,为什么搜索引擎迟迟不收录你的页面呢?想知道每天都有哪些蜘蛛“拜访”你的网站吗?作为一名网站长,有必要知道每天都有哪些蜘蛛爬行过你的网站,以便于了解各搜索引擎蜘蛛爬行频率,对网站进 ...
- oracle数据导入/导出
Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据 ...
- JAVA中的TreeSet
TreeSet简介 TreeSet是一个有序的集合,它的作用是提供一个有序的Set集合,它继承于AbstractSet抽象类实现了NavigableSet<E>, Cloneable, j ...
- Get请求中文乱码的几种解决方式
1.将字符串转码:new String("xxxxx".getBytes("iso-8859-1"),"utf-8") 这种 ...
- win7下wndows virtual pc 2007 装xp比新版本的 Windows virtual pc 好用
2007下装xp虚拟机启动快,支持拖放.
- python - socket - client端指定ip和端口
问题描述: 在设备中有3个NI, ip分别为192.168.1.5/6/7.其中本端192.168.1.6同对端192.168.1.10建立了一个tunnel. 我希望测试tunnel连通性, 对端起 ...
- PHP 模拟 HTTP 基本认证(Basic Authentication)
当某个页面需要认证才能进行访问时,接到请求后服务器端会在响应头中发送一个 WWW-Authenticate 首部(用来标识认证安全域),语法为 WWW-Authenticate:Basic relam ...
- 自动化小应用系列----利用selenium启动多个独立的浏览器
在我们测试的时候对于同一个系统,我们往往需要登陆多个不同的账号,由于cookie的原因,我们只能退出一个账号在登陆另外一颗账号,非常麻烦.我们可以使用selenium来启动浏览器,这样每个浏览器的属性 ...