vcs DPI机制调用c函数

方案1:

1.

准备c文件, cprog.c:

#include<stdio.h>
void echo(char* str){
  printf("chaogang test\n");
  printf("test str %s\n",str);      
}

2.

通过vcs去编译该c文件:

 

 3.

在sv中想要使用cprog.c中定义的echo函数的地方,通过DPI机制导入,然后可以直接调用:

 

方案2:

将写好的c文件编译成共享库,在执行simv的时候通过 -sv_root -sv_lib 参数告知simv 共享库的路径

生成共享库方法如下:

 

 

gcc -fPIC -Wall -c cprog.c

gcc -fPIC -shared -o cprog.so cprog.o

这种情况在vcs编译阶段不需要编译c代码:

 

 在执行simv的时候通过-sv_lib 参数传递共享库。共享库文件名为cprog.so,但传递-sv_lib参数时不带.so后缀。 -sv_root参数可以指定共享库的路径,在共享库与simv不在同一目录时需要-sv_root指定共享库所在路径。

 

posted @   学号党  阅读(2512)  评论(2编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示