Gentoo Archives: gentoo-commits

From: Justin Bronder <jsbronder@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: sys-cluster/openmpi/
Date: Thu, 01 Jun 2017 22:09:51
Message-Id: 1496354978.bf3a341097042030aaa61e391dc6707690aad5f0.jsbronder@gentoo
1 commit: bf3a341097042030aaa61e391dc6707690aad5f0
2 Author: Justin Bronder <jsbronder <AT> gentoo <DOT> org>
3 AuthorDate: Thu Jun 1 22:00:46 2017 +0000
4 Commit: Justin Bronder <jsbronder <AT> gentoo <DOT> org>
5 CommitDate: Thu Jun 1 22:09:38 2017 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bf3a3410
7
8 sys-cluster/openmpi: bump 2.0.3
9
10 Package-Manager: Portage-2.3.3, Repoman-2.3.1
11
12 sys-cluster/openmpi/Manifest | 1 +
13 sys-cluster/openmpi/openmpi-2.0.3.ebuild | 175 +++++++++++++++++++++++++++++++
14 2 files changed, 176 insertions(+)
15
16 diff --git a/sys-cluster/openmpi/Manifest b/sys-cluster/openmpi/Manifest
17 index 946008b428d..a39ba0ea0e4 100644
18 --- a/sys-cluster/openmpi/Manifest
19 +++ b/sys-cluster/openmpi/Manifest
20 @@ -7,4 +7,5 @@ DIST openmpi-1.8.4.tar.bz2 13488749 SHA256 23158d916e92c80e2924016b746a93913ba7f
21 DIST openmpi-1.8.7.tar.bz2 13228742 SHA256 da629e9bd820a379cfafe15f842ee9b628d7451856085ccc23ee75ab3e1b48c7 SHA512 953e007b00c9753bafc05d13e6f686c9aa47f76f55fcc4eda565174d410de059e07862b7e667d15df13afb80418661d9a8d5ee17fdcc211d3e044992cd9ceede WHIRLPOOL 374edbca97262217dfe405414deff2f6a3cacc06daec56e3356ea76f27804ef3caa3f37050dc8a81f257b83c1ced49fd5f66647c2cba4892fbe4ec9746a6f84e
22 DIST openmpi-1.8.8.tar.bz2 13231433 SHA256 a28382d1e6a36f4073412dc00836ff2524e42b674da9caf6ca7377baad790b94 SHA512 8ca2e3ebb9d9ba0f33faba9bef76fe95293721b73619cbc18176611074a56c277e9ab6cae7fa6c87ace11f16151c1bc495b2a8dbc8ad064d5a8f89f5d431a660 WHIRLPOOL e36186452978ba7a368c83b84b8b089f6995450fa866b7b8300d32eec7e64a816abf5f301dc716bf25b3b45b987489952ffc4b7057f4407677f2a2df5ee67cdd
23 DIST openmpi-2.0.2.tar.bz2 8311215 SHA256 cae396e643f9f91f0a795f8d8694adf7bacfb16f967c22fb39e9e28d477730d3 SHA512 87dc3c23db4b9cb92dbacc9b384b21ce8c4288fe4edc204fbf4a3bef70d8ac4329269e777ed190fa87933d78b73b9e5550ea3b925b2039599cfef3953567232a WHIRLPOOL 9403135fbf1682597c211b1ca0d1e300bd6f49294e9a70bf21f030c48a54f85d2d7ce8de8693dccaf81e2b46fbfd9a43a817bf598dc1f96e122b3f6ea6ffc3c6
24 +DIST openmpi-2.0.3.tar.bz2 8285131 SHA256 b52c0204c0e5954c9c57d383bb22b4181c09934f97783292927394d29f2a808a SHA512 158f90e3fac41540036d0c9cbcbf6abfe3f420c9f295d50a28f00e98181367769167dc3a59bb47ea34bdcd5a1c5a43bd2e77dad5b0c8b08d91f65340ff2b8547 WHIRLPOOL 07740f47814279f239aab0ef52f97fdd2c4a3ed5eb643ec5e9cf8b09d2096cbb8039f60d02153002c1035fc3514f7029b525b1fceb50bdbe05ec307c06fb7501
25 DIST openmpi-2.1.1.tar.bz2 8242859 SHA256 bd7badd4ff3afa448c0d7f3ca0ee6ce003b957e9954aa87d8e4435759b5e4d16 SHA512 c11bba6ec815f9c8d32fce3578f8995f6cd694e02fb850d7e6cd3975989bb38fdbef348064264a1de418d0a21411c70ca74347ecff4f27eb5a2f6835019d6bca WHIRLPOOL a1bda50b6ea982333b79feb2883b0e5f04f19f973fe50c467ffd209b4ff3a693b1b8378c25bc5afa5ccf7304d460938a15edbd24bc6119c1bb0b36f94dff6ac4
26
27 diff --git a/sys-cluster/openmpi/openmpi-2.0.3.ebuild b/sys-cluster/openmpi/openmpi-2.0.3.ebuild
28 new file mode 100644
29 index 00000000000..a711f277800
30 --- /dev/null
31 +++ b/sys-cluster/openmpi/openmpi-2.0.3.ebuild
32 @@ -0,0 +1,175 @@
33 +# Copyright 1999-2017 Gentoo Foundation
34 +# Distributed under the terms of the GNU General Public License v2
35 +
36 +EAPI=6
37 +
38 +FORTRAN_NEEDED=fortran
39 +
40 +inherit cuda flag-o-matic fortran-2 java-pkg-opt-2 toolchain-funcs versionator multilib-minimal
41 +
42 +MY_P=${P/-mpi}
43 +S=${WORKDIR}/${MY_P}
44 +
45 +IUSE_OPENMPI_FABRICS="
46 + openmpi_fabrics_ofed
47 + openmpi_fabrics_knem
48 + openmpi_fabrics_psm"
49 +
50 +IUSE_OPENMPI_RM="
51 + openmpi_rm_pbs
52 + openmpi_rm_slurm"
53 +
54 +IUSE_OPENMPI_OFED_FEATURES="
55 + openmpi_ofed_features_control-hdr-padding
56 + openmpi_ofed_features_connectx-xrc
57 + openmpi_ofed_features_udcm
58 + openmpi_ofed_features_rdmacm
59 + openmpi_ofed_features_dynamic-sl
60 + openmpi_ofed_features_failover"
61 +
62 +DESCRIPTION="A high-performance message passing library (MPI)"
63 +HOMEPAGE="http://www.open-mpi.org"
64 +SRC_URI="http://www.open-mpi.org/software/ompi/v$(get_version_component_range 1-2)/downloads/${MY_P}.tar.bz2"
65 +LICENSE="BSD"
66 +SLOT="0"
67 +KEYWORDS="~alpha ~amd64 ~arm ~ia64 ~ppc ~ppc64 ~sparc ~x86 ~amd64-fbsd ~x86-fbsd ~amd64-linux"
68 +IUSE="cma cuda cxx elibc_FreeBSD fortran heterogeneous ipv6 java mpi-threads numa romio threads
69 + ${IUSE_OPENMPI_FABRICS} ${IUSE_OPENMPI_RM} ${IUSE_OPENMPI_OFED_FEATURES}"
70 +
71 +REQUIRED_USE="openmpi_rm_slurm? ( !openmpi_rm_pbs )
72 + openmpi_rm_pbs? ( !openmpi_rm_slurm )
73 + openmpi_fabrics_psm? ( openmpi_fabrics_ofed )
74 + openmpi_ofed_features_control-hdr-padding? ( openmpi_fabrics_ofed )
75 + openmpi_ofed_features_connectx-xrc? ( openmpi_fabrics_ofed )
76 + openmpi_ofed_features_udcm? ( openmpi_fabrics_ofed )
77 + openmpi_ofed_features_rdmacm? ( openmpi_fabrics_ofed )
78 + openmpi_ofed_features_dynamic-sl? ( openmpi_fabrics_ofed )
79 + openmpi_ofed_features_failover? ( openmpi_fabrics_ofed )"
80 +
81 +# dev-util/nvidia-cuda-toolkit is always multilib
82 +CDEPEND="
83 + !sys-cluster/mpich
84 + !sys-cluster/mpich2
85 + !sys-cluster/nullmpi
86 + !sys-cluster/mpiexec
87 + >=dev-libs/libevent-2.0.22[${MULTILIB_USEDEP},threads]
88 + dev-libs/libltdl:0[${MULTILIB_USEDEP}]
89 + >=sys-apps/hwloc-1.11.2[${MULTILIB_USEDEP},numa?]
90 + >=sys-libs/zlib-1.2.8-r1[${MULTILIB_USEDEP}]
91 + cuda? ( >=dev-util/nvidia-cuda-toolkit-6.5.19-r1 )
92 + elibc_FreeBSD? ( dev-libs/libexecinfo )
93 + openmpi_fabrics_ofed? ( sys-fabric/ofed:* )
94 + openmpi_fabrics_knem? ( sys-cluster/knem )
95 + openmpi_fabrics_psm? ( sys-fabric/infinipath-psm:* )
96 + openmpi_rm_pbs? ( sys-cluster/torque )
97 + openmpi_rm_slurm? ( sys-cluster/slurm )
98 + openmpi_ofed_features_rdmacm? ( sys-fabric/librdmacm:* )"
99 +
100 +RDEPEND="${CDEPEND}
101 + java? ( >=virtual/jre-1.6 )"
102 +
103 +DEPEND="${CDEPEND}
104 + java? ( >=virtual/jdk-1.6 )"
105 +
106 +MULTILIB_WRAPPED_HEADERS=(
107 + /usr/include/mpi.h
108 + /usr/include/openmpi/ompi/mpi/java/mpiJava.h
109 +)
110 +
111 +pkg_setup() {
112 + fortran-2_pkg_setup
113 + java-pkg-opt-2_pkg_setup
114 +
115 + elog
116 + elog "OpenMPI has an overwhelming count of configuration options."
117 + elog "Don't forget the EXTRA_ECONF environment variable can let you"
118 + elog "specify configure options if you find them necessary."
119 + elog
120 +}
121 +
122 +src_prepare() {
123 + default
124 +
125 + # Necessary for scalibility, see
126 + # http://www.open-mpi.org/community/lists/users/2008/09/6514.php
127 + if use threads; then
128 + echo 'oob_tcp_listen_mode = listen_thread' \
129 + >> opal/etc/openmpi-mca-params.conf || die
130 + fi
131 +}
132 +
133 +multilib_src_configure() {
134 + if use java; then
135 + # We must always build with the right -source and -target
136 + # flags. Passing flags to javac isn't explicitly supported here
137 + # but we can cheat by overriding the configure test for javac.
138 + export ac_cv_path_JAVAC="$(java-pkg_get-javac) $(java-pkg_javac-args)"
139 + fi
140 +
141 + ECONF_SOURCE=${S} econf \
142 + --sysconfdir="${EPREFIX}/etc/${PN}" \
143 + --enable-pretty-print-stacktrace \
144 + --enable-orterun-prefix-by-default \
145 + --with-hwloc="${EPREFIX}/usr" \
146 + --with-libltdl="${EPREFIX}/usr" \
147 + --with-libevent="${EPREFIX}/usr" \
148 + --enable-mpi-fortran=$(usex fortran all no) \
149 + $(use_enable cxx mpi-cxx) \
150 + $(use_with cma) \
151 + $(use_with cuda cuda "${EPREFIX}"/opt/cuda) \
152 + $(use_enable romio io-romio) \
153 + $(use_enable heterogeneous) \
154 + $(use_enable ipv6) \
155 + $(multilib_native_use_enable java) \
156 + $(multilib_native_use_enable java mpi-java) \
157 + $(multilib_native_use_enable mpi-threads mpi-thread-multiple) \
158 + $(multilib_native_use_with openmpi_fabrics_ofed verbs "${EPREFIX}"/usr) \
159 + $(multilib_native_use_with openmpi_fabrics_knem knem "${EPREFIX}"/usr) \
160 + $(multilib_native_use_with openmpi_fabrics_psm psm "${EPREFIX}"/usr) \
161 + $(multilib_native_use_enable openmpi_ofed_features_control-hdr-padding openib-control-hdr-padding) \
162 + $(multilib_native_use_enable openmpi_ofed_features_connectx-xrc openib-connectx-xrc) \
163 + $(multilib_native_use_enable openmpi_ofed_features_rdmacm openib-rdmacm) \
164 + $(multilib_native_use_enable openmpi_ofed_features_udcm openib-udcm) \
165 + $(multilib_native_use_enable openmpi_ofed_features_dynamic-sl openib-dynamic-sl) \
166 + $(multilib_native_use_enable openmpi_ofed_features_failover btl-openib-failover) \
167 + $(multilib_native_use_with openmpi_rm_pbs tm) \
168 + $(multilib_native_use_with openmpi_rm_slurm slurm)
169 +}
170 +
171 +multilib_src_test() {
172 + # Doesn't work with the default src_test as the dry run (-n) fails.
173 + emake -j1 check
174 +}
175 +
176 +multilib_src_install() {
177 + default
178 +
179 + # fortran header cannot be wrapped (bug #540508), workaround part 1
180 + if multilib_is_native_abi && use fortran; then
181 + mkdir "${T}"/fortran || die
182 + mv "${ED}"usr/include/mpif* "${T}"/fortran || die
183 + else
184 + # some fortran files get installed unconditionally
185 + rm "${ED}"usr/include/mpif* "${ED}"usr/bin/mpif* || die
186 + fi
187 +}
188 +
189 +multilib_src_install_all() {
190 + # fortran header cannot be wrapped (bug #540508), workaround part 2
191 + if use fortran; then
192 + mv "${T}"/fortran/mpif* "${ED}"usr/include || die
193 + fi
194 +
195 + # Remove la files, no static libs are installed and we have pkg-config
196 + find "${ED}" -name '*.la' -delete || die
197 +
198 + if use java; then
199 + local mpi_jar="${ED}"usr/$(get_libdir)/mpi.jar
200 + java-pkg_dojar "${mpi_jar}"
201 + # We don't want to install the jar file twice
202 + # so let's clean after ourselves.
203 + rm "${mpi_jar}" || die
204 + fi
205 +
206 + einstalldocs
207 +}