You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gentoo-overlay/sys-cluster/mpich2/mpich2-1.4.1_p1.ebuild

166 lines
4.5 KiB

# Copyright 1999-2012 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/sys-cluster/mpich2/mpich2-1.4.1_p1.ebuild,v 1.1 2012/03/07 01:28:34 jsbronder Exp $
EAPI=4
inherit autotools eutils fortran-2 toolchain-funcs
MY_PV=${PV/_/}
DESCRIPTION="A high performance and portable MPI implementation"
HOMEPAGE="http://www.mcs.anl.gov/research/projects/mpich2/index.php"
SRC_URI="http://www.mcs.anl.gov/research/projects/mpich2/downloads/tarballs/${MY_PV}/${PN}-${MY_PV}.tar.gz"
LICENSE="as-is"
SLOT="0"
KEYWORDS="~amd64 ~hppa ~ppc ~ppc64 ~x86"
IUSE="+cxx debug doc fortran mpi-threads romio threads"
COMMON_DEPEND="dev-libs/libaio
sys-apps/hwloc
romio? ( net-fs/nfs-utils )"
DEPEND="${COMMON_DEPEND}
dev-lang/perl
sys-devel/libtool"
RDEPEND="${COMMON_DEPEND}
fortran? ( virtual/fortran )
!sys-cluster/openmpi
!sys-cluster/lam-mpi"
S="${WORKDIR}"/${PN}-${MY_PV}
pkg_setup() {
if use fortran; then
FORTRAN_STANDARD="77 90"
fortran-2_pkg_setup
fi
if use mpi-threads && ! use threads; then
ewarn "mpi-threads requires threads, assuming that's what you want"
fi
}
src_prepare() {
# Cannot use bin/mpiexec as hydra is built by autotools and is
# a shell wrapped executable.
sed -i \
-e "s,@MPIEXEC@,${S}/src/pm/hydra/mpiexec.hydra,g" \
$(find ./test/ -name 'Makefile.in') || die
# #293665
# We could use MPICH2LIB_XFLAGS here and unset the cooresponding ones
# in the environment, however that's messy and doesn't for for LDFLAGS.
sed -i \
-e 's,\(.*=\ *\)"@WRAPPER_[A-Z]*FLAGS@",\1"",' \
src/env/*.in || die
# See
# http://lists.mcs.anl.gov/pipermail/mpich-discuss/2011-August/010680.html
# http://lists.mcs.anl.gov/pipermail/mpich-discuss/2011-August/010678.html
# and countless other sources pointing out the insanity.
sed -i \
-e 's|prefix=${DESTDIR}|prefix=|g' \
-e 's|dir=${DESTDIR}|dir=|g' \
Makefile.in || die
sed -i \
-e "s|prefix='\${DESTDIR}|prefix='|" \
-e "s|dir='\${DESTDIR}|dir='|" \
src/env/Makefile.in || die
# 369263 and 1500 upstream.
epatch "${FILESDIR}"/mpich2-1.4.1-fix-pkg-config-files.patch
# 393361, backport of r8809 upstream.
epatch "${FILESDIR}"/mpich2-hvector.patch
AT_M4DIR="${S}"/confdb eautoreconf || die
}
src_configure() {
local c="--enable-shared --disable-rpath"
local romio_conf
# The configure statements can be somewhat confusing, as they
# don't all show up in the top level configure, however, they
# are picked up in the children directories.
use debug && c="${c} --enable-g=dbg --enable-debuginfo"
if use mpi-threads; then
# MPI-THREAD requries threading.
c="${c} --with-thread-package=pthreads"
c="${c} --enable-threads=runtime"
else
if use threads ; then
c="${c} --with-thread-package=pthreads"
else
c="${c} --with-thread-package=none"
fi
c="${c} --enable-threads=single"
fi
c="${c} --sysconfdir=${EPREFIX}/etc/${PN}"
econf ${c} ${romio_conf} \
--docdir=/usr/share/doc/${PF} \
--with-pm=hydra \
--disable-mpe \
--with-hwloc-prefix="${EPREFIX}/usr" \
--disable-fast \
--enable-smpcoll \
$(use_enable romio) \
$(use_enable cxx) \
$(use_enable fortran f77) \
$(use_enable fortran fc)
}
src_compile() {
# Oh, the irony.
# http://wiki.mcs.anl.gov/mpich2/index.php/Frequently_Asked_Questions#Q:_The_build_fails_when_I_use_parallel_make.
# https://trac.mcs.anl.gov/projects/mpich2/ticket/711
emake -j1
}
src_test() {
# See #362655 and comments in the testlist files.
# large_message: only on machines with > 8gb of ram
# bcastlength: This is an extension to MPI that's not necessary
# non_zero_root: performance test
# Also note that I/O tests may fail on non-local filesystems.
sed -i '/^[# ]*large_message/d' test/mpi/pt2pt/testlist || die
sed -i '/^[# ]*bcastlength/d' test/mpi/errors/coll/testlist || die
sed -i '/^[# ]*non_zero_root/d' test/mpi/perf/testlist || die
# Failing tests based on requiring MPI_THREAD_MULTIPLE.
# http://lists.mcs.anl.gov/pipermail/mpich-discuss/2012-January/011618.html
sed -i \
-e '/^[# ]*pt2pt/d' \
-e '/^[# ]*comm/d' \
-e '/^[# ]*spawn/d' \
test/mpi/threads/testlist || die
emake -j1 \
CC="${S}"/bin/mpicc \
CXX="${S}"/bin/mpicxx \
F77="${S}"/bin/mpif77 \
FC="${S}"/bin/mpif90 \
testing
}
src_install() {
emake -j1 DESTDIR="${D}" install
dodir /usr/share/doc/${PF}
dodoc COPYRIGHT README CHANGES RELEASE_NOTES || die
newdoc src/pm/hydra/README README.hydra|| die
if use romio; then
newdoc src/mpi/romio/README README.romio || die
fi
if ! use doc; then
rm -rf "${D}"/usr/share/doc/${PF}/www* || die
fi
}