OpenCVDetectCUDALanguage.cmake 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. #######################
  2. # Previously in FindCUDA and still required for FindCUDNN
  3. macro(FIND_CUDA_HELPER_LIBS _name)
  4. if(CMAKE_CROSSCOMPILING AND (ARM OR AARCH64))
  5. set(_cuda_cross_arm_lib_dir "lib/stubs")
  6. endif()
  7. find_library(CUDA_${_name}_LIBRARY ${_name}
  8. NAMES ${_name}
  9. PATHS "${CUDAToolkit_LIBRARY_ROOT}"
  10. PATH_SUFFIXES "lib/x64" "lib64" ${_cuda_cross_arm_lib_dir} "lib/Win32" "lib"
  11. DOC "\"${_name}\" library"
  12. )
  13. mark_as_advanced(CUDA_${_name}_LIBRARY)
  14. endmacro()
  15. #######################
  16. include(cmake/OpenCVDetectCUDAUtils.cmake)
  17. if((WIN32 AND NOT MSVC) OR OPENCV_CMAKE_FORCE_CUDA)
  18. message(STATUS "CUDA: Compilation is disabled (due to only Visual Studio compiler supported on your platform).")
  19. return()
  20. endif()
  21. if((NOT UNIX AND CV_CLANG) OR OPENCV_CMAKE_FORCE_CUDA)
  22. message(STATUS "CUDA: Compilation is disabled (due to Clang unsupported on your platform).")
  23. return()
  24. endif()
  25. #set(OPENCV_CMAKE_CUDA_DEBUG 1)
  26. find_package(CUDAToolkit)
  27. if(CMAKE_CUDA_COMPILER AND CUDAToolkit_FOUND)
  28. set(CUDA_FOUND TRUE)
  29. set(CUDA_TOOLKIT_INCLUDE ${CUDAToolkit_INCLUDE_DIRS})
  30. set(CUDA_VERSION_STRING ${CUDAToolkit_VERSION})
  31. set(CUDA_VERSION ${CUDAToolkit_VERSION})
  32. if(CUDA_VERSION VERSION_LESS 11.0)
  33. set(CMAKE_CUDA_STANDARD 11)
  34. elseif(CUDA_VERSION VERSION_LESS 12.8)
  35. set(CMAKE_CUDA_STANDARD 14)
  36. else()
  37. set(CMAKE_CUDA_STANDARD 17)
  38. endif()
  39. if(UNIX AND NOT BUILD_SHARED_LIBS)
  40. set(CUDA_LIB_EXT "_static")
  41. endif()
  42. endif()
  43. if(NOT CUDA_FOUND)
  44. unset(CUDA_ARCH_BIN CACHE)
  45. unset(CUDA_ARCH_PTX CACHE)
  46. return()
  47. endif()
  48. set(HAVE_CUDA 1)
  49. if(WITH_CUFFT)
  50. set(HAVE_CUFFT 1)
  51. endif()
  52. if(WITH_CUBLAS)
  53. set(HAVE_CUBLAS 1)
  54. endif()
  55. if(WITH_CUDNN)
  56. set(CMAKE_MODULE_PATH "${OpenCV_SOURCE_DIR}/cmake" ${CMAKE_MODULE_PATH})
  57. find_host_package(CUDNN "${MIN_VER_CUDNN}")
  58. list(REMOVE_AT CMAKE_MODULE_PATH 0)
  59. if(CUDNN_FOUND)
  60. set(HAVE_CUDNN 1)
  61. endif()
  62. endif()
  63. if(WITH_NVCUVID OR WITH_NVCUVENC)
  64. ocv_check_for_nvidia_video_codec_sdk("${CUDAToolkit_LIBRARY_ROOT}")
  65. endif()
  66. ocv_check_for_cmake_cuda_architectures()
  67. ocv_set_cuda_detection_nvcc_flags(CMAKE_CUDA_HOST_COMPILER)
  68. ocv_set_cuda_arch_bin_and_ptx(${CUDAToolkit_NVCC_EXECUTABLE})
  69. # NVCC flags to be set
  70. set(NVCC_FLAGS_EXTRA "")
  71. # These vars will be passed into the templates
  72. set(OPENCV_CUDA_ARCH_BIN "")
  73. set(OPENCV_CUDA_ARCH_PTX "")
  74. set(OPENCV_CUDA_ARCH_FEATURES "")
  75. # Tell NVCC to add binaries for the specified GPUs
  76. string(REGEX MATCHALL "[0-9()]+" ARCH_LIST "${ARCH_BIN_NO_POINTS}")
  77. foreach(ARCH IN LISTS ARCH_LIST)
  78. if(ARCH MATCHES "([0-9]+)\\(([0-9]+)\\)")
  79. # User explicitly specified PTX for the concrete BIN
  80. set(CMAKE_CUDA_ARCHITECTURES ${CMAKE_CUDA_ARCHITECTURES} ${CMAKE_MATCH_2}-virtual;${CMAKE_MATCH_1}-real;)
  81. set(OPENCV_CUDA_ARCH_BIN "${OPENCV_CUDA_ARCH_BIN} ${CMAKE_MATCH_1}")
  82. set(OPENCV_CUDA_ARCH_FEATURES "${OPENCV_CUDA_ARCH_FEATURES} ${CMAKE_MATCH_2}")
  83. else()
  84. # User didn't explicitly specify PTX for the concrete BIN, we assume PTX=BIN
  85. set(CMAKE_CUDA_ARCHITECTURES ${CMAKE_CUDA_ARCHITECTURES} ${ARCH}-real;)
  86. set(OPENCV_CUDA_ARCH_BIN "${OPENCV_CUDA_ARCH_BIN} ${ARCH}")
  87. set(OPENCV_CUDA_ARCH_FEATURES "${OPENCV_CUDA_ARCH_FEATURES} ${ARCH}")
  88. endif()
  89. endforeach()
  90. set(NVCC_FLAGS_EXTRA ${NVCC_FLAGS_EXTRA} -D_FORCE_INLINES)
  91. # Tell NVCC to add PTX intermediate code for the specified architectures
  92. string(REGEX MATCHALL "[0-9]+" ARCH_LIST "${ARCH_PTX_NO_POINTS}")
  93. foreach(ARCH IN LISTS ARCH_LIST)
  94. set(CMAKE_CUDA_ARCHITECTURES ${CMAKE_CUDA_ARCHITECTURES} ${ARCH}-virtual;)
  95. set(OPENCV_CUDA_ARCH_PTX "${OPENCV_CUDA_ARCH_PTX} ${ARCH}")
  96. set(OPENCV_CUDA_ARCH_FEATURES "${OPENCV_CUDA_ARCH_FEATURES} ${ARCH}")
  97. endforeach()
  98. ocv_set_nvcc_threads_for_vs()
  99. # These vars will be processed in other scripts
  100. set(CUDA_NVCC_FLAGS ${CUDA_NVCC_FLAGS} ${NVCC_FLAGS_EXTRA})
  101. set(OpenCV_CUDA_CC "${CMAKE_CUDA_ARCHITECTURES}")
  102. if(ANDROID)
  103. set(CUDA_NVCC_FLAGS ${CUDA_NVCC_FLAGS} "-Xptxas;-dlcm=ca")
  104. endif()
  105. message(STATUS "CUDA: NVCC target flags ${CUDA_NVCC_FLAGS}")
  106. OCV_OPTION(CUDA_FAST_MATH "Enable --use_fast_math for CUDA compiler " OFF)
  107. if(CUDA_FAST_MATH)
  108. set(CUDA_NVCC_FLAGS ${CUDA_NVCC_FLAGS} --use_fast_math)
  109. endif()
  110. OCV_OPTION(CUDA_ENABLE_DELAYLOAD "Enable delayed loading of CUDA DLLs" OFF VISIBLE_IF MSVC)
  111. mark_as_advanced(CUDA_BUILD_CUBIN CUDA_BUILD_EMULATION CUDA_VERBOSE_BUILD CUDA_SDK_ROOT_DIR)
  112. macro(ocv_cuda_unfilter_options)
  113. foreach(var CMAKE_CXX_FLAGS CMAKE_CXX_FLAGS_RELEASE CMAKE_CXX_FLAGS_DEBUG)
  114. set(${var} "${${var}_backup_in_cuda_compile_}")
  115. unset(${var}_backup_in_cuda_compile_)
  116. endforeach()
  117. endmacro()
  118. macro(ocv_cuda_compile_flags)
  119. ocv_cuda_filter_options()
  120. ocv_nvcc_flags()
  121. set(CMAKE_CXX_FLAGS_CUDA ${CMAKE_CXX_FLAGS})
  122. set(CMAKE_CXX_FLAGS_RELEASE_CUDA ${CMAKE_CXX_FLAGS_RELEASE})
  123. set(CMAKE_CXX_FLAGS_DEBUG_CUDA ${CMAKE_CXX_FLAGS_DEBUG})
  124. ocv_cuda_unfilter_options()
  125. endmacro()
  126. if(HAVE_CUDA)
  127. ocv_apply_cuda_stub_workaround("${CUDA_cuda_driver_LIBRARY}")
  128. ocv_check_cuda_delayed_load("${cuda_toolkit_root_dir}")
  129. endif()