This commit was obtained by running: ./pre-inst-env guix style without any additional argument.
		
			
				
	
	
		
			231 lines
		
	
	
	
		
			9 KiB
		
	
	
	
		
			Scheme
		
	
	
	
	
	
			
		
		
	
	
			231 lines
		
	
	
	
		
			9 KiB
		
	
	
	
		
			Scheme
		
	
	
	
	
	
| ;;; GNU Guix --- Functional package management for GNU
 | |
| ;;; Copyright © 2017 Dave Love <fx@gnu.org>
 | |
| ;;; Copyright © 2018, 2019 Tobias Geerinckx-Rice <me@tobias.gr>
 | |
| ;;; Copyright © 2019 Ricardo Wurmus <rekado@elephly.net>
 | |
| ;;; Copyright © 2019 Ludovic Courtès <ludo@gnu.org>
 | |
| ;;;
 | |
| ;;; This file is part of GNU Guix.
 | |
| ;;;
 | |
| ;;; GNU Guix is free software; you can redistribute it and/or modify it
 | |
| ;;; under the terms of the GNU General Public License as published by
 | |
| ;;; the Free Software Foundation; either version 3 of the License, or (at
 | |
| ;;; your option) any later version.
 | |
| ;;;
 | |
| ;;; GNU Guix is distributed in the hope that it will be useful, but
 | |
| ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| ;;; GNU General Public License for more details.
 | |
| ;;;
 | |
| ;;; You should have received a copy of the GNU General Public License
 | |
| ;;; along with GNU Guix.  If not, see <http://www.gnu.org/licenses/>.
 | |
| 
 | |
| (define-module (gnu packages fabric-management)
 | |
|   #:use-module (guix packages)
 | |
|   #:use-module (guix licenses)
 | |
|   #:use-module (guix download)
 | |
|   #:use-module (guix git-download)
 | |
|   #:use-module (guix utils)
 | |
|   #:use-module (guix build-system gnu)
 | |
|   #:use-module (gnu packages)
 | |
|   #:use-module (gnu packages autotools)
 | |
|   #:use-module (gnu packages bison)
 | |
|   #:use-module (gnu packages flex)
 | |
|   #:use-module (gnu packages glib)
 | |
|   #:use-module (gnu packages graphviz)
 | |
|   #:use-module (gnu packages linux)
 | |
|   #:use-module (gnu packages perl)
 | |
|   #:use-module (gnu packages pkg-config)
 | |
|   #:use-module (gnu packages swig)
 | |
|   #:use-module (gnu packages tcl))
 | |
| 
 | |
| ;; Fixme: Done for the library, but needs support for running the daemon
 | |
| ;;        (shepherd definition).
 | |
| ;;        We should probably have a lib output, but that currently generates
 | |
| ;;        a cycle.
 | |
| (define-public opensm
 | |
|   (package
 | |
|     (name "opensm")
 | |
|     (version "3.3.22")
 | |
|     (source
 | |
|      (origin
 | |
|        (method url-fetch)
 | |
|        (uri
 | |
|         (string-append "https://github.com/linux-rdma/opensm/releases/download/"
 | |
|                        version "/opensm-" version ".tar.gz"))
 | |
|        (sha256
 | |
|         (base32 "19scwwpwqhqsyq4hbr5cflcmypss828lalxxd36yby7mbimca38y"))))
 | |
|     (build-system gnu-build-system)
 | |
|     (native-inputs
 | |
|      (list bison
 | |
|            flex
 | |
|            ;; The 3.3.21 'release' tarball isn't properly bootstrapped.
 | |
|            autoconf
 | |
|            automake
 | |
|            libtool))
 | |
|     (inputs
 | |
|      (list rdma-core))
 | |
|     (arguments
 | |
|      `(#:configure-flags '("--disable-static")
 | |
|        #:phases
 | |
|        (modify-phases %standard-phases
 | |
|          (add-after 'install 'install-doc
 | |
|            (lambda* (#:key outputs #:allow-other-keys)
 | |
|              (let* ((base (assoc-ref outputs "out"))
 | |
|                     (doc  (string-append base "/share/doc/"
 | |
|                                          ,name "-" ,version)))
 | |
|                (for-each (lambda (file)
 | |
|                            (install-file file doc))
 | |
|                          (find-files "doc"))
 | |
|                #t))))))
 | |
|     (home-page "https://www.openfabrics.org/")
 | |
|     (synopsis "OpenIB InfiniBand Subnet Manager and management utilities")
 | |
|     (description "\
 | |
| OpenSM is the OpenIB project's Subnet Manager for Infiniband networks.
 | |
| The subnet manager is run as a system daemon on one of the machines in
 | |
| the infiniband fabric to manage the fabric's routing state.  This package
 | |
| also contains various tools for diagnosing and testing Infiniband networks
 | |
| that can be used from any machine and do not need to be run on a machine
 | |
| running the opensm daemon.")
 | |
|     (license (list gpl2 bsd-2))))
 | |
| 
 | |
| (define-public infiniband-diags
 | |
|   (package
 | |
|     (name "infiniband-diags")
 | |
|     (version "2.0.0")
 | |
|     (source
 | |
|      (origin
 | |
|        (method url-fetch)
 | |
|        (uri (string-append "https://github.com/linux-rdma/infiniband-diags/archive/"
 | |
|                            version ".tar.gz"))
 | |
|        (file-name (string-append name "-" version ".tar.gz"))
 | |
|        (sha256
 | |
|         (base32 "1ns9sjwvxnklhi47d6k5x8kxdk1n7f5362y45xwxqmr7gwfvpmwa"))))
 | |
|     (build-system gnu-build-system)
 | |
|     (inputs
 | |
|      (list rdma-core opensm glib))
 | |
|     (outputs '("out" "lib"))
 | |
|     (native-inputs
 | |
|      ;; FIXME: needs rst2man for man pages
 | |
|      (list autoconf automake libtool perl pkg-config))
 | |
|     (arguments
 | |
|      '(#:configure-flags
 | |
|        (list (string-append "CPPFLAGS=-I" (assoc-ref %build-inputs "opensm")
 | |
|                             "/include/infiniband")
 | |
|              (string-append "--with-perl-installdir=" (assoc-ref %outputs "lib")
 | |
|                             "/lib/perl5/vendor_perl")
 | |
|              "--disable-static")
 | |
|        #:phases
 | |
|        (modify-phases %standard-phases
 | |
|          (add-after 'install 'licence
 | |
|            (lambda _
 | |
|              (let ((doc (string-append (assoc-ref %outputs "lib") "/share/doc")))
 | |
|                (mkdir-p doc)
 | |
|                (install-file "COPYING" doc))))
 | |
|          (add-after 'install-file 'move-perl
 | |
|            ;; Avoid perl in lib closure
 | |
|            (lambda _
 | |
|              (let ((perlout (string-append (assoc-ref %outputs "out") "/lib"))
 | |
|                    (perlin (string-append (assoc-ref %outputs "lib")
 | |
|                                           "/lib/perl5")))
 | |
|                (mkdir-p perlout)
 | |
|                (rename-file perlin perlout)
 | |
|                #t))))))
 | |
|     (home-page "https://github.com/linux-rdma/infiniband-diags")
 | |
|     (synopsis "Infiniband diagnostic tools")
 | |
|     (description "This is a set of command-line utilities to help configure,
 | |
| debug, and maintain Infiniband (IB) fabrics.
 | |
| 
 | |
| In addition to the utilities, a sub-library, @file{libibnetdisc}, is provided
 | |
| to scan an entire IB fabric and return data structures representing it.  The
 | |
| interface to this library is not guaranteed to be stable.")
 | |
|     (license (list gpl2 bsd-2)))) ; dual
 | |
| 
 | |
| (define-public ibutils
 | |
|   (package
 | |
|     (name "ibutils")
 | |
|     (version "1.5.7-0.2.gbd7e502")
 | |
|     (source
 | |
|      (origin
 | |
|        (method url-fetch)
 | |
|        (uri (string-append "https://www.openfabrics.org/downloads/ibutils/ibutils-"
 | |
|                            version ".tar.gz"))
 | |
|        (sha256
 | |
|         (base32 "00x7v6cf8l5y6g9xwh1sg738ch42fhv19msx0h0090nhr0bv98v7"))))
 | |
|     (build-system gnu-build-system)
 | |
|     (inputs (list graphviz
 | |
|                   tcl
 | |
|                   tk
 | |
|                   infiniband-diags
 | |
|                   rdma-core
 | |
|                   opensm
 | |
|                   perl))
 | |
|     (native-inputs (list swig))
 | |
|     (arguments
 | |
|      `(#:configure-flags
 | |
|        (list (string-append "--with-osm="  (assoc-ref %build-inputs "opensm"))
 | |
|              (string-append "--with-tk-lib=" (assoc-ref %build-inputs "tk") "/lib")
 | |
|              "--disable-static")))
 | |
|     (synopsis "InfiniBand network utilities")
 | |
|     (description "These command-line utilities allow for diagnosing and
 | |
| testing InfiniBand networks.")
 | |
|     (home-page "https://www.openfabrics.org/downloads/ibutils/")
 | |
|     (license bsd-2)))
 | |
| 
 | |
| (define-public ucx
 | |
|   (package
 | |
|     (name "ucx")
 | |
|     (version "1.9.0")
 | |
|     (source (origin
 | |
|               (method git-fetch)
 | |
|               (uri (git-reference
 | |
|                     (url "https://github.com/openucx/ucx")
 | |
|                     (commit (string-append "v" version))))
 | |
|               (file-name (git-file-name name version))
 | |
|               (patches (search-patches "ucx-tcp-iface-ioctl.patch"))
 | |
|               (sha256
 | |
|                (base32
 | |
|                 "0i0ji5ivzxjqh3ys1m517ghw3am7cw1hvf40ma7hsq3wznsyx5s1"))))
 | |
|     (build-system gnu-build-system)
 | |
|     (arguments
 | |
|      '( ;; These are some of the flags found in 'contrib/configure-release'.
 | |
|        #:configure-flags (list
 | |
|                           "--disable-static"
 | |
| 
 | |
|                           ;; XXX: Disable optimizations specific to the build
 | |
|                           ;; machine (AVX, etc.)  There's apparently no way to
 | |
|                           ;; have them picked up at load time.
 | |
|                           "--disable-optimizations"
 | |
| 
 | |
|                           "--disable-logging"
 | |
|                           "--disable-debug"
 | |
|                           "--disable-assertions"
 | |
|                           "--disable-params-check"
 | |
| 
 | |
|                           (string-append "--with-verbs="
 | |
|                                          (assoc-ref %build-inputs
 | |
|                                                     "rdma-core"))
 | |
| 
 | |
|                           (string-append "--with-rdmacm="
 | |
|                                          (assoc-ref %build-inputs
 | |
|                                                     "rdma-core")))
 | |
| 
 | |
|        ;; Be verbose so that compiler flags are displayed.
 | |
|        #:make-flags '("V=1")))
 | |
|     (native-inputs
 | |
|      (list autoconf automake libtool pkg-config))
 | |
|     (inputs
 | |
|      (list numactl rdma-core))
 | |
|     (synopsis "Optimized communication layer for message passing in HPC")
 | |
|     (description
 | |
|      "Unified Communication X (UCX) provides an optimized communication layer
 | |
| for message passing (MPI), portable global address space (PGAS) languages and
 | |
| run-time support libraries, as well as RPC and data-centric applications.
 | |
| 
 | |
| UCX utilizes high-speed networks for inter-node communication, and shared
 | |
| memory mechanisms for efficient intra-node communication.")
 | |
|     (home-page "https://www.openucx.org/")
 | |
|     (license bsd-3)
 | |
| 
 | |
|     ;; <ucm/bistro/bistro.h> lists only PowerPC64, AArch64, and x86_64 as
 | |
|     ;; supported.
 | |
|     (supported-systems '("x86_64-linux" "aarch64-linux"))))
 |