1

当我在设备上定义一个数组(在本例中使用“Hello”字符串初始化)并尝试将其复制到主机时,我得到错误代码cudaErrorInvalidValue。但是,d_helloStr[]可以从内核内部访问 。参考 CUDA 编程指南第 B.2.1 章,这样的变量也应该可以通过运行时库访问。为什么此示例代码不起作用?

#include <cuda.h>
#include <stdio.h>


__device__ char d_helloStr[] = {'H','e','l','l','o','\0'};

// Host function
int
main(int argc, char** argv)
{
  cudaError_t err;
  char h_helloStr [sizeof(d_helloStr)];

  // copy device string to host string: 
  err = cudaMemcpy(h_helloStr, d_helloStr, sizeof(d_helloStr), cudaMemcpyDeviceToHost);
  printf("err = %d\n", err);

  // result string:   
  printf("%s\n", h_helloStr);

  return 0;
}
4

1 回答 1

1

您应该使用 cudaMemcpyFromSymbol。

于 2010-06-21T21:14:33.183 回答