summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrey Prokopenko <prokopenkoav@ornl.gov>2020-06-25 15:20:31 -0400
committerGitHub <noreply@github.com>2020-06-25 14:20:31 -0500
commit9f3e542d30a94b7f23b1f55eb8958db4072190ea (patch)
treea1149e43d50941b356e531517ec908c9991421ca
parent7c54aa2eb088398d626b8ce4354623d62f3a4638 (diff)
downloadspack-9f3e542d30a94b7f23b1f55eb8958db4072190ea.tar.gz
spack-9f3e542d30a94b7f23b1f55eb8958db4072190ea.tar.bz2
spack-9f3e542d30a94b7f23b1f55eb8958db4072190ea.tar.xz
spack-9f3e542d30a94b7f23b1f55eb8958db4072190ea.zip
Update ArborX for new Kokkos (#17213)
* Update ArborX for new Kokkos * Set maintainer
-rw-r--r--var/spack/repos/builtin/packages/arborx/package.py59
1 files changed, 40 insertions, 19 deletions
diff --git a/var/spack/repos/builtin/packages/arborx/package.py b/var/spack/repos/builtin/packages/arborx/package.py
index 7d10ef1fab..5353b09de2 100644
--- a/var/spack/repos/builtin/packages/arborx/package.py
+++ b/var/spack/repos/builtin/packages/arborx/package.py
@@ -9,42 +9,63 @@ from spack import *
class Arborx(CMakePackage):
"""ArborX is a performance-portable library for geometric search"""
- homepage = "http://github.com/arborx/arborx"
- url = "https://github.com/arborx/arborx/archive/v0.8-beta2.tar.gz"
+ homepage = "https://github.com/arborx/arborx"
+ url = "https://github.com/arborx/arborx/archive/v0.9-beta.tar.gz"
git = "https://github.com/arborx/arborx.git"
+ maintainers = ['aprokop']
+
version('master', branch='master')
- version('0.8-beta2', sha256='e68733bc77fbb84313f3ff059f746fa79ab2ffe24a0a391126eefa47ec4fd2df')
+ version('0.9-beta', sha256='b349b5708d1aa00e8c20c209ac75dc2d164ff9bf1b85adb5437346d194ba6c0d')
+
+ # ArborX relies on Kokkos to provide devices, providing one-to-one matching
+ # variants. The only way to disable those devices is to make sure Kokkos
+ # does not provide them.
+ kokkos_backends = {
+ 'serial': (True, "enable Serial backend (default)"),
+ 'cuda': (False, "enable Cuda backend"),
+ 'openmp': (False, "enable OpenMP backend"),
+ 'hip': (False, "enable HIP backend")
+ }
- variant('cuda', default=False, description='enable Cuda backend')
- variant('openmp', default=False, description='enable OpenMP backend')
- variant('serial', default=True, description='enable Serial backend (default)')
variant('mpi', default=True, description='enable MPI')
+ for backend in kokkos_backends:
+ deflt, descr = kokkos_backends[backend]
+ variant(backend.lower(), default=deflt, description=descr)
+ variant('trilinos', default=False, description='use Kokkos from Trilinos')
depends_on('cmake@3.12:', type='build')
- depends_on('cuda', when='+cuda')
depends_on('mpi', when='+mpi')
- # ArborX relies on Kokkos to provide devices, thus having one-to-one match
- # The only way to disable those devices is to make sure Kokkos does not
- # provide them
- depends_on('kokkos-legacy@2.7.00:+cuda+enable_lambda cxxstd=c++14', when='+cuda')
- depends_on('kokkos-legacy@2.7.00:+openmp cxxstd=c++14', when='+openmp')
- depends_on('kokkos-legacy@2.7.00:+serial cxxstd=c++14', when='+serial')
+ # Standalone Kokkos
+ depends_on('kokkos@3.1.00:', when='~trilinos')
+ for backend in kokkos_backends:
+ depends_on('kokkos+%s' % backend.lower(), when='~trilinos+%s' %
+ backend.lower())
+ depends_on('kokkos+cuda_lambda', when='~trilinos+cuda')
+
+ # Trilinos/Kokkos
+ # Notes:
+ # - there is no Trilinos release with Kokkos 3.1 yet
+ # - current version of Trilinos package does not allow disabling Serial
+ # - current version of Trilinos package does not allow enabling CUDA
+ depends_on('trilinos+kokkos@develop', when='+trilinos')
+ depends_on('trilinos+openmp', when='trilinos+openmp')
+ conflicts('~serial', when='+trilinos')
+ conflicts('+cuda', when='+trilinos')
def cmake_args(self):
spec = self.spec
options = [
- '-DCMAKE_PREFIX_PATH=%s' % spec['kokkos-legacy'].prefix,
- '-DARBORX_ENABLE_TESTS=OFF',
- '-DARBORX_ENABLE_EXAMPLES=OFF',
- '-DARBORX_ENABLE_BENCHMARKS=OFF',
+ '-DKokkos_ROOT=%s' % (spec['kokkos'].prefix if '~trilinos' in spec
+ else spec['trilinos'].prefix),
'-DARBORX_ENABLE_MPI=%s' % ('ON' if '+mpi' in spec else 'OFF')
]
if '+cuda' in spec:
- nvcc_wrapper_path = spec['kokkos'].prefix.bin.nvcc_wrapper
- options.append('-DCMAKE_CXX_COMPILER=%s' % nvcc_wrapper_path)
+ # Only Kokkos allows '+cuda' for now
+ options.append(
+ '-DCMAKE_CXX_COMPILER=%s' % spec["kokkos"].kokkos_cxx)
return options