From d145f6ddafc6ae741d621ddc6016b31be46deaac Mon Sep 17 00:00:00 2001 From: MSVSphere Packaging Team Date: Thu, 28 Mar 2024 18:06:18 +0300 Subject: [PATCH] import pmix-3.2.3-5.el9 --- .gitignore | 1 + .pmix.metadata | 1 + ...Do-not-follow-links-when-doing-chown.patch | 133 ++++++++ SPECS/pmix.spec | 307 ++++++++++++++++++ 4 files changed, 442 insertions(+) create mode 100644 .gitignore create mode 100644 .pmix.metadata create mode 100644 SOURCES/0001-Do-not-follow-links-when-doing-chown.patch create mode 100644 SPECS/pmix.spec diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..0676d5b --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +SOURCES/pmix-3.2.3.tar.bz2 diff --git a/.pmix.metadata b/.pmix.metadata new file mode 100644 index 0000000..19dfe95 --- /dev/null +++ b/.pmix.metadata @@ -0,0 +1 @@ +97978abcd4da1b2a3d2bf2452247c4d47f8cc6a3 SOURCES/pmix-3.2.3.tar.bz2 diff --git a/SOURCES/0001-Do-not-follow-links-when-doing-chown.patch b/SOURCES/0001-Do-not-follow-links-when-doing-chown.patch new file mode 100644 index 0000000..9a7ae26 --- /dev/null +++ b/SOURCES/0001-Do-not-follow-links-when-doing-chown.patch @@ -0,0 +1,133 @@ +From 247fe50c796402ccb1734e66dcc1f0ee4c196774 Mon Sep 17 00:00:00 2001 +From: Ralph Castain +Date: Thu, 7 Sep 2023 07:59:57 -0600 +Subject: [PATCH] Do not follow links when doing "chown" + +There is a potential issue with allowing a "chown" operation +to follow user-created links, so let's limit any use of that +function to "lchown" - which directs the "chown" operation to +NOT follow a link. + +Signed-off-by: Ralph Castain +(cherry picked from commit ae62cdf67b19e80fd821420816f09bf0a56a8166) +(cherry picked from commit da036933c2795c1f40d0835e15f17e204e4daf0f) +Signed-off-by: Kamal Heib +--- + src/mca/common/dstore/dstore_base.c | 4 ++-- + src/mca/common/dstore/dstore_segment.c | 4 ++-- + src/mca/gds/ds12/gds_ds12_lock_fcntl.c | 2 +- + src/mca/gds/ds12/gds_ds12_lock_pthread.c | 2 +- + src/mca/ptl/usock/ptl_usock_component.c | 6 +++--- + src/util/pmix_pty.c | 2 +- + 6 files changed, 10 insertions(+), 10 deletions(-) + +diff --git a/src/mca/common/dstore/dstore_base.c b/src/mca/common/dstore/dstore_base.c +index f22461cdeb7a..7ff2e4d6aa2c 100644 +--- a/src/mca/common/dstore/dstore_base.c ++++ b/src/mca/common/dstore/dstore_base.c +@@ -528,7 +528,7 @@ static int _esh_session_init(pmix_common_dstore_ctx_t *ds_ctx, size_t idx, ns_ma + } + } + if (s->setjobuid > 0){ +- if (0 > chown(s->nspace_path, (uid_t) s->jobuid, (gid_t) -1)){ ++ if (0 > lchown(s->nspace_path, (uid_t) s->jobuid, (gid_t) -1)){ + rc = PMIX_ERROR; + PMIX_ERROR_LOG(rc); + return rc; +@@ -1682,7 +1682,7 @@ pmix_common_dstore_ctx_t *pmix_common_dstor_init(const char *ds_name, pmix_info_ + } + } + if (ds_ctx->setjobuid > 0) { +- if (chown(ds_ctx->base_path, (uid_t) ds_ctx->jobuid, (gid_t) -1) < 0){ ++ if (lchown(ds_ctx->base_path, (uid_t) ds_ctx->jobuid, (gid_t) -1) < 0){ + rc = PMIX_ERR_NO_PERMISSIONS; + PMIX_ERROR_LOG(rc); + goto err_exit; +diff --git a/src/mca/common/dstore/dstore_segment.c b/src/mca/common/dstore/dstore_segment.c +index f0c4f9bb9efc..0e68dbf4fedf 100644 +--- a/src/mca/common/dstore/dstore_segment.c ++++ b/src/mca/common/dstore/dstore_segment.c +@@ -120,7 +120,7 @@ PMIX_EXPORT pmix_dstore_seg_desc_t *pmix_common_dstor_create_new_lock_seg(const + + if (setuid > 0){ + rc = PMIX_ERR_PERM; +- if (0 > chown(file_name, (uid_t) uid, (gid_t) -1)){ ++ if (0 > lchown(file_name, (uid_t) uid, (gid_t) -1)){ + PMIX_ERROR_LOG(rc); + goto err_exit; + } +@@ -211,7 +211,7 @@ PMIX_EXPORT pmix_dstore_seg_desc_t *pmix_common_dstor_create_new_segment(pmix_ds + + if (setuid > 0){ + rc = PMIX_ERR_PERM; +- if (0 > chown(file_name, (uid_t) uid, (gid_t) -1)){ ++ if (0 > lchown(file_name, (uid_t) uid, (gid_t) -1)){ + PMIX_ERROR_LOG(rc); + goto err_exit; + } +diff --git a/src/mca/gds/ds12/gds_ds12_lock_fcntl.c b/src/mca/gds/ds12/gds_ds12_lock_fcntl.c +index 445231668c57..82b6d358316e 100644 +--- a/src/mca/gds/ds12/gds_ds12_lock_fcntl.c ++++ b/src/mca/gds/ds12/gds_ds12_lock_fcntl.c +@@ -127,7 +127,7 @@ pmix_status_t pmix_gds_ds12_lock_init(pmix_common_dstor_lock_ctx_t *ctx, const c + } + } + if (0 != setuid) { +- if (0 > chown(lock_ctx->lockfile, uid, (gid_t) -1)) { ++ if (0 > lchown(lock_ctx->lockfile, uid, (gid_t) -1)) { + rc = PMIX_ERROR; + PMIX_ERROR_LOG(rc); + goto error; +diff --git a/src/mca/gds/ds12/gds_ds12_lock_pthread.c b/src/mca/gds/ds12/gds_ds12_lock_pthread.c +index 8192f0532e03..57d855f52049 100644 +--- a/src/mca/gds/ds12/gds_ds12_lock_pthread.c ++++ b/src/mca/gds/ds12/gds_ds12_lock_pthread.c +@@ -113,7 +113,7 @@ pmix_status_t pmix_gds_ds12_lock_init(pmix_common_dstor_lock_ctx_t *ctx, const c + } + memset(lock_ctx->segment->seg_base_addr, 0, size); + if (0 != setuid) { +- if (0 > chown(lock_ctx->lockfile, (uid_t) uid, (gid_t) -1)){ ++ if (0 > lchown(lock_ctx->lockfile, (uid_t) uid, (gid_t) -1)){ + rc = PMIX_ERROR; + PMIX_ERROR_LOG(rc); + goto error; +diff --git a/src/mca/ptl/usock/ptl_usock_component.c b/src/mca/ptl/usock/ptl_usock_component.c +index 312030250a9d..660b03370ac1 100644 +--- a/src/mca/ptl/usock/ptl_usock_component.c ++++ b/src/mca/ptl/usock/ptl_usock_component.c +@@ -265,16 +265,16 @@ static pmix_status_t setup_listener(pmix_info_t info[], size_t ninfo, + CLOSE_THE_SOCKET(lt->socket); + goto sockerror; + } +- /* chown as required */ ++ /* lchown as required */ + if (lt->owner_given) { +- if (0 != chown(address->sun_path, lt->owner, -1)) { ++ if (0 != lchown(address->sun_path, lt->owner, -1)) { + pmix_output(0, "CANNOT CHOWN socket %s: %s", address->sun_path, strerror (errno)); + CLOSE_THE_SOCKET(lt->socket); + goto sockerror; + } + } + if (lt->group_given) { +- if (0 != chown(address->sun_path, -1, lt->group)) { ++ if (0 != lchown(address->sun_path, -1, lt->group)) { + pmix_output(0, "CANNOT CHOWN socket %s: %s", address->sun_path, strerror (errno)); + CLOSE_THE_SOCKET(lt->socket); + goto sockerror; +diff --git a/src/util/pmix_pty.c b/src/util/pmix_pty.c +index 58e8d5143e8a..e01b854d17f0 100644 +--- a/src/util/pmix_pty.c ++++ b/src/util/pmix_pty.c +@@ -248,7 +248,7 @@ static int ptys_open(int fdm, char *pts_name) + gid = -1; /* group tty is not in the group file */ + } + /* following two functions don't work unless we're root */ +- chown(pts_name, getuid(), gid); ++ lchown(pts_name, getuid(), gid); // DO NOT FOLLOW LINKS + chmod(pts_name, S_IRUSR | S_IWUSR | S_IWGRP); + fds = open(pts_name, O_RDWR); + if (fds < 0) { +-- +2.41.0 + diff --git a/SPECS/pmix.spec b/SPECS/pmix.spec new file mode 100644 index 0000000..3471b47 --- /dev/null +++ b/SPECS/pmix.spec @@ -0,0 +1,307 @@ +Name: pmix +Version: 3.2.3 +Release: 5%{?dist} +Summary: Process Management Interface Exascale (PMIx) +License: BSD +URL: https://pmix.org/ +Source0: https://github.com/pmix/%{name}/releases/download/v%{version}/%{name}-%{version}.tar.bz2 + +Patch1: 0001-Do-not-follow-links-when-doing-chown.patch + +BuildRequires: autoconf +BuildRequires: automake +BuildRequires: flex +BuildRequires: gcc +BuildRequires: hwloc-devel +BuildRequires: libevent-devel +BuildRequires: libtool +BuildRequires: make +BuildRequires: munge-devel +BuildRequires: perl-interpreter + +%description +The Process Management Interface (PMI) has been used for quite some time as +a means of exchanging wireup information needed for interprocess +communication. Two versions (PMI-1 and PMI-2) have been released as part of +the MPICH effort. While PMI-2 demonstrates better scaling properties than its +PMI-1 predecessor, attaining rapid launch and wireup of the roughly 1M +processes executing across 100k nodes expected for exascale operations remains +challenging. + +PMI Exascale (PMIx) represents an attempt to resolve these questions by +providing an extended version of the PMI standard specifically designed to +support clusters up to and including exascale sizes. The overall objective of +the project is not to branch the existing pseudo-standard definitions - in +fact, PMIx fully supports both of the existing PMI-1 and PMI-2 APIs - but +rather to (a) augment and extend those APIs to eliminate some current +restrictions that impact scalability, and (b) provide a reference +implementation of the PMI-server that demonstrates the desired level of +scalability. + +%package devel +Summary: Development files for %{name} +Requires: %{name}%{?_isa} = %{version}-%{release} +%description devel +The %{name}-devel package contains libraries and header files for +developing applications that use %{name}. + +%package pmi +Summary: The %{name} implementation of libpmi and libpmi2 +Requires: %{name}%{?_isa} = %{version}-%{release} +Conflicts: slurm-pmi +%description pmi +The %{name}-pmi package contains the %{name} implementation of +the libpmi and libpmi2 backward-compatibility libraries. + +%package pmi-devel +Summary: Development files for %{name}-pmi +Requires: %{name}-pmi%{?_isa} = %{version}-%{release} +Conflicts: slurm-pmi-devel +%description pmi-devel +The %{name}-pmi-devel package contains the development files for +the libpmi and libpmi2 backward-compatibility libraries. + +%package tools +Summary: Tools for %{name} +Requires: %{name}%{?_isa} = %{version}-%{release} +%description tools +The %{name}-tools package contains for use with PMIx-based RMs and language- +based starters (e.g., mpirun). + +* pinfo - show MCA params, build info, etc. +* pps - get list of active nspaces, retrieve status of jobs/nodes/procs +* pevent - inject an event into the system + +%prep +%setup -q -n %{name}-%{version} + +%patch1 -p1 + +# touch lexer sources to recompile them +find src -name \*.l -print -exec touch --no-create {} \; + +%build +%{_builddir}/%{name}-%{version}/autogen.pl +%configure \ + --prefix=%{_prefix} \ + --sysconfdir=%{_sysconfdir}/%{name} \ + --disable-static \ + --disable-silent-rules \ + --with-tests-examples \ + --enable-shared \ + --enable-pmi-backward-compatibility \ + --with-munge + +%make_build + +%check +%make_build check + +%install +%make_install + +# remove libtool archives +find %{buildroot} -name '*.la' | xargs rm -f + +# set up pmix self-test infra for install +install -d -m 0755 %{buildroot}%{_datadir}/%{name}/test +for f in pmix_client pmix_regex +do + mv test/.libs/$f %{buildroot}%{_datadir}/%{name}/$f +done +mv test/.libs/pmix_test %{buildroot}%{_datadir}/%{name}/test/pmix_test + +%ldconfig_scriptlets +%ldconfig_scriptlets devel + +%files +%license LICENSE +%doc README +%dir %{_datadir}/%{name} +%dir %{_datadir}/%{name}/test +%dir %{_libdir}/%{name} +%dir %{_sysconfdir}/%{name} +%config(noreplace) %{_sysconfdir}/%{name}/*.conf +%{_datadir}/%{name}/*.txt +%{_datadir}/%{name}/pmix_* +%{_datadir}/%{name}/test/pmix_test +%{_libdir}/libmca_common_dstore.so.1* +%{_libdir}/libpmix.so.2* +%{_libdir}/%{name}/*.so + +%files devel +%{_datadir}/%{name}/*.supp +%{_includedir}/pmix*.h +%{_libdir}/libmca_common_dstore.so +%{_libdir}/libpmix.so +%{_libdir}/pkgconfig/*.pc + +%files pmi +%{_libdir}/libpmi.so.1* +%{_libdir}/libpmi2.so.1* + +%files pmi-devel +%{_includedir}/{pmi,pmi2}.h +%{_libdir}/libpmi.so +%{_libdir}/libpmi2.so + +%files tools +%{_bindir}/* + +%changelog +* Tue Nov 14 2023 Kamal Heib - 3.2.3-5 +- Add pmix_test +- Resolves: RHEL-3693 + +* Thu Nov 02 2023 Kamal Heib - 3.2.3-4 +- Fix CVE-2023-41915 +- Resolves: RHEL-3693 + +* Mon Aug 09 2021 Mohan Boddu - 3.2.3-3 +- Rebuilt for IMA sigs, glibc 2.34, aarch64 flags + Related: rhbz#1991688 + +* Fri Apr 16 2021 Mohan Boddu - 3.2.3-2 +- Rebuilt for RHEL 9 BETA on Apr 15th 2021. Related: rhbz#1947937 + +* Tue Feb 16 2021 Philip Kovacs - 3.2.3-1 +* Update to 3.2.3 + +* Wed Jan 27 2021 Fedora Release Engineering - 3.2.2-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild + +* Wed Dec 9 2020 Philip Kovacs - 3.2.2-1 +* Update to 3.2.2 + +* Fri Nov 13 2020 Philip Kovacs - 3.2.1-1 +* Update to 3.2.1 + +* Fri Oct 30 2020 Philip Kovacs - 3.2.1.0.1.rc1 +* Update to 3.2.1rc1 + +* Tue Sep 15 2020 Philip Kovacs - 3.1.6.0.2.rc1 +* Bump for libevent changes + +* Mon Aug 10 2020 Philip Kovacs - 3.1.6.0.1.rc1 +* Update to 3.1.6rc1 + +* Fri Aug 7 2020 Philip Kovacs - 3.1.5-6 +- Give post-build checks more time to complete + +* Thu Aug 6 2020 Philip Kovacs - 3.1.5-5 +- Restore armv7hl without post-build checks + +* Tue Aug 4 2020 Philip Kovacs - 3.1.5-4 +- Exclude armv7hl + +* Sat Aug 01 2020 Fedora Release Engineering - 3.1.5-3 +- Second attempt - Rebuilt for + https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Tue Jul 28 2020 Fedora Release Engineering - 3.1.5-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Mon Feb 24 2020 Philip Kovacs - 3.1.5-1 +- Update to 3.1.5 + +* Thu Feb 20 2020 Philip Kovacs - 3.1.5-0.4.rc4 +- Update to 3.1.5rc4 + +* Wed Feb 12 2020 Philip Kovacs - 3.1.5-0.3.rc3 +- Update to 3.1.5rc3 + +* Mon Feb 10 2020 Philip Kovacs - 3.1.5-0.2.rc2 +- Update to 3.1.5rc2 + +* Thu Jan 30 2020 Fedora Release Engineering - 3.1.4-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild + +* Sun Aug 25 2019 Zbigniew Jędrzejewski-Szmek - 3.1.4-2 +- Rebuilt for hwloc-2.0 + +* Fri Aug 9 2019 Philip Kovacs - 3.1.4-1 +- Update to 3.1.4 + +* Fri Jul 26 2019 Fedora Release Engineering - 3.1.4-0.4.rc2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild + +* Sun Jul 21 2019 Philip Kovacs - 3.1.4-0.3.rc2 +- Create pmix-pmi and pmix-pmi-devel subpackages for pmi/pmi2 libs +- Remove rpm-generated pkgconfig files until upstream provides them +- Do not pull dependencies with pkgconfig unless package uses it + +* Sat Jul 20 2019 Philip Kovacs - 3.1.4-0.2.rc2 +- Update to 3.1.4rc2 + +* Fri Jul 19 2019 Philip Kovacs - 3.1.4-0.1.rc1 +- Update to 3.1.4rc1 + +* Sat Jul 13 2019 Philip Kovacs - 3.1.3-1 +- Update to 3.1.3 + +* Tue Jul 2 2019 Philip Kovacs - 3.1.2-2 +- Install libpmi/pmi2 backward-compatible libraries normally, +- not as a pmi environment module + +* Wed Jun 19 2019 Philip Kovacs - 3.1.2-1 +- Update to 3.1.2 +- Replace __make with make + +* Sat Feb 02 2019 Fedora Release Engineering - 3.0.2-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild + +* Sun Nov 25 2018 Orion Poplawski - 3.0.2-1 +- Update to 3.0.2 + +* Mon Oct 1 2018 Philip Kovacs - 2.1.4-1 +- Update to 2.1.4 + +* Fri Mar 16 2018 Philip Kovacs - 2.1.1-1 +- Update to 2.1.1 + +* Sun Feb 18 2018 Philip Kovacs - 2.1.0-3 +- Add patch to remove unneeded check for C++ + +* Thu Feb 15 2018 Philip Kovacs - 2.1.0-2 +- Rebuild for libevent soname bump + +* Sat Feb 10 2018 Philip Kovacs - 2.1.0-1 +- Update to 2.1.0 +- Added enviromnent module for pmi/pmix +- Added pkgconfig files for pmix/pmi/pmi2 +- Ensure lexer sources are rebuilt +- Removed obsolete sasl support +- Use new ldconfig_scriplets macro + +* Fri Feb 09 2018 Fedora Release Engineering - 1.2.2-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild + +* Thu Aug 03 2017 Fedora Release Engineering - 1.2.2-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Binutils_Mass_Rebuild + +* Thu Jul 27 2017 Fedora Release Engineering - 1.2.2-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild + +* Tue Mar 21 2017 Orion Poplawski - 1.2.2-1 +- Update to 1.2.2 + +* Sat Feb 11 2017 Fedora Release Engineering - 1.1.5-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild + +* Wed Sep 7 2016 Orion Poplawski - 1.1.5-1 +- Update to 1.1.5 + +* Fri Jun 10 2016 Orion Poplawski - 1.1.4-1 +- Update to 1.1.4 + +* Tue Mar 8 2016 Orion Poplawski - 1.1.3-1 +- Update to 1.1.3 + +* Mon Nov 16 2015 Orion Poplawski - 1.1.1-1 +- Update to 1.1.1 + +* Sat Nov 14 2015 Orion Poplawski - 1.1.0-1 +- Update to 1.1.0 + +* Tue Sep 1 2015 Orion Poplawski - 1.0.0-1 +- Initial version