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使用的更多相关文章

  1. Verification of WISHBONE I2C Master Core(IRUN+Simvision)

    一.前言 很久没写技术博客了,有些懈怠,生活还得继续折腾.转眼工作一年多,时间越长越发觉得自己知之甚少,当然这跟IC行业技术密集有关.用空余时间在opencores网站上下载些小的IP看看 验证下,让 ...

  2. IUS database

    仿真中的database主要存放关于signal transition以及时间点的信息. IUS中的的database包括: 1) SHM, Verilog/VHDL/mixed-language的d ...

  3. simvision1 database和invoke

    VCD是一种ASCII码的文件,可以直接用gvim来打开.有两种格式:1)Four-state,  2) Extended, 相比较而言,Extended VCD会多一些strength的信息. VC ...

  4. IUS tcl cmd

    Incisive simulator中的command-line language基于TCL. Ncsim> command [-modifier] [-options] [arguments] ...

  5. ncsim仿真VHDL

    ncsim仿真VHDL 1.文件列表 ctrl.vhd design_io.vhd tb.vhd compile.nc simulate.nc ./shm/shmtb.tcl 2. Compile你的 ...

  6. 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 ...

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

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

  8. cadence upf低功耗流程的仿真验证

    本文是记录项目过程中遇到的奇巧淫技,如有遗漏或者不足,请大家改正和补充,谢谢. 随着深亚微米技术的普及与发展,leakage功耗在整个功耗中的比重越来越大,比如45nm下,已经占到了60%以上,所以低 ...

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

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

随机推荐

  1. Tornado学习笔记12 tornado.httpserver-.非阻塞的Http服务器

    是一个非阻塞的,单线程的Http 服务器. 一般地,应用程序很少与HttpServer类直接交互,除非在进程开始时启动服务时(甚至在使用tornado.web.Applicaiton.listen时也 ...

  2. maven 项目打包 及window下部署到tomcat

    1.maven项目打包 2.将war文件拷贝到tomcat目录webapps下(不要再建目录)3.将必要的jar文件拷贝到tomcat目录libx下 war包 或jar 包 会生成到项目所在路径 的t ...

  3. .net core 基本概念

    asp.net core 是基于 .net core的,所以能够跨平台. 目前存在.NET Framework (CLR), .NET Core (CoreCLR) or Mono,可根据项目的具体情 ...

  4. 在C#用HttpWebRequest中发送GET/HTTP/HTTPS请求

    通用辅助类  下面是我编写的一个辅助类,在这个类中采用了HttpWebRequest中发送GET/HTTP/HTTPS请求,因为有的时候需 要获取认证信息(如Cookie),所以返回的是HttpWeb ...

  5. debian 安装svn apache 小记. AuthzSVNAccessFile 不生效问题.

    docker 使用docker镜像搭建svn+Apache环境 https://my.oschina.net/u/2006667/blog/637882 1,安装 apache ,svnapt-get ...

  6. HashSet

  7. 如何使用sysdba身份通过jdbc连接oracle?

    Class.forName("oracle.jdbc.driver.OracleDriver").newInstance(); Properties conProps = new ...

  8. ANDROID开发实用小工具

    分享一些 Android开发中的实用小工具,你有发现好工具吗? 来这里分享一下呗 一.find bugs 静态检查工具 http://findbugs.sourceforge.net/ FindBug ...

  9. finally类

    finally叫做最后的执行快,什么是最后的执行快?他的意思是这样的 他是写在try catch 的后面但是只能写一个,他设计这个finally的意思就是,如果try里面出错肯定会往陷阱里 面跑.没有 ...

  10. Yii源码阅读笔记(三十)

    Widget类是所有小部件的基类,开始,结束和渲染小部件内容的方法的注释: namespace yii\base; use Yii; use ReflectionClass; /** * Widget ...