verdi加载vhdl和verilog混合RTL设计的方法

2024-03-19 16:32

本文主要是介绍verdi加载vhdl和verilog混合RTL设计的方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

采用三步法完成混合语言RTL设计的加载。

step1. 用vhdlcom将所有的VHDL RTL代码编译成库
    1.1 将所有的vhdl文件放到vhdl.f文件中,如:
        vhdl.f
        ---------
        my_design.vhd
        my_lib.vhd
        tb_my_design.vhd
    1.2 编译成库
        vhdlcom -f vhdl.f
        编译完成后,在运行路径下可看到自动生成的一个库文件夹work.lib++
        注意:
        a) 一般情况下vhdlcom命令不需要加其他参数。若出现vhdl版本问题,可考虑
增加-vhdl08等参数:vhdlcom -vhdl08 -f verilog.f
        b) 编译后的log为vhdlcomLog/compiler.log
        c) -lib 参数可指定一个库名。不指定,则默认库命为work。所有的生成的库
的库名都是自由附加了".lib++"后缀。对于混合仿真vhdl和verilog的库名要保持一致,
否则可能出现其中一个库无法识别的问题(verdi版本为2015,可能后续版本解决了该问
题)。例:vhdlcom -lib mylib -f vhdl.f,生成mylib.lib++库

step2. 用vericom将所有的verilog RTL代码编译成库
    2.1 将所有的verilog文件放到verilog.f文件中,如:
        verilog.f
        ---------
        my_verilog_design.v
        my_verilog_lib.v
        tb_top_design.v      
        以上tb_top_design为顶层设计.
    2.2 编译成库
        vericom -f verilog.f
        编译完成后,可看到work.lib++库中新增了my_verilog_design.tdc等库。(假定vhdlcom时没有指定-lib参数,则库名为work)
        注意:
        a) 一般情况下vericom命令不需要加其他参数。若出现verilog版本问题,可考
虑增加-2001等参数:vericom -2001 -f verilog.f
        b) 编译后的log为vericomLog/compiler.log
        c) -lib 参数可指定一个库名。不指定,则默认库命为work。所有的生成的库
的库名都是自由附加了".lib++"后缀。库名与vhdl库名要保持一致,否则可能出现其中
一个库无法识别的问题(verdi版本为2015,可能后续版本解决了该问题)。例:
vericom -lib mylib -f verilog.f,新增的库文件被添加至mylib.lib++库

step3. 用verdi加载已编译的库,并指定top design
    3.1 用命令行直接加载
        verdi -lib work -top tb_top_design &
    3.2 GUI加载
        verdi & 
        打开verdi后:File -〉import design -〉From Library,然后在Library中选
择work库,再在右栏的Design unit中找到tb_top_design, 点击ok完成加载。

这篇关于verdi加载vhdl和verilog混合RTL设计的方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/826606

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Git中恢复已删除分支的几种方法

《Git中恢复已删除分支的几种方法》:本文主要介绍在Git中恢复已删除分支的几种方法,包括查找提交记录、恢复分支、推送恢复的分支等步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录1. 恢复本地删除的分支场景方法2. 恢复远程删除的分支场景方法3. 恢复未推送的本地删除分支场景方法4. 恢复

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

Window Server2016加入AD域的方法步骤

《WindowServer2016加入AD域的方法步骤》:本文主要介绍WindowServer2016加入AD域的方法步骤,包括配置DNS、检测ping通、更改计算机域、输入账号密码、重启服务... 目录一、 准备条件二、配置ServerB加入ServerA的AD域(test.ly)三、查看加入AD域后的变

Window Server2016 AD域的创建的方法步骤

《WindowServer2016AD域的创建的方法步骤》本文主要介绍了WindowServer2016AD域的创建的方法步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、准备条件二、在ServerA服务器中常见AD域管理器:三、创建AD域,域地址为“test.ly”

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,