2015-10-08 08:24:03 +02:00
|
|
|
#
|
|
|
|
# spec file for package openucx
|
|
|
|
#
|
2017-07-12 19:33:54 +02:00
|
|
|
# Copyright (c) 2017 SUSE LINUX GmbH, Nuernberg, Germany.
|
2015-10-08 08:24:03 +02:00
|
|
|
#
|
|
|
|
# All modifications and additions to the file contributed by third parties
|
|
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
|
|
# upon. The license for this file, and modifications and additions to the
|
|
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
|
|
# license for the pristine package is not an Open Source License, in which
|
|
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
|
|
# published by the Open Source Initiative.
|
|
|
|
|
|
|
|
# Please submit bugfixes or comments via http://bugs.opensuse.org/
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
|
|
Name: openucx
|
|
|
|
Summary: Unifieid Communication X
|
|
|
|
License: BSD-3-Clause
|
|
|
|
Group: Development/Libraries/C and C++
|
Accepting request 527297 from home:NMoreyChaisemartin:branches:science:HPC
- Switch to version 1.2.1
Previous 1.3+ version was based on a development branch.
Supported platforms
- Shared memory: KNEM, CMA, XPMEM, SYSV, Posix
- VERBs over InfiniBand and RoCE.
VERBS over other RDMA interconnects (iWarp, OmniPath, etc.) is available
for community evaluation and has not been tested in context of this release
- Cray Gemini and Aries
- Architectures: x86_64, ARMv8 (64bit), Power64
Features:
- Added support for InfiniBand DC and UD transports, including accelerated verbs for Mellanox devices
- Full support for PGAS/SHMEM interfaces, blocking and non-blocking APIs
- Support for MPI tag matching, both in software and offload mode
- Zero copy protocols and rendezvous, registration cache
- Handling transport errors
- Flow control for DC/RC
- Dataypes support: contiguous, IOV, generic
- Multi-threading support
- Support for ARMv8 64bit architecture
- A new API for efficient memory polling
- Support for malloc-hooks and memory registration caching
OBS-URL: https://build.opensuse.org/request/show/527297
OBS-URL: https://build.opensuse.org/package/show/science:HPC/openucx?expand=0&rev=7
2017-09-19 15:27:22 +02:00
|
|
|
Version: 1.2.1
|
2015-10-08 08:24:03 +02:00
|
|
|
Release: 0
|
|
|
|
Url: http://openucx.org/
|
|
|
|
|
|
|
|
#Git-Clone: git://github.com/openucx/ucx
|
|
|
|
#Git-Web: https://github.com/openucx/ucx
|
2017-09-19 15:53:14 +02:00
|
|
|
Source: https://github.com/openucx/ucx/releases/download/v%version/ucx-%version.tar.gz
|
|
|
|
Patch1: openucx-s390x-support.patch
|
2015-10-08 08:24:03 +02:00
|
|
|
BuildRequires: autoconf >= 2.63
|
|
|
|
BuildRequires: automake >= 1.10
|
2017-07-12 19:33:54 +02:00
|
|
|
BuildRequires: binutils-devel
|
2015-10-08 08:24:03 +02:00
|
|
|
BuildRequires: doxygen
|
|
|
|
BuildRequires: gcc-c++
|
|
|
|
BuildRequires: libibverbs-devel
|
2017-07-12 19:33:54 +02:00
|
|
|
BuildRequires: libnuma-devel
|
2015-10-08 08:24:03 +02:00
|
|
|
BuildRequires: libtool
|
|
|
|
BuildRequires: pkg-config
|
|
|
|
BuildRequires: zlib-devel
|
|
|
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
2017-07-12 19:33:54 +02:00
|
|
|
ExclusiveArch: aarch64 %power64 x86_64 s390x
|
2015-10-08 08:24:03 +02:00
|
|
|
|
|
|
|
%description
|
|
|
|
UCX is a communication library implementing high-performance
|
|
|
|
messaging for MPI/PGAS frameworks.
|
|
|
|
|
|
|
|
%package tools
|
|
|
|
Summary: OpenUCX utilities
|
|
|
|
Group: System/Console
|
|
|
|
|
|
|
|
%description tools
|
|
|
|
Miscallaneous utilities for Unified Communication X.
|
|
|
|
|
2016-06-19 10:50:43 +02:00
|
|
|
%package -n libucm0
|
|
|
|
Summary: Memory (un)happing hooks for Unified Communication X
|
|
|
|
Group: System/Libraries
|
|
|
|
|
|
|
|
%description -n libucm0
|
|
|
|
libucm is a standalone non-unloadable library which installs hooks
|
|
|
|
for virtual memory changes in the current process. Then, it calls
|
|
|
|
user-defined callbacks, which may potentially override the default
|
|
|
|
behavior, or just passively listen and update their own data. libucm
|
|
|
|
does not use libuct, to avoid making it non-unloadable as well, and
|
|
|
|
impelements a basic logging service which is safe to use from malloc
|
|
|
|
hooks.
|
|
|
|
|
|
|
|
%package -n libucm-devel
|
|
|
|
Summary: Development files for Unified Communication X Memory Hooks
|
|
|
|
Group: Development/Libraries/C and C++
|
|
|
|
Requires: libucm0 = %version
|
|
|
|
|
|
|
|
%description -n libucm-devel
|
|
|
|
libucm is a standalone non-unloadable library which installs hooks
|
|
|
|
for virtual memory changes in the current process.
|
|
|
|
|
2017-07-12 19:33:54 +02:00
|
|
|
%package -n libucp0
|
2015-10-08 08:24:03 +02:00
|
|
|
Summary: Infiniband Unified Communication Protocols
|
|
|
|
Group: System/Libraries
|
|
|
|
|
2017-07-12 19:33:54 +02:00
|
|
|
%description -n libucp0
|
2015-10-08 08:24:03 +02:00
|
|
|
High-level API uses UCT framework to construct protocols commonly
|
|
|
|
found in applications (MPI, OpenSHMEM, PGAS, etc.)
|
|
|
|
|
|
|
|
%package -n libucp-devel
|
|
|
|
Summary: Development files for Unified Communication Protocols (UC-P)
|
|
|
|
Group: Development/Libraries/C and C++
|
2017-07-12 19:33:54 +02:00
|
|
|
Requires: libucp0 = %version
|
2015-10-08 08:24:03 +02:00
|
|
|
|
|
|
|
%description -n libucp-devel
|
|
|
|
High-level API uses UCT framework to construct protocols commonly
|
|
|
|
found in applications (MPI, OpenSHMEM, PGAS, etc.)
|
|
|
|
|
2017-07-12 19:33:54 +02:00
|
|
|
%package -n libucs0
|
2015-10-08 08:24:03 +02:00
|
|
|
Summary: Infiniband Unicified Communication Services
|
|
|
|
Group: System/Libraries
|
|
|
|
|
2017-07-12 19:33:54 +02:00
|
|
|
%description -n libucs0
|
2015-10-08 08:24:03 +02:00
|
|
|
This framework provides basic infrastructure for component based
|
|
|
|
programming, memory management, and useful system utilities.
|
|
|
|
|
|
|
|
%package -n libucs-devel
|
|
|
|
Summary: Development files for Unified Communication Services (UC-S)
|
|
|
|
Group: Development/Libraries/C and C++
|
2017-07-12 19:33:54 +02:00
|
|
|
Requires: libucs0 = %version
|
2015-10-08 08:24:03 +02:00
|
|
|
|
|
|
|
%description -n libucs-devel
|
|
|
|
This framework provides basic infrastructure for component based
|
|
|
|
programming, memory management, and useful system utilities.
|
|
|
|
|
2017-07-12 19:33:54 +02:00
|
|
|
%package -n libuct0
|
2015-10-08 08:24:03 +02:00
|
|
|
Summary: Infiniband Unified Communication Transport
|
|
|
|
Group: System/Libraries
|
|
|
|
|
2017-07-12 19:33:54 +02:00
|
|
|
%description -n libuct0
|
2015-10-08 08:24:03 +02:00
|
|
|
Low-level API that expose basic network operations supported by
|
|
|
|
underlying hardware.
|
|
|
|
|
|
|
|
%package -n libuct-devel
|
|
|
|
Summary: Development files for Unified Communication Transport (UC-T)
|
|
|
|
Group: Development/Libraries/C and C++
|
2017-07-12 19:33:54 +02:00
|
|
|
Requires: libuct0 = %version
|
2015-10-08 08:24:03 +02:00
|
|
|
|
|
|
|
%description -n libuct-devel
|
|
|
|
Low-level API that expose basic network operations supported by
|
|
|
|
underlying hardware.
|
|
|
|
|
|
|
|
%prep
|
2017-09-19 15:53:14 +02:00
|
|
|
%setup -qn ucx-%version
|
|
|
|
%patch -P 1 -p1
|
2015-10-08 08:24:03 +02:00
|
|
|
|
|
|
|
%build
|
|
|
|
autoreconf -fi
|
2017-07-12 19:33:54 +02:00
|
|
|
export UCX_CFLAGS="%optflags -Wno-error"
|
|
|
|
%ifarch x86_64
|
|
|
|
export UCX_CFLAGS="$UCX_CFLAGS -mno-avx"
|
|
|
|
%endif
|
|
|
|
%ifarch %ix86
|
|
|
|
export UCX_CFLAGS="$UCX_CFLAGS -mno-sse -mno-sse2"
|
|
|
|
%endif
|
|
|
|
%configure --disable-static --without-avx
|
|
|
|
make %{?_smp_mflags} V=1
|
|
|
|
|
|
|
|
%post -n libucp0 -p /sbin/ldconfig
|
|
|
|
%postun -n libucp0 -p /sbin/ldconfig
|
|
|
|
%post -n libucs0 -p /sbin/ldconfig
|
|
|
|
%postun -n libucs0 -p /sbin/ldconfig
|
|
|
|
%post -n libuct0 -p /sbin/ldconfig
|
|
|
|
%postun -n libuct0 -p /sbin/ldconfig
|
2016-06-19 10:50:43 +02:00
|
|
|
%post -n libucm0 -p /sbin/ldconfig
|
|
|
|
%postun -n libucm0 -p /sbin/ldconfig
|
2015-10-08 08:24:03 +02:00
|
|
|
|
|
|
|
%install
|
|
|
|
%make_install
|
|
|
|
rm -fv "%buildroot/%_libdir"/*.la
|
|
|
|
|
|
|
|
%files tools
|
|
|
|
%defattr(-,root,root)
|
|
|
|
%_bindir/ucx_*
|
|
|
|
%_datadir/ucx/
|
2017-07-12 19:33:54 +02:00
|
|
|
%_libdir/pkgconfig/ucx.pc
|
2015-10-08 08:24:03 +02:00
|
|
|
%doc LICENSE
|
|
|
|
|
2016-06-19 10:50:43 +02:00
|
|
|
%files -n libucm0
|
|
|
|
%defattr(-,root,root)
|
|
|
|
%_libdir/libucm.so.*
|
|
|
|
|
|
|
|
%files -n libucm-devel
|
|
|
|
%defattr(-,root,root)
|
|
|
|
%_includedir/ucm/
|
|
|
|
%_libdir/libucm.so
|
|
|
|
|
2017-07-12 19:33:54 +02:00
|
|
|
%files -n libucp0
|
2015-10-08 08:24:03 +02:00
|
|
|
%defattr(-,root,root)
|
|
|
|
%_libdir/libucp.so.*
|
|
|
|
|
|
|
|
%files -n libucp-devel
|
|
|
|
%defattr(-,root,root)
|
|
|
|
%_includedir/ucp/
|
|
|
|
%_libdir/libucp.so
|
|
|
|
|
2017-07-12 19:33:54 +02:00
|
|
|
%files -n libucs0
|
2015-10-08 08:24:03 +02:00
|
|
|
%defattr(-,root,root)
|
|
|
|
%_libdir/libucs.so.*
|
|
|
|
|
|
|
|
%files -n libucs-devel
|
|
|
|
%defattr(-,root,root)
|
|
|
|
%_includedir/ucs/
|
|
|
|
%_libdir/libucs.so
|
|
|
|
|
2017-07-12 19:33:54 +02:00
|
|
|
%files -n libuct0
|
2015-10-08 08:24:03 +02:00
|
|
|
%defattr(-,root,root)
|
|
|
|
%_libdir/libuct.so.*
|
|
|
|
|
|
|
|
%files -n libuct-devel
|
|
|
|
%defattr(-,root,root)
|
|
|
|
%_includedir/uct/
|
|
|
|
%_libdir/libuct.so
|
|
|
|
|
|
|
|
%changelog
|