Vivado与Synplify联合设计FPGA

article/2025/9/18 6:49:20

这篇文章主要记录近几天在使用Vivado以及Synplify工具进行FPGA的Synthesis、Implementation、以及BitStream出现的相关问题。

一、工具使用

RTL代码编辑:修改Vivido内置编辑器为VSCode编辑器,个人习惯,偏好VSCode。修改内置编辑器:Tool -> setting 在Tool Settings里的Text Editor使用Custom Editor,然后配置想要编辑器的文件位置即可。

Simulation:由于最近常使用Vivado,就直接使用的是内置仿真器,如果做SoC设计,更偏好于VCS或者ModeSim。

Synthesis:当Coding量一多,如果只使用Vivado进行Synthesis,会非常慢。通过之前的项目经验,采用算法先进的Synplify对来综合,会使综合效果更好,针对我这个等级的学生来说,主要是综合的越快就更好了。

Implementation:由于使用Xilinx的A7200T系列FPGA芯片,故实现选择在Vivado上进行。

二、记录问题

2.1 Synplify怎么综合带有Vivado IP核的工程呢?

		由于我在工程中有使用到,BRAM,PLL这两个IP核,所以如果想在Synplify中综合该Project,必须解决IP核问题。

方法一 white box:将IP核放到Synplify中综合,综合完成后自动导入Synplify的工程。
操作步骤:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
最后点击import即可,不过在综合之前需要配置好vivado的位置,即Synplify中的P& R Implementation。
在这里插入图片描述
这样就可以在Synplify中使用在Vivado中定义的IP核,但会出现一个问题,如果使用了两个相同的IP核,但是参数不同。例如,配置两个BRAM,如果BRAM的大小不一样,且COE配置文件也不一样。那就会由两个IP,但是这两个IP都是来自同一个Block Memory Generator。就表明内部实现其实是一样的,但是网表会根据不同配置产生不同的结果。但是如果只是在Synplify生成”white box“,会产生.v文件,那就会产生上述两个IP中可能存在相同子模块,其实经过查看综合后结果,发现各模块名,除了顶层IP模块名有自己定义,其他均一模一样,这样直接综合会导致编译报错:出现了相同的block,当然这个错误在Synplify中通过command可以ignore,但是我在尝试该方法后,电路功能错误。便没有继续在此方法上继续花费时间,主要是该工程用到分布式的RAM,且有多个相同的IP。便继续下述的方法二了。

方法二 black box:这个方法在Xilinx官方的User Guide里面的ug994里面的使用第三方工具进行综合中有详细讲解。基本思想主要是将加入的IP核当成一个黑盒,在Synthesis的时候不对其进行优化,所以我们仅需要在Synplify的Project中加入生成IP核时的×××_stub.v文件即可,这是Vivado自动生成的文件,也是非常的人性化。最后点击RUN进行Synthesis即可生成网表以及约束文件,该网表是可以直接给Vivado进行实现的。

2.2 如何Implementation呢?

根据基础的知识,想要对设计进行Implementation,必须要有综合后的门级电路网表以及时序约束核管脚约束等文件。电路网表已经在Synplify中生成,时序约束也自动生成了,不过要根据具体的约束以及结果进行修改和编写。管教约束为自己根据FPGA的引脚以及顶层输入输出引脚进行配置。最后,只差了IP核的电路网表,在 Xilinx的ISE中,使用IP核是会直接生成网表的,但在升级后的Vivado中,会生成DCP文件或者更高级的XCI文件。其实在这里使用DCP文件即可了。最后各个文件加入,点击Implementation即可。
在这里插入图片描述


http://chatgpt.dhexx.cn/article/FRsL8i9d.shtml

相关文章

如何使用Synplify综合vivado带IP核的工程

文章目录 使用Synplify综合的好处synplify的教程方法1(无效)方法2 VIVODO工程遇到的问题 使用Synplify综合的好处 下面的说法来自网上: 综合时间更好,综合出来所使用的逻辑更少综合的时序更好 在IC设计中,使用Synplif…

Oracle分析函数取平均值,7-oracle_分析函数(一)

1.分组聚合函数 聚合函数主要有求和:sum();最大数:max();最小数:min();平均值:avg();统计数:count()等,在应用此类函数的时候,要么是从全集合来看…

oracle分析函数-RATIO_TO_REPORT() OVER()

1、RATIO_TO_REPORT()为比例函数 2、创建测试表,并插入数据 CREATE TABLE TEST_V( DEPTNO VARCHAR2(10), NAME VARCHAR2(10), SAL NUMBER ); 3、实例1:要求计算各部门工资合计,以及该工资合计占总工资的比例: SELECT TT.DEPT…

Oracle分析函数之Rank函数

本文主要讲述Oracle分析函数之Rank函数的用法 最近接触到Oracle这个功能强大而灵活的函数。这个函数特别适用于各种统计查询,下面就来说一说。 首先存在 product 表 SELECT p.create_time, p.name, p.service_evaluate_fee, p.product_type FROM product p 表数…

oracle 分析函数之分组求和、连续求和

最近在《sql cookbook》书上发现了名叫 分析函数 的东西,之前学 oracle 时没有印象,现在感觉其分析函数的功能相当强大、神奇, 就特意去找到了 chm 文档研究了一下,想要的朋友在本文末尾自行下载。 本文的例子都来源于 chm 文档…

在Oracle分析函数中使用FIRST_VALUE和LAST_VALUE

FIRST_VALUE and LAST_VALUE in Oracle Oracle中的FIRST_VALUE和LAST_VALUE These are Oracle analytical functions used to return the first value or the last value from a set of ordered rows. These functions can get the first value or the last value within a co…

Oracle 分析函数over,列转行函数pivot理解及综合运用(报表中的小计和合计)

1、Over函数(分析统计函数) 1.1语法 sum/avg/count() over(partition by ..)over()在什么条件之上;partition by 按哪个字段划分组; 1.2示例 SELECT E.ENAME,E.JOB,E.SAL,E.DEPTNO,SUM(E.SAL) OVER(PARTITION BY E.DEPTNO) SUM_SAL, …

oracle 百分位数,oracle分析函数 percent_rank, percentile_cont, percentile_disc

)*20=18 percentile_disc() PERCENTILE_DISC 这里就不做详细分析。 Syntax Purpose PERCENTILE_DISC is an inverse distribution function that assumes a discrete distribution model. It takes a percentile value and a sort specification and returns an element from t…

Oracle所有分析函数

Oracle分析函数 Oracle分析函数——函数列表 SUM :该函数计算组中表达式的累积和 MIN :在一个组中的数据窗口中查找表达式的最小值 MAX :在一个组中的数据窗口中查找表达式的最大值 AVG :用于计算…

oracle分析函数over(Partition by...)及开窗函数详解

说明:聚合函数(如sum()、max()等)可以计算基于组的某种聚合值,但是聚合函数对于某个组只能返回一行记录。若想对于某组返回多行记录,则需要使用分析函数。 1、rank()/dense_rank over(partition by ... order by ...) …

【Oracle】Oracle分析函数详解

Oracle数据库中的函数有多种,比如单行函数、聚合函数、对象引用函数、模型函数、OLAP函数等。本篇将详细介绍Oracle数据库中的分析函数。 一 分析函数概述 所谓分析函数,是基于一组数据行计算聚合值,其与聚合函数的不同之处在于&#xff0c…

oracle分析函数详解

一、Oracle分析函数 分析函数是什么? 分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计值。 分析函数和聚合函数的不同之处是什么…

Oracle 分析函数练习实例

创建表 create table emp(deptno varchar2(20) ,empno varchar2(20),ename varchar(20),sal number );sql演示 –显示各部门员工的工资,并附带显示该部分的最高工资。 select e.deptno,e.empno,e.ename,e.sal,last_value(e.sal)over(partition by e.deptnoorder …

oracle ntile函数,Oracle分析函数ntile

Oracle分析函数ntile 有这么一个需求,将课程的成绩分成四个等级,为学生打A、B、C、D的绩效。 drop table course purge; create table course ( id number, grade number ); insert into course values(1,50); insert into course values(2,55); insert …

Oracle之分析函数

目录 1. 认识分析函数 1.1 什么是分析函数 1.2 分析函数和聚合函数的不同 1.3 分析函数的形式 2. 理解over()函数 2.1 两个order by 的执行机制 2.2 分析函数中的分组、排序、窗口 2.3 帮助理解over()的实例 3. 常见分析函数 3.1 演示表和数据的生成 3.2 first_valu…

Oracle中的分析函数

目录 1、理解什么是分析函数? 2、分析函数和聚合函数区别? 3、分析函数的语法: 4、常用的分析函数: 5、运用分析函数求相关累计问题 6、运用分析函数求相关排序问题 1. RANK()函数: 2. DENSE_RANK()函数&#…

常用Oracle分析函数大全

Oracle的分析函数功能非常强大,工作这些年来经常用到。这次将平时经常使用到的分析函数整理出来,以备日后查看。 我们拿案例来学习,这样理解起来更容易一些。 1、建表 1 2 3 4 5 6 7 8 9 10 create table earnings -- 打工赚钱表 ( ear…

oracle分析函数技术详解(配上开窗函数over())

一、Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计值。 分析函数和聚合函数的不同之处是什么?普通的聚合函数用…

Python 输出小数点后保留两位有效数字简便方法

用round(a,n) a代表变量,n代表想保留的小数点的个数;比如:

金额千位分隔符及保留2位小数

目录 numberObject.toFixed(num) 正则 $1、$2 正则 {} 正则 ? 正则 ?: 正则 正则 $ 正则 | numberObject.toFixed(num) NumberObject.toFixed(num) 方法把 Number 四舍五入为指定小数位数数字,返回 string 类型num 规定小数位数 0 ~ 20 之间…