From be11f86ff2615f7aab302bb8bf18b132c8e663dc Mon Sep 17 00:00:00 2001 From: Simeon Ehrig Date: Wed, 13 Nov 2024 14:57:15 +0100 Subject: [PATCH] Check in CMake and alpaka.hpp if the compiler supports the minimum required C++ standard --- cmake/alpakaCommon.cmake | 29 +++++++++++++++++++++++++++++ include/alpaka/alpaka.hpp | 4 ++++ 2 files changed, 33 insertions(+) diff --git a/cmake/alpakaCommon.cmake b/cmake/alpakaCommon.cmake index 4147f719c1d..7fff99a495c 100644 --- a/cmake/alpakaCommon.cmake +++ b/cmake/alpakaCommon.cmake @@ -57,6 +57,20 @@ function(alpaka_set_compiler_options scope type name) endif() endfunction() +# Check if compiler supports required C++ standard. +# +# language - can be CXX, HIP or CUDA +# min_cxx_standard - C++ standard which is the minimum requirement +function(checkCompilerCXXSupport language min_cxx_standard) + string(TOUPPER "${language}" language_upper_case) + string(TOLOWER "${language}" language_lower_case) + + if(NOT "${language_lower_case}_std_${min_cxx_standard}" IN_LIST CMAKE_${language_upper_case}_COMPILE_FEATURES) + message(FATAL_ERROR "The ${language_upper_case} compiler does not support C++ ${min_cxx_standard}. \ + Please upgrade your compiler or use alpaka 1.2 which supports C++17.") + endif() +endfunction() + # HIP and platform selection and warning about unsupported features option(alpaka_ACC_GPU_HIP_ENABLE "Enable the HIP back-end (all other back-ends must be disabled)" OFF) option(alpaka_ACC_GPU_HIP_ONLY_MODE "Only back-ends using HIP can be enabled in this mode." OFF) # HIP only runs without other back-ends @@ -114,6 +128,8 @@ endif() set(alpaka_DEBUG "0" CACHE STRING "Debug level") set_property(CACHE alpaka_DEBUG PROPERTY STRINGS "0;1;2") +# minimum required C++ standard +set(alpaka_MIN_CXX_STANDARD "20") set(alpaka_CXX_STANDARD_DEFAULT "20") # Check whether alpaka_CXX_STANDARD has already been defined as a non-cached variable. if(DEFINED alpaka_CXX_STANDARD) @@ -123,6 +139,12 @@ endif() set(alpaka_CXX_STANDARD ${alpaka_CXX_STANDARD_DEFAULT} CACHE STRING "C++ standard version") set_property(CACHE alpaka_CXX_STANDARD PROPERTY STRINGS "20") +if(${alpaka_CXX_STANDARD} VERSION_LESS ${alpaka_MIN_CXX_STANDARD}) + message(FATAL_ERROR "The alpaka_CXX_STANDARD standard must be at least C++${alpaka_MIN_CXX_STANDARD}") +endif() + +checkCompilerCXXSupport(CXX ${alpaka_MIN_CXX_STANDARD}) + if(NOT TARGET alpaka) add_library(alpaka INTERFACE) @@ -174,6 +196,10 @@ if(MSVC) if(alpaka_ACC_GPU_CUDA_ONLY_MODE) target_compile_options(alpaka INTERFACE "$<$:SHELL:-Xcompiler /wd4505>") endif() + + # the flag is required, that the MSVC sets the correct value for the preprocessor macro __cplusplus + # https://learn.microsoft.com/en-us/cpp/build/reference/zc-cplusplus?view=msvc-170 + alpaka_set_compiler_options(HOST_DEVICE target alpaka "/Zc:__cplusplus>") else() # For std::future we need to pass the correct pthread flag for the compiler and the linker: # https://github.com/alpaka-group/cupla/pull/128#issuecomment-545078917 @@ -406,6 +432,7 @@ if(alpaka_ACC_GPU_CUDA_ENABLE) endif() enable_language(CUDA) + checkCompilerCXXSupport(CUDA ${alpaka_MIN_CXX_STANDARD}) if(DEFINED _CLANG_CUDA_VERSION) message(DEBUG "Workaround: reset variables for clang as cuda compiler -std=c++98 fix") @@ -579,6 +606,8 @@ if(alpaka_ACC_GPU_HIP_ENABLE) set(_alpaka_HIP_MIN_VER 5.1) set(_alpaka_HIP_MAX_VER 6.2) + + checkCompilerCXXSupport(HIP ${alpaka_MIN_CXX_STANDARD}) # construct hip version only with major and minor level # cannot use hip_VERSION because of the patch level diff --git a/include/alpaka/alpaka.hpp b/include/alpaka/alpaka.hpp index bc04c4e1a2b..31d713e0351 100644 --- a/include/alpaka/alpaka.hpp +++ b/include/alpaka/alpaka.hpp @@ -5,6 +5,10 @@ #pragma once +#if __cplusplus < 202002L +# error Alpaka supports only C++ 20 and later standards +#endif + // Include the whole library. // version number