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 @ 2022-03-07 10:06  学号党  阅读(2011)  评论(2编辑  收藏  举报