From 1d741a2110e6cf71b46dc93860278eb548aae8f0 Mon Sep 17 00:00:00 2001 From: Geoffrey Oxberry Date: Fri, 23 Jun 2017 06:50:49 -0700 Subject: suite-sparse: add openmp variant (#4563) Fixes #4549. --- .../repos/builtin/packages/suite-sparse/package.py | 75 +++++++++++----------- 1 file changed, 37 insertions(+), 38 deletions(-) diff --git a/var/spack/repos/builtin/packages/suite-sparse/package.py b/var/spack/repos/builtin/packages/suite-sparse/package.py index 7884e540ba..74b8c53bec 100644 --- a/var/spack/repos/builtin/packages/suite-sparse/package.py +++ b/var/spack/repos/builtin/packages/suite-sparse/package.py @@ -40,6 +40,7 @@ class SuiteSparse(Package): variant('tbb', default=False, description='Build with Intel TBB') variant('pic', default=True, description='Build position independent code (required to link with shared libraries)') variant('cuda', default=False, description='Build with CUDA') + variant('openmp', default=False, description='Build with OpenMP') depends_on('blas') depends_on('lapack') @@ -63,11 +64,12 @@ class SuiteSparse(Package): # logic in it. Any kind of customization will need to go through # filtering of that file - make_args = ['INSTALL=%s' % prefix] + pic_flag = self.compiler.pic_flag if '+pic' in spec else '' - make_args.extend([ + make_args = [ + 'INSTALL=%s' % prefix, # By default, the Makefile uses the Intel compilers if - # they are found. This flag disables this behavior, + # they are found. The AUTOCC flag disables this behavior, # forcing it to use Spack's compiler wrappers. 'AUTOCC=no', # CUDA=no does NOT disable cuda, it only disables internal search @@ -75,47 +77,44 @@ class SuiteSparse(Package): # completely disabled. See # [SuiteSparse/SuiteSparse_config/SuiteSparse_config.mk] for more. 'CUDA=no', - 'CUDA_PATH={0}'.format( - spec['cuda'].prefix if '+cuda' in spec else '' - ), - 'CFOPENMP={0}'.format(self.compiler.openmp_flag) - ]) - - if '+pic' in spec: - make_args.extend([ - 'CFLAGS={0}'.format(self.compiler.pic_flag), - 'FFLAGS={0}'.format(self.compiler.pic_flag) - ]) + 'CUDA_PATH=%s' % (spec['cuda'].prefix if '+cuda' in spec else ''), + 'CFOPENMP=%s' % (self.compiler.openmp_flag + if '+openmp' in spec else ''), + 'CFLAGS=-O3 %s' % pic_flag, + # Both FFLAGS and F77FLAGS are used in SuiteSparse makefiles; + # FFLAGS is used in CHOLMOD, F77FLAGS is used in AMD and UMFPACK. + 'FFLAGS=%s' % pic_flag, + 'F77FLAGS=%s' % pic_flag, + # use Spack's metis in CHOLMOD/Partition module, + # otherwise internal Metis will be compiled + 'MY_METIS_LIB=%s' % spec['metis'].libs.ld_flags, + 'MY_METIS_INC=%s' % spec['metis'].prefix.include, + # Make sure Spack's Blas/Lapack is used. Otherwise System's + # Blas/Lapack might be picked up. Need to add -lstdc++, following + # with the TCOV path of SparseSuite 4.5.1's Suitesparse_config.mk, + # even though this fix is ugly + 'BLAS=%s' % (spec['blas'].libs.ld_flags + ( + '-lstdc++' if '@4.5.1' in spec else '')), + 'LAPACK=%s' % spec['lapack'].libs.ld_flags, + ] + + # SuiteSparse defaults to using '-fno-common -fexceptions' in + # CFLAGS, but not all compilers use the same flags for these + # optimizations + if any([x in spec + for x in ('%clang', '%gcc', '%intel')]): + make_args += ['CFLAGS+=-fno-common -fexceptions'] + elif '%pgi' in spec: + make_args += ['CFLAGS+=--exceptions'] if '%xl' in spec or '%xl_r' in spec: - make_args.extend(['CFLAGS+=-DBLAS_NO_UNDERSCORE']) - - # use Spack's metis in CHOLMOD/Partition module, - # otherwise internal Metis will be compiled - make_args.extend([ - 'MY_METIS_LIB=-L%s -lmetis' % spec['metis'].prefix.lib, - 'MY_METIS_INC=%s' % spec['metis'].prefix.include, - ]) + make_args += ['CFLAGS+=-DBLAS_NO_UNDERSCORE'] # Intel TBB in SuiteSparseQR if 'tbb' in spec: - make_args.extend([ + make_args += [ 'SPQR_CONFIG=-DHAVE_TBB', 'TBB=-L%s -ltbb' % spec['tbb'].prefix.lib, - ]) - - # Make sure Spack's Blas/Lapack is used. Otherwise System's - # Blas/Lapack might be picked up. - blas = spec['blas'].libs.ld_flags - lapack = spec['lapack'].libs.ld_flags - if '@4.5.1' in spec: - # adding -lstdc++ is clearly an ugly way to do this, but it follows - # with the TCOV path of SparseSuite 4.5.1's Suitesparse_config.mk - blas += ' -lstdc++' - - make_args.extend([ - 'BLAS=%s' % blas, - 'LAPACK=%s' % lapack - ]) + ] make('install', *make_args) -- cgit v1.2.3-70-g09d2