• 令新手头疼的modelsim库编译


    估计很多人买了CB哥的书来看吧,他们在学习modelsim仿真的过程中可能遇到过明明是按照书上的步骤添加器件库的了,但还是出现如下的错误:

    仿真出错_thumb[4]

    首先,我想说的是CB哥书上的modelsim-altera10.1d是随QuartusII一起安装的,它已经编译了altera的器件库。它是一个免费版的仿真工具,不需要破解,当然它的功能不是最强大的,仿真速度也不是最快的,但已经可以满足我们一般的仿真了。有些人可能装了速度较快的SE版本的不带altera器件库的modelsim,这时器件库的问题就来了,尤其是那些新手。为了搞定上图的错误,在这里给出了一种解决办法,希望对大家有所帮助。

    (1)在我们的设计中经常会用到宏定义模块,这是就需要我们添加altera器件库,其中必要的编译资源文件有quartusII安装目录/eda/sim_lib下的220model.v和altera_mf.v(以Verilog描述电路),另外还常用到PLL,因此还要目标器件库,如quartusII安装目录/eda/sim_lib下的cycloneive_atoms.v等。接下来,让我们开始编译我们指定的器件库。以上一篇博文安装的modelsim se 6.5g来进行库的编译,首先在modelsim的安装目录下新建altera文件。

    编译正确_thumb[6]

    (2)启动modelsim仿真软件,点击“File”--->“Change Directory…”,在弹出的对话框中选择刚刚在modelsim安装目录下新建的altera文件,点击“确定”。

    lujing_thumb[2]

    (3)点击“File”--->“New”--->”Library…”,输入库的名字:220model以新建一个库,点击“OK”。

    新建库_thumb[2]

    (4)点击“Compile”--->”Compile…”,在弹出的对话框中,选Library为刚刚新建的220model,查找范围为quartusII安装目录/eda/sim_lib,选择220model.v,然后点击“Compile”,“Done”。

    编译库1_thumb[2]

    (5)同理,在altera文件下新建库文件altera_mf和cycloneive_atoms,然后将quartusII安装目录/eda/sim_lib下的编译资源文件altera_mf.v和cycloneive_atoms.v编译到相应的库文件。

    新建库1_thumb[2]

    新建库2_thumb[2]

    新建库3_thumb[2]

    新建库4_thumb[2]

    (6)接着将上面编译的库添加到modelsim.ini文件中。右击modelsim安装目录下的modelsim.ini文件,选择“属性”,去掉只读。

    配置1_thumb[3]

    去掉只读_thumb[2]

    (7)打开modelsim.ini文件,添加如下内容,然后关闭文件,并加上只读属性。

    添加1_thumb[3]

    只读_thumb[2]

    (8)以后打开modelsim,都可以看到我们添加的库。

    库_thumb[3]

    (9)接下来,以CB哥的Sobel边缘检测例程为例进行仿真,看是否还出现之前的错误。打开modelsim工程,点击“Compile”--->”Compile All”,结果出现以下问题:

    找不到文件1_thumb[2]

    (10)根据错误提示可知,找不到源文件,原因是我改变了modelsim工程的路径,从而无法找到源文件。解决方法是将工程中的源文件删掉(切不可勾选从磁盘中删除),重新加载源文件。

    删除源文件_thumb[2]

    删除源文件1_thumb[2]

    添加源文件1_thumb[2]

    添加源文件2_thumb[2]

    (11)从新全编译源文件,发现编译都通过。

    编译通过1_thumb[2]

    (12)点击“Simulate”--->”Start Simulation…”,由于本设计中使用了Shift_RAM和PLL,需在Libraries选项卡下添加搜索库220model、altera_mf和cycloneive_atoms。

    搜索库1_thumb[2]

    搜索库2_thumb[2]

    (13)切换到Design选项卡,展开库work,选中Video_Image_Processor_TB,点击“OK”开始仿真。

    仿真1_thumb[2]

    (14)结果发现没有信号出来,由编译信息可以设计被优化了。

    优化1_thumb[3]

    (15)解决的办法是将modelsim.ini文件的“VoptFlow = 1”改为“VoptFlow = 0”(修改之前记得把modelsim.ini属性去掉,修改完后把只读改回来)。

    解决优化_thumb[3]

    (16)有时还会出现下面的问题,我个人的解决方法是重新建立工程,不知大家是否有更好的办法(希望互相告知)。

    重建工程_thumb[2]

    (17)重建工程后,再进行仿真就大功告成了。

    成功_thumb[2]

    我晕,现在已经凌晨2:30了,明早8:30还要实习呢!该睡了,88,晚安*^_^*

  • 相关阅读:
    websword-update-notification
    SQL Server2005+、MySQL、Oracle 数据库字典生成工具
    fullcalendar小结
    Oracle 表空间查询
    Oracle正则表达式
    深度学习高性能集群(HPC)提交作业总结
    读《Oracle DBA工作笔记》知识点-获取创建语句
    discuz x3.1 整站搬家换域名攻略
    读《Oracle PLSQL 程序设计第五版》创建包规范和包体
    pls-00329非法引用表结构
  • 原文地址:https://www.cnblogs.com/CrazyBirdLin/p/4331199.html
Copyright © 2020-2023  润新知