diff options
author | Rong Ou <rong.ou@gmail.com> | 2021-01-08 00:20:24 (GMT) |
---|---|---|
committer | Rong Ou <rong.ou@gmail.com> | 2021-01-11 08:18:04 (GMT) |
commit | fb2afef620e623c28e3251f3dfc56a91d37efd2f (patch) | |
tree | 4a52efa4fe674e25bf3e46a924a5557d324fe9fb /Modules/FindCUDAToolkit.cmake | |
parent | 1fb0670f4bb2bb56bff655913df5b5b38e5d500d (diff) | |
download | CMake-fb2afef620e623c28e3251f3dfc56a91d37efd2f.zip CMake-fb2afef620e623c28e3251f3dfc56a91d37efd2f.tar.gz CMake-fb2afef620e623c28e3251f3dfc56a91d37efd2f.tar.bz2 |
CUDA: Support nvcc symlinking to ccache
Invoke `nvcc -v` to find the real CUDA bin directory.
This is needed if `nvcc` is a symlink to `ccache` or `colornvcc`.
Fixes: #21177
Diffstat (limited to 'Modules/FindCUDAToolkit.cmake')
-rw-r--r-- | Modules/FindCUDAToolkit.cmake | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/Modules/FindCUDAToolkit.cmake b/Modules/FindCUDAToolkit.cmake index 61e264b..0d80c80 100644 --- a/Modules/FindCUDAToolkit.cmake +++ b/Modules/FindCUDAToolkit.cmake @@ -519,7 +519,19 @@ else() endif() if(CUDAToolkit_NVCC_EXECUTABLE) - get_filename_component(CUDAToolkit_BIN_DIR "${CUDAToolkit_NVCC_EXECUTABLE}" DIRECTORY) + # If NVCC is a symlink due to a wrapper script (e.g. ccache or colornvcc), then invoke it to find the + # real non-scattered toolkit. + if(IS_SYMLINK ${CUDAToolkit_NVCC_EXECUTABLE}) + execute_process(COMMAND ${CUDAToolkit_NVCC_EXECUTABLE} "-v" "__cmake_determine_cuda" ERROR_VARIABLE NVCC_ERR) + if(NVCC_ERR MATCHES " _HERE_=([^\r\n]*)") + set(CUDAToolkit_BIN_DIR "${CMAKE_MATCH_1}") + else() + message(FATAL_ERROR "Could not execute nvcc with -v.") + endif() + unset(NVCC_ERR) + else() + get_filename_component(CUDAToolkit_BIN_DIR "${CUDAToolkit_NVCC_EXECUTABLE}" DIRECTORY) + endif() set(CUDAToolkit_BIN_DIR "${CUDAToolkit_BIN_DIR}" CACHE PATH "" FORCE) mark_as_advanced(CUDAToolkit_BIN_DIR) |