这个程序似乎很好,但我仍然得到一个错误,一些建议?
程序:
#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;
}
Run Code Online (Sandbox Code Playgroud)
错误:
DotProductCuda.cpp:27:错误:在
'<'令牌
DotProductCuda.cpp 之前的预期primary-expression :27:错误:'>'令牌之前的预期primary-expression
Ste*_*ows 14
<<< >>>调用内核的语法不是标准C或C++.这些调用必须位于NVCC编译器编译的文件中.这些文件通常以.cu扩展名命名.对CUDA的其他API调用cudaMalloc可以是常规的.c或.cpp文件.
nvcc使用文件扩展名来确定如何处理文件的内容。如果文件中有 CUDA 语法,则它必须具有 .cu 扩展名,否则 nvcc 只会将文件原封不动地传递给主机编译器,从而导致您观察到的语法错误。