8

下面,我包含了一个自包含的示例,用于cudaMemcpyFromSymbol()从内核中检索结果。该示例将符号参数(调用中的第二个参数)作为常规变量传递。但是,据我了解 CUDA 文档,将参数作为字符串传递,即:

cudaMemcpyFromSymbol(&out, "out_d", sizeof(out_d), 0, cudaMemcpyDeviceToHost);

(在符号名称周围加上引号),也应该有效。这对我不起作用。

符号名称何时起作用,符号名称作为字符串何时起作用?

#include "cuda_runtime.h"
#include <stdio.h>

__device__ int out_d;

__global__ void test() {
  out_d = 123;
}

int main() {
  test<<<1,1>>>();
  int out;
  cudaMemcpyFromSymbol(&out, out_d, sizeof(out_d), 0, cudaMemcpyDeviceToHost);
  printf("%d\n", out);
  return 0;
}
4

1 回答 1

9

在 CUDA 4.2 中不推荐将符号名称作为字符串参数传递,并且在 cuda 5.0 中消除了该语法。原因与启用单独的设备代码链接器功能有关,该功能出现在 CUDA 5 中。对于 cuda 5 工具包,此更改记录在发行说明中

  • 不再支持使用字符串来指示设备符号,这在某些 API 函数中是可能的。相反,应直接使用该符号。
于 2013-02-10T04:15:06.673 回答