编译Cuda时出错 - 预期的primary-expression

时间:2011-05-13 00:36:12

标签: c++ cuda gpgpu

这个程序看起来没问题,但我还有一个错误,一些建议?

程序:

#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

4 个答案:

答案 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)?