ncverilog 使用 systemverilog DPI调用C、C++

DPI: Direct program interface

通过DPI我们可以直接在测试阶段调用c函数完成一些任务(产生激励,时序分析,等。。。)

用ncverilog进行仿真时需要注意以下几点:


1 ncvlog -sv 选项打开

2 ncsim -sv_lib "libname" lib name 是包含c函数的动态链接库,可以是完整的路径,也可以是lib的名字,

                -sv_root: 如果libname不是给出的完整路径,用该选项来指定路径

3 编写的c函数,文件名尽量与函数名一致,并且在函数明前加上DPI_DLLESPEC,头文件包含“svdpi.h”

4 编译产生动态链接库(尽量使用同样的机器编译和运行ncverilog(同为32位或者64位否则会产生 wrong ELF class: ELFCLASS32的错误)

   编译命令为: gcc -fPIC -shared -o libname cfiles.c

5 在verilog中使用:

   import  "DPI-C" function/task  void/int.... function_name (input ... ouput....inout); 

 直接调用unction_name;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值