VHDL生成的ngc文件被verilog的工程调用的问题

1. 问题的提出

工程a是一个soft core,用VHDL写的,综合的时候去掉了"Add I/O buffers" ,并将-iob(Pack I/O Registers into IOBs)置为否。综合最后生成了a.ngc文件供其他工程使用。在生成完ngc后,还可以在 "Design Utilities" -> "View HDL Instantiation Template" 中生成相应的调用文件。

工程b调用的a.ngc,但是工程b使用verilog写的,在调用的时候出现了找不到a模块的错误。

2. 问题的解决方法a

使用netgen命令将该ngc转换成vhdl或者verilog文件,然后在调用转换后的文件

linux下

netgen -ofmt verilog filename.ngc
netgen -ofmt vhdlfilename.ngc

windows 下

netgen.exe -ofmt verilog filename.ngc
netgen.exe -ofmt vhdlfilename.ngc

3. 问题的解决办法b

上述的办法只是一种取巧的办法,更好地办法是通过使用wrapper文件来实现。

假定原来的ngc文件为abc.ngc, 则其wrapper文件名为abc.v 或者 abc.vhd. 这个wrapper文件只申明abc模块的输入输出端口,不包含其他信息。

一种简单的生成wrapper文件的办法就是利用解决办法a中提到的netgen工具,利用netgen生成的verilog文件或者vhdl文件,将其他语句删除,仅保留其申明部分。

然后在工程中同时添加该wrapper文件和ngc文件即可。

 

时间: 2024-08-26 05:13:09

VHDL生成的ngc文件被verilog的工程调用的问题的相关文章

python生成requirements.txt文件

------------恢复内容开始------------ requirements.txt文件是为了维护python项目相关的依赖包依赖包及其精确的版本号.以便后续新环境部署. 生成requirements.txt文件: 在python工程目录输入:pip freeze > requirement.txt 如图: 查看requirements.txt文件内容: type requirements.txt 如图: 批量执行requirements.txt文件: pip install -r r

Android gen根目录下自动生成的R文件指向问题

今天才弄明白,原来在调用vitamio包的时候使用它们的R文件,然后在迁入广告的时候出现了问题,但是瞎胡搞半天后把问题解决了,可没有明白这是什么原因. 今天更新应用又出现了相同的情况,无意中打开了gen的根目录妈蛋!发现里面的报名根本就不是我现在应用的包名.而是调用的那个工程的包名!这下终于找到根本原因了,但是怎么解决呢???----------->修改包名呗~~~~~~~可是你改了它又会自动生成了原来的那个,--------------后来终于发现原来这个R文件的包名适合manifest文件中

文件分割器,一个读取流,相应多个输出流,并且生成的碎片文件都有有序的编号

import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.util.Properties; public class FileSpilte { /** * @param args * @throws IOException */

【转】Android NDK学习(3)使用Javah命令生成JNI头文件 .

第一步: 在Eclipse中创建android项目,并声明Native接口: public native int add (int a, int b);public native int sub (int a, int b); 编译.运行: 这样在bin目录下就会生成类文件: 第二步: 打开命令行cmd,到达bin目录: F:\fww\workspace\TestJNI\bin> 输入如下命令: F:\fww\workspace\TestJNI\bin>javah -d header -cla

win7 安装oracle 10g 未生成监听文件 导致配置监听时无法保存

最近这两天一直在为安装 的oracle 配置监听无法保存 再找各种解决方案,最后自己居然自己配置出来了. 因为缺少监听文件,拷贝别人的放到自己的目录下C:\oracle\product\10.2.0\client_1\NETWORK\ADMIN   listener.ora.tnsnames.ora和 sqlnet.ora 1.修改 tnsnames.ora  中的 # tnsnames.ora Network Configuration File:  c:\oracle\product\10.

用T4生成多个文件(转)

初次认识并尝试使用T4生成代码的时候,相关学习资料似乎比较少.不过现在VS2010 的MSDN里已有相关章节,可参看<代码生成和文本模板>章节.可以用C#的语法写模板,实在舒服很多. 很快就发现T4难以生成多个文件的缺陷,微软似乎也不着急改进这一点.通过搜索,从InfoQ找到一篇文章<用T4生成多个文件>,链接到一篇文章,Damien Guard的扩展可以方便的生成多个文件.原文是英文,能看懂,然而如果翻译则斟酌字词太辛苦. 首先,保存以下代码为一个模板文件(例如保存文件名为Man

基于MVC4+EasyUI的Web开发框架经验总结(14)--自动生成图标样式文件和图标的选择操作

在很多Web系统中,一般都可能提供一些图标的选择,方便配置按钮,菜单等界面元素的图标,从而是Web系统界面看起来更加美观和协调.但是在系统中一般内置的图标样式相对比较有限,而且硬编码写到样式表里面,这样给我们扩展使用有很多的不方便.基于这个原因,我想如果能够独立一个模块,自动根据图标生成图标CSS样式文件,并存储相应的记录到数据库里面,方便我们查询显示,那样我们使用起来就很方便了,最后有了这些数据,只需要做一个通用的图标选择界面,并可以在很多地方重用了.本文正是基于这个思路,开发了一个图标管理模

C++调用C#生成的DLL文件的各种问题

C++调用C#生成的DLL文件: 首先选择建立一个C#的类库,然后再按照需求编写需要的函数 之后,对于C++调用过程需要注意的几点: 1.使用#using <....some.dll>指出DLL文件的位置来调用DLL 2.using namespace some 方便之后调用函数 3.Class1 ^c = gcnew Class1(); gcnew和new的区别(引自百度知道): gcnew返回的是一个句柄(Handle),而new返回的是实际的内存地址. gcnew创建的对象由虚拟机托管,

java文本、表格word转换生成PDF加密文件代码下载

原文:java文本.表格word转换生成PDF加密文件代码下载 代码下载地址:http://www.zuidaima.com/share/1550463239146496.htm 这个实现了PDF加密功能,和一些基本的问题. java文本.表格word转换生成PDF加密文件代码下载,布布扣,bubuko.com