-3

我在 ubuntu 12.04 上使用 cuda-5.5 在我的 gtx570 上运行一个简单的代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include <time.h>
#include <unistd.h>

#include <cuda_runtime_api.h>
#include <cuda.h>
#include "book.h"

__global__ void add(int *a, int *b, int *c){
int tid = blockIdx.x;
if (tid < 10)
        c[tid] = a[tid] + b[tid];
}


int main(void) {

int a[10],b[10],c[10];
int *dev_a,*dev_b,*dev_c;

cudaError_t err = cudaMalloc( ( void**)&dev_a, 10 * sizeof(int) ) ;
if(err != cudaSuccess){
     printf("The error is %s", cudaGetErrorString(err));
}


cudaError_t err2 = cudaMalloc( ( void**)&dev_b, 10 * sizeof(int) ) ;
if(err2 != cudaSuccess){
     printf("The error is %s", cudaGetErrorString(err));
}
cudaError_t err3 = cudaMalloc( ( void**)&dev_c, 10 * sizeof(int) ) ;
if(err3 != cudaSuccess){
     printf("The error is %s", cudaGetErrorString(err));
}


for (int i = 0; i<10 ; i++)
        {
        a[i] = -i;
        b[i] = i*i;
        }


cudaError_t err4 = cudaMemcpy( dev_a,a,10*sizeof(int), cudaMemcpyHostToDevice ) ;
if(err4 != cudaSuccess){
     printf("The error is %s", cudaGetErrorString(err));
}

cudaError_t err5 =cudaMemcpy( dev_b,b,10*sizeof(int), cudaMemcpyHostToDevice ) ;
if(err5 != cudaSuccess){
     printf("The error is %s", cudaGetErrorString(err));
}

add<<<10,1>>>(dev_a,dev_c,dev_c);
if (cudaPeekAtLastError() != cudaSuccess) {
    printf("The error is %s", cudaGetErrorString(cudaGetLastError()));
}
cudaError_t err6 = cudaMemcpy(c,dev_c,10*sizeof(int), cudaMemcpyDeviceToHost);
if(err6 != cudaSuccess){
     printf("The error is %s", cudaGetErrorString(err));
}


for (int i = 0; i<10; i++)
        {
        printf("%d + %d = %d\n", a[i],b[i],c[i]);
        }


cudaFree( dev_a);
cudaFree( dev_b);
cudaFree( dev_c);

return 0 ;
}

此代码编译没有错误,但给出了无意义的答案:

0 + 0 = -1087278592
-1 + 1 = -1245725046
-2 + 4 = 2139095032
-3 + 9 = 780509949
-4 + 16 = 1195091696
-5 + 25 = -921707890
-6 + 36 = 33554408
-7 + 49 = 936179122
-8 + 64 = 1026206341
-9 + 81 = -1090519076

是的,我从 cuda 网站 https://developer.nvidia.com/cuda-downloads获得了 cuda 代码 是的,我从 nvidia 网站http://www.geforce.com/drivers/results/67567 获得了 nvidia 驱动程序

我以前运行过它,但是后来我超级破坏了我的 ubuntu 分区,现在我遇到了麻烦。

编辑:解决它,至少它似乎工作。我使用 valgrind 发现函数 fwrite 存在段错误。奇怪的是我的计算机上的 fwrite 段错误,而不是我之前运行模拟的服务器上。

4

1 回答 1

3

好吧,检查这行代码

add<<<10,1>>>(dev_a,dev_c,dev_c);

dev_c 未初始化,您正在将 dev_a 值添加到未初始化的值。这就是胡说八道发生的地方。

于 2013-10-16T14:01:33.773 回答