Quartus同Modelsim联合仿真

本文介绍了FPGA开发环境(quartus和ise/vivado)与modelsim的联合仿真。以quartus为例,详细说明了安装集成包、新建工程、设置仿真工具、配置modelsim路径、生成并关联testbench等步骤,最后在quartus调出modelsim进行仿真。

我看到网上很多人在问如何用modelsim仿真,研究了一番如何在modelsim建立工程,如何关联库之后便放弃了,其实我也遇到过这样的问题,还好有大神指导,知道了联合仿真的概念,少走了不少弯路,下面我就向大家介绍一下FPGA开发环境同modelsim的联合仿真。

所谓FPGA开发环境其实就是quartus和ise/vivado,quartus 现在已经有了集成安装包,直接安装就好了,ise/vivado还是要外部调用。

  1. quartus和modelsim的联合仿真

首先安装quartus和modelsim的集成安装包,我装的是quartus prime 16.0。

然后新建工程,可以新建的过程中在EDA TOOL Settings时设置Simulation 为Modelsim-Altera。如下图

或者在工程建立完成后在Assignments->Settings->EDA TOOL Settings设置Simulation 为Modelsim-Altera。如下图

然后再设置一下modelsim的路径,一般集成环境都会自动配置,以防外一还是配置一下,Tools->Options->General-> EDA TOOL Options->Modelsim-Altera 点击后面浏览选择modelsim路径,我是装在C盘的。如下图

接下来就要配置关联的testbench了,可以自己写testbench,建议还是用quartus自动生成,前提是你综合完成。

Processing->Start->Start Test Bench Template Write,点击就会在你的工程目录下自动生成一个simulation的文件夹,里面有modelsim文件夹,下面就有一个自动生成的一个顶层文件名.vt的test bench文件。

生成test bench后在Assignments->Settings->EDA TOOL Settings->Simulation配置关联信息。如下图

选中Compile test bench,点击Test Benches。

点击New。

系统自动生成的test bench 一般是顶层文件名_vlg_tst,例化名是i1,这些都可以改,我一般是将test bench 模块名改为顶层文件名_sim, 例化名改为uut。

仿真时间可以不填,我一般是填个10us,然后配置test bench路径,设置后点击add,然后一路ok,就设置完成了。

最后就是在quartus 调出modelsim了,Tools->Run Simulation Tool->RTL Simulation。等待一会,modelsim波形窗口就会弹出来了,如果没有反应,就返回去检查一下配置。

 

### QuartusModelSim联合仿真的VHDL配置教程及设置方法 #### 1. 安装与环境准备 为了实现QuartusModelSim之间的联合仿真,需先确保两者已正确安装并相互兼容。具体步骤如下: - **确认版本匹配**:QuartusModelSim的版本应保持一致或经过官方验证支持[^2]。 - **路径配置**:在Quartus中添加ModelSim可执行文件所在的路径。通过`Tools -> Options -> EDA Tool Settings`完成此操作[^3]。 #### 2. 创建Quartus工程项目 新建一个Quartus工程用于存储设计源码及相关文件。以下是主要步骤: - 打开Quartus软件,选择`File -> New Project Wizard`启动向导。 - 设置顶层实体名称,并指定工作目录位置[^4]。 - 添加所需的VHDL源文件到项目中。 #### 3. 配置Testbench文件 Testbench是模拟电路行为的关键部分,在Quartus中可以通过以下方式生成: - 使用内置工具自动生成初始Testbench框架。 - 或者手动编写`.vhd`格式的激励文件来驱动被测模块的行为[^1]。 #### 4. 启动联合仿真过程 当一切就绪后,按照下面的方法运行仿真分析: - 在Quartus界面下切换至Simulation视图模式。 - 导航至`\simulation\modelsim\`子目录寻找对应的测试平台脚本(.vt扩展名)。 - 对选定的.vt文件应用适当属性调整;例如经由菜单项`Assignments->Settings->Simulation`定义输入/输出端口映射关系等参数设定。 #### 5. 运行ModelSim查看结果 最后一步是在独立窗口里利用ModelSim图形化界面直观展示信号变化趋势: - 如果之前已完成必要关联,则可以直接双击目标条目触发外部程序加载动作。 - 利用时间轴标记功能定位感兴趣的时间片段进一步审查细节特性。 ```vhdl -- Example of a simple VHDL testbench structure. library IEEE; use IEEE.STD_LOGIC_1164.ALL; entity tb_example is end entity tb_example; architecture Behavioral of tb_example is -- Component declaration and signal definitions here... begin process begin wait for 10 ns; -- Simulate some delay before applying stimulus -- Apply stimuli to DUT ports as needed... wait; -- End the simulation after all tests are done end process; end architecture Behavioral; ```
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

superyan0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值