From 04d88995828e555f45a75dc58668927ffe05bd4b Mon Sep 17 00:00:00 2001 From: Philip Kovacs Date: Fri, 30 Aug 2019 16:40:36 -0400 Subject: [PATCH] Apply upstream PR 6946 to avoid linking private glibc symbol __mmap Add build deps to run upstream autogen.pl Remove embedded tabs in the spec --- 6946.patch | 46 ++++++++++++++++++++ openmpi.spec | 116 ++++++++++++++++++++++++++++----------------------- 2 files changed, 110 insertions(+), 52 deletions(-) create mode 100644 6946.patch diff --git a/6946.patch b/6946.patch new file mode 100644 index 0000000..f40430d --- /dev/null +++ b/6946.patch @@ -0,0 +1,46 @@ +From fbbacc1303f02b4c955975911b82e8755ea0721c Mon Sep 17 00:00:00 2001 +From: Harumi Kuno +Date: Tue, 30 Jul 2019 06:32:27 -0700 +Subject: [PATCH] Fix mmap infinite recurse in memory patcher + +This commit fixes issue #6853 by removing +MacOS/Darwin-specific logic from intercept_mmap. + +Signed-off-by: Harumi Kuno +--- + opal/mca/memory/patcher/configure.m4 | 4 ---- + opal/mca/memory/patcher/memory_patcher_component.c | 5 ----- + 2 files changed, 9 deletions(-) + +diff --git a/opal/mca/memory/patcher/configure.m4 b/opal/mca/memory/patcher/configure.m4 +index 6881ec69366..0c5d8553259 100644 +--- a/opal/mca/memory/patcher/configure.m4 ++++ b/opal/mca/memory/patcher/configure.m4 +@@ -40,10 +40,6 @@ AC_DEFUN([MCA_opal_memory_patcher_CONFIG],[ + + AC_CHECK_HEADERS([linux/mman.h sys/syscall.h]) + +- AC_CHECK_DECLS([__mmap], [], [], [#include ]) +- +- AC_CHECK_FUNCS([__mmap]) +- + AC_CHECK_DECLS([__syscall], [], [], [#include ]) + + AC_CHECK_FUNCS([__syscall]) +diff --git a/opal/mca/memory/patcher/memory_patcher_component.c b/opal/mca/memory/patcher/memory_patcher_component.c +index 5db3a6016f8..687d430fa36 100644 +--- a/opal/mca/memory/patcher/memory_patcher_component.c ++++ b/opal/mca/memory/patcher/memory_patcher_component.c +@@ -125,12 +125,7 @@ static void *_intercept_mmap(void *start, size_t length, int prot, int flags, in + } + + if (!original_mmap) { +-#ifdef HAVE___MMAP +- /* the darwin syscall returns an int not a long so call the underlying __mmap function */ +- result = __mmap (start, length, prot, flags, fd, offset); +-#else + result = (void*)(intptr_t) memory_patcher_syscall(SYS_mmap, start, length, prot, flags, fd, offset); +-#endif + } else { + result = original_mmap (start, length, prot, flags, fd, offset); + } diff --git a/openmpi.spec b/openmpi.spec index da5c4ca..9a01566 100644 --- a/openmpi.spec +++ b/openmpi.spec @@ -30,71 +30,77 @@ %bcond_with ucx %endif -Name: openmpi%{?_cc_name_suffix} -Version: 4.0.2 -Release: 0.1.rc1%{?dist} -Summary: Open Message Passing Interface -License: BSD and MIT and Romio -URL: http://www.open-mpi.org/ +Name: openmpi%{?_cc_name_suffix} +Version: 4.0.2 +Release: 0.2.rc1%{?dist} +Summary: Open Message Passing Interface +License: BSD and MIT and Romio +URL: http://www.open-mpi.org/ # We can't use %%{name} here because of _cc_name_suffix -Source0: https://www.open-mpi.org/software/ompi/v4.0/downloads/openmpi-%{version}rc1.tar.bz2 -Source1: openmpi.module.in -Source2: openmpi.pth.py2 -Source3: openmpi.pth.py3 -Source4: macros.openmpi +Source0: https://www.open-mpi.org/software/ompi/v4.0/downloads/openmpi-%{version}rc1.tar.bz2 +Source1: openmpi.module.in +Source2: openmpi.pth.py2 +Source3: openmpi.pth.py3 +Source4: macros.openmpi +# Upstream PR 6946 to avoid linking private glibc symbol __mmap +Patch0: https://patch-diff.githubusercontent.com/raw/open-mpi/ompi/pull/6946.patch -BuildRequires: gcc-c++ -BuildRequires: gcc-gfortran -BuildRequires: valgrind-devel +BuildRequires: autoconf +BuildRequires: automake +BuildRequires: gcc-c++ +BuildRequires: gcc-gfortran +BuildRequires: libtool +BuildRequires: valgrind-devel %ifnarch %{arm} -BuildRequires: opensm-devel > 3.3.0 +BuildRequires: opensm-devel > 3.3.0 %endif -BuildRequires: rdma-core-devel +BuildRequires: rdma-core-devel # Doesn't compile: # vt_dyn.cc:958:28: error: 'class BPatch_basicBlockLoop' has no member named 'getLoopHead' # loop->getLoopHead()->getStartAddress(), loop_stmts ); -#BuildRequires: dyninst-devel -BuildRequires: hwloc-devel +#BuildRequires: dyninst-devel +BuildRequires: hwloc-devel # So configure can find lstopo -BuildRequires: hwloc-gui -BuildRequires: java-devel +BuildRequires: hwloc-gui +BuildRequires: java-devel # Old libevent causes issues %if !0%{?el7} -BuildRequires: libevent-devel +BuildRequires: libevent-devel %endif -BuildRequires: libfabric-devel +BuildRequires: libfabric-devel %ifnarch s390 s390x -BuildRequires: papi-devel +BuildRequires: papi-devel %endif -BuildRequires: orangefs-devel -BuildRequires: perl-generators -BuildRequires: perl(Getopt::Long) -BuildRequires: pmix-devel -BuildRequires: python2 -BuildRequires: python2-devel -BuildRequires: python%{python3_pkgversion}-devel +BuildRequires: orangefs-devel +BuildRequires: perl-generators +BuildRequires: perl-interpreter +BuildRequires: perl(Getopt::Long) +BuildRequires: pmix-devel +BuildRequires: python2 +BuildRequires: python2-devel +BuildRequires: python%{python3_pkgversion}-devel %ifarch x86_64 -BuildRequires: infinipath-psm-devel -BuildRequires: libpsm2-devel +BuildRequires: infinipath-psm-devel +BuildRequires: libpsm2-devel %endif %if %{with ucx} -BuildRequires: ucx-devel +BuildRequires: ucx-devel %endif -BuildRequires: zlib-devel +BuildRequires: zlib-devel %if !0%{?el7} -BuildRequires: rpm-mpi-hooks +BuildRequires: rpm-mpi-hooks %endif -Provides: mpi +Provides: mpi %if 0%{?rhel} # Need this for /etc/profile.d/modules.sh -Requires: environment-modules +Requires: environment-modules %endif -Requires: environment(modules) +Requires: environment(modules) # openmpi currently requires ssh to run # https://svn.open-mpi.org/trac/ompi/ticket/4228 -Requires: openssh-clients +Requires: openssh-clients # Private openmpi libraries %global __provides_exclude_from %{_libdir}/openmpi/lib/(lib(mca|ompi|open-(pal|rte|trace))|openmpi/).*.so @@ -125,21 +131,21 @@ Requires: (python(abi) = %{python3_version} if python3) Contains development headers and libraries for openmpi. %package java -Summary: Java library -Requires: %{name} = %{version}-%{release} +Summary: Java library +Requires: %{name} = %{version}-%{release} %if 0%{?fedora} >= 20 || 0%{?rhel} >= 7 -Requires: java-headless +Requires: java-headless %else -Requires: java +Requires: java %endif %description java Java library. %package java-devel -Summary: Java development files for openmpi -Requires: %{name}-java = %{version}-%{release} -Requires: java-devel +Summary: Java development files for openmpi +Requires: %{name}-java = %{version}-%{release} +Requires: java-devel %description java-devel Contains development wrapper for compiling Java with openmpi. @@ -149,17 +155,17 @@ Contains development wrapper for compiling Java with openmpi. %global namearch openmpi-%{_arch}%{?_cc_name_suffix} %package -n python2-openmpi -Summary: OpenMPI support for Python 2 -Requires: %{name} = %{version}-%{release} -Requires: python(abi) = %{python2_version} +Summary: OpenMPI support for Python 2 +Requires: %{name} = %{version}-%{release} +Requires: python(abi) = %{python2_version} %description -n python2-openmpi OpenMPI support for Python 2. %package -n python%{python3_pkgversion}-openmpi -Summary: OpenMPI support for Python 3 -Requires: %{name} = %{version}-%{release} -Requires: python(abi) = %{python3_version} +Summary: OpenMPI support for Python 3 +Requires: %{name} = %{version}-%{release} +Requires: python(abi) = %{python3_version} %description -n python%{python3_pkgversion}-openmpi OpenMPI support for Python 3. @@ -169,6 +175,7 @@ OpenMPI support for Python 3. %autosetup -p1 -n openmpi-%{version}rc1 %build +./autogen.pl --force ./configure --prefix=%{_libdir}/%{name} \ --mandir=%{_mandir}/%{namearch} \ --includedir=%{_includedir}/%{namearch} \ @@ -347,6 +354,11 @@ make check %changelog +* Fri Aug 30 2019 Philip Kovacs - 4.0.2-0.2.rc1 +- Apply upstream PR 6946 to avoid linking private glibc symbol __mmap +- Add build deps to run upstream autogen.pl +- Remove embedded tabs in the spec + * Thu Aug 29 2019 Philip Kovacs - 4.0.2-0.1.rc1 - Update to 4.0.2rc1 - Closes bug #1746564