我很难编译一个只有两个文件的简单 cuda 程序。
main.c 看起来像这样:
#include "my_cuda.h"
int main(int argc, char** argv){
dummy_gpu();
}
cuda.h 看起来像这样:
#ifndef MY_DUMMY
#define MY_DUMMY
void dummy_gpu();
#endif
my_cuda.cu 文件如下所示:
#include <cuda_runtime.h>
#include "my_cuda.h"
__global__ void dummy_gpu_kernel(){
//do something
}
void dummy_gpu(){
dummy_gpu_kernel<<<128,128>>>();
}
但是,如果我编译我总是收到以下错误:
gcc -I/usr/local/cuda/5.0.35/include/ -c main.c
nvcc -c my_cuda.cu
gcc -L/usr/local_rwth/sw/cuda/5.0.35/lib64 -lcuda -lcudart -o md.exe main.o my_cuda.o
main.o: In function `main':
main.c:(.text+0x15): undefined reference to `dummy_gpu'
collect2: ld returned 1 exit status
谢谢您的帮助。