mvapich: init at 2.3.6
This commit is contained in:
parent
ab0d28758e
commit
3ecfccd223
2 changed files with 75 additions and 0 deletions
73
pkgs/development/libraries/mvapich/default.nix
Normal file
73
pkgs/development/libraries/mvapich/default.nix
Normal file
|
@ -0,0 +1,73 @@
|
|||
{ lib, stdenv, fetchurl, pkg-config, bison, numactl, libxml2
|
||||
, perl, gfortran, slurm, openssh, hwloc, zlib, makeWrapper
|
||||
# InfiniBand dependencies
|
||||
, opensm, rdma-core
|
||||
# OmniPath dependencies
|
||||
, libpsm2, libfabric
|
||||
# Compile with slurm as a process manager
|
||||
, useSlurm ? false
|
||||
# Network type for MVAPICH2
|
||||
, network ? "ethernet"
|
||||
} :
|
||||
|
||||
assert builtins.elem network [ "ethernet" "infiniband" "omnipath" ];
|
||||
|
||||
stdenv.mkDerivation rec {
|
||||
pname = "mvapich";
|
||||
version = "2.3.6";
|
||||
|
||||
src = fetchurl {
|
||||
url = "http://mvapich.cse.ohio-state.edu/download/mvapich/mv2/mvapich2-${version}.tar.gz";
|
||||
sha256 = "0jd28vy9ivl3rcpkxmhw73b6krzm0pd9jps8asw92wa00lm2z9mk";
|
||||
};
|
||||
|
||||
nativeBuildInputs = [ pkg-config bison makeWrapper ];
|
||||
propagatedBuildInputs = [ numactl rdma-core zlib opensm ];
|
||||
buildInputs = with lib; [
|
||||
numactl
|
||||
libxml2
|
||||
perl
|
||||
gfortran
|
||||
openssh
|
||||
hwloc
|
||||
] ++ optionals (network == "infiniband") [ rdma-core opensm ]
|
||||
++ optionals (network == "omnipath") [ libpsm2 libfabric ]
|
||||
++ optional useSlurm slurm;
|
||||
|
||||
configureFlags = with lib; [
|
||||
"--with-pm=hydra"
|
||||
"--enable-fortran=all"
|
||||
"--enable-cxx"
|
||||
"--enable-threads=multiple"
|
||||
"--enable-hybrid"
|
||||
"--enable-shared"
|
||||
] ++ optional useSlurm "--with-pm=slurm"
|
||||
++ optional (network == "ethernet") "--with-device=ch3:sock"
|
||||
++ optionals (network == "infiniband") [ "--with-device=ch3:mrail" "--with-rdma=gen2" ]
|
||||
++ optionals (network == "omnipath") ["--with-device=ch3:psm" "--with-psm2=${libpsm2}"];
|
||||
|
||||
doCheck = true;
|
||||
|
||||
preFixup = ''
|
||||
# /tmp/nix-build... ends up in the RPATH, fix it manually
|
||||
for entry in $out/bin/mpichversion $out/bin/mpivars; do
|
||||
echo "fix rpath: $entry"
|
||||
patchelf --set-rpath "$out/lib" $entry
|
||||
done
|
||||
|
||||
# Ensure the default compilers are the ones mvapich was built with
|
||||
substituteInPlace $out/bin/mpicc --replace 'CC="gcc"' 'CC=${stdenv.cc}/bin/gcc'
|
||||
substituteInPlace $out/bin/mpicxx --replace 'CXX="g++"' 'CC=${stdenv.cc}/bin/g++'
|
||||
substituteInPlace $out/bin/mpifort --replace 'FC="gfortran"' 'CC=${gfortran}/bin/gfortran'
|
||||
'';
|
||||
|
||||
enableParallelBuilding = true;
|
||||
|
||||
meta = with lib; {
|
||||
description = "MPI-3.1 implementation optimized for Infiband transport";
|
||||
homepage = "https://mvapich.cse.ohio-state.edu";
|
||||
license = licenses.bsd3;
|
||||
maintainers = [ maintainers.markuskowa ];
|
||||
platforms = platforms.linux;
|
||||
};
|
||||
}
|
|
@ -17135,6 +17135,8 @@ in
|
|||
|
||||
mutest = callPackage ../development/libraries/mutest { };
|
||||
|
||||
mvapich = callPackage ../development/libraries/mvapich { };
|
||||
|
||||
mygpoclient = pythonPackages.mygpoclient;
|
||||
|
||||
mygui = callPackage ../development/libraries/mygui {
|
||||
|
|
Loading…
Reference in a new issue