cmake_policy (SET CMP0048 NEW)
时间: 2023-09-11 14:08:45 浏览: 265
这是一个 CMake 的命令,用于设置 CMake 策略 CMP0048 的值为 NEW。CMP0048 是一个 CMake 中的策略,用于控制项目的版本信息。设置为 NEW 表示使用 CMake 3.0 的新行为,即在项目中自动设置版本号。这个命令通常会放在 CMakeLists.txt 的开头,以确保在项目构建前设置好 CMP0048 策略。
相关问题
cmake_policy
CMake中的cmake_policy命令用于设置和检查policy的行为。policy是CMake中的一种机制,用于控制特定功能的行为。引用\[1\]中的示例代码展示了如何设置policy的行为。通过使用cmake_policy(SET CMP0128 NEW)命令,可以将CMP0128 policy的行为设置为NEW。类似地,可以使用cmake_policy(SET CMP0065 OLD)命令将CMP0065 policy的行为设置为OLD。引用\[2\]中的示例代码展示了如何检查policy的行为。通过使用cmake_policy(GET CMP0127 var)命令,可以获取CMP0127 policy的行为,并将其存储在变量var中。类似地,可以使用cmake_policy(GET CMP0065 var)命令获取CMP0065 policy的行为。引用\[3\]中提到,建议根据CMake的版本设置policy。可以使用cmake_policy(VERSION <min>\[...<max>\])命令根据CMake的版本设置policy。
#### 引用[.reference_title]
- *1* *2* *3* [CMake中cmake_policy的使用](https://blog.csdn.net/fengbingchun/article/details/127474000)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
解释:if(CUDA_FOUND) message(STATUS "Found CUDA Toolkit v${CUDA_VERSION_STRING}") enable_language(CUDA) set(HAVE_CUDA TRUE) if (CMAKE_CUDA_COMPILER_ID STREQUAL "NVIDIA") if(${CUDA_VERSION_STRING} VERSION_GREATER_EQUAL "11.1") execute_process(COMMAND ${CMAKE_CUDA_COMPILER} --list-gpu-code RESULT_VARIABLE EXIT_CODE OUTPUT_VARIABLE OUTPUT_VAL) if(EXIT_CODE EQUAL 0) #Remove sm_ string(REPLACE "sm_" "" OUTPUT_VAL ${OUTPUT_VAL}) #Convert to list string(REPLACE "\n" ";" __CUDA_ARCH_BIN ${OUTPUT_VAL}) #Remove last empty entry list(REMOVE_AT __CUDA_ARCH_BIN -1) else() message(FATAL_ERROR "Failed to run NVCC to get list of GPU codes: ${EXIT_CODE}") endif() elseif(${CUDA_VERSION_STRING} VERSION_GREATER_EQUAL "11.0") set(__CUDA_ARCH_BIN "35;37;50;52;53;60;61;62;70;72;75;80") elseif(${CUDA_VERSION_STRING} VERSION_GREATER_EQUAL "10.0") set(__CUDA_ARCH_BIN "30;32;35;37;50;52;53;60;61;62;70;72;75") elseif(${CUDA_VERSION_STRING} VERSION_GREATER_EQUAL "9.1") set(__CUDA_ARCH_BIN "30;32;35;37;50;52;53;60;61;62;70;72") else() set(__CUDA_ARCH_BIN "30;32;35;37;50;52;53;60;61;62;70") endif() else() message(FATAL_ERROR "Unsupported CUDA compiler ${CMAKE_CUDA_COMPILER_ID}.") endif() set(CUDA_ARCH_BIN ${__CUDA_ARCH_BIN} CACHE STRING "Specify 'real' GPU architectures to build binaries for") if(POLICY CMP0104) cmake_policy(SET CMP0104 NEW) set(CMAKE_CUDA_ARCHITECTURES ${CUDA_ARCH_BIN}) message(STATUS "CMAKE_CUDA_ARCHITECTURES: ${CMAKE_CUDA_ARCHITECTURES}") #Add empty project as its not required with newer CMake add_library(pcl_cuda INTERFACE) else() # Generate SASS set(CMAKE_CUDA_ARCHITECTURES ${CUDA_ARCH_BIN}) # Generate PTX for last architecture list(GET CUDA_ARCH_BIN -1 ver) set(CMAKE_CUDA_FLAGS "${CMAKE_CUDA_FLAGS} -gencode arch=compute_${ver},code=compute_${ver}") message(STATUS "CMAKE_CUDA_FLAGS: ${CMAKE_CUDA_FLAGS}") add_library(pcl_cuda INTERFACE) target_include_directories(pcl_cuda INTERFACE ${CUDA_TOOLKIT_INCLUDE}) endif () endif()
这段代码是CMake脚本,主要用于检测CUDA是否安装,并设置CUDA相关的编译器标志和选项。
首先,它检查CUDA是否被找到,如果有就输出CUDA Toolkit的版本号,并启用CUDA编程语言。然后,它设置了一个名为HAVE_CUDA的变量为TRUE,以表示CUDA已被找到。
接下来,它检查CUDA的编译器ID是否为"NVIDIA",如果是,就根据CUDA版本号设置__CUDA_ARCH_BIN变量,该变量包含了支持的GPU架构。如果CUDA版本号大于等于11.1,则通过执行nvcc命令获取支持的GPU架构列表,并将其存储在__CUDA_ARCH_BIN变量中。如果CUDA版本号在11.0到10.0之间,则设置__CUDA_ARCH_BIN变量为支持的GPU架构列表。如果CUDA版本号在9.1及以下,则设置__CUDA_ARCH_BIN变量为支持的GPU架构列表。
如果CUDA编译器ID不是"NVIDIA",则会输出一个错误信息,表示不支持该CUDA编译器。
最后,它设置了一个名为CUDA_ARCH_BIN的缓存变量,该变量包含了要为哪些GPU架构构建代码的选项。然后,它使用CMake策略CMP0104来设置CMAKE_CUDA_ARCHITECTURES变量,该变量指定要为哪些GPU架构生成代码。如果未设置CMP0104策略,则会设置CMAKE_CUDA_FLAGS变量来指定要为哪些GPU架构生成代码,并将CUDA_TOOLKIT_INCLUDE路径添加到pcl_cuda库的包含目录中。最后,它创建一个名为pcl_cuda的接口库,以便在其他目标中链接CUDA库。
阅读全文