summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSatish Balay <balay@mcs.anl.gov>2021-11-12 17:20:35 -0600
committerGitHub <noreply@github.com>2021-11-12 17:20:35 -0600
commit446e4ff54bcf10354ce4530a00f9ff2af684ba07 (patch)
tree867f3db872a9fdd875eb76e1bf2d540778317a1b
parent203a5a0f7126b473bc768d3f2027bc63f15c337e (diff)
downloadspack-446e4ff54bcf10354ce4530a00f9ff2af684ba07.tar.gz
spack-446e4ff54bcf10354ce4530a00f9ff2af684ba07.tar.bz2
spack-446e4ff54bcf10354ce4530a00f9ff2af684ba07.tar.xz
spack-446e4ff54bcf10354ce4530a00f9ff2af684ba07.zip
xsdk: add version @0.7.0 (#27250)
- add xsdk_depends_on() that propagates cuda, rocm options - enable +cuda for hypre, mfem, amrex - enable +rocm for mfem, sundials, magma, amrex, tasmanian, ginkgo, heffte - deprecate @0.5.0 - remove 'debug' variant as it doesn't really exist - heffte: remove binding to openmpi+cuda - dtk: use 3.1-rc2 on macos (3.1-rc3 elsewhere) - petsc: disable trilinos Co-authored-by: Cody Balos <balos1@llnl.gov>
-rw-r--r--var/spack/repos/builtin/packages/xsdk/package.py482
1 files changed, 309 insertions, 173 deletions
diff --git a/var/spack/repos/builtin/packages/xsdk/package.py b/var/spack/repos/builtin/packages/xsdk/package.py
index 0ee4c05161..b6f496867e 100644
--- a/var/spack/repos/builtin/packages/xsdk/package.py
+++ b/var/spack/repos/builtin/packages/xsdk/package.py
@@ -5,28 +5,92 @@
import sys
+from copy import deepcopy
from spack import *
-class Xsdk(BundlePackage):
+def xsdk_depends_on_accl(accl_name, accl_var, *args, **kwargs):
+ if accl_name == 'cuda':
+ accl_arch_name = 'cuda_arch'
+ accl_arch_values = list(deepcopy(CudaPackage.cuda_arch_values))
+ elif accl_name == 'rocm':
+ accl_arch_name = 'amdgpu_target'
+ accl_arch_values = list(deepcopy(ROCmPackage.amdgpu_targets))
+ # require ~cuda when xsdk~cuda (and '?cuda' not used)
+ usedep = 1
+ args_new = list(deepcopy(args))
+ if not isinstance(accl_var, list):
+ accl_var = [accl_var]
+ for idx, var in enumerate(accl_var):
+ # skip variants starting with '?' so that
+ # that that they are left unspecified by xsdk
+ if not var.startswith('?'):
+ args_new[0] += ' ~%s' % var
+ else:
+ accl_var[idx] = var.replace('?', '')
+ # if '?cuda' skip adding '~cuda' dep
+ if var == '?' + accl_name:
+ usedep = 0
+ kwargs_new = deepcopy(kwargs)
+ if 'when' in kwargs_new:
+ kwargs_new['when'] += ' ~' + accl_name
+ else:
+ kwargs_new['when'] = '~' + accl_name
+ if usedep:
+ depends_on(*args_new, **kwargs_new)
+
+ # require +cuda when xsdk+cuda, and match the arch
+ for arch in accl_arch_values:
+ args_new = list(deepcopy(args))
+ kwargs_new = deepcopy(kwargs)
+ args_new[0] += '+%s %s=%s' % ('+'.join(accl_var), accl_arch_name, str(arch))
+ if 'when' in kwargs_new:
+ kwargs_new['when'] += ' +%s %s=%s' % (accl_name, accl_arch_name, str(arch))
+ else:
+ kwargs_new['when'] = '+%s %s=%s' % (accl_name, accl_arch_name, str(arch))
+ depends_on(*args_new, **kwargs_new)
+
+
+def xsdk_depends_on(spec, cuda_var='', rocm_var='', **kwargs):
+ """
+ Wrapper for depends_on which can handle propagating cuda and rocm
+ variants.
+
+ Currently, it propagates +cuda_var when xsdk+cuda and rocm_var
+ when xsdk+rocm. When xsdk~[cuda|rocm], then ~[cuda|rocm]_var is
+ selected unless the variant string is prefixed with a '?'
+ (see the tasmanian use below). When '?' prefix is used, then
+ the variant is left unspecified.
+
+ [cuda|rocm]_var can be an array of variant strings or just a single
+ variant string. The spack '+' and '~' symbols should not appear
+ in the strings.
+ """
+ if bool(cuda_var):
+ xsdk_depends_on_accl('cuda', cuda_var, spec, **kwargs)
+ if bool(rocm_var):
+ xsdk_depends_on_accl('rocm', rocm_var, spec, **kwargs)
+ if not bool(cuda_var) and not bool(rocm_var):
+ depends_on(spec, **kwargs)
+
+
+class Xsdk(BundlePackage, CudaPackage, ROCmPackage):
"""Xsdk is a suite of Department of Energy (DOE) packages for numerical
simulation. This is a Spack bundle package that installs the xSDK
packages
"""
homepage = "https://xsdk.info"
-
- maintainers = ['balay', 'luszczek']
+ maintainers = ['balay', 'luszczek', 'balos1']
version('develop')
+ version('0.7.0')
version('0.6.0')
- version('0.5.0')
+ version('0.5.0', deprecated=True)
version('0.4.0', deprecated=True)
version('0.3.0', deprecated=True)
- variant('debug', default=False, description='Compile in debug mode')
- variant('cuda', default=False, description='Enable CUDA dependent packages')
variant('trilinos', default=True, description='Enable trilinos package build')
variant('datatransferkit', default=True, description='Enable datatransferkit package build')
variant('omega-h', default=True, description='Enable omega-h package build')
@@ -43,133 +107,196 @@ class Xsdk(BundlePackage):
variant('slate', default=True, description='Enable slate package build')
variant('arborx', default=True, description='Enable ArborX build')
- depends_on('hypre@develop+superlu-dist+shared', when='@develop')
- depends_on('hypre@2.20.0+superlu-dist+shared', when='@0.6.0')
- depends_on('hypre@2.18.2+superlu-dist+shared', when='@0.5.0')
- depends_on('hypre@2.15.1~internal-superlu', when='@0.4.0')
- depends_on('hypre@2.12.1~internal-superlu', when='@0.3.0')
-
- depends_on('mfem@develop+mpi+superlu-dist+petsc+sundials+examples+miniapps', when='@develop')
- depends_on('mfem@4.2.0+mpi+superlu-dist+petsc+sundials+examples+miniapps', when='@0.6.0')
- depends_on('mfem@4.0.1-xsdk+mpi~superlu-dist+petsc+sundials+examples+miniapps', when='@0.5.0')
- depends_on('mfem@3.4.0+mpi+superlu-dist+petsc+sundials+examples+miniapps', when='@0.4.0')
- depends_on('mfem@3.3.2+mpi+superlu-dist+petsc+sundials+examples+miniapps', when='@0.3.0')
-
- depends_on('superlu-dist@develop', when='@develop')
- depends_on('superlu-dist@6.4.0', when='@0.6.0')
- depends_on('superlu-dist@6.1.1', when='@0.5.0')
- depends_on('superlu-dist@6.1.0', when='@0.4.0')
- depends_on('superlu-dist@5.2.2', when='@0.3.0')
-
- depends_on('trilinos@develop+hypre+superlu-dist+hdf5~mumps+boost~suite-sparse+tpetra+nox+ifpack2+zoltan+zoltan2+amesos2~exodus~dtk+intrepid2+shards+stratimikos gotype=int cxxstd=14',
- when='@develop +trilinos')
- depends_on('trilinos@13.0.1+hypre+superlu-dist+hdf5~mumps+boost~suite-sparse+tpetra+nox+ifpack2+zoltan+zoltan2+amesos2~exodus~dtk+intrepid2+shards gotype=int',
- when='@0.6.0 +trilinos')
- depends_on('trilinos@12.18.1+hypre+superlu-dist+hdf5~mumps+boost~suite-sparse+tpetra+nox+ifpack2+zoltan+zoltan2+amesos2~exodus+dtk+intrepid2+shards',
- when='@0.5.0 +trilinos')
- depends_on('trilinos@12.14.1+hypre+superlu-dist+hdf5~mumps+boost~suite-sparse+tpetra+nox+ifpack2+zoltan+zoltan2+amesos2~exodus+dtk+intrepid2+shards',
- when='@0.4.0 +trilinos')
- depends_on('trilinos@12.12.1+hypre+superlu-dist+hdf5~mumps+boost~suite-sparse~tpetra~ifpack2~zoltan~zoltan2~amesos2~exodus',
- when='@0.3.0 +trilinos')
-
- depends_on('datatransferkit@master', when='@develop +trilinos +datatransferkit')
- depends_on('datatransferkit@3.1-rc2', when='@0.6.0 +trilinos +datatransferkit')
-
- depends_on('petsc +trilinos', when='+trilinos')
- depends_on('petsc +cuda', when='+cuda @0.6.0:')
- depends_on('petsc +batch', when='platform=cray @0.5.0:')
- depends_on('petsc@main+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
- when='@develop')
- depends_on('petsc@3.14.1+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
- when='@0.6.0')
- depends_on('petsc@3.12.1+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
- when='@0.5.0')
- depends_on('petsc@3.10.3+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
- when='@0.4.0')
- depends_on('petsc@3.8.2+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
- when='@0.3.0')
-
- depends_on('dealii +trilinos~adol-c', when='+trilinos +dealii')
- depends_on('dealii ~trilinos', when='~trilinos +dealii')
- depends_on('dealii@master~assimp~python~doc~gmsh+petsc+slepc+mpi~int64+hdf5~netcdf+metis~sundials~ginkgo~symengine~nanoflann', when='@develop +dealii')
- depends_on('dealii@9.2.0~assimp~python~doc~gmsh+petsc+slepc+mpi~int64+hdf5~netcdf+metis~sundials~ginkgo~symengine~simplex~arborx', when='@0.6.0 +dealii')
- depends_on('dealii@9.1.1~assimp~python~doc~gmsh+petsc+slepc+mpi~int64+hdf5~netcdf+metis~sundials~ginkgo~symengine', when='@0.5.0 +dealii')
- depends_on('dealii@9.0.1~assimp~python~doc~gmsh+petsc~slepc+mpi~int64+hdf5~netcdf+metis~ginkgo~symengine', when='@0.4.0 +dealii')
-
- depends_on('pflotran@develop', when='@develop')
- depends_on('pflotran@xsdk-0.6.0', when='@0.6.0')
- depends_on('pflotran@xsdk-0.5.0', when='@0.5.0')
- depends_on('pflotran@xsdk-0.4.0', when='@0.4.0')
- depends_on('pflotran@xsdk-0.3.0', when='@0.3.0')
-
- depends_on('alquimia@develop', when='@develop +alquimia')
- depends_on('alquimia@xsdk-0.6.0', when='@0.6.0 +alquimia')
- depends_on('alquimia@xsdk-0.5.0', when='@0.5.0 +alquimia ')
- depends_on('alquimia@xsdk-0.4.0', when='@0.4.0 +alquimia')
- depends_on('alquimia@xsdk-0.3.0', when='@0.3.0 +alquimia')
-
- depends_on('sundials +cuda', when='+cuda @0.6.0:')
- depends_on('sundials +trilinos', when='+trilinos @0.6.0:')
- depends_on('sundials@develop~int64+hypre+petsc+superlu-dist', when='@develop')
- depends_on('sundials@5.5.0~int64+hypre+petsc+superlu-dist', when='@0.6.0')
- depends_on('sundials@5.0.0~int64+hypre+petsc+superlu-dist', when='@0.5.0')
- depends_on('sundials@3.2.1~int64+hypre', when='@0.4.0')
- depends_on('sundials@3.1.0~int64+hypre', when='@0.3.0')
-
- depends_on('plasma@20.9.20:', when='@develop %gcc@6.0:')
- depends_on('plasma@20.9.20:', when='@0.6.0 %gcc@6.0:')
- depends_on('plasma@19.8.1:', when='@0.5.0 %gcc@6.0:')
- depends_on('plasma@18.11.1:', when='@0.4.0 %gcc@6.0:')
-
- depends_on('magma@2.5.4', when='@develop +cuda')
- depends_on('magma@2.5.4', when='@0.6.0 +cuda')
- depends_on('magma@2.5.1', when='@0.5.0 +cuda')
- depends_on('magma@2.4.0', when='@0.4.0 +cuda')
- depends_on('magma@2.2.0', when='@0.3.0 +cuda')
-
- depends_on('amrex@develop', when='@develop %intel')
- depends_on('amrex@develop', when='@develop %gcc')
- depends_on('amrex@20.10', when='@0.6.0 %intel')
- depends_on('amrex@20.10', when='@0.6.0 %gcc')
- depends_on('amrex@19.08', when='@0.5.0 %intel')
- depends_on('amrex@19.08', when='@0.5.0 %gcc')
- depends_on('amrex@18.10.1', when='@0.4.0 %intel')
- depends_on('amrex@18.10.1', when='@0.4.0 %gcc')
-
- depends_on('slepc@main', when='@develop')
- depends_on('slepc@3.14.0', when='@0.6.0')
- depends_on('slepc@3.12.0', when='@0.5.0')
- depends_on('slepc@3.10.1', when='@0.4.0')
-
- depends_on('omega-h +trilinos', when='+trilinos +omega-h')
- depends_on('omega-h ~trilinos', when='~trilinos +omega-h')
- depends_on('omega-h@main', when='@develop +omega-h')
- depends_on('omega-h@9.32.5', when='@0.6.0 +omega-h')
- depends_on('omega-h@9.29.0', when='@0.5.0 +omega-h')
- depends_on('omega-h@9.19.1', when='@0.4.0 +omega-h')
-
- depends_on('strumpack ~cuda', when='~cuda @0.6.0: +strumpack')
- depends_on('strumpack@master~slate~openmp', when='@develop +strumpack')
- depends_on('strumpack@5.0.0~slate~openmp', when='@0.6.0 +strumpack')
- depends_on('strumpack@3.3.0~slate~openmp', when='@0.5.0 +strumpack')
- depends_on('strumpack@3.1.1~slate~openmp', when='@0.4.0 +strumpack')
-
- depends_on('pumi@master', when='@develop')
- depends_on('pumi@2.2.5', when='@0.6.0')
- depends_on('pumi@2.2.1', when='@0.5.0')
- depends_on('pumi@2.2.0', when='@0.4.0')
+ xsdk_depends_on('hypre@develop+superlu-dist+shared', when='@develop',
+ cuda_var='cuda')
+ xsdk_depends_on('hypre@2.23.0+superlu-dist+shared', when='@0.7.0',
+ cuda_var='cuda')
+ xsdk_depends_on('hypre@2.20.0+superlu-dist+shared', when='@0.6.0')
+ xsdk_depends_on('hypre@2.18.2+superlu-dist+shared', when='@0.5.0')
+ xsdk_depends_on('hypre@2.15.1~internal-superlu', when='@0.4.0')
+ xsdk_depends_on('hypre@2.12.1~internal-superlu', when='@0.3.0')
+
+ xsdk_depends_on('mfem@develop+mpi+superlu-dist+petsc+sundials+examples+miniapps',
+ when='@develop', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('mfem@4.3.0+mpi+superlu-dist+petsc+sundials+examples+miniapps',
+ when='@0.7.0', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('mfem@4.2.0+mpi+superlu-dist+petsc+sundials+examples+miniapps',
+ when='@0.6.0', cuda_var='cuda')
+ xsdk_depends_on('mfem@4.0.1-xsdk+mpi~superlu-dist+petsc+sundials+examples+miniapps',
+ when='@0.5.0')
+ xsdk_depends_on('mfem@3.4.0+mpi+superlu-dist+petsc+sundials+examples+miniapps',
+ when='@0.4.0')
+ xsdk_depends_on('mfem@3.3.2+mpi+superlu-dist+petsc+sundials+examples+miniapps',
+ when='@0.3.0')
+
+ xsdk_depends_on('superlu-dist@develop', when='@develop')
+ xsdk_depends_on('superlu-dist@7.1.1', when='@0.7.0')
+ xsdk_depends_on('superlu-dist@6.4.0', when='@0.6.0')
+ xsdk_depends_on('superlu-dist@6.1.1', when='@0.5.0')
+ xsdk_depends_on('superlu-dist@6.1.0', when='@0.4.0')
+ xsdk_depends_on('superlu-dist@5.2.2', when='@0.3.0')
+ xsdk_depends_on('trilinos@develop+hypre+superlu-dist+hdf5~mumps+boost' +
+ '~suite-sparse+tpetra+nox+ifpack2+zoltan+zoltan2+amesos2' +
+ '~exodus~dtk+intrepid2+shards+stratimikos gotype=int' +
+ ' cxxstd=14', when='@develop +trilinos')
+ xsdk_depends_on('trilinos@13.2.0+hypre+superlu-dist+hdf5~mumps+boost' +
+ '~suite-sparse+tpetra+nox+ifpack2+zoltan+zoltan2+amesos2' +
+ '~exodus~dtk+intrepid2+shards+stratimikos gotype=int' +
+ ' cxxstd=14', when='@0.7.0 +trilinos')
+ xsdk_depends_on('trilinos@13.0.1+hypre+superlu-dist+hdf5~mumps+boost' +
+ '~suite-sparse+tpetra+nox+ifpack2+zoltan+zoltan2+amesos2' +
+ '~exodus~dtk+intrepid2+shards gotype=int' +
+ ' cxxstd=11', when='@0.6.0 +trilinos')
+ xsdk_depends_on('trilinos@12.18.1+hypre+superlu-dist+hdf5~mumps+boost' +
+ '~suite-sparse+tpetra+nox+ifpack2+zoltan+zoltan2+amesos2' +
+ '~exodus+dtk+intrepid2+shards', when='@0.5.0 +trilinos')
+ xsdk_depends_on('trilinos@12.14.1+hypre+superlu-dist+hdf5~mumps+boost' +
+ '~suite-sparse+tpetra+nox+ifpack2+zoltan+zoltan2+amesos2' +
+ '~exodus+dtk+intrepid2+shards', when='@0.4.0 +trilinos')
+ xsdk_depends_on('trilinos@12.12.1+hypre+superlu-dist+hdf5~mumps+boost' +
+ '~suite-sparse~tpetra~ifpack2~zoltan~zoltan2~amesos2'
+ '~exodus', when='@0.3.0 +trilinos')
+
+ xsdk_depends_on('datatransferkit@master',
+ when='@develop +trilinos +datatransferkit')
+ dtk7ver = '3.1-rc2' if sys.platform == 'darwin' else '3.1-rc3'
+ xsdk_depends_on('datatransferkit@' + dtk7ver,
+ when='@0.7.0 +trilinos +datatransferkit')
+ xsdk_depends_on('datatransferkit@3.1-rc2',
+ when='@0.6.0 +trilinos +datatransferkit')
+
+ xsdk_depends_on('petsc +trilinos', when='+trilinos @:0.6.0')
+ xsdk_depends_on('petsc +batch', when='platform=cray @0.5.0:')
+ xsdk_depends_on('petsc@main+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
+ when='@develop', cuda_var='cuda')
+ xsdk_depends_on('petsc@3.16.1+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
+ when='@0.7.0', cuda_var='cuda')
+ xsdk_depends_on('petsc@3.14.1+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
+ when='@0.6.0', cuda_var='cuda')
+ xsdk_depends_on('petsc@3.12.1+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
+ when='@0.5.0')
+ xsdk_depends_on('petsc@3.10.3+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
+ when='@0.4.0')
+ xsdk_depends_on('petsc@3.8.2+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
+ when='@0.3.0')
+
+ xsdk_depends_on('dealii +trilinos~adol-c', when='+trilinos +dealii')
+ xsdk_depends_on('dealii ~trilinos', when='~trilinos +dealii')
+ xsdk_depends_on('dealii@master~assimp~python~doc~gmsh+petsc+slepc+mpi~int64+hdf5' +
+ '~netcdf+metis~sundials~ginkgo~symengine~nanoflann~simplex~arborx',
+ when='@develop +dealii')
+ xsdk_depends_on('dealii@9.3.2~assimp~python~doc~gmsh+petsc+slepc+mpi~int64+hdf5' +
+ '~netcdf+metis~sundials~ginkgo~symengine~simplex~arborx',
+ when='@0.7.0 +dealii')
+ xsdk_depends_on('dealii@9.2.0~assimp~python~doc~gmsh+petsc+slepc+mpi~int64+hdf5' +
+ '~netcdf+metis~sundials~ginkgo~symengine~simplex~arborx',
+ when='@0.6.0 +dealii')
+ xsdk_depends_on('dealii@9.1.1~assimp~python~doc~gmsh+petsc+slepc+mpi~int64+hdf5' +
+ '~netcdf+metis~sundials~ginkgo~symengine',
+ when='@0.5.0 +dealii')
+ xsdk_depends_on('dealii@9.0.1~assimp~python~doc~gmsh+petsc~slepc+mpi~int64+hdf5' +
+ '~netcdf+metis~ginkgo~symengine',
+ when='@0.4.0 +dealii')
+
+ xsdk_depends_on('pflotran@develop', when='@develop')
+ xsdk_depends_on('pflotran@3.0.2', when='@0.7.0')
+ xsdk_depends_on('pflotran@xsdk-0.6.0', when='@0.6.0')
+ xsdk_depends_on('pflotran@xsdk-0.5.0', when='@0.5.0')
+ xsdk_depends_on('pflotran@xsdk-0.4.0', when='@0.4.0')
+ xsdk_depends_on('pflotran@xsdk-0.3.0', when='@0.3.0')
+
+ xsdk_depends_on('alquimia@develop', when='@develop +alquimia')
+ xsdk_depends_on('alquimia@1.0.9', when='@0.7.0 +alquimia')
+ xsdk_depends_on('alquimia@xsdk-0.6.0', when='@0.6.0 +alquimia')
+ xsdk_depends_on('alquimia@xsdk-0.5.0', when='@0.5.0 +alquimia ')
+ xsdk_depends_on('alquimia@xsdk-0.4.0', when='@0.4.0 +alquimia')
+ xsdk_depends_on('alquimia@xsdk-0.3.0', when='@0.3.0 +alquimia')
+
+ xsdk_depends_on('sundials +trilinos', when='+trilinos @0.6.0:')
+ xsdk_depends_on('sundials@develop~int64+hypre+petsc+superlu-dist',
+ when='@develop', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('sundials@5.8.0~int64+hypre+petsc+superlu-dist',
+ when='@0.7.0', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('sundials@5.5.0~int64+hypre+petsc+superlu-dist',
+ when='@0.6.0', cuda_var='cuda')
+ xsdk_depends_on('sundials@5.0.0~int64+hypre+petsc+superlu-dist', when='@0.5.0')
+ xsdk_depends_on('sundials@3.2.1~int64+hypre', when='@0.4.0')
+ xsdk_depends_on('sundials@3.1.0~int64+hypre', when='@0.3.0')
+
+ xsdk_depends_on('plasma@develop:', when='@develop %gcc@6.0:')
+ xsdk_depends_on('plasma@21.8.29:', when='@0.7.0 %gcc@6.0:')
+ xsdk_depends_on('plasma@20.9.20:', when='@0.6.0 %gcc@6.0:')
+ xsdk_depends_on('plasma@19.8.1:', when='@0.5.0 %gcc@6.0:')
+ xsdk_depends_on('plasma@18.11.1:', when='@0.4.0 %gcc@6.0:')
+
+ xsdk_depends_on('magma@master', when='@develop', cuda_var='?cuda', rocm_var='?rocm')
+ xsdk_depends_on('magma@2.6.1', when='@0.7.0', cuda_var='?cuda', rocm_var='?rocm')
+ xsdk_depends_on('magma@2.5.4', when='@0.6.0', cuda_var='?cuda')
+ xsdk_depends_on('magma@2.5.1', when='@0.5.0', cuda_var='?cuda')
+ xsdk_depends_on('magma@2.4.0', when='@0.4.0', cuda_var='?cuda')
+ xsdk_depends_on('magma@2.2.0', when='@0.3.0', cuda_var='?cuda')
+
+ xsdk_depends_on('amrex@develop+sundials',
+ when='@develop %intel', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('amrex@develop+sundials',
+ when='@develop %gcc', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('amrex@develop+sundials',
+ when='@develop %cce', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('amrex@21.10+sundials',
+ when='@0.7.0 %intel', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('amrex@21.10+sundials',
+ when='@0.7.0 %gcc', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('amrex@21.10+sundials',
+ when='@0.7.0 %cce', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('amrex@20.10', when='@0.6.0 %intel')
+ xsdk_depends_on('amrex@20.10', when='@0.6.0 %gcc')
+ xsdk_depends_on('amrex@19.08', when='@0.5.0 %intel')
+ xsdk_depends_on('amrex@19.08', when='@0.5.0 %gcc')
+ xsdk_depends_on('amrex@18.10.1', when='@0.4.0 %intel')
+ xsdk_depends_on('amrex@18.10.1', when='@0.4.0 %gcc')
+
+ xsdk_depends_on('slepc@main', when='@develop')
+ xsdk_depends_on('slepc@3.16.0', when='@0.7.0')
+ xsdk_depends_on('slepc@3.14.0', when='@0.6.0')
+ xsdk_depends_on('slepc@3.12.0', when='@0.5.0')
+ xsdk_depends_on('slepc@3.10.1', when='@0.4.0')
+
+ xsdk_depends_on('omega-h +trilinos', when='+trilinos +omega-h')
+ xsdk_depends_on('omega-h ~trilinos', when='~trilinos +omega-h')
+ xsdk_depends_on('omega-h@main', when='@develop +omega-h')
+ xsdk_depends_on('omega-h@9.34.1', when='@0.7.0 +omega-h')
+ xsdk_depends_on('omega-h@9.32.5', when='@0.6.0 +omega-h')
+ xsdk_depends_on('omega-h@9.29.0', when='@0.5.0 +omega-h')
+ xsdk_depends_on('omega-h@9.19.1', when='@0.4.0 +omega-h')
+
+ xsdk_depends_on('strumpack ~cuda', when='~cuda @0.6.0: +strumpack')
+ xsdk_depends_on('strumpack@master~slate~openmp', when='@develop +strumpack')
+ xsdk_depends_on('strumpack@6.1.0~slate~openmp', when='@0.7.0 +strumpack')
+ xsdk_depends_on('strumpack@5.0.0~slate~openmp', when='@0.6.0 +strumpack')
+ xsdk_depends_on('strumpack@3.3.0~slate~openmp', when='@0.5.0 +strumpack')
+ xsdk_depends_on('strumpack@3.1.1~slate~openmp', when='@0.4.0 +strumpack')
+
+ xsdk_depends_on('pumi@master', when='@develop')
+ xsdk_depends_on('pumi@2.2.6', when='@0.7.0')
+ xsdk_depends_on('pumi@2.2.5', when='@0.6.0')
+ xsdk_depends_on('pumi@2.2.1', when='@0.5.0')
+ xsdk_depends_on('pumi@2.2.0', when='@0.4.0')
tasmanian_openmp = '~openmp' if sys.platform == 'darwin' else '+openmp'
- depends_on('tasmanian@develop+xsdkflags+blas' + tasmanian_openmp, when='@develop')
- depends_on('tasmanian@develop+xsdkflags+blas+cuda+magma' + tasmanian_openmp, when='@develop +cuda')
- depends_on('tasmanian@7.3+xsdkflags+mpi+blas' + tasmanian_openmp, when='@0.6.0')
- depends_on('tasmanian@7.3+xsdkflags+mpi+blas+cuda+magma' + tasmanian_openmp, when='@0.6.0 +cuda')
- depends_on('tasmanian@7.0+xsdkflags+mpi+blas' + tasmanian_openmp, when='@0.5.0')
- depends_on('tasmanian@7.0+xsdkflags+mpi+blas+cuda+magma' + tasmanian_openmp, when='@0.5.0 +cuda')
- depends_on('tasmanian@6.0+xsdkflags+blas~openmp', when='@0.4.0')
- depends_on('tasmanian@6.0+xsdkflags+blas+cuda+magma~openmp', when='@0.4.0 +cuda')
-
- depends_on('arborx@1.0', when='@develop +arborx')
+ xsdk_depends_on('tasmanian@develop+xsdkflags+blas' + tasmanian_openmp,
+ when='@develop',
+ cuda_var=['cuda', '?magma'], rocm_var=['rocm', '?magma'])
+ xsdk_depends_on('tasmanian@7.7+xsdkflags+mpi+blas' + tasmanian_openmp,
+ when='@0.7.0', cuda_var=['cuda', '?magma'])
+ xsdk_depends_on('tasmanian@7.3+xsdkflags+mpi+blas' + tasmanian_openmp,
+ when='@0.6.0', cuda_var=['cuda', '?magma'])
+ xsdk_depends_on('tasmanian@7.0+xsdkflags+mpi+blas' + tasmanian_openmp,
+ when='@0.5.0', cuda_var=['cuda', '?magma'])
+ xsdk_depends_on('tasmanian@6.0+xsdkflags+blas~openmp', when='@0.4.0',
+ cuda_var=['cuda', '?magma'])
+
+ xsdk_depends_on('arborx@master', when='@develop +arborx')
+ xsdk_depends_on('arborx@1.1', when='@0.7.0 +arborx')
# the Fortran 2003 bindings of phist require python@3:, but this
# creates a conflict with other packages like petsc@main. Actually
@@ -177,45 +304,54 @@ class Xsdk(BundlePackage):
# This will be fixed once the new concretizer becomes available
# (says @adamjstewart)
- depends_on('phist kernel_lib=tpetra', when='+trilinos +phist')
- depends_on('phist kernel_lib=petsc', when='~trilinos +phist')
- depends_on('phist@develop ~fortran ~scamac ~openmp ~host ~int64', when='@develop +phist')
- depends_on('phist@1.9.3 ~fortran ~scamac ~openmp ~host ~int64', when='@0.6.0 +phist')
- depends_on('phist@1.8.0 ~fortran ~scamac ~openmp ~host ~int64', when='@0.5.0 +phist')
- depends_on('phist@1.7.5 ~fortran ~scamac ~openmp ~host ~int64', when='@0.4.0 +phist')
-
- depends_on('ginkgo@develop ~openmp', when='@develop +ginkgo')
- depends_on('ginkgo@develop ~openmp+cuda', when='@develop +ginkgo +cuda')
- depends_on('ginkgo@1.3.0 ~openmp', when='@0.6.0 +ginkgo')
- depends_on('ginkgo@1.3.0 ~openmp+cuda', when='@0.6.0 +cuda +ginkgo')
- depends_on('ginkgo@1.1.0 ~openmp', when='@0.5.0 +ginkgo')
- depends_on('ginkgo@1.1.0 ~openmp+cuda', when='@0.5.0 +cuda +ginkgo')
-
- depends_on('py-libensemble@develop+petsc4py', type='run', when='@develop +libensemble')
- depends_on('py-petsc4py@main', type='run', when='@develop +libensemble')
- depends_on('py-libensemble@0.7.1+petsc4py', type='run', when='@0.6.0 +libensemble')
- depends_on('py-petsc4py@3.14.0', type='run', when='@0.6.0 +libensemble')
- depends_on('py-libensemble@0.5.2+petsc4py', type='run', when='@0.5.0 +libensemble')
- depends_on('py-petsc4py@3.12.0', type='run', when='@0.5.0 +libensemble')
-
- depends_on('precice ~petsc', when='platform=cray +precice')
- depends_on('precice@develop', when='@develop +precice')
- depends_on('precice@2.1.1', when='@0.6.0 +precice')
- depends_on('precice@1.6.1', when='@0.5.0 +precice')
-
- depends_on('butterflypack@master', when='@develop +butterflypack')
- depends_on('butterflypack@1.2.1', when='@0.6.0 +butterflypack')
- depends_on('butterflypack@1.1.0', when='@0.5.0 +butterflypack')
-
- depends_on('heffte +fftw+cuda+magma', when='+cuda +heffte')
- depends_on('openmpi +cuda', when='+cuda +heffte')
- depends_on('heffte@develop+fftw', when='@develop +heffte')
- depends_on('heffte@2.0.0+fftw', when='@0.6.0 +heffte')
-
- depends_on('slate@master ~cuda', when='@develop ~cuda +slate %gcc@6.0:')
- depends_on('slate@master +cuda', when='@develop +cuda +slate %gcc@6.0:')
- depends_on('slate@2020.10.00 ~cuda', when='@0.6.0 ~cuda +slate %gcc@6.0:')
- depends_on('slate@2020.10.00 +cuda', when='@0.6.0 +cuda +slate %gcc@6.0:')
-
- # How do we propagate debug flag to all depends on packages ?
- # If I just do spack install xsdk+debug will that propogate it down?
+ xsdk_depends_on('phist kernel_lib=tpetra', when='+trilinos +phist')
+ xsdk_depends_on('phist kernel_lib=petsc', when='~trilinos +phist')
+ xsdk_depends_on('phist@develop ~fortran ~scamac ~openmp ~host ~int64',
+ when='@develop +phist')
+ xsdk_depends_on('phist@1.9.5 ~fortran ~scamac ~openmp ~host ~int64',
+ when='@0.7.0 +phist')
+ xsdk_depends_on('phist@1.9.3 ~fortran ~scamac ~openmp ~host ~int64',
+ when='@0.6.0 +phist')
+ xsdk_depends_on('phist@1.8.0 ~fortran ~scamac ~openmp ~host ~int64',
+ when='@0.5.0 +phist')
+ xsdk_depends_on('phist@1.7.5 ~fortran ~scamac ~openmp ~host ~int64',
+ when='@0.4.0 +phist')
+
+ xsdk_depends_on('ginkgo@develop ~openmp', when='@develop +ginkgo',
+ cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('ginkgo@1.4.0 ~openmp',
+ when='@0.7.0 +ginkgo', cuda_var='cuda', rocm_var='rocm')
+ xsdk_depends_on('ginkgo@1.3.0 ~openmp',
+ when='@0.6.0 +ginkgo', cuda_var='cuda')
+ xsdk_depends_on('ginkgo@1.1.0 ~openmp', when='@0.5.0 +ginkgo')
+
+ xsdk_depends_on('py-libensemble@develop+petsc4py', when='@develop +libensemble')
+ xsdk_depends_on('py-petsc4py@main', when='@develop +libensemble')
+ xsdk_depends_on('py-libensemble@0.8.0+petsc4py', when='@0.7.0 +libensemble')
+ xsdk_depends_on('py-petsc4py@3.16.1', when='@0.7.0 +libensemble')
+ xsdk_depends_on('py-libensemble@0.7.1+petsc4py', when='@0.6.0 +libensemble')
+ xsdk_depends_on('py-petsc4py@3.14.0', when='@0.6.0 +libensemble')
+ xsdk_depends_on('py-libensemble@0.5.2+petsc4py', when='@0.5.0 +libensemble')
+ xsdk_depends_on('py-petsc4py@3.12.0', when='@0.5.0 +libensemble')
+
+ xsdk_depends_on('precice ~petsc', when='platform=cray +precice')
+ xsdk_depends_on('precice@develop', when='@develop +precice')
+ xsdk_depends_on('precice@2.3.0', when='@0.7.0 +precice')
+ xsdk_depends_on('precice@2.1.1', when='@0.6.0 +precice')
+ xsdk_depends_on('precice@1.6.1', when='@0.5.0 +precice')
+
+ xsdk_depends_on('butterflypack@master', when='@develop +butterflypack')
+ xsdk_depends_on('butterflypack@2.0.0', when='@0.7.0 +butterflypack')
+ xsdk_depends_on('butterflypack@1.2.1', when='@0.6.0 +butterflypack')
+ xsdk_depends_on('butterflypack@1.1.0', when='@0.5.0 +butterflypack')
+
+ xsdk_depends_on('heffte@develop+fftw', when='@develop +heffte',
+ cuda_var=['cuda', '?magma'], rocm_var=['rocm', '?magma'])
+ xsdk_depends_on('heffte@2.2.0+fftw', when='@0.7.0 +heffte',
+ cuda_var=['cuda', '?magma'], rocm_var=['rocm', '?magma'])
+ xsdk_depends_on('heffte@2.0.0+fftw', when='@0.6.0 +heffte',
+ cuda_var=['cuda', '?magma'])
+
+ xsdk_depends_on('slate@master', when='@develop +slate %gcc@6.0:', cuda_var='cuda')
+ xsdk_depends_on('slate@2021.05.02', when='@0.7.0 +slate %gcc@6.0:', cuda_var='cuda')
+ xsdk_depends_on('slate@2020.10.00', when='@0.6.0 +slate %gcc@6.0:', cuda_var='cuda')