diff options
Diffstat (limited to 'var/spack/repos/builtin/packages/arrayfire/package.py')
-rw-r--r-- | var/spack/repos/builtin/packages/arrayfire/package.py | 36 |
1 files changed, 28 insertions, 8 deletions
diff --git a/var/spack/repos/builtin/packages/arrayfire/package.py b/var/spack/repos/builtin/packages/arrayfire/package.py index d3a7b65e2c..0315dffadc 100644 --- a/var/spack/repos/builtin/packages/arrayfire/package.py +++ b/var/spack/repos/builtin/packages/arrayfire/package.py @@ -1,4 +1,4 @@ -# Copyright 2013-2020 Lawrence Livermore National Security, LLC and other +# Copyright 2013-2021 Lawrence Livermore National Security, LLC and other # Spack Project Developers. See the top-level COPYRIGHT file for details. # # SPDX-License-Identifier: (Apache-2.0 OR MIT) @@ -15,6 +15,8 @@ class Arrayfire(CMakePackage, CudaPackage): git = "https://github.com/arrayfire/arrayfire.git" version('master', submodules=True) + version('3.7.3', submodules=True, tag='v3.7.3') + version('3.7.2', submodules=True, tag='v3.7.2') version('3.7.0', submodules=True, tag='v3.7.0') variant('cuda', default=False, description='Enable Cuda backend') @@ -22,7 +24,7 @@ class Arrayfire(CMakePackage, CudaPackage): variant('opencl', default=False, description='Enable OpenCL backend') depends_on('boost@1.65:') - depends_on('fftw') + depends_on('fftw-api@3:') depends_on('blas') depends_on('cuda@7.5:', when='+cuda') depends_on('cudnn', when='+cuda') @@ -34,14 +36,32 @@ class Arrayfire(CMakePackage, CudaPackage): depends_on('fontconfig', when='+forge') depends_on('glfw@3.1.4:', when='+forge') + @property + def libs(self): + query_parameters = self.spec.last_query.extra_parameters + + libraries = [] + if 'cpu' in query_parameters: + libraries.append('libafcpu') + if 'cuda' in query_parameters and '+cuda' in self.spec: + libraries.append('libafcuda') + if 'opencl' in query_parameters and '+opencl' in self.spec: + libraries.append('libafopencl') + if not query_parameters or 'unified' in query_parameters: + libraries.append('libaf') + + return find_libraries(libraries, root=self.prefix, recursive=True) + def cmake_args(self): args = [] args.extend([ - '-DAF_BUILD_CUDA={0}'.format( - 'ON' if '+cuda' in self.spec else 'OFF'), - '-DAF_BUILD_FORGE={0}'.format( - 'ON' if '+forge' in self.spec else 'OFF'), - '-DAF_BUILD_OPENCL={0}'.format( - 'ON' if '+opencl' in self.spec else 'OFF'), + self.define_from_variant('AF_BUILD_CUDA', 'cuda'), + self.define_from_variant('AF_BUILD_FORGE', 'forge'), + self.define_from_variant('AF_BUILD_OPENCL', 'opencl'), ]) + if '^mkl' in self.spec: + args.append('-DUSE_CPU_MKL=ON') + if '%intel' not in self.spec: + args.append('-DMKL_THREAD_LAYER=GNU OpenMP') + return args |