"不知道如何处理' nvcc致命错误

时间:2014-03-29 11:27:35

标签: ubuntu compilation nvcc

我在Ubuntu终端中使用命令行。

我正在尝试编译CUDA_Compiler_Driver_NVCC.pdf中提供的三个文件

当我使用这3个文件的文档给出的命令行时,我会收到以下错误:

nvcc致命:不知道如何处理' -dc'

如果我在命令行中擦除-dc,我也会收到以下错误: nvcc致命:不知道如何处理' -arch = sm = 20'

有谁知道如何解决这个问题?

非常感谢您的帮助

盖博

下面,您将找到我在终端中输入的命令行以及文件。

使用的命令行: nvcc -arch = sm_20 -dc a.cu b.cu nvcc -arch = sm_20 a.o b.o

文件代码(只是文档的复制粘贴): (似乎代码警察在粘贴时会改变,对这个小问题感到抱歉)

******* b.h ***********
#define N 8

extern __device__ int g[N];
extern __device__ void bar(void);

******* b.cu***********
#include "b.h"
__device__ int g[N];
__device__ void bar (void)
{
g[threadIdx.x]++;
}

******* a.cu ***********
#include <stdio.h>

#include "b.h"

__global__ void foo (void) {
__shared__ int a[N];
a[threadIdx.x] = threadIdx.x;
__syncthreads();
g[threadIdx.x] = a[blockDim.x - threadIdx.x - 1];
}

bar();

int main (void) {
unsigned int i;
int *dg, hg[N];

int sum = 0;

foo<<<1, N>>>();

if(cudaGetSymbolAddress((void**)&dg, g)){
printf("couldn't get the symbol addr\n");
return 1;
}

if(cudaMemcpy(hg, dg, N * sizeof(int), cudaMemcpyDeviceToHost)){
printf("couldn't memcpy\n");
return 1;
}

for (i = 0; i < N; i++) {
sum += hg[i];
}

if (sum == 36) {
printf("PASSED\n");
} else {
printf("FAILED (%d)\n", sum);
}

return 0;
}

1 个答案:

答案 0 :(得分:2)

确保使用正确版本的nvcc。我有这样的问题,因为我使用的是NVCC 5.5而不是6.0。

还要确保破折号具有正确的符号:使用 - (0x2D)而不是 - (0xD0)。