Атомарные операции в CUDA? Какой файл заголовка включить?

для использования атомарных операций в CUDA необходимо включить некоторый файл заголовка CUDA? Руководство по программированию CUDA, похоже, плотно сжато на этом.

код glmax.cu, приведенный ниже, дает мне следующую ошибку компиляции.

gaurish108 MyPractice: nvcc glmax.cu -o glmax
glmax.cu(11): error: identifier "atomicMax" is undefined

1 error detected in the compilation of "/tmp/tmpxft_000010fa_00000000-4_glmax.cpp1.ii".

вот код. Он в основном вычисляет максимальное значение массива на GPU, используя атомарную операцию atomicMax. Поскольку я новичок в CUDA, я уверен, что это довольно наивный код, но я написал это, чтобы помочь себе разбирайтесь в атомарных операциях.

#include<stdio.h>
#include<stdlib.h>
#include<math.h>

__global__ void global_max(int* values, int* gl_max)
{

  int i=threadIdx.x + blockDim.x * blockIdx.x;
  int val=values[i];

  atomicMax(gl_max,val);

}


int main(void)
{
  int array_size=5;
  int num_bytes=array_size*sizeof(int);
  int *device_array=0;
  int *host_array=0;

  int *device_max=0;
  int *host_max=0;

  //Allocate memory on the host
  host_array=(int*)malloc(num_bytes);

  //Allocate memory on the device
  cudaMalloc((void**)&device_array,num_bytes);
  cudaMalloc((void**)&device_max,sizeof(int));


  //If either memory allocation failed, report an error message
  if(host_array == 0 || device_array == 0)
  {
    printf("couldn't allocate memoryn");
    return 1;
  }

  //Assign a random integer in the  interval [0,25] to host_array members
  for(int i=0;i<array_size;++i)
    {
      *(host_array+i)=rand()%26;
    }

  //Print the host array members
  printf("Host Arrayn");
  for(int i=0;i<array_size;++i)
    {
      printf("%d  ",*(host_array+i));
    }
  printf("n");

  //Copy array from host to device.
  cudaMemcpy(device_array,host_array,num_bytes,cudaMemcpyHostToDevice);

  //Configure and launch the kernel which calculates the maximum element in the device array.
  int grid_size=1;//Only 1 block of threads is used
  int block_size=5;//One block contains only 5 threads

  //Device array passed to the kernel as data. 
  global_max<<<grid_size,block_size>>>(device_array,device_max);

  //Transfer the maximum value so calculated into the CPU and print it
  cudaMemcpy(host_max,device_max,sizeof(int),cudaMemcpyDeviceToHost);
  printf("nMaximum value is %dn",*host_max);


  // deallocate memory
  free(host_array);
  cudaFree(device_array);
  cudaFree(device_max);
  return 0;
}

1 ответов


Я не верю #include необходимо. Атомарные операции недоступны в "вычислительной способности" 1.0 (sm_10) устройства, которые вы спрашиваете nvcc для компиляции (по умолчанию).

использовать atomicMax в коде укажите хотя бы -arch=sm_11 в командной строке:

$nvcc -arch=sm_11 glmax.cu -o glmax

для дальнейшего использования вы можете ознакомиться с приложением F руководства по программированию CUDA C для получения информации о том, какие атомарные операции доступны на платформах конкретного вычисления Способность.

конечно, вам понадобится sm_11-совместимый GPU для выполнения кода. У меня сложилось впечатление, что они уже стали обычными.