【问题标题】:How to install Open MPI with Cuda-Aware MPI in Linux Debian如何在 Linux Debian 中使用 Cuda-Aware MPI 安装 Open MPI
【发布时间】:2015-12-27 16:40:09
【问题描述】:

我正在我的 Linux Debian 上安装 Open MPI v1.8.8 和 CUDA v7.5。 我已经测试了 CUDA 并且它有效,测试了 OpenMPI 并且它也有效。但是当我尝试将它们组合成一个程序时,我遇到了一个错误:找不到 cuda.h 文件。这是我的场景:

我的程序源代码包含这些.h文件

include "cuda.h" include "mpi.h"

我运行命令: mpicc <filePath> -o test And error appear:cuda.h:没有这样的文件或目录 #include "cuda.h"`

omp_info 给我:mca:mpi:base:param:mpi_built_with_cuda_support:value:false

我用谷歌搜索过,我遵循了一些我发现的方法: ./configure --with-cuda ./configure --with-cuda=/usr/local/cuda-7.5 (来源链接:http://mirror.its.dal.ca/openmpi/faq/?category=buildcuda) 之后,我重新制作所有内容,重新制作安装 Open Mpi。我运行:mpicc 或 mpirun,编译器给我错误:mpirun error mca: base: component find: unable to open /usr/local/lib/openmpi/mca_mpool_sm

我设置了软链接:ln -s /usr/local/cuda/include /usr/include(在链接中描述:Building CUDA-aware openMPI on Ubuntu 12.04 cannot find cuda.h)。 但它不能解决我的问题。

有人成功安装了吗?请帮助我或分享您的经验。 谢谢。

【问题讨论】:

    标签: linux cuda mpi openmpi


    【解决方案1】:

    我认为您将安装问题与不正确的编译器选项混淆了。在使用 mpi 包装的主机编译器编译和链接主机代码时,有必要明确指定 CUDA 的包含路径、库路径和库。

    类似:

    mpicc -I/usr/local/cuda-7.5/include -L/usr/local/cuda-7.5/lib -o test <filePath> -lcuda
    

    将是构建调用 cuda 驱动程序 API 的简单 MPI 程序的常规方法。您需要为使用运行时 API 的设备代码和主机代码添加 nvcc 编译。

    在您的 MPI 风格中明显缺乏 CUDA 支持是一个单独的问题,您可能应该在另一个论坛中讨论这个问题(例如您使用的 MPI 风格的用户邮件列表)。

    【讨论】:

    • 你让我开心。现在我可以通过 mpicc/mpirun 编译和运行我的 Cuda-Aware MPI 代码。再次感谢。
    猜你喜欢
    • 2012-09-10
    • 2017-03-14
    • 2012-03-12
    • 1970-01-01
    • 2020-01-21
    • 2015-05-02
    • 2014-02-04
    • 2014-02-04
    • 1970-01-01
    相关资源
    最近更新 更多