How to return a single variable from a CUDA kernel function?

前端 未结 2 1918
梦谈多话
梦谈多话 2021-02-04 03:26

I have a CUDA search function which calculate one single variable. How can I return it back.

__global__ 
void G_SearchByNameID(node* Node, long nodeCount, long s         


        
2条回答
  •  说谎
    说谎 (楼主)
    2021-02-04 03:57

    I've been using __device__ variables for this purpose, that way you don't have to bother with cudaMalloc and cudaFree and you don't have to pass a pointer as a kernel argument, which saves you a register in your kernel to boot.

    __device__ long d_answer;
    
    __global__ void G_SearchByNameID() {
      d_answer = 2;
    }
    
    int main() {
      SearchByNameID<<<1,1>>>();
      typeof(d_answer) answer;
      cudaMemcpyFromSymbol(&answer, "d_answer", sizeof(answer), 0, cudaMemcpyDeviceToHost);
      printf("answer: %d\n", answer);
      return 0;
    }
    

提交回复
热议问题