From 44702849197960d73c3c4481fb0709537ddc8c99 Mon Sep 17 00:00:00 2001 From: Phil Miller Date: Wed, 5 Apr 2023 10:54:14 -0700 Subject: [PATCH] Fix definitions and docs to remove CUDA Lambda option --- .jenkins | 4 ---- cmake/KokkosCore_config.h.in | 1 - cmake/kokkos_arch.cmake | 4 ++-- cmake/kokkos_enable_options.cmake | 10 +--------- core/src/Kokkos_Macros.hpp | 5 +++++ generate_makefile.bash | 6 ++---- scripts/trilinos-integration/waterman_cuda_env.sh | 2 +- scripts/trilinos-integration/white_cuda_env.sh | 2 +- 8 files changed, 12 insertions(+), 22 deletions(-) diff --git a/.jenkins b/.jenkins index b7591d1a23..a4d2f7cefc 100644 --- a/.jenkins +++ b/.jenkins @@ -84,7 +84,6 @@ pipeline { -DKokkos_ENABLE_DEPRECATED_CODE_4=OFF \ -DKokkos_ENABLE_TESTS=ON \ -DKokkos_ENABLE_CUDA=ON \ - -DKokkos_ENABLE_CUDA_LAMBDA=ON \ -DKokkos_ENABLE_OPENMP=ON \ .. && \ make -j8 && ctest --verbose''' @@ -313,7 +312,6 @@ pipeline { -DKokkos_ENABLE_TESTS=ON \ -DKokkos_ENABLE_BENCHMARKS=ON \ -DKokkos_ENABLE_CUDA=ON \ - -DKokkos_ENABLE_CUDA_LAMBDA=ON \ -DKokkos_ENABLE_TUNING=ON \ -DKokkos_ARCH_VOLTA70=ON \ .. && \ @@ -386,7 +384,6 @@ pipeline { -DKokkos_ENABLE_COMPILER_WARNINGS=ON \ -DKokkos_ENABLE_OPENMP=OFF \ -DKokkos_ENABLE_CUDA=ON \ - -DKokkos_ENABLE_CUDA_LAMBDA=OFF \ -DKokkos_ENABLE_CUDA_UVM=ON \ -DKokkos_ENABLE_CUDA_RELOCATABLE_DEVICE_CODE=ON \ -DKokkos_ENABLE_DEPRECATED_CODE_3=ON \ @@ -453,7 +450,6 @@ pipeline { -DKokkos_ENABLE_TESTS=ON \ -DKokkos_ENABLE_BENCHMARKS=ON \ -DKokkos_ENABLE_CUDA=ON \ - -DKokkos_ENABLE_CUDA_LAMBDA=ON \ -DKokkos_ENABLE_LIBDL=OFF \ .. && \ make -j8 && ctest --verbose && \ diff --git a/cmake/KokkosCore_config.h.in b/cmake/KokkosCore_config.h.in index bcfa16d742..2b1ea092e0 100644 --- a/cmake/KokkosCore_config.h.in +++ b/cmake/KokkosCore_config.h.in @@ -35,7 +35,6 @@ #cmakedefine KOKKOS_ENABLE_CUDA_RELOCATABLE_DEVICE_CODE #cmakedefine KOKKOS_ENABLE_CUDA_UVM -#cmakedefine KOKKOS_ENABLE_CUDA_LAMBDA #cmakedefine KOKKOS_ENABLE_CUDA_CONSTEXPR #cmakedefine KOKKOS_ENABLE_IMPL_CUDA_MALLOC_ASYNC #cmakedefine KOKKOS_ENABLE_HIP_RELOCATABLE_DEVICE_CODE diff --git a/cmake/kokkos_arch.cmake b/cmake/kokkos_arch.cmake index 2448c43f10..2137344c5e 100644 --- a/cmake/kokkos_arch.cmake +++ b/cmake/kokkos_arch.cmake @@ -172,8 +172,8 @@ IF(KOKKOS_CXX_COMPILER_ID STREQUAL NVIDIA) GLOBAL_APPEND(KOKKOS_CUDA_OPTIONS "-Wext-lambda-captures-this") ENDIF() -IF(DEFINED KOKKOS_ENABLE_CUDA_LAMBDA) - IF(KOKKOS_ENABLE_CUDA_LAMBDA) +IF(DEFINED Kokkos_ENABLE_CUDA_LAMBDA) + IF(Kokkos_ENABLE_CUDA_LAMBDA) MESSAGE(DEPRECATION "CUDA extended lambda support is now always enabled. The option Kokkos_ENABLE_CUDA_LAMBDA will be removed") ELSE() MESSAGE(FATAL_ERROR "Support for disabling CUDA extended lambdas has been removed. Please unset Kokkos_ENABLE_CUDA_LAMBDA, or see #5964 if this is necessary for your application") diff --git a/cmake/kokkos_enable_options.cmake b/cmake/kokkos_enable_options.cmake index 7d8026989a..145815c7f2 100644 --- a/cmake/kokkos_enable_options.cmake +++ b/cmake/kokkos_enable_options.cmake @@ -67,14 +67,6 @@ mark_as_advanced(Kokkos_ENABLE_IMPL_MDSPAN) mark_as_advanced(Kokkos_ENABLE_MDSPAN_EXTERNAL) mark_as_advanced(Kokkos_ENABLE_IMPL_SKIP_COMPILER_MDSPAN) -IF (Trilinos_ENABLE_Kokkos AND TPL_ENABLE_CUDA) - SET(CUDA_LAMBDA_DEFAULT ON) -ELSEIF (KOKKOS_ENABLE_CUDA) - SET(CUDA_LAMBDA_DEFAULT ON) -ELSE() - SET(CUDA_LAMBDA_DEFAULT OFF) -ENDIF() -KOKKOS_ENABLE_OPTION(CUDA_LAMBDA ${CUDA_LAMBDA_DEFAULT} "Whether to activate experimental lambda features") IF (Trilinos_ENABLE_Kokkos) SET(COMPLEX_ALIGN_DEFAULT OFF) ELSE() @@ -123,7 +115,7 @@ FUNCTION(check_device_specific_options) ENDIF() ENDFUNCTION() -CHECK_DEVICE_SPECIFIC_OPTIONS(DEVICE CUDA OPTIONS CUDA_UVM CUDA_RELOCATABLE_DEVICE_CODE CUDA_LAMBDA CUDA_CONSTEXPR CUDA_LDG_INTRINSIC) +CHECK_DEVICE_SPECIFIC_OPTIONS(DEVICE CUDA OPTIONS CUDA_UVM CUDA_RELOCATABLE_DEVICE_CODE CUDA_CONSTEXPR CUDA_LDG_INTRINSIC) CHECK_DEVICE_SPECIFIC_OPTIONS(DEVICE HIP OPTIONS HIP_RELOCATABLE_DEVICE_CODE) CHECK_DEVICE_SPECIFIC_OPTIONS(DEVICE HPX OPTIONS IMPL_HPX_ASYNC_DISPATCH) diff --git a/core/src/Kokkos_Macros.hpp b/core/src/Kokkos_Macros.hpp index 8cc4a6efa3..f765efe68c 100644 --- a/core/src/Kokkos_Macros.hpp +++ b/core/src/Kokkos_Macros.hpp @@ -607,4 +607,9 @@ static constexpr bool kokkos_omp_on_host() { return false; } #define KOKKOS_IMPL_ENFORCE_EMPTY_BASE_OPTIMIZATION #endif +// This was previously defined from the configuration option which was removed +#if defined(KOKKOS_ENABLE_CUDA) +#define KOKKOS_ENABLE_CUDA_LAMBDA +#endif + #endif // #ifndef KOKKOS_MACROS_HPP diff --git a/generate_makefile.bash b/generate_makefile.bash index 018426c9b8..47321c5e14 100755 --- a/generate_makefile.bash +++ b/generate_makefile.bash @@ -64,9 +64,7 @@ get_kokkos_cuda_option_list() { for CUDA_ in $PARSE_CUDA_LST do CUDA_OPT_NAME= - if [ "${CUDA_}" == "enable_lambda" ]; then - CUDA_OPT_NAME=CUDA_LAMBDA - elif [ "${CUDA_}" == "rdc" ]; then + if [ "${CUDA_}" == "rdc" ]; then CUDA_OPT_NAME=CUDA_RELOCATABLE_DEVICE_CODE elif [ "${CUDA_}" == "force_uvm" ]; then CUDA_OPT_NAME=CUDA_UVM @@ -231,7 +229,7 @@ display_help_text() { echo " disable_profiling = do not compile with profiling hooks" echo " " echo "--with-cuda-options=[OPT]: Additional options to CUDA:" - echo " force_uvm, use_ldg, enable_lambda, rdc" + echo " force_uvm, use_ldg, rdc" echo "--with-hip-options=[OPT]: Additional options to HIP:" echo " rdc" echo "--with-hpx-options=[OPT]: Additional options to HPX:" diff --git a/scripts/trilinos-integration/waterman_cuda_env.sh b/scripts/trilinos-integration/waterman_cuda_env.sh index 445b4f9697..0301eb0717 100755 --- a/scripts/trilinos-integration/waterman_cuda_env.sh +++ b/scripts/trilinos-integration/waterman_cuda_env.sh @@ -30,7 +30,7 @@ export CUDA_LAUNCH_BLOCKING=1 export CUDA_MANAGED_FORCE_DEVICE_ALLOC=1 -export KOKKOS_EXTRA_FLAGS="-DKokkos_ENABLE_CUDA_LAMBDA=ON" +export KOKKOS_EXTRA_FLAGS="" scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" echo "DIR=$scriptdir" NVCC_WRAPPER=`realpath $scriptdir/../../bin/nvcc_wrapper` diff --git a/scripts/trilinos-integration/white_cuda_env.sh b/scripts/trilinos-integration/white_cuda_env.sh index f3745ede8c..4f6f4bcd9a 100755 --- a/scripts/trilinos-integration/white_cuda_env.sh +++ b/scripts/trilinos-integration/white_cuda_env.sh @@ -31,7 +31,7 @@ export CUDA_LAUNCH_BLOCKING=1 export CUDA_MANAGED_FORCE_DEVICE_ALLOC=1 -export KOKKOS_EXTRA_FLAGS="-DKokkos_ENABLE_CUDA_LAMBDA=ON" +export KOKKOS_EXTRA_FLAGS="" scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" NVCC_WRAPPER=`realpath $scriptdir/../../bin/nvcc_wrapper` export OMPI_CXX=$NVCC_WRAPPER