2021-02-18 01:36:33 +00:00
|
|
|
%{!?python3_sitearch: %global python3_sitearch %(%{__python3} -c "from distutils.sysconfig import get_python_lib; print get_python_lib(1)")}
|
|
|
|
|
|
|
|
Name: mvapich2
|
2021-06-20 11:30:20 +00:00
|
|
|
Version: 2.3.6
|
|
|
|
Release: 1%{?dist}
|
2021-02-18 01:36:33 +00:00
|
|
|
Summary: OSU MVAPICH2 MPI package
|
|
|
|
Group: Development/Libraries
|
|
|
|
# Richard Fontana wrote in https://bugzilla.redhat.com/show_bug.cgi?id=1333114:
|
|
|
|
## The mvapich2 source code is predominantly 3-clause BSD with a smattering of
|
|
|
|
## 2-clause BSD, MIT and proto-MIT licensed source code. Under the license
|
|
|
|
## abbreviation system inherited from Fedora that set of licenses is adequately
|
|
|
|
## described as 'BSD and MIT'.
|
|
|
|
## There are a couple of source files that indicate they are taken from glibc
|
|
|
|
## with LGPL license notices, but context strongly suggests that the author of
|
|
|
|
## that particular code placed it under the MIT license (which is consistent
|
|
|
|
## with the approach to copyright assignment in glibc in which the author
|
|
|
|
## receives a broad grant-back license permitting sublicensing under terms
|
|
|
|
## other than LGPL).
|
|
|
|
License: BSD and MIT
|
|
|
|
URL: http://mvapich.cse.ohio-state.edu
|
2021-06-20 11:30:20 +00:00
|
|
|
Source: http://mvapich.cse.ohio-state.edu/download/mvapich/mv2/%{name}-%{version}.tar.gz
|
2021-02-18 01:36:33 +00:00
|
|
|
Source1: mvapich2.module.in
|
|
|
|
Source2: mvapich2.macros.in
|
|
|
|
# We delete bundled stuff in the prep step. The *-unbundle-* patches adjust
|
|
|
|
# the configure scripts and Makefiles accordingly.
|
2021-06-20 11:30:20 +00:00
|
|
|
Patch1: 0001-mvapich23-unbundle-contrib-hwloc.patch
|
|
|
|
Patch2: 0002-mvapich23-unbundle-osu_benchmarks.patch
|
2021-02-18 01:36:33 +00:00
|
|
|
|
|
|
|
BuildRequires: gcc-gfortran, gcc-c++
|
|
|
|
BuildRequires: libibumad-devel, libibverbs-devel >= 1.1.3, librdmacm-devel
|
|
|
|
BuildRequires: python3-devel, perl-Digest-MD5, hwloc-devel, rdma-core-devel
|
|
|
|
BuildRequires: bison, flex
|
|
|
|
BuildRequires: autoconf, automake, libtool
|
|
|
|
BuildRequires: rpm-mpi-hooks, rdma-core-devel, infiniband-diags-devel
|
2021-06-20 11:30:20 +00:00
|
|
|
%ifarch x86_64
|
|
|
|
BuildRequires: libpsm2-devel >= 10.3.58
|
|
|
|
%endif
|
2021-02-18 01:36:33 +00:00
|
|
|
ExcludeArch: s390 s390x
|
|
|
|
Provides: mpi
|
|
|
|
Requires: environment-modules
|
|
|
|
|
|
|
|
%global common_desc MVAPICH2 is a Message Passing Interface (MPI 3.0) implementation based on MPICH\
|
|
|
|
and developed by Ohio State University.
|
|
|
|
|
|
|
|
%description
|
|
|
|
%{common_desc}
|
|
|
|
|
|
|
|
%package devel
|
|
|
|
Summary: Development files for %{name}
|
|
|
|
Group: Development/Libraries
|
|
|
|
Provides: mpi-devel
|
|
|
|
Requires: librdmacm-devel, libibverbs-devel, libibumad-devel
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: gcc-gfortran
|
|
|
|
|
|
|
|
%description devel
|
|
|
|
Contains development headers and libraries for %{name}.
|
|
|
|
|
|
|
|
%package doc
|
|
|
|
Summary: Documentation files for mvapich2
|
|
|
|
Group: Documentation
|
|
|
|
BuildArch: noarch
|
|
|
|
|
|
|
|
%description doc
|
|
|
|
Additional documentation for mvapich2.
|
|
|
|
|
2021-06-20 11:30:20 +00:00
|
|
|
%ifarch x86_64
|
|
|
|
%package psm2
|
|
|
|
Summary: OSU MVAPICH2 MPI package 2.3 for Omni-Path adapters
|
|
|
|
Group: Development/Libraries
|
|
|
|
Provides: mpi
|
|
|
|
Requires: environment-modules
|
|
|
|
|
|
|
|
%description psm2
|
|
|
|
%{common_desc}
|
|
|
|
|
|
|
|
This is a version of mvapich2 2.3 that uses the PSM2 transport for Omni-Path
|
|
|
|
adapters.
|
|
|
|
|
|
|
|
%package psm2-devel
|
|
|
|
Summary: Development files for %{name}-psm2
|
|
|
|
Group: Development/Libraries
|
|
|
|
Provides: mpi-devel
|
|
|
|
Requires: librdmacm-devel, libibverbs-devel, libibumad-devel
|
|
|
|
Requires: %{name}-psm2%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: gcc-gfortran
|
|
|
|
|
|
|
|
%description psm2-devel
|
|
|
|
Contains development headers and libraries for %{name}-psm2.
|
|
|
|
|
|
|
|
%endif
|
|
|
|
|
2021-02-18 01:36:33 +00:00
|
|
|
%prep
|
2021-06-20 11:30:20 +00:00
|
|
|
%setup -q
|
2021-02-18 01:36:33 +00:00
|
|
|
%patch1 -p1
|
2021-06-20 11:30:20 +00:00
|
|
|
%patch2 -p1
|
2021-02-18 01:36:33 +00:00
|
|
|
# bundled hwloc, knem kernel module
|
|
|
|
rm -r contrib/
|
|
|
|
# limic kernel module
|
|
|
|
rm -r limic2-0.5.6/
|
|
|
|
# bundled OSU benchmarks
|
|
|
|
rm -r osu_benchmarks/
|
|
|
|
|
|
|
|
# Remove rpath, part 1
|
|
|
|
find . -name configure -exec \
|
|
|
|
sed -i -r 's/(hardcode_into_libs)=.*$/\1=no/' '{}' ';'
|
|
|
|
|
2021-06-20 11:30:20 +00:00
|
|
|
mkdir .default
|
|
|
|
mv * .default
|
|
|
|
mv .default default
|
|
|
|
|
|
|
|
%ifarch x86_64
|
|
|
|
cp -pr default psm2
|
|
|
|
%endif
|
|
|
|
|
|
|
|
|
2021-02-18 01:36:33 +00:00
|
|
|
%build
|
|
|
|
%set_build_flags
|
|
|
|
export FFLAGS="$FFLAGS -fallow-argument-mismatch"
|
|
|
|
export AR=ar
|
|
|
|
|
2021-06-20 11:30:20 +00:00
|
|
|
%ifarch x86_64
|
|
|
|
%global variant %{name}-psm2
|
|
|
|
%global libname %{variant}
|
|
|
|
%global namearch %{variant}-%{_arch}
|
|
|
|
|
|
|
|
cd psm2
|
|
|
|
./configure \
|
|
|
|
--prefix=%{_libdir}/%{libname} \
|
|
|
|
--exec-prefix=%{_libdir}/%{libname} \
|
|
|
|
--bindir=%{_libdir}/%{libname}/bin \
|
|
|
|
--sbindir=%{_libdir}/%{libname}/bin \
|
|
|
|
--libdir=%{_libdir}/%{libname}/lib \
|
|
|
|
--mandir=%{_mandir}/%{namearch} \
|
|
|
|
--includedir=%{_includedir}/%{namearch} \
|
|
|
|
--sysconfdir=%{_sysconfdir}/%{namearch} \
|
|
|
|
--datarootdir=%{_datadir}/%{libname} \
|
|
|
|
--docdir=%{_docdir}/%{name} \
|
|
|
|
--enable-error-checking=runtime \
|
|
|
|
--enable-timing=none \
|
|
|
|
--enable-g=mem,dbg,meminit \
|
|
|
|
--enable-fast=all \
|
|
|
|
--enable-shared \
|
|
|
|
--enable-static \
|
|
|
|
--enable-fortran=all \
|
|
|
|
--enable-cxx \
|
|
|
|
--disable-silent-rules \
|
|
|
|
--disable-wrapper-rpath \
|
|
|
|
--with-hwloc=v2 \
|
|
|
|
--with-device=ch3:psm
|
|
|
|
|
|
|
|
# Remove rpath, part 2
|
|
|
|
find . -name libtool -exec \
|
|
|
|
sed -i 's|^hardcode_libdir_flag_spec=.*|hardcode_libdir_flag_spec=""|g;
|
|
|
|
s|^runpath_var=LD_RUN_PATH|runpath_var=DIE_RPATH_DIE|g' '{}' ';'
|
|
|
|
make %{?_smp_mflags}
|
|
|
|
cd ..
|
|
|
|
%endif
|
|
|
|
|
2021-02-18 01:36:33 +00:00
|
|
|
%global variant %{name}
|
|
|
|
%global libname %{variant}
|
|
|
|
%global namearch %{variant}-%{_arch}
|
|
|
|
|
2021-06-20 11:30:20 +00:00
|
|
|
cd default
|
2021-02-18 01:36:33 +00:00
|
|
|
./configure \
|
|
|
|
--prefix=%{_libdir}/%{libname} \
|
|
|
|
--exec-prefix=%{_libdir}/%{libname} \
|
|
|
|
--bindir=%{_libdir}/%{libname}/bin \
|
|
|
|
--sbindir=%{_libdir}/%{libname}/bin \
|
|
|
|
--libdir=%{_libdir}/%{libname}/lib \
|
|
|
|
--mandir=%{_mandir}/%{namearch} \
|
|
|
|
--includedir=%{_includedir}/%{namearch} \
|
|
|
|
--sysconfdir=%{_sysconfdir}/%{namearch} \
|
|
|
|
--datarootdir=%{_datadir}/%{libname} \
|
|
|
|
--docdir=%{_docdir}/%{name} \
|
|
|
|
--enable-error-checking=runtime \
|
|
|
|
--enable-timing=none \
|
|
|
|
--enable-g=mem,dbg,meminit \
|
|
|
|
--enable-fast=all \
|
|
|
|
--enable-shared \
|
|
|
|
--enable-static \
|
|
|
|
--enable-fortran=all \
|
|
|
|
--enable-cxx \
|
|
|
|
--disable-silent-rules \
|
|
|
|
--disable-wrapper-rpath \
|
|
|
|
--with-hwloc=v2
|
|
|
|
|
|
|
|
# Remove rpath, part 2
|
|
|
|
find . -name libtool -exec \
|
|
|
|
sed -i 's|^hardcode_libdir_flag_spec=.*|hardcode_libdir_flag_spec=""|g;
|
|
|
|
s|^runpath_var=LD_RUN_PATH|runpath_var=DIE_RPATH_DIE|g' '{}' ';'
|
|
|
|
make %{?_smp_mflags}
|
2021-06-20 11:30:20 +00:00
|
|
|
cd ..
|
2021-02-18 01:36:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
%install
|
|
|
|
finish_install() {
|
|
|
|
local VARIANT="$1"
|
|
|
|
local LIBNAME="$VARIANT"
|
|
|
|
local NAMEARCH="$VARIANT-%{_arch}"
|
|
|
|
|
|
|
|
local MODULE_TEMPLATE="$2"
|
|
|
|
local MACROS_TEMPLATE="$3"
|
|
|
|
local FORTRAN_SUBDIR_SUFFIX="$4"
|
|
|
|
|
|
|
|
find %{buildroot}%{_libdir}/$LIBNAME/lib -name \*.la -delete
|
|
|
|
|
|
|
|
mkdir -p %{buildroot}%{_mandir}/$NAMEARCH/man{2,4,5,6,7,8,9,n}
|
|
|
|
mkdir -p %{buildroot}/%{_fmoddir}/$LIBNAME$FORTRAN_SUBDIR_SUFFIX
|
|
|
|
mkdir -p %{buildroot}/%{python3_sitearch}/$LIBNAME
|
|
|
|
|
|
|
|
# Make the environment-modules file
|
|
|
|
mkdir -p %{buildroot}%{_sysconfdir}/modulefiles/mpi
|
|
|
|
sed "s#@LIBDIR@#%{_libdir}/$LIBNAME#g;
|
|
|
|
s#@ETCDIR@#%{_sysconfdir}/$NAMEARCH#g;
|
|
|
|
s#@FMODDIR@#%{_fmoddir}/$LIBNAME$FORTRAN_SUBDIR_SUFFIX#g;
|
|
|
|
s#@INCDIR@#%{_includedir}/$NAMEARCH#g;
|
|
|
|
s#@MANDIR@#%{_mandir}/$NAMEARCH#g;
|
|
|
|
s#@PYSITEARCH@#%{python3_sitearch}/$LIBNAME#g;
|
|
|
|
s#@COMPILER@#$NAMEARCH#g;
|
|
|
|
s#@SUFFIX@#_$VARIANT#g" \
|
|
|
|
< $MODULE_TEMPLATE \
|
|
|
|
> %{buildroot}%{_sysconfdir}/modulefiles/mpi/$NAMEARCH
|
|
|
|
|
|
|
|
# make the rpm config file
|
|
|
|
mkdir -p %{buildroot}%{_sysconfdir}/rpm
|
|
|
|
# do not expand _arch
|
|
|
|
sed "s#@MACRONAME@#${LIBNAME//[-.]/_}#g;
|
|
|
|
s#@MODULENAME@#$NAMEARCH#" \
|
|
|
|
< $MACROS_TEMPLATE \
|
|
|
|
> %{buildroot}/%{_sysconfdir}/rpm/macros.$NAMEARCH
|
|
|
|
}
|
|
|
|
|
|
|
|
# 'make install' fails to mkdir docdir by itself before installing index.html
|
|
|
|
mkdir -p %{buildroot}%{_docdir}/%{name}
|
|
|
|
|
2021-06-20 11:30:20 +00:00
|
|
|
%ifarch x86_64
|
|
|
|
cd psm2
|
|
|
|
%make_install
|
|
|
|
finish_install %{name}-psm2 %SOURCE1 %SOURCE2 ""
|
|
|
|
cd ..
|
|
|
|
%endif
|
|
|
|
|
|
|
|
cd default
|
2021-02-18 01:36:33 +00:00
|
|
|
%make_install
|
|
|
|
finish_install %{name} %SOURCE1 %SOURCE2 ""
|
2021-06-20 11:30:20 +00:00
|
|
|
cd ..
|
2021-02-18 01:36:33 +00:00
|
|
|
|
|
|
|
%global variant %{name}
|
|
|
|
%global libname %{variant}
|
|
|
|
%global namearch %{variant}-%{_arch}
|
|
|
|
|
|
|
|
%files
|
|
|
|
%dir %{_libdir}/%{libname}
|
|
|
|
%dir %{_libdir}/%{libname}/bin
|
|
|
|
%dir %{_libdir}/%{libname}/lib
|
|
|
|
%dir %{_mandir}/%{namearch}
|
|
|
|
%dir %{_mandir}/%{namearch}/man*
|
|
|
|
%dir %{_fmoddir}/%{libname}
|
|
|
|
%dir %{python3_sitearch}/%{libname}
|
|
|
|
|
|
|
|
%{_libdir}/%{libname}/bin/hydra_nameserver
|
|
|
|
%{_libdir}/%{libname}/bin/hydra_persist
|
|
|
|
%{_libdir}/%{libname}/bin/hydra_pmi_proxy
|
|
|
|
%{_libdir}/%{libname}/bin/mpichversion
|
|
|
|
%{_libdir}/%{libname}/bin/mpiexec
|
|
|
|
%{_libdir}/%{libname}/bin/mpiexec.hydra
|
|
|
|
%{_libdir}/%{libname}/bin/mpiexec.mpirun_rsh
|
|
|
|
%{_libdir}/%{libname}/bin/mpiname
|
|
|
|
%{_libdir}/%{libname}/bin/mpirun
|
|
|
|
%{_libdir}/%{libname}/bin/mpirun_rsh
|
|
|
|
%{_libdir}/%{libname}/bin/mpispawn
|
|
|
|
%{_libdir}/%{libname}/bin/mpivars
|
|
|
|
%{_libdir}/%{libname}/bin/parkill
|
|
|
|
%{_libdir}/%{libname}/lib/*.so.*
|
|
|
|
%{_mandir}/%{namearch}/man1/hydra_*
|
|
|
|
%{_mandir}/%{namearch}/man1/mpiexec.*
|
|
|
|
%{_sysconfdir}/modulefiles/mpi/%{namearch}
|
|
|
|
|
|
|
|
%files devel
|
|
|
|
%dir %{_includedir}/%{namearch}
|
|
|
|
%{_sysconfdir}/rpm/macros.%{namearch}
|
|
|
|
%{_includedir}/%{namearch}/*
|
|
|
|
%{_libdir}/%{libname}/bin/mpic++
|
|
|
|
%{_libdir}/%{libname}/bin/mpicc
|
|
|
|
%{_libdir}/%{libname}/bin/mpicxx
|
|
|
|
%{_libdir}/%{libname}/bin/mpif77
|
|
|
|
%{_libdir}/%{libname}/bin/mpif90
|
|
|
|
%{_libdir}/%{libname}/bin/mpifort
|
|
|
|
%{_libdir}/%{libname}/lib/pkgconfig
|
|
|
|
%{_libdir}/%{libname}/lib/*.a
|
|
|
|
%{_libdir}/%{libname}/lib/*.so
|
|
|
|
%{_mandir}/%{namearch}/man1/mpi[cf]*
|
|
|
|
%{_mandir}/%{namearch}/man3/*
|
|
|
|
|
|
|
|
%files doc
|
|
|
|
%{_docdir}/%{name}
|
|
|
|
|
2021-06-20 11:30:20 +00:00
|
|
|
%ifarch x86_64
|
|
|
|
%global variant %{name}-psm2
|
|
|
|
%global libname %{variant}
|
|
|
|
%global namearch %{variant}-%{_arch}
|
|
|
|
|
|
|
|
%files psm2
|
|
|
|
%dir %{_libdir}/%{libname}
|
|
|
|
%dir %{_libdir}/%{libname}/bin
|
|
|
|
%dir %{_libdir}/%{libname}/lib
|
|
|
|
%dir %{_mandir}/%{namearch}
|
|
|
|
%dir %{_mandir}/%{namearch}/man*
|
|
|
|
%dir %{_fmoddir}/%{libname}
|
|
|
|
%dir %{python3_sitearch}/%{libname}
|
|
|
|
|
|
|
|
%{_libdir}/%{libname}/bin/hydra_nameserver
|
|
|
|
%{_libdir}/%{libname}/bin/hydra_persist
|
|
|
|
%{_libdir}/%{libname}/bin/hydra_pmi_proxy
|
|
|
|
%{_libdir}/%{libname}/bin/mpichversion
|
|
|
|
%{_libdir}/%{libname}/bin/mpiexec
|
|
|
|
%{_libdir}/%{libname}/bin/mpiexec.hydra
|
|
|
|
%{_libdir}/%{libname}/bin/mpiexec.mpirun_rsh
|
|
|
|
%{_libdir}/%{libname}/bin/mpiname
|
|
|
|
%{_libdir}/%{libname}/bin/mpirun
|
|
|
|
%{_libdir}/%{libname}/bin/mpirun_rsh
|
|
|
|
%{_libdir}/%{libname}/bin/mpispawn
|
|
|
|
%{_libdir}/%{libname}/bin/mpivars
|
|
|
|
%{_libdir}/%{libname}/bin/parkill
|
|
|
|
%{_libdir}/%{libname}/lib/*.so.*
|
|
|
|
%{_mandir}/%{namearch}/man1/hydra_*
|
|
|
|
%{_mandir}/%{namearch}/man1/mpiexec.*
|
|
|
|
%{_sysconfdir}/modulefiles/mpi/%{namearch}
|
|
|
|
|
|
|
|
%files psm2-devel
|
|
|
|
%dir %{_includedir}/%{namearch}
|
|
|
|
%{_sysconfdir}/rpm/macros.%{namearch}
|
|
|
|
%{_includedir}/%{namearch}/*
|
|
|
|
%{_libdir}/%{libname}/bin/mpic++
|
|
|
|
%{_libdir}/%{libname}/bin/mpicc
|
|
|
|
%{_libdir}/%{libname}/bin/mpicxx
|
|
|
|
%{_libdir}/%{libname}/bin/mpif77
|
|
|
|
%{_libdir}/%{libname}/bin/mpif90
|
|
|
|
%{_libdir}/%{libname}/bin/mpifort
|
|
|
|
%{_libdir}/%{libname}/lib/pkgconfig
|
|
|
|
%{_libdir}/%{libname}/lib/*.a
|
|
|
|
%{_libdir}/%{libname}/lib/*.so
|
|
|
|
%{_mandir}/%{namearch}/man1/mpi[cf]*
|
|
|
|
%{_mandir}/%{namearch}/man3/*
|
|
|
|
%endif
|
|
|
|
|
|
|
|
|
2021-02-18 01:36:33 +00:00
|
|
|
%changelog
|
2021-06-20 11:30:20 +00:00
|
|
|
* Sun Jun 20 2021 Honggang Li <honli@redhat.com> - 2.3.6-1
|
|
|
|
- Update to upstream stable point release v2.3.6
|
|
|
|
- Resolves: rhbz#1960478
|
|
|
|
|
2021-04-16 02:19:26 +00:00
|
|
|
* Fri Apr 16 2021 Mohan Boddu <mboddu@redhat.com> - 2.3.5-3
|
|
|
|
- Rebuilt for RHEL 9 BETA on Apr 15th 2021. Related: rhbz#1947937
|
|
|
|
|
2021-02-18 01:36:33 +00:00
|
|
|
* Wed Feb 17 2021 Honggang Li <honli@redhat.com> - 2.3.5-2
|
|
|
|
- build mvapich2-2.3.5-2.tar.gz for RHEL9
|
|
|
|
- Resolves: rhbz#1923559
|