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>
This commit is contained in:
Satish Balay 2021-11-12 17:20:35 -06:00 committed by GitHub
parent 203a5a0f71
commit 446e4ff54b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -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')
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')
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',
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')
depends_on('petsc@3.10.3+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
xsdk_depends_on('mfem@3.4.0+mpi+superlu-dist+petsc+sundials+examples+miniapps',
when='@0.4.0')
depends_on('petsc@3.8.2+mpi+hypre+superlu-dist+metis+hdf5~mumps+double~int64',
xsdk_depends_on('mfem@3.3.2+mpi+superlu-dist+petsc+sundials+examples+miniapps',
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')
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')
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')
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')
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')
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')
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')
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')
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:')
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')
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')
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')
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')
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')
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')
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:')
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')
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')
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')
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')
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('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')
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'])
depends_on('arborx@1.0', when='@develop +arborx')
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')
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')
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')
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')
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')
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')
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')
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')
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')
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')
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')
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'])
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('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')