【问题标题】:How to use GPUDirect RDMA with Infiniband如何在 Infiniband 中使用 GPUDirect RDMA
【发布时间】:2015-09-11 19:49:36
【问题描述】:

我有两台机器。每台机器上有多张特斯拉卡。每台机器上还有一张 InfiniBand 卡。我想通过 InfiniBand 在不同机器上的 GPU 卡之间进行通信。只需点对点单播就可以了。我当然想使用 GPUDirect RDMA,这样我就可以省去额外的复制操作。

我知道 Mellanox 现在为其 InfiniBand 卡提供了 driver。但它没有提供详细的开发指南。我也知道 OpenMPI 支持我要求的功能。但是 OpenMPI 对于这个简单的任务来说太重了,它不支持单个进程中的多个 GPU。

我想知道直接使用驱动程序进行通信是否可以得到任何帮助。代码示例,教程,任何东西都会很好。另外,如果有人能帮我在 OpenMPI 中找到处理这个问题的代码,我将不胜感激。

【问题讨论】:

  • 这听起来像是你应该和 Mellanox 谈谈的事情
  • 有问题的代码主要位于openib BTL 组件中。查找名称中包含 gdr 的内容,以及预处理器符号名称中包含 CUDAGRD 的条件编译块。
  • 请注意,对场外资源(例如教程)的请求在此处被视为离题,使您的问题处于离题边缘。

标签: cuda openmpi infiniband gpudirect


【解决方案1】:

要使 GPUDirect RDMA 工作,您需要安装以下内容:

应安装以上所有内容(按上面列出的顺序),并加载相关模块。 之后,您应该能够注册在 GPU 视频内存上分配的内存用于 RDMA 事务。示例代码如下所示:

void * gpu_buffer;
struct ibv_mr *mr;
const int size = 64*1024;
cudaMalloc(&gpu_buffer,size); // TODO: Check errors
mr = ibv_reg_mr(pd,gpu_buffer,size,IBV_ACCESS_LOCAL_WRITE|IBV_ACCESS_REMOTE_WRITE|IBV_ACCESS_REMOTE_READ);

这将创建(在启用 GPUDirect RDMA 的系统上)一个内存区域,其中包含一个有效的内存密钥,您可以将其用于与我们的 HCA 进行 RDMA 事务。

有关在代码中使用 RDMA 和 InfiniBand 动词的更多详细信息,您可以参考此document

【讨论】:

  • 您能否使用 Mellanox 的 RDMA 从 GPU 读取/写入服务器的远程内存?
猜你喜欢
  • 2018-05-28
  • 2017-03-25
  • 2016-04-26
  • 2012-08-19
  • 2012-08-10
  • 2013-08-28
  • 2021-10-26
  • 2016-01-10
  • 2017-05-05
相关资源
最近更新 更多