From d031bd7461159da78ad6c65c8acee01cd65c589d Mon Sep 17 00:00:00 2001 From: Ricardo Silva Date: Mon, 1 Oct 2018 22:43:40 +0200 Subject: patching p4est to select the proper openmp lib (#9381) * patching p4est to select the proper openmp lib * For when compiler.openmp_flag isn't supported * authored by @nrichart, I only tested it * Adding openmp variant Signed-off-by: Ricardo Silva --- var/spack/repos/builtin/packages/p4est/package.py | 27 ++++++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) (limited to 'var') diff --git a/var/spack/repos/builtin/packages/p4est/package.py b/var/spack/repos/builtin/packages/p4est/package.py index e14061d126..e0b3478edb 100644 --- a/var/spack/repos/builtin/packages/p4est/package.py +++ b/var/spack/repos/builtin/packages/p4est/package.py @@ -36,6 +36,8 @@ class P4est(AutotoolsPackage): version('2.0', 'c522c5b69896aab39aa5a81399372a19a6b03fc6200d2d5d677d9a22fe31029a') version('1.1', '37ba7f4410958cfb38a2140339dbf64f') + variant('openmp', default=False, description='Enable OpenMP') + # build dependencies depends_on('automake', type='build') depends_on('autoconf', type='build') @@ -45,8 +47,20 @@ class P4est(AutotoolsPackage): depends_on('mpi') depends_on('zlib') + # from sc upstream, correct the default libraries + patch('https://github.com/cburstedde/libsc/commit/b506aab224b988fec210cc212469f2c4f58b2d04.patch', + sha256='e9418b1a9347a409be241cd185519b31950e42a7f55b6fb80ce53097657098ee', + working_dir='sc') + patch('https://github.com/cburstedde/libsc/commit/b45a51a7ef97883a3d4dcbd05cb2c77890a76f75.patch', + sha256='8fb829e34e3a1e28afdd6e56e0bdc1d377af569b7ccb9e9d8da0eeb5829ed27e', + working_dir='sc') + + def autoreconf(self, spec, prefix): + bootstrap = Executable('./bootstrap') + bootstrap() + def configure_args(self): - return [ + args = [ '--enable-mpi', '--enable-shared', '--disable-vtk-binary', @@ -58,3 +72,14 @@ class P4est(AutotoolsPackage): 'FC=%s' % self.spec['mpi'].mpifc, 'F77=%s' % self.spec['mpi'].mpif77 ] + + if '+openmp' in self.spec: + try: + args.append( + '--enable-openmp={0}'.format(self.compiler.openmp_flag)) + except UnsupportedCompilerFlag: + args.append('--enable-openmp') + else: + args.append('--disable-openmp') + + return args -- cgit v1.2.3-70-g09d2