来源:电子产品世界;

注:本文由NingHeChuan本人多出整理所得,原文章图片不清晰,自己整理配图后重新发表

  安装好ISE,系统已经自带了ISim仿真软件,相比于专业的仿真软件Modelsim,ISim是免费的,不用编译库,小型设计仿真速度较快,对于轻量级的设计应该是完全足够的。Modelsim作为专业的仿真软件,具备了ISim的所有功能,同时还具备了ISim不具备的功能比如波形显示,任意添加中间变量到波形图中,数据导出等。不过能够真正用好ISim,掌握住仿真技巧,你就无敌啦。

  先来看看ISim的界面吧,跟ISE的界面类似,在界面的上方是菜单栏,和一些功能菜单,界面中间是波形界面,界面的下面是控制台窗口和一些其他功能窗口,界面的左侧包含了仿真的工程文件(Instances and Processes Name),对应文件的输入输出端口(Objects)等,这些窗口都是可以自由拖动的,可以将窗口的位置摆放到一个自己习惯的位置,如果没有这些窗口,可以点击菜单栏的View -> Panels 勾选需要显示的窗口即可。

技巧一:更改数据显示格式

  ISim在仿真时默认是二进制格式,为了方便显示,我们可以更改其显示的格式,右键单击需要更改显示格式的数据上,Radix -> 选择合适的格式即可(如图2所示),Binary(二进制),Hexadecimal(十六进制),Unsigned Decimal(无符号十进制数),Signed Decimal(有符号十进制数),Octal(八进制),ASCII(ASCII码)。如果发现高低位不对,可以选择 Reverse bit order(反转bit顺序,即高位和地位对换)。

  对于1bit数据,有些人不喜欢看一个孤零零的线(类似于图1中的CLK_62M5),可以选中这个数据右键单击,选择New Virtual Bus,然后修改名字为原来的信号名字,以防忘记。如图3所示,为修改后的数据,将CLK_62M5修改成了New Virtual Bus形式,将datain更改成了无符号十进制数。

  

技巧二:查看中间变量

  有些时候由于沟通不到位,导致模块与模块之间的连接出现问题,则需查看中间变量来确定问题所在。

  在Instances and Processes Name 窗口中选择对应的非顶层模块(中间模块),会在Objects中出现可以添加到波形文件的信号名字,选择需要添加信号,可以直接拖到波形文件列表中,也可以右键添加至波形文件列表中(如图4所示),或者按(Ctrl+W)添加对应信号到波形文件中。

  为了方便再次仿真,能够看到这些中间变量,而不用手动添加(对更改数据显示格式也适用),可以保存波形文件,File -> Save As 输入你想要的名字即可,关闭ISim时记得保存波形文件。再次仿真时,ISim不会直接调用你保存的波形文件,而是一个defalut.wcfg,此时只需通过File->Open打开你保存的波形文件,然后重新仿真即可。

技巧三:断点调试

  断点调试是一个十分方便的功能,可以查看指定位置是否有错误,方便debug程序。相对与其他仿真,FPGA是并行执行,更多的时候是查看波形是否正确,通过波形发现错误,进而定位到对应的语句或者状态,然后断点查找错误。

  在Instances and Processes Name窗口中,双击对应模块,则可打开对应的.v文件,然后在需要的地方加入断点,此时点击reset(Ctrl+Shift+F5)按钮,然后点击run all(F5)运行,即可运行到断点处。此时可以点击单步(step 快捷键F11)执行按钮,查看是否有bug。

 

技巧四:产看Memory

  很多时候我们需要查看我们的存储空间是否正确的存储了我们所需的值;有些时候会遇到,明明给了使能,却没有数据输出,或者数据输出时错误的,此时,若能够真实的看一看存储器的状态,然后在波形文件中添加入存储器相关的变量,就很有可能发现问题了。

  点击Memory窗口,如果没有发现Memory窗口,可以点击菜单栏的View -> Panels 勾选,然后双击需要显示的内存空间,则可打开对应的memory空间。

默认显示的数值为二进制,可以修改数据显示的格式(二进制、十进制有符号数、十进制无符号数、十六进制、八进制、ASCII码),同时也可以修改地址显示的格式。如果要查找某个地址的值,只需在地址栏中输入这个值,按回车即可。

技巧五:添加块

  添加块不是添加模块,而是添加一个实心方块或者分组,可以将不同模块之间的信号,分个开,方便查看。如图8所示。

  这样添加分割线和分组后看起来就很方便了,一眼就看清楚了信号的作用以及所在模块的,十分方便。

  点击波形文件的Name 空白处,右键 –> New Divider/New Group,即可添加分割和分组,当然也可以选中需要加入分组的信号,然后右键 – > New Group然后修改为相应的名字即可,如图9所示。

技巧七:测量时间

  在有些时候,需要测量两个信号之间的时间间隔,可以通过如下方式来实现。

  如果只是简单的测量两个边沿的时间间隔,如图10所示,可先按着鼠标左键选中一个边沿,然后拖动鼠标到另一个边沿,此时在波形的下面将出现时间轴,则可测量两个上升沿之间的时间。

                

  如果需要测量的时间太多,可以添加Marker,鼠标左键单击击到要加入标记的地方,然后点击标记按钮,或者右键 –> Markers->Add Marker,此时并不能出现时间轴,鼠标单击Marker线,蓝色的线将变成白色,并以此为时刻0点,此时就可以看到时间间隔啦,如图11所示。

技巧八:重仿真

  在编写verilog模块后,很重要的一部分就是对所编写的模块进行仿真。而在仿真过程中,很重要的一部分就是观察波形。这里所谈的技巧其实是对于我个人而言,可能大部分人都已经知道。但还是记录下来,算是对我自己的提醒吧。

  现在想想还是觉得好笑,以前每次打开波形窗口的时候,都是点击下图的Simulate Behavioral Model.每次修改了代码,都是关掉原来的波形窗口,然后再重新点击打开,麻烦程度不言而喻(好吧,当初因为程序简单,其实还不觉得很麻烦。)

  现在明白了,对于这种情况,肯定是会有简单的操作的,否则这用户体验也太差了。

  当然,第一次仿真打开波形窗口时,还是老方法,点击上图的Simulate Behavioral Model。添加内部信号以及修改数值进制后结果如下图(这里采用的是一个FIFO读写程序,程序不是这里需要在意的问题,我们只关心软件的操作)。

  下面我们通过修改din[3:0]的初始值来反映这个过程,由上图可知,din[3:0]的初始值为6.接下来我把代码中din[3:0]的初始值改为0后重新观察波形,那该如何操作呢?千万不要像我以前那么傻的关掉现有窗口然后重新仿真打开了。这样我们又要重新添加内部信号以及修改数值显示了。

方便的步骤应该是,首先,将该波形保存,这部很简单就不贴图了,保存的其实就是你对该窗口的各种配置,哪怕以后你重新打开软件,也可以通过打开之前保存的波形配置来查看仿真波形,而不用重新配置了。

保存后,修改完代码(这里我把din[3:0]的初始值改为0,另外,代码要记得保存,保存后代码才能生效),然后点击波形窗口的re-launch(如果之前没进行保存操作的话,点击re-launch后软件也会提示你保存的).就可以看到仿真波形发生了变化,din[3:0]的初始值由之前的6变成了0.

  另外,关于re-launch边上的那几个按钮,也都是很有用处的,尤其仿真时间设置的,甚至有的时候还会因为这些设置的问题导致老是不能出现预期结果,这些操作很简单,就不一一解释了,大家稍微用用就知道了。

  注意:当你每次修改完test_bench文件后,就不用关闭isimulator,重新打开,这样可以提高仿真的效率。

技巧九:改变波形颜色

  在进行比较大的工程进行仿真时,信号比较多,仿真起来不容易查看波形,所以可以选中信号右键点击 signal color,可以把你的信号设置成各种你喜欢的颜色,这样便提高了仿真的效率!

技巧十:重新打开之前配置好的仿真分组

我们为了仿真方便,一次仿真后将仿真所配置的分组和文件保存到指定文件夹,为了后面再次打开。

如下图,右键点击Simulate Behavioral Model,选择Process Properties。

勾选Use Custom Waveform Configuration File这一选项

在下面那一栏添加你刚才保存的仿真文件路径,完成后点击apply。

如下图,右键点击Simulate Behavioral Model,点击Run ,这样你就可以打开自己原来所配置的仿真分组文件了。

最后

  仿真真的是很重要,我学习了一年FPGA才真正算的是仿真能力入了门,如果对于一个工程仿真做的好的话,可以节省你很多时间的。这是我最近用的vivodo中的Isim做的仿真,算是充分利用了仿真工具,这么久以来,这可能是我做过的最漂亮的仿真了!

转载请注明出处:NingHeChuan(宁河川)

个人微信订阅号:NingHeChuan

如果你想及时收到个人撰写的博文推送,可以扫描左边二维码(或者长按识别二维码)关注个人微信订阅号

知乎ID:NingHeChuan

微博ID:NingHeChuan

原文地址:http://www.cnblogs.com/ninghechuan/p/6214706.html

【转】Isim——基本技巧的更多相关文章

  1. Isim你不得不知道的技巧(整理)

    来源:电子产品世界: 注:本文由本人多出整理所得,原文章图片不清晰,自己整理配图后重新发表 安装好ISE,系统已经自带了ISim仿真软件,相比于专业的仿真软件Modelsim,ISim是免费的,不用编 ...

  2. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  3. 前端极易被误导的css选择器权重计算及css内联样式的妙用技巧

    记得大学时候,专业课的网页设计书籍里面讲过css选择器权重的计算:id是100,class是10,html标签是5等等,然后全部加起来的和进行比较... 我只想说:真是误人子弟,害人不浅! 最近,在前 ...

  4. 前端网络、JavaScript优化以及开发小技巧

    一.网络优化 YSlow有23条规则,中文可以参考这里.这几十条规则最主要是在做消除或减少不必要的网络延迟,将需要传输的数据压缩至最少. 1)合并压缩CSS.JavaScript.图片,静态资源CDN ...

  5. 工欲善其事,必先利其器 之 VS2013全攻略(安装,技巧,快捷键,插件)!

    如有需要WPF工具的朋友可以移步 工欲善其事,必先利其器 之 WPF篇: 随着开发轨迹来看高效WPF开发的工具和技巧 之前一篇<c++的性能, c#的产能?!鱼和熊掌可以兼得,.NET NATI ...

  6. 15个关于Chrome的开发必备小技巧[译]

    谷歌Chrome,是当前最流行且被众多web开发人员使用的浏览器.最快六周就更新发布一次以及伴随着它不断强大的开发组件,使得Chrome成为你必备的开发工具.例如,在线编辑CSS,console以及d ...

  7. Git小技巧 - 指令别名及使用Beyond Compare作为差异比较工具

    前言 本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率.至于使用命令还是GUI(Tortoise Git或VS的Git插件)就不在此讨论了,大家根据自己的的喜好选择就好.我个人是比较 ...

  8. 【工具使用】mac电脑使用技巧

    本文地址 分享提纲: 1.  mac命令行和finder的交互 2. 一些mac的插件 3. 一些开发的配置 1.mac命令行和findder交互           1)命令行中打开当前文件夹: o ...

  9. Function.prototype.toString 的使用技巧

    Function.prototype.toString这个原型方法可以帮助你获得函数的源代码, 比如: function hello ( msg ){ console.log("hello& ...

随机推荐

  1. vuex传递数据的流程

    当组件修改数据的时候必须通过store.dispatch来调用actions中的方法,当actions中的方法被触发的时候通过调用commit的方法来触发mutations里面的方法,mutation ...

  2. x64下进程保护HOOK

    目录 x64(32)下的进程保护回调. 一丶进程保护线程保护 1.简介以及原理 1.2 代码 1.3注意的问题 二丶丶回调函数写法 2.1 遇到的问题. 2.2 回调代码 x64(32)下的进程保护回 ...

  3. shell 小数比较大小

    a=1.6b=6.1c=`echo "$a > $b" | bc`然後,如果 $c 是 1 ,那就成立,否則不成立. 参考: http://ju.outofmemory.cn ...

  4. 新款戴尔笔记本win10系统改win7 安装教程

    下载U盘启动制作工具 及戴尔DELL ghost win7 旗舰版GHO 文件 下载地址:http://pan.baidu.com/s/1c17JqpU  插入制作好的U盘启动盘,开机按F2进入BIO ...

  5. Content-type解析

    一.是什么? 是Http的实体首部字段,用于说明请求或返回的消息主体是用何种方式编码,在request header和response header里都存在. Content-Type(内容类型),一 ...

  6. Android Studio 之 LiveData 的配合使用,底层数据变化,自动通知界面

    Android Studio 之 LiveData 的配合使用,底层数据变化,自动通知界面 viewModelWithLikeData.getLikeNumber().observe(this, ne ...

  7. Net core学习系列(七)——Net Core中间件

    一.什么是中间件(Middleware)? 中间件是组装到应用程序管道中以处理请求和响应的软件. 每个组件: 选择是否将请求传递给管道中的下一个组件. 可以在调用管道中的下一个组件之前和之后执行工作. ...

  8. 暗黑战神! Unity3D网游ARPG实战案例

    前面开发了几个单机小游戏,该是时候挑战一下网络游戏方面的开发了! 3D网游ARPG实战案例(第二季),使用Unity2017.3版本制作 内容包括 服务端部分 1.网络通信编码,协议及传输 2.数据驱 ...

  9. spark 监控--WebUi、Metrics System(转载)

    转载自:https://www.cnblogs.com/barrenlake/p/4364644.html Spark 监控相关的部分有WebUi 及 Metrics System; WebUi用于展 ...

  10. Java13新特性 -- 新增 移除 废弃 已知问题等

    新增 添加FileSystems.newFileSystem(Path, Map<String, ?>) Method 新的java.nio.ByteBuffer Bulk get/put ...