Cuda 未知错误(错误编号: 30) on cudaMalloc().



我已经搜索了原因,但没有运气。它在如此简单的程序上失败:

#include <iostream>
using namespace std;
int main() {
  int* n;
  cout << cudaMallocManaged(&n, 4 * sizeof(int)) << endl;
  return 0;
}

返回代码为 30,未知错误。 cudaMalloc在相同的代码下也会失败。

这是我的硬件:

$ lspci | grep NV
01:00.0 3D controller: NVIDIA Corporation GF117M [GeForce 610M/710M/820M / GT 620M/625M/630M/720M] (rev a1)
$ nvidia-smi
Sat Mar  7 14:02:04 2015       
+------------------------------------------------------+                       
| NVIDIA-SMI 331.113    Driver Version: 331.113        |                       
|-------------------------------+----------------------+----------------------+
| GPU  Name        Persistence-M| Bus-Id        Disp.A | Volatile Uncorr. ECC |
| Fan  Temp  Perf  Pwr:Usage/Cap|         Memory-Usage | GPU-Util  Compute M. |
|===============================+======================+======================|
|   0  NVS 5200M           Off  | 0000:01:00.0     N/A |                  N/A |
| N/A   53C  N/A     N/A /  N/A |    279MiB /  1023MiB |     N/A      Default |
+-------------------------------+----------------------+----------------------+
+-----------------------------------------------------------------------------+
| Compute processes:                                               GPU Memory |
|  GPU       PID  Process name                                     Usage      |
|=============================================================================|
|    0            Not Supported                                               |
+-----------------------------------------------------------------------------+

我正在使用 Ubuntu 14.10,以及官方存储库中的 CUDA 6.0(希望,如果 Ubuntu 不搞砸它)。

这是联想T430s实验室顶部,该卡位于擎天柱上,因此可能会导致一些问题。我已经在另一台机器上进行了测试,并且相同的代码有效。

更新 1

好的,nvidia_uvm没有加载...

$ lsmod |grep nv
nvidia              10744914  65 
nvram                  14362  1 thinkpad_acpi
drm                   310919  6 i915,drm_kms_helper,nvidia
$ sudo modprobe nvidia_uvm
modprobe: ERROR: ../libkmod/libkmod-module.c:816 kmod_module_insert_module() could not find module by name='nvidia_331_updates_uvm'
modprobe: ERROR: could not insert 'nvidia_331_updates_uvm': Function not implemented

更新 2

好的,我重新安装了nvidia-331-updates-uvm,模块已加载。

$ lsmod | grep nv
nvidia_uvm             34855  0 
nvidia              10744914  66 nvidia_uvm
nvram                  14362  1 thinkpad_acpi
drm                   310919  6 i915,drm_kms_helper,nvidia

但是,代码仍返回错误 30。

更新 3

经过更多测试(主要是尝试以root身份运行),现在我得到错误71:不支持操作。但是,如果我只是使用cudaMalloc它成功了。我还会检查我的设备是否支持统一内存寻址。

更新 4

好的,我的卡只支持SM 2.1,所以它不支持统一内存。

AFAIK nvidia_uvm内核模块是 CUDA 工作所必需的。

您需要使用该内核模块安装软件包,例如 nvidia-331-uvm和通过安装nvidia-modprobe包启用它的自动加载:

sudo apt-get install nvidia-modprobe nvidia-331-uvm

如果您不想在安装 nvidia-modprobe 后重新启动,您可以尝试以 root 身份运行您的程序(例如 sudo ./a.out ) — 模块应在以 root 用户身份运行时加载。

相关内容

  • 没有找到相关文章

最新更新