summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJames Bigler <jamesbigler@gmail.com>2013-03-14 05:57:37 (GMT)
committerBrad King <brad.king@kitware.com>2013-03-14 13:57:15 (GMT)
commitb6e9b8f1270914ed509bda2c53ea9c30dfd09d54 (patch)
tree344bc403aac2dd33603bc330fc3cf4778eadc0e4
parent6a19150b54fd4b34aa3138b4dd734779b956ea98 (diff)
downloadCMake-b6e9b8f1270914ed509bda2c53ea9c30dfd09d54.zip
CMake-b6e9b8f1270914ed509bda2c53ea9c30dfd09d54.tar.gz
CMake-b6e9b8f1270914ed509bda2c53ea9c30dfd09d54.tar.bz2
FindCUDA: Use the PRE_LINK mode only for MSVC >= 10
Use normal custom command dependencies by default. Use the PRE_LINK approach only to work around what seems to be a bug in msbuild handling of custom build rules that chain together.
-rw-r--r--Modules/FindCUDA.cmake41
1 files changed, 28 insertions, 13 deletions
diff --git a/Modules/FindCUDA.cmake b/Modules/FindCUDA.cmake
index 03e4f3f..cd4dd20 100644
--- a/Modules/FindCUDA.cmake
+++ b/Modules/FindCUDA.cmake
@@ -1327,13 +1327,6 @@ endfunction()
function(CUDA_LINK_SEPARABLE_COMPILATION_OBJECTS output_file cuda_target options object_files)
if (object_files)
- if(NOT EXISTS "${output_file}")
- # Some generators (e.g. makefiles) can't proceed to the link phase if all
- # input files aren't available. This guarantees the file exists, so that
- # linking can begin.
- execute_process(COMMAND ${CMAKE_COMMAND} -E touch "${output_file}")
- endif()
-
set_source_files_properties("${output_file}"
PROPERTIES
EXTERNAL_OBJECT TRUE # This is an object file not to be compiled, but only
@@ -1365,12 +1358,34 @@ function(CUDA_LINK_SEPARABLE_COMPILATION_OBJECTS output_file cuda_target options
endforeach()
endforeach()
file(RELATIVE_PATH output_file_relative_path "${CMAKE_BINARY_DIR}" "${output_file}")
- add_custom_command(
- TARGET ${cuda_target}
- PRE_LINK
- COMMAND ${CMAKE_COMMAND} -E echo "Building NVCC intermediate link file ${output_file_relative_path}"
- COMMAND ${CUDA_NVCC_EXECUTABLE} ${nvcc_flags} ${flags} -dlink ${object_files} -o "${output_file}"
- )
+
+ # Some generators don't handle the multiple levels of custom command
+ # dependencies correctly (obj1 depends on file1, obj2 depends on obj1), so
+ # we work around that issue by compiling the intermediate link object as a
+ # pre-link custom command in that situation.
+ set(do_obj_build_rule TRUE)
+ if (MSVC_VERSION GREATER 1599)
+ # VS 2010 and 2012 have this problem. If future versions fix this issue,
+ # it should still work, it just won't be as nice as the other method.
+ set(do_obj_build_rule FALSE)
+ endif()
+
+ if (do_obj_build_rule)
+ add_custom_command(
+ OUTPUT ${output_file}
+ DEPENDS ${object_files}
+ COMMAND ${CUDA_NVCC_EXECUTABLE} ${nvcc_flags} -dlink ${object_files} -o ${output_file}
+ ${flags}
+ COMMENT "Building NVCC intermediate link file ${output_file_relative_path}"
+ )
+ else()
+ add_custom_command(
+ TARGET ${cuda_target}
+ PRE_LINK
+ COMMAND ${CMAKE_COMMAND} -E echo "Building NVCC intermediate link file ${output_file_relative_path}"
+ COMMAND ${CUDA_NVCC_EXECUTABLE} ${nvcc_flags} ${flags} -dlink ${object_files} -o "${output_file}"
+ )
+ endif()
endif()
endfunction()