如何使用CUDA并行NSight调试器监视引用变量



使用NSight调试时,我可以正确地监视任何变量或指针,但不能对引用变量执行此操作。我已经尝试过在手表或即时窗口中将引用转换为指针,但没有成功。我不想用指针重写我的代码。我在Windows 7 64位计算机、CUDA 4.0、Parallel NSight 2.0中使用Visual Studio 2010 SP1,我的代码是为Win32编译的。

示例:__device__ void函数(int&parameter)

无法调试参数。调试器无法访问它。

我已经在我的机器上复制了这个问题。Windows 7 64位,Visual Studio 2010,CUDA 4.1。

我无法调试:

__device__ int myfunc(int& myint)
{
  return myint * 5;
}

我可以用return在行上设置断点,但我不能查看变量,因为它是通过引用传递的。

如果我将其更改为:

__device__ int myfunc(int& myint)
{
  int debug(myint);
  return debug * 5;
}

我可以查看debug变量。

我认为你应该向NVIDIA提交一个bug。我不知道他们的系统是否已经恢复到足够的程度。

更新到Nsight 2.2、CUDA 4.2和Dev驱动程序301.32,这就成功了。

最新更新