summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Beckingsale <davidbeckingsale@gmail.com>2022-05-18 22:48:22 -0700
committerGitHub <noreply@github.com>2022-05-18 22:48:22 -0700
commitc2af154cd24ab3ef501a7efc020f818ef60aa552 (patch)
tree74bb53d68fdb50f240b56eb562010688637f107b
parent1f6b880fffb161016e81da03fb06e5553bb74c09 (diff)
downloadspack-c2af154cd24ab3ef501a7efc020f818ef60aa552.tar.gz
spack-c2af154cd24ab3ef501a7efc020f818ef60aa552.tar.bz2
spack-c2af154cd24ab3ef501a7efc020f818ef60aa552.tar.xz
spack-c2af154cd24ab3ef501a7efc020f818ef60aa552.zip
RAJA and associated packages: add v2022.03.0 (#30047)
* Add raja@2022.03.0 * Add camp@2022.03.0 * Add chai@2022.03.0 * Add umpire@2022.03.1 * Latest chai, raja, umpire versions don't need submodules * Latest chai, raja, umpire versions update CMake option names * New umpire +device_alloc option (for latest version) * All versions of dray are now required to build with raja@:0.14 Co-authored-by: Marty McFadden <mcfadden8@users.noreply.github.com>
-rw-r--r--var/spack/repos/builtin/packages/camp/package.py1
-rw-r--r--var/spack/repos/builtin/packages/chai/package.py20
-rw-r--r--var/spack/repos/builtin/packages/dray/package.py2
-rw-r--r--var/spack/repos/builtin/packages/raja/package.py20
-rw-r--r--var/spack/repos/builtin/packages/umpire/package.py40
5 files changed, 61 insertions, 22 deletions
diff --git a/var/spack/repos/builtin/packages/camp/package.py b/var/spack/repos/builtin/packages/camp/package.py
index 51394911db..b8932d02f3 100644
--- a/var/spack/repos/builtin/packages/camp/package.py
+++ b/var/spack/repos/builtin/packages/camp/package.py
@@ -19,6 +19,7 @@ class Camp(CMakePackage, CudaPackage, ROCmPackage):
maintainers = ['trws']
version('main', branch='main', submodules='True')
+ version('2022.03.0', sha256='e9090d5ee191ea3a8e36b47a8fe78f3ac95d51804f1d986d931e85b8f8dad721')
version('0.3.0', sha256='129431a049ca5825443038ad5a37a86ba6d09b2618d5fe65d35f83136575afdb')
version('0.2.3', sha256='58a0f3bd5eadb588d7dc83f3d050aff8c8db639fc89e8d6553f9ce34fc2421a7')
version('0.2.2', sha256='194d38b57e50e3494482a7f94940b27f37a2bee8291f2574d64db342b981d819')
diff --git a/var/spack/repos/builtin/packages/chai/package.py b/var/spack/repos/builtin/packages/chai/package.py
index a79528b8ed..bac5fca95e 100644
--- a/var/spack/repos/builtin/packages/chai/package.py
+++ b/var/spack/repos/builtin/packages/chai/package.py
@@ -19,8 +19,9 @@ class Chai(CachedCMakePackage, CudaPackage, ROCmPackage):
maintainers = ['davidbeckingsale']
- version('develop', branch='develop', submodules=True)
- version('main', branch='main', submodules=True)
+ version('develop', branch='develop', submodules=False)
+ version('main', branch='main', submodules=False)
+ version('2022.03.0', tag='v2022.03.0', submodules=False)
version('2.4.0', tag='v2.4.0', submodules=True)
version('2.3.0', tag='v2.3.0', submodules=True)
version('2.2.2', tag='v2.2.2', submodules=True)
@@ -45,12 +46,15 @@ class Chai(CachedCMakePackage, CudaPackage, ROCmPackage):
depends_on('cmake@3.8:', type='build')
depends_on('cmake@3.9:', type='build', when="+cuda")
+ depends_on('cmake@3.14:', when='@2022.03.0:')
+ depends_on('blt@0.5.0:', type='build', when='@2022.03.0:')
depends_on('blt@0.4.1:', type='build', when='@2.4.0:')
depends_on('blt@0.4.0:', type='build', when='@2.3.0')
depends_on('blt@0.3.6:', type='build', when='@:2.2.2')
depends_on('umpire')
+ depends_on('umpire@2022.03.0:', when='@2022.03.0:')
depends_on('umpire@6.0.0', when="@2.4.0")
depends_on('umpire@4.1.2', when="@2.2.0:2.3.0")
depends_on('umpire@main', when='@main')
@@ -73,6 +77,7 @@ class Chai(CachedCMakePackage, CudaPackage, ROCmPackage):
depends_on('raja@0.14.0', when="@2.4.0")
depends_on('raja@0.13.0', when="@2.3.0")
depends_on('raja@0.12.0', when="@2.2.0:2.2.2")
+ depends_on('raja@2022.03.0:', when='@2022.03.0:')
depends_on('raja@main', when='@main')
with when('+cuda'):
@@ -147,16 +152,21 @@ class Chai(CachedCMakePackage, CudaPackage, ROCmPackage):
spec = self.spec
entries = []
+ option_prefix = "CHAI_" if spec.satisfies("@2022.03.0:") else ""
+
entries.append(cmake_cache_path("BLT_SOURCE_DIR", spec['blt'].prefix))
if '+raja' in spec:
- entries.append(cmake_cache_option("ENABLE_RAJA_PLUGIN", True))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_RAJA_PLUGIN".format(option_prefix), True))
entries.append(cmake_cache_path("RAJA_DIR", spec['raja'].prefix))
- entries.append(cmake_cache_option('ENABLE_PICK', '+enable_pick' in spec))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_PICK".format(option_prefix), '+enable_pick' in spec))
entries.append(cmake_cache_path(
"umpire_DIR", spec['umpire'].prefix.share.umpire.cmake))
entries.append(cmake_cache_option("ENABLE_TESTS", '+tests' in spec))
entries.append(cmake_cache_option("ENABLE_BENCHMARKS", '+benchmarks' in spec))
- entries.append(cmake_cache_option("ENABLE_EXAMPLES", '+examples' in spec))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_EXAMPLES".format(option_prefix), '+examples' in spec))
entries.append(cmake_cache_option("BUILD_SHARED_LIBS", '+shared' in spec))
return entries
diff --git a/var/spack/repos/builtin/packages/dray/package.py b/var/spack/repos/builtin/packages/dray/package.py
index 16b3b04323..a26cc566f4 100644
--- a/var/spack/repos/builtin/packages/dray/package.py
+++ b/var/spack/repos/builtin/packages/dray/package.py
@@ -78,6 +78,8 @@ class Dray(Package, CudaPackage):
depends_on("apcomp~shared", when="~shared")
depends_on("apcomp+shared", when="+shared")
+ depends_on("raja@0.12.0:")
+ depends_on("raja@:0.14", when='@0.1.7:')
depends_on("raja@:0.13", when="@:0.1.6")
depends_on("raja~cuda", when="~cuda")
depends_on("raja+cuda", when="+cuda")
diff --git a/var/spack/repos/builtin/packages/raja/package.py b/var/spack/repos/builtin/packages/raja/package.py
index a839eaee92..5a96d0fa1f 100644
--- a/var/spack/repos/builtin/packages/raja/package.py
+++ b/var/spack/repos/builtin/packages/raja/package.py
@@ -17,8 +17,9 @@ class Raja(CachedCMakePackage, CudaPackage, ROCmPackage):
maintainers = ['davidbeckingsale']
- version('develop', branch='develop', submodules='True')
- version('main', branch='main', submodules='True')
+ version('develop', branch='develop', submodules=False)
+ version('main', branch='main', submodules=False)
+ version('2022.03.0', tag='v2022.03.0', submodules=False)
version('0.14.0', tag='v0.14.0', submodules='True')
version('0.13.0', tag='v0.13.0', submodules='True')
version('0.12.1', tag='v0.12.1', submodules="True")
@@ -56,10 +57,12 @@ class Raja(CachedCMakePackage, CudaPackage, ROCmPackage):
depends_on('blt@0.4.0:', type='build', when='@0.13.0')
depends_on('blt@0.3.6:', type='build', when='@:0.12.0')
- depends_on('camp@0.2.2', when='@0.14.0:')
- depends_on('camp@0.1.0', when='@0.12.0:0.13.0')
+ depends_on('camp@0.2.2', when='@0.14.0')
+ depends_on('camp@0.1.0', when='@0.10.0:0.13.0')
+ depends_on('camp@2022.03.0:', when='@2022.03.0:')
depends_on('cmake@:3.20', when='+rocm', type='build')
+ depends_on('cmake@3.14:', when='@2022.03.0:')
with when('+rocm @0.12.0:'):
depends_on('camp+rocm')
@@ -128,14 +131,17 @@ class Raja(CachedCMakePackage, CudaPackage, ROCmPackage):
spec = self.spec
entries = []
+ option_prefix = "RAJA_" if spec.satisfies("@2022.03.0:") else ""
+
entries.append(cmake_cache_path("BLT_SOURCE_DIR", spec['blt'].prefix))
if 'camp' in self.spec:
entries.append(cmake_cache_path("camp_DIR", spec['camp'].prefix))
entries.append(cmake_cache_option("BUILD_SHARED_LIBS", '+shared' in spec))
- entries.append(cmake_cache_option("ENABLE_EXAMPLES", '+examples' in spec))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_EXAMPLES".format(option_prefix), '+examples' in spec))
if spec.satisfies('@0.14.0:'):
- entries.append(cmake_cache_option("RAJA_ENABLE_EXERCISES",
- '+exercises' in spec))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_EXERCISES".format(option_prefix), '+exercises' in spec))
else:
entries.append(cmake_cache_option("ENABLE_EXERCISES",
'+exercises' in spec))
diff --git a/var/spack/repos/builtin/packages/umpire/package.py b/var/spack/repos/builtin/packages/umpire/package.py
index f67ec62f7b..028ba2ee17 100644
--- a/var/spack/repos/builtin/packages/umpire/package.py
+++ b/var/spack/repos/builtin/packages/umpire/package.py
@@ -21,8 +21,10 @@ class Umpire(CachedCMakePackage, CudaPackage, ROCmPackage):
maintainers = ['davidbeckingsale']
- version('develop', branch='develop', submodules=True)
- version('main', branch='main', submodules=True)
+ version('develop', branch='develop', submodules=False)
+ version('main', branch='main', submodules=False)
+ version('2022.03.1', tag='v2022.03.1', submodules=False)
+ version('2022.03.0', tag='v2022.03.0', submodules=False)
version('6.0.0', tag='v6.0.0', submodules=True)
version('5.0.1', tag='v5.0.1', submodules=True)
version('5.0.0', tag='v5.0.0', submodules=True)
@@ -70,19 +72,22 @@ class Umpire(CachedCMakePackage, CudaPackage, ROCmPackage):
variant('examples', default=True, description='Build Umpire Examples')
variant('tests', default='none', values=('none', 'basic', 'benchmarks'),
multi=False, description='Tests to run')
+ variant('device_alloc', default=True, description='Build Umpire Device Allocator')
depends_on('cmake@3.8:', type='build')
depends_on('cmake@3.9:', when='+cuda', type='build')
depends_on('cmake@:3.20', when='+rocm', type='build')
+ depends_on('cmake@3.14:', when='@2022.03.0:')
- depends_on('blt@0.5.0:', type='build', when='@6.0.1:')
+ depends_on('blt@0.5.0:', type='build', when='@2022.03.0:')
depends_on('blt@0.4.1', type='build', when='@6.0.0')
depends_on('blt@0.4.0:', type='build', when='@4.1.3:5.0.1')
depends_on('blt@0.3.6:', type='build', when='@:4.1.2')
depends_on('camp', when='@5.0.0:')
- depends_on('camp@0.2.2', when='@6.0.0:')
+ depends_on('camp@0.2.2', when='@6.0.0')
depends_on('camp@0.1.0', when='@5.0.0:5.0.1')
+ depends_on('camp@2022.03.0:', when='@2022.03.0:')
with when('@5.0.0:'):
with when('+cuda'):
@@ -99,6 +104,7 @@ class Umpire(CachedCMakePackage, CudaPackage, ROCmPackage):
conflicts('+numa', when='@:0.3.2')
conflicts('~c', when='+fortran', msg='Fortran API requires C API')
+ conflicts('+device_alloc', when='@:2022.03.0')
# device allocator exports device code, which requires static libs
# currently only available for cuda.
@@ -131,12 +137,15 @@ class Umpire(CachedCMakePackage, CudaPackage, ROCmPackage):
spec = self.spec
entries = super(Umpire, self).initconfig_compiler_entries()
+ option_prefix = "UMPIRE_" if spec.satisfies("@2022.03.0:") else ""
+
if '+fortran' in spec and self.compiler.fc is not None:
entries.append(cmake_cache_option("ENABLE_FORTRAN", True))
else:
entries.append(cmake_cache_option("ENABLE_FORTRAN", False))
- entries.append(cmake_cache_option("ENABLE_C", '+c' in spec))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_C".format(option_prefix), '+c' in spec))
return entries
@@ -144,6 +153,8 @@ class Umpire(CachedCMakePackage, CudaPackage, ROCmPackage):
spec = self.spec
entries = super(Umpire, self).initconfig_hardware_entries()
+ option_prefix = "UMPIRE_" if spec.satisfies("@2022.03.0:") else ""
+
if '+cuda' in spec:
entries.append(cmake_cache_option("ENABLE_CUDA", True))
@@ -158,7 +169,8 @@ class Umpire(CachedCMakePackage, CudaPackage, ROCmPackage):
"CMAKE_CUDA_FLAGS", '{0}'.format(flag)))
entries.append(cmake_cache_option(
- "ENABLE_DEVICE_CONST", spec.satisfies('+deviceconst')))
+ "{}ENABLE_DEVICE_CONST".format(option_prefix),
+ spec.satisfies('+deviceconst')))
else:
entries.append(cmake_cache_option("ENABLE_CUDA", False))
@@ -180,6 +192,8 @@ class Umpire(CachedCMakePackage, CudaPackage, ROCmPackage):
spec = self.spec
entries = []
+ option_prefix = "UMPIRE_" if spec.satisfies("@2022.03.0:") else ""
+
# TPL locations
entries.append("#------------------{0}".format("-" * 60))
entries.append("# TPLs")
@@ -188,12 +202,18 @@ class Umpire(CachedCMakePackage, CudaPackage, ROCmPackage):
entries.append(cmake_cache_path("BLT_SOURCE_DIR", spec['blt'].prefix))
if spec.satisfies('@5.0.0:'):
entries.append(cmake_cache_path("camp_DIR", spec['camp'].prefix))
- entries.append(cmake_cache_option("ENABLE_NUMA", '+numa' in spec))
- entries.append(cmake_cache_option("ENABLE_OPENMP", '+openmp' in spec))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_NUMA".format(option_prefix), '+numa' in spec))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_OPENMP".format(option_prefix), '+openmp' in spec))
entries.append(cmake_cache_option(
"ENABLE_BENCHMARKS", 'tests=benchmarks' in spec))
- entries.append(cmake_cache_option("ENABLE_EXAMPLES", '+examples' in spec))
- entries.append(cmake_cache_option("ENABLE_DOCS", False))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_EXAMPLES".format(option_prefix), '+examples' in spec))
+ entries.append(cmake_cache_option(
+ "{}ENABLE_DOCS".format(option_prefix), False))
+ entries.append(cmake_cache_option("UMPIRE_ENABLE_DEVICE_ALLOCATOR",
+ "+device_alloc" in spec))
entries.append(cmake_cache_option("BUILD_SHARED_LIBS", '+shared' in spec))
entries.append(cmake_cache_option("ENABLE_TESTS", 'tests=none' not in spec))