我想从我的Go代码调用CUDA函数。 我有以下三个文件。Golang调用CUDA库
test.h:
int test_add(void);
test.cu:
__global__ void add(int *a, int *b, int *c){
*c = *a + *b;
}
int test_add(void) {
int a, b, c; // host copies of a, b, c
int *d_a, *d_b, *d_c; // device copies of a, b, c
int size = sizeof(int);
// Allocate space for device copies of a, b, c
cudaMalloc((void **)&d_a, size);
cudaMalloc((void **)&d_b, size);
cudaMalloc((void **)&d_c, size);
// Setup input values
a = 2;
b = 7;
// Copy inputs to device
cudaMemcpy(d_a, &a, size, cudaMemcpyHostToDevice);
cudaMemcpy(d_b, &b, size, cudaMemcpyHostToDevice);
// Launch add() kernel on GPU
add<<<1,1>>>(d_a, d_b, d_c);
// Copy result back to host
cudaMemcpy(&c, d_c, size, cudaMemcpyDeviceToHost);
// Cleanup
cudaFree(d_a); cudaFree(d_b); cudaFree(d_c);
return 0;
}
test.go:
package main
import "fmt"
//#cgo CFLAGS: -I.
//#cgo LDFLAGS: -L. -ltest
//#cgo LDFLAGS: -lcudart
//#include <test.h>
import "C"
func main() {
fmt.Printf("Invoking cuda library...\n")
fmt.Println("Done ", C.test_add())
}
我CUDA代码编译有:
nvcc -m64 -arch=sm_20 -o libtest.so --shared -Xcompiler -fPIC test.cu
所有三个文件 - test.h,test.cu和test.go都在同一个目录中。 我尝试使用go进行构建时遇到的错误是“未定义的对test_add的引用”。
我对C/C++有很少的经验,并且是CUDA的总新手。
我一直在试图解决我的问题两天,现在将是 非常感谢任何输入。
谢谢。
我不熟悉走,但它可能是一个C与C++连接的问题。尝试将'test_add()'原型封装在'extern“C”{...}' –
@RobertCrovella:你在哪里看到C代码? CUDA是基于C++的。 – Olaf
@Olaf我在哪里说“我看到C代码”。 ?我知道CUDA使用C++风格的链接。如果碰巧('C'的导入期望函数提供C风格链接](https://golang.org/cmd/cgo/#hdr-Go_references_to_C),那么你会遇到这个问题。这只是一个猜测。 –