kokkos: add serial backend explicitly. add kokkos options and kokkos cuda options. (#9276)
This commit is contained in:
		 Geoff Womeldorff
					Geoff Womeldorff
				
			
				
					committed by
					
						 Christoph Junghans
						Christoph Junghans
					
				
			
			
				
	
			
			
			 Christoph Junghans
						Christoph Junghans
					
				
			
						parent
						
							691a19226c
						
					
				
				
					commit
					57236fa2ce
				
			| @@ -45,13 +45,43 @@ class Kokkos(Package): | |||||||
|     version('2.02.15', 'de41e38f452a50bb03363c519fe20769') |     version('2.02.15', 'de41e38f452a50bb03363c519fe20769') | ||||||
|     version('2.02.07', 'd5baeea70109249f7dca763074ffb202') |     version('2.02.07', 'd5baeea70109249f7dca763074ffb202') | ||||||
|  |  | ||||||
|  |     variant('serial', default=True, description="enable Serial backend (default)") | ||||||
|     variant('qthreads', default=False, description="enable Qthreads backend") |     variant('qthreads', default=False, description="enable Qthreads backend") | ||||||
|     variant('cuda', default=False, description="enable Cuda backend") |     variant('cuda', default=False, description="enable Cuda backend") | ||||||
|     variant('openmp', default=False, description="enable OpenMP backend") |     variant('openmp', default=False, description="enable OpenMP backend") | ||||||
|  |  | ||||||
|  |     # 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', |     gpu_values = ('Kepler30', 'Kepler32', 'Kepler35', 'Kepler37', | ||||||
|                   'Maxwell50', 'Maxwell52', 'Maxwell53', |                   'Maxwell50', 'Maxwell52', 'Maxwell53', | ||||||
|                   'Pascal60', 'Pascal61') |                   'Pascal60', 'Pascal61', | ||||||
|  |                   'Volta70', 'Volta72') | ||||||
|  |  | ||||||
|  |     cuda_options = ('force_uvm', 'use_ldg', 'rdc', 'enable_lambda') | ||||||
|  |  | ||||||
|     # Host architecture variant |     # Host architecture variant | ||||||
|     variant( |     variant( | ||||||
| @@ -71,18 +101,43 @@ class Kokkos(Package): | |||||||
|         description='Set the GPU architecture to use' |         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 |     # Check that we haven't specified a gpu architecture | ||||||
|     # without specifying CUDA |     # without specifying CUDA | ||||||
|     for p in gpu_values: |     for p in gpu_values: | ||||||
|         conflicts('gpu_arch={0}'.format(p), when='~cuda', |         conflicts('gpu_arch={0}'.format(p), when='~cuda', | ||||||
|             msg='Must specify CUDA backend to use a GPU architecture.') |             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 |     # conflicts on kokkos version and cuda enabled | ||||||
|     # see kokkos issue #1296 |     # see kokkos issue #1296 | ||||||
|     # https://github.com/kokkos/kokkos/issues/1296 |     # https://github.com/kokkos/kokkos/issues/1296 | ||||||
|     conflicts('+cuda', when='@2.5.00:develop', |     conflicts('+cuda', when='@2.5.00:develop', | ||||||
|         msg='Kokkos build system has issue when CUDA enabled' |         msg='Kokkos build system has issue when CUDA enabled' | ||||||
|         ' in version 2.5.00, 2.7.00, and develop until ' |         ' in version 2.5.00 through 2.7.00, and develop until ' | ||||||
|         'issue #1296 is resolved.') |         'issue #1296 is resolved.') | ||||||
|  |  | ||||||
|     # Specify that v1.x is required as v2.x has API changes |     # Specify that v1.x is required as v2.x has API changes | ||||||
| @@ -97,10 +152,14 @@ def install(self, spec, prefix): | |||||||
|             g_args = [ |             g_args = [ | ||||||
|                 '--prefix=%s' % prefix, |                 '--prefix=%s' % prefix, | ||||||
|                 '--with-hwloc=%s' % spec['hwloc'].prefix, |                 '--with-hwloc=%s' % spec['hwloc'].prefix, | ||||||
|                 '--with-serial' |  | ||||||
|             ] |             ] | ||||||
|             arch_args = [] |             arch_args = [] | ||||||
|  |             kokkos_options_args = [] | ||||||
|  |             cuda_options_args = [] | ||||||
|  |  | ||||||
|             # Backends |             # Backends | ||||||
|  |             if 'serial' in spec: | ||||||
|  |                 g_args.append('--with-serial') | ||||||
|             if '+openmp' in spec: |             if '+openmp' in spec: | ||||||
|                 g_args.append('--with-openmp') |                 g_args.append('--with-openmp') | ||||||
|             if 'qthreads' in spec: |             if 'qthreads' in spec: | ||||||
| @@ -115,9 +174,42 @@ def install(self, spec, prefix): | |||||||
|                 arch_args.append(host_arch) |                 arch_args.append(host_arch) | ||||||
|             if gpu_arch: |             if gpu_arch: | ||||||
|                 arch_args.append(gpu_arch) |                 arch_args.append(gpu_arch) | ||||||
|  |             # Combined architecture flags | ||||||
|             if arch_args: |             if arch_args: | ||||||
|                 g_args.append('--arch={0}'.format(','.join(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) |             generate(*g_args) | ||||||
|             make() |             make() | ||||||
|             make('install') |             make('install') | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user