3

我有一个具有 2Gb 内存的 GTX570,当我尝试通过一个 cudamalloc 调用分配比大约 804Mb 更多的内存时,我遇到了麻烦。有人知道为什么会这样吗?这是我的第一个电话,所以我怀疑它是碎片化的。

没问题:

Memory avaliable: Free: 2336116736, Total: 2684026880
requesting 804913152 bytes
no error
Memory avaliable: Free: 1531199488, Total: 2684026880
requesting 804913152 bytes
no error
Memory avaliable: Free: 726286336, Total: 2684026880

问题:

Memory avaliable: Free: 2327601152, Total: 2684026880
requesting 805306368 bytes
out of memory
Memory avaliable: Free: 2327597056, Total: 2684026880
requesting 805306368 bytes
out of memory
Memory avaliable: Free: 2327597056, Total: 2684026880
4

1 回答 1

1

这是由 Windows WDDM 子系统施加的限制引起的。可以分配多少内存有一个硬性限制,计算为

MIN ( ( System Memory Size in MB - 512 MB ) / 2, PAGING_BUFFER_SEGMENT_SIZE )

对于桌面窗口 PAGING_BUFFER_SEGMENT_SIZE 约为 2Gb IIRC。您有两个选项可以解决此问题:

  1. 获取 Telsa 卡并使用专用的 Windows TCC 模式驱动程序,该驱动程序将设备的内存管理从 WDDM 中分离出来,消除了限制。
  2. 安装 linux 或使用支持 CUDA 的实时分发版进行 GPU 计算。Linux 驱动程序对超出设备可用内存容量的内存分配没有限制。
于 2012-12-13T10:25:22.307 回答