[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 06/14] gnu: scotch, pt-scotch: Build esmumps libraries.
From: |
ericbavier |
Subject: |
[PATCH 06/14] gnu: scotch, pt-scotch: Build esmumps libraries. |
Date: |
Sat, 27 Jun 2015 22:45:43 -0500 |
From: Eric Bavier <address@hidden>
* gnu/packages/maths.scm (scotch)[arguments]: Add 'build-esmumps
phase. Install esmumps libraries and headers in 'install phase.
(pt-scotch)[arguments]: Build ptesmumps in 'build phase. Add
make parallelism.
---
gnu/packages/maths.scm | 22 ++++++++++++++++++++--
1 file changed, 20 insertions(+), 2 deletions(-)
diff --git a/gnu/packages/maths.scm b/gnu/packages/maths.scm
index a3611cf..765a111 100644
--- a/gnu/packages/maths.scm
+++ b/gnu/packages/maths.scm
@@ -818,6 +818,7 @@ OBJ = .o
MAKE = make
AR = ar
ARFLAGS = -ruv
+CAT = cat
CCS = gcc
CCP = mpicc
CCD = gcc
@@ -835,10 +836,18 @@ YACC = bison -pscotchyy -y -b y
'("COMMON_FILE_COMPRESS_GZ"
"COMMON_PTHREAD"
"COMMON_RANDOM_FIXED_SEED"
+ ;; Prevents symbolc clashes with libesmumps
+ "SCOTCH_RENAME"
;; XXX: Causes invalid frees in superlu-dist tests
;; "SCOTCH_PTHREAD"
;; "SCOTCH_PTHREAD_NUMBER=2"
"restrict=__restrict"))))))
+ (add-after
+ 'build 'build-esmumps
+ (lambda _
+ (zero? (system* "make"
+ (format #f "-j~a" (current-processor-count))
+ "esmumps"))))
(replace
'install
(lambda* (#:key outputs #:allow-other-keys)
@@ -846,7 +855,14 @@ YACC = bison -pscotchyy -y -b y
(mkdir out)
(zero? (system* "make"
(string-append "prefix=" out)
- "install"))))))))
+ "install"))
+ ;; esmumps files are not installed with the above
+ (for-each (lambda (f)
+ (copy-file f (string-append out "/include/" f)))
+ (find-files "../include" ".*esmumps.h$"))
+ (for-each (lambda (f)
+ (copy-file f (string-append out "/lib/" f)))
+ (find-files "../lib" "^lib.*esmumps.*"))))))))
(home-page "http://www.labri.fr/perso/pelegrin/scotch/")
(synopsis "Programs and libraries for graph algorithms")
(description "SCOTCH is a set of programs and libraries which implement
@@ -873,7 +889,9 @@ bio-chemistry.")
;; TODO: Would like to add parallelism here
(lambda _
(and
- (zero? (system* "make" "ptscotch"))
+ (zero? (system* "make"
+ (format #f "-j~a" (current-processor-count))
+ "ptscotch" "ptesmumps"))
;; Install the serial metis compatibility library
(zero? (system* "make" "-C" "libscotchmetis" "install")))))
(replace
--
2.2.1
- [PATCH 02/14] gnu: hwloc: Move numactl to inputs., (continued)
- [PATCH 02/14] gnu: hwloc: Move numactl to inputs., ericbavier, 2015/06/27
- [PATCH 03/14] gnu: openmpi: Upgrade to 1.8.5., ericbavier, 2015/06/27
- [PATCH 04/14] gnu: Update scotch to 6.0.4., ericbavier, 2015/06/27
- [PATCH 07/14] gnu: Add ScaLAPACK., ericbavier, 2015/06/27
- [PATCH 05/14] gnu: scotch, pt-scotch: Use modify-phases., ericbavier, 2015/06/27
- [PATCH 06/14] gnu: scotch, pt-scotch: Build esmumps libraries.,
ericbavier <=
- [PATCH 08/14] gnu: Add p4est., ericbavier, 2015/06/27
- [PATCH 13/14] gnu: Add SLEPc., ericbavier, 2015/06/27
- [PATCH 12/14] gnu: Add arpack-ng-openmpi., ericbavier, 2015/06/27
- [PATCH 11/14] gnu: petsc: Upgrade to 3.6.0., ericbavier, 2015/06/27
- [PATCH 10/14] gnu: Add MUMPS., ericbavier, 2015/06/27