diff options
Diffstat (limited to 'var/spack/repos/builtin/packages/kokkos/package.py')
-rw-r--r-- | var/spack/repos/builtin/packages/kokkos/package.py | 199 |
1 files changed, 171 insertions, 28 deletions
diff --git a/var/spack/repos/builtin/packages/kokkos/package.py b/var/spack/repos/builtin/packages/kokkos/package.py index e1ebf79eca..6de38510c4 100644 --- a/var/spack/repos/builtin/packages/kokkos/package.py +++ b/var/spack/repos/builtin/packages/kokkos/package.py @@ -1,27 +1,8 @@ -############################################################################## -# Copyright (c) 2013-2017, Lawrence Livermore National Security, LLC. -# Produced at the Lawrence Livermore National Laboratory. +# Copyright 2013-2018 Lawrence Livermore National Security, LLC and other +# Spack Project Developers. See the top-level COPYRIGHT file for details. # -# This file is part of Spack. -# Created by Todd Gamblin, tgamblin@llnl.gov, All rights reserved. -# LLNL-CODE-647188 -# -# For details, see https://github.com/spack/spack -# Please also see the NOTICE and LICENSE files for our notice and the LGPL. -# -# This program is free software; you can redistribute it and/or modify -# it under the terms of the GNU Lesser General Public License (as -# published by the Free Software Foundation) version 2.1, February 1999. -# -# This program is distributed in the hope that it will be useful, but -# WITHOUT ANY WARRANTY; without even the IMPLIED WARRANTY OF -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the terms and -# conditions of the GNU Lesser General Public License for more details. -# -# You should have received a copy of the GNU Lesser General Public -# License along with this program; if not, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -############################################################################## +# SPDX-License-Identifier: (Apache-2.0 OR MIT) + from spack import * @@ -31,13 +12,121 @@ class Kokkos(Package): homepage = "https://github.com/kokkos/kokkos" url = "https://github.com/kokkos/kokkos/archive/2.03.00.tar.gz" + git = "https://github.com/kokkos/kokkos.git" + version('develop', branch='develop') + version('2.7.00', 'b357f9374c1008754babb4495f95e392') + version('2.5.00', '2db83c56587cb83b772d0c81a3228a21') + version('2.04.11', 'd4849cee6eb9001d61c30f1d9fe74336') + version('2.04.04', '2c6d1c2569b91c9fcd4117296438e65c') + version('2.04.00', 'd99ac790ff5f29545d8eb53de90c0a85') + version('2.03.13', '3874a159a517384541ea5b52f85501ba') + version('2.03.05', '8727d783453f719eec392e10a36b49fd') version('2.03.00', 'f205d659d4304747759fabfba32d43c3') + version('2.02.15', 'de41e38f452a50bb03363c519fe20769') + version('2.02.07', 'd5baeea70109249f7dca763074ffb202') + variant('serial', default=True, description="enable Serial backend (default)") variant('qthreads', default=False, description="enable Qthreads backend") variant('cuda', default=False, description="enable Cuda backend") + variant('openmp', default=False, description="enable OpenMP backend") + + # Compilation options + variant('pic', default=False, + description="enable position independent code (-fPIC flag)") + + # Kokkos options + variant('aggressive_vectorization', default=False, + description="set aggressive_vectorization Kokkos option") + variant('disable_profiling', default=False, + description="set disable_profiling Kokkos option") + variant('disable_dualview_modify_check', default=False, + description="set disable_dualview_modify_check Kokkos option") + variant('enable_profile_load_print', default=False, + description="set enable_profile_load_print Kokkos option") + variant('compiler_warnings', default=False, + description="set compiler_warnings Kokkos option") + variant('disable_deprecated_code', default=False, + description="set disable_deprecated_code Kokkos option") + variant('enable_eti', default=False, + description="set enable_eti Kokkos option") + + # CUDA options + variant('force_uvm', default=False, + description="set force_uvm Kokkos CUDA option") + variant('use_ldg', default=False, + description="set use_ldg Kokkos CUDA option") + variant('rdc', default=False, + description="set rdc Kokkos CUDA option") + variant('enable_lambda', default=False, + description="set enable_lambda Kokkos CUDA option") + + gpu_values = ('Kepler30', 'Kepler32', 'Kepler35', 'Kepler37', + 'Maxwell50', 'Maxwell52', 'Maxwell53', + 'Pascal60', 'Pascal61', + 'Volta70', 'Volta72') + + cuda_options = ('force_uvm', 'use_ldg', 'rdc', 'enable_lambda') + + # Host architecture variant + variant( + 'host_arch', + default=None, + values=('AMDAVX', 'ARMv80', 'ARMv81', 'ARMv8-ThunderX', + 'Power7', 'Power8', 'Power9', + 'WSM', 'SNB', 'HSW', 'BDW', 'SKX', 'KNC', 'KNL'), + description='Set the host architecture to use' + ) - depends_on('hwloc') + # GPU architecture variant + variant( + 'gpu_arch', + default=None, + values=gpu_values, + description='Set the GPU architecture to use' + ) + + # Checks on Kokkos version and Kokkos options + conflicts('+aggressive_vectorization', when='@:2.0.99',) + conflicts('+disable_profiling', when='@:2.0.99',) + conflicts('+disable_dualview_modify_check', when='@:2.03.04',) + conflicts('+enable_profile_load_print', when='@:2.03.04',) + conflicts('+compiler_warnings', when='@:2.03.14',) + conflicts('+disable_deprecated_code', when='@:2.5.99',) + conflicts('+enable_eti', when='@:2.6.99',) + + # Check that we haven't specified a gpu architecture + # without specifying CUDA + for p in gpu_values: + conflicts('gpu_arch={0}'.format(p), when='~cuda', + msg='Must specify CUDA backend to use a GPU architecture.') + + # Check that we haven't specified a Kokkos CUDA option + # without specifying CUDA + conflicts('+force_uvm', when='~cuda', + msg='Must enable CUDA to use force_uvm.') + conflicts('+use_ldg', when='~cuda', + msg='Must enable CUDA to use use_ldg.') + conflicts('+rdc', when='~cuda', + msg='Must enable CUDA to use rdc.') + conflicts('+enable_lambda', when='~cuda', + msg='Must enable CUDA to use enable_lambda.') + + # Check that we haven't asked for a GPU architecture that + # the revision of kokkos does not support + conflicts('gpu_arch=Volta70', when='@:2.5.99') + conflicts('gpu_arch=Volta72', when='@:2.5.99') + + # conflicts on kokkos version and cuda enabled + # see kokkos issue #1296 + # https://github.com/kokkos/kokkos/issues/1296 + conflicts('+cuda', when='@2.5.00:develop', + msg='Kokkos build system has issue when CUDA enabled' + ' in version 2.5.00 through 2.7.00, and develop until ' + 'issue #1296 is resolved.') + + # Specify that v1.x is required as v2.x has API changes + depends_on('hwloc@:1') depends_on('qthreads', when='+qthreads') depends_on('cuda', when='+cuda') @@ -48,13 +137,67 @@ class Kokkos(Package): g_args = [ '--prefix=%s' % prefix, '--with-hwloc=%s' % spec['hwloc'].prefix, - '--with-serial', - '--with-openmp', ] - if 'qthreads' in spec: + arch_args = [] + kokkos_options_args = [] + cuda_options_args = [] + + # PIC + if '+pic' in spec: + g_args.append('--cxxflags=-fPIC') + + # Backends + if '+serial' in spec: + g_args.append('--with-serial') + if '+openmp' in spec: + g_args.append('--with-openmp') + if '+qthreads' in spec: g_args.append('--with-qthreads=%s' % spec['qthreads'].prefix) - if 'cuda' in spec: + if '+cuda' in spec: g_args.append('--with-cuda=%s' % spec['cuda'].prefix) + # Host architectures + host_arch = spec.variants['host_arch'].value + # GPU architectures + gpu_arch = spec.variants['gpu_arch'].value + if host_arch: + arch_args.append(host_arch) + if gpu_arch: + arch_args.append(gpu_arch) + # Combined architecture flags + if arch_args: + g_args.append('--arch={0}'.format(','.join(arch_args))) + + # CUDA options + if '+force_uvm' in spec: + cuda_options_args.append('force_uvm') + if '+use_ldg' in spec: + cuda_options_args.append('use_ldg') + if '+rdc' in spec: + cuda_options_args.append('rdc') + if '+enable_lambda' in spec: + cuda_options_args.append('enable_lambda') + if cuda_options_args: + g_args.append('--with-cuda-options={0}' + .format(','.join(cuda_options_args))) + + # Kokkos options + if '+aggressive_vectorization' in spec: + kokkos_options_args.append('aggressive_vectorization') + if '+disable_profiling' in spec: + kokkos_options_args.append('disable_profiling') + if '+disable_dualview_modify_check' in spec: + kokkos_options_args.append('disable_dualview_modify_check') + if '+enable_profile_load_print' in spec: + kokkos_options_args.append('enable_profile_load_print') + if '+compiler_warnings' in spec: + kokkos_options_args.append('compiler_warnings') + if '+disable_deprecated_code' in spec: + kokkos_options_args.append('disable_deprecated_code') + if '+enable_eti' in spec: + kokkos_options_args.append('enable_eti') + if kokkos_options_args: + g_args.append('--with-options={0}' + .format(','.join(kokkos_options_args))) generate(*g_args) make() |