modelsim仿真使用到vivado的IP,该如何使用!

modelsim仿真时,如果使用到了vivado的IP就会报错,本次就告诉大家如何将vivado的IP添加到modelsim中直接仿真。

一、生成ini文件以及IP打包

打开vivado,点击上方的Tools-->Compile Simulation Libraries得到如下界面

simulator:选择相应的仿真器,本次讲解的时modelsim,所以该选什么你们懂的。

language:选择语言,自行判断。

library:一个相关的一个是相关的,也就是你调用的IP是相关的,没有调用的就是不相关的。总之你不理解的话,就选All。

family:选择你所用的板子,同理不知道什么板子的就全选。

compiled library location:选择IP包和ini文件的存储位置(注意:要记清这个位置,而且最好是在modelsim安装的地方)。

simulator executable path:选择modelsim启动程序,找到你modelsim安装的位置里面有win64类似的启动程序。比如我的位置在这里

后面的几个就不解释了,用不到!

勾选的话就选第一个就行,我把第二个也选了是因为我已经生成了,所以需要覆盖一下。

然后点击compile就可以了。那之后就是慢慢等了,大概要个半个多小时的时间。

二、综合IP与ini的关系

1.修改权限

用文本方式打开modelsim安装下的modelsim.ini(后面简称为ini1),同时记得在属性里面修改一下它的权限,把它改为可改写。

2.修改

然后打开,找到library

同时打开我们刚刚生成的ini,也就是上面我让你记住的文件位置。里面也会有一个modelsim.ini(后面就简称为ini2

打开后别弄混淆了哦,两个可是长得很像的,也同样找到相应的位置library位置,将ini2中library下面,到DefineOptionset中间的数据复制到ini1相同的位置(要覆盖里面的library到DefineOptionset)。这一步慢慢看懂看清楚,错了就要重来的喔!

3.检查

弄完之后你就可以检查一下modelsim有没有上面的IP,打开modelsim点开library,就可以看到相应的IP。但还没完,有后续的!

三、加入数据

1.找到IP

打开你vivado生成的程序文件夹,找到你想要仿真的IP,复制 xxx_sim_netlist.v,如果你用的是VHDL你就赋值下面那个。

2.存储IP

将IP粘贴到你的仿真程序文件夹里,再和你的仿真程序一起加到modelsim里(modelsim创建和加入文件应该不需要我交吧,需要的留言,我看看有多少,后面再补充),我用的是FIFO示例

3.加入库

将程序compile之后,点simulate-->start  simulate-->Libraries-->add...

向里面加入以下五个库secureip、simprims_ver、unifast、unifast_ver、unimacro、unimacro_ver、unisim、unisims_ver。这些库在刚刚vivado生成的文件夹里面!加完之后就可以在work里面找到一些数据命名的文件。

然后你就可以点击ok仿真了。

四、错误

在仿真文件里面例化一下glbl,这样可以避免时钟报错,还有modelsim是不支持PS端的仿真,别瞎搞!另外其他报错,就是你需要重新添加一下上面的库,因为重新打开貌似需要重新添加库。还有vivado生成的那些文件不要删除、也不要移动或者改名字,改了那就改回来,要么你就从头开始!

后续有问题就留言吧,或者私聊,觉得有用就动动小手点个赞+收藏+关注,后续会出一些更多有意义的操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/457366.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Flink入门修炼】1-2 Mac 搭建 Flink 源码阅读环境

在后面学习 Flink 相关知识时,会深入源码探究其实现机制。因此,需要现在本地配置好源码阅读环境。 本文搭建环境: Mac M1(Apple Silicon)Java 8IDEAFlink 官方源码 一、 下载 Flink 源码 github 地址:h…

日历功能——C语言

实现日历功能&#xff0c;输入年份月份&#xff0c;输出日历 #include<stdio.h>int leap_year(int year) {if(year % 4 0 && year % 100 ! 0 || year % 400 0){return 1;}else{return 0;} }int determine_year_month_day(int *day,int month,int year) {if(mo…

【刷题日记】最长定差子序列

给你一个整数数组 arr 和一个整数 difference&#xff0c;请你找出并返回 arr 中最长等差子序列的长度&#xff0c;该子序列中相邻元素之间的差等于 difference 。 子序列 是指在不改变其余元素顺序的情况下&#xff0c;通过删除一些元素或不删除任何元素而从 arr 派生出来的序…

挑战杯 python+深度学习+opencv实现植物识别算法系统

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于深度学习的植物识别算法研究与实现 &#x1f947;学长这里给一个题目综合评分(每项满分5分) 难度系数&#xff1a;4分工作量&#xff1a;4分创新点&#xff1a;4分 &#x1f9ff; 更多…

ElastAlert 错误日志告警

文章目录 前言一、ElastAlert 概览1.1 简介1.2 ElastAlert 特性 二、ElastAlert 下载部署2.1 安装 Python3 环境2.2 下载 ElastAlert2.3 部署 ElastAlert 三、接入平台3.1 对外接口层3.2 服务层 前言 ElastAlert 是 Yelp 公司基于 python 开发的 ELK 日志告警插件&#xff0c;…

JavaWeb后端——控制反转IOC/依赖注入DI

控制反转&#xff1a;why&#xff0c;目标是要做到控制反转 依赖注入&#xff1a;how&#xff0c;如何实现控制反转&#xff0c;控制反转有很多方法&#xff0c;依赖注入是其中一种方法 控制反转&#xff08;Inversion of Control, IoC&#xff09;和依赖注入&#xff08;Depe…

JavaEE企业级应用软件开发—Spring框架入门学习笔记(一)

一、认识框架 实际开发中&#xff0c;随着业务的发展&#xff0c;软件系统变得越来越复杂&#xff0c;如果所有的软件都从底层功能开始开发&#xff0c;那将是一个漫长而繁琐的过程。此外&#xff0c;团队协作开发时&#xff0c;由于没有统一的调用规范&#xff0c;系统会出现大…

Java+SpringBoot:构建稳定高效的计算机基础教学平台

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java实战 |…

ORM模型类

模型 创建两个表 创建模型类 from django.db import models# Create your models here. class BookInfo(models.Model):name models.CharField(max_length10, uniqueTrue) # 书名pub_date models.DateField(nullTrue) # 发布时间read_count models.IntegerField(default…

【力扣 51】N 皇后(回溯+剪枝+深度优先搜索)

按照国际象棋的规则&#xff0c;皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 给你一个整数 n &#xff0c;返回所有不同的 n 皇后问题 的解决方案。 每一种…

【自然语言处理-工具篇】spaCy<1>--介绍及安装指南

目录 前言 安装指南 pip conda spaCy升级 总结 前言 spaCy是一个开源的自然语言处理库,用于处理和分析文本数据。它提供了许多功能,包括分词、词性标注

三网码支付系统源码,三网免挂有PC软件,有云端源码,附带系统搭建教程

搭建教程 1.先上传云端源码 然后配置Core/Config.php文件里面数据库信息注改&#xff1b;数据库帐号密码 2.云端源码里面Core/Api_Class/Instant_Url_List.php文件配置终端地址注改&#xff1b;第4 http://终端地址/ 3.导入云端数据库 账号admin 密码123456注改&#xff1…