cl 编译器忽略了 -allow-unsupported-compiler 选项,因为这是一个 nvcc 特定的选项,而不是 cl 的选项。
为了确保这个选项仅传递给 nvcc 而不是 cl,你需要在 CMakeLists.txt 中更明确地设置 nvcc 编译器选项。
下面是如何实现这一点的示例:
cmake_minimum_required(VERSION 3.10)
set(CUDA_MIN_VERSION "8.0")
set(CUDA_TOOLKIT_ROOT_DIR "C:/Program Files/NVIDIA GPU Computing Toolkit/CUDA/v12.3")
set(CUDA_PATH "C:/Program Files/NVIDIA GPU Computing Toolkit/CUDA/v12.3")
find_package(CUDA REQUIRED)
# 指定主机编译器
set(CUDA_HOST_COMPILER "C:/Program Files (x86)/Microsoft Visual Studio 14.0/VC/bin/cl.exe")
set(CMAKE_CXX_COMPILER "C:/Program Files (x86)/Microsoft Visual Studio 14.0/VC/bin/cl.exe")
set(CMAKE_C_COMPILER "C:/Program Files (x86)/Microsoft Visual Studio 14.0/VC/bin/cl.exe")
# 设置 nvcc 标志
list(APPEND CUDA_NVCC_FLAGS "-ccbin \"C:/Program Files (x86)/Microsoft Visual Studio 14.0/VC/bin\"")
# 关键设置
list(APPEND CUDA_NVCC_FLAGS "-allow-unsupported-compiler")
# 添加对 CUDA 版本的支持
IF ((CUDA_VERSION VERSION_GREATER "11.2") OR (CUDA_VERSION VERSION_EQUAL "11.2"))
list(APPEND CUDA_NVCC_FLAGS "-gencode arch=compute_80,code=sm_80")
list(APPEND CUDA_NVCC_FLAGS "-gencode arch=compute_86,code=sm_86")
list(APPEND CUDA_NVCC_FLAGS "-gencode arch=compute_89,code=sm_89")
add_definitions(-DMNN_CUDA_ENABLE_SM80 -DMNN_CUDA_ENABLE_SM86 -DMNN_CUDA_ENABLE_SM89)
ENDIF()
# 其他 CMake 配置
# ...
解释
使用 list(APPEND …) 添加 nvcc 标志:这是为了确保这些标志仅传递给 nvcc,而不是 cl 编译器。
清晰指定 ccbin 和 -allow-unsupported-compiler 选项:确保这些选项仅用于 nvcc,避免 cl 编译器忽略未知选项的警告。
通过这种方式,你可以确保 -allow-unsupported-compiler 选项正确应用于 nvcc 编译器,而不会被 cl 编译器忽略。保存文件后,重新运行 CMake 并尝试编译项目。