这个程序看起来没问题,但我还有一个错误,一些建议?
程序:
#include "dot.h"
#include <cuda.h>
#include <cuda_runtime.h>
#include <stdio.h>
int main(int argc, char** argv)
{
int *a, *b, *c;
int *dev_a, *dev_b, *dev_c;
int size = N * sizeof(int);
cudaMalloc((void**)&dev_a, size);
cudaMalloc((void**)&dev_b, size);
cudaMalloc((void**)&dev_c, sizeof(int));
a = (int *)malloc (size);
b = (int *)malloc (size);
c = (int *)malloc (sizeof(int));
random_ints(a, N);
random_ints(b, N);
cudaMemcpy(dev_a, a, size, cudaMemcpyHostToDevice);
cudaMemcpy(dev_b, b, size, cudaMemcpyHostToDevice);
int res = N/THREADS_PER_BLOCK;
dot<<< res, THREADS_PER_BLOCK >>> (dev_a, dev_b, dev_c);
//helloWorld<<< dimGrid, dimBlock >>>(d_str);
cudaMemcpy (c, dev_c, sizeof(int), cudaMemcpyDeviceToHost);
free(a); free(b); free(c);
cudaFree(dev_a);
cudaFree(dev_b);
cudaFree(dev_c);
return 0;
}
错误:
DotProductCuda.cpp:27:错误:
'<'
令牌之前的预期primary-expression
DotProductCuda.cpp:27:错误:'>'
令牌之前的预期primary-expression
答案 0 :(得分:13)
调用内核的<<< >>>
语法不是标准C或C ++。这些调用必须位于NVCC编译器编译的文件中。这些文件通常以.cu扩展名命名。对CUDA的其他API调用(例如cudaMalloc
)可以是常规的.c或.cpp文件。
答案 1 :(得分:4)
编译器似乎无法识别&lt;&lt;&lt;&lt;&lt;,&gt;&gt;&gt;句法。我没有使用CUDA的经验,但我想你需要使用特殊的编译器而不是普通的C编译器来编译这个文件。
答案 2 :(得分:3)
nvcc
使用文件扩展名来确定如何处理文件的内容。如果文件中包含CUDA语法,则它必须具有.cu扩展名,否则nvcc将简单地将文件传递给主编译器,从而导致您观察到的语法错误。
答案 3 :(得分:-3)
也许您在内核中使用主机函数(例如printf)?