mirror of
https://github.com/saymrwulf/pytorch.git
synced 2026-05-14 20:57:59 +00:00
Summary: This brings proper versioning in Caffe2: instead of manual version macros, this puts the version information in CMake (replacing the TODO bwasti line) and uses macros.h.in to then generate the version in the C++ header. A few misc updates: - Removed the mac os rpath, verified on local macbook that it is no longer needed. - Misc updates for caffe2 ready: - Mapped cmake/Cuda.cmake with gloo's setting. - upstreamed third_party/nccl so it builds with cuda 9. - Separated the Caffe2 cpu dependencies and cuda dependencies - now libCaffe2_CPU.so do not depend on any cuda libs. - caffe2 python extensions now depend on cpu and gpu separately too. - Reduced the number of unused functions in Utils.cmake Closes https://github.com/caffe2/caffe2/pull/1256 Reviewed By: dzhulgakov Differential Revision: D5899210 Pulled By: Yangqing fbshipit-source-id: 36366e47366c3258374d646cf410b5f49f95767b
227 lines
8.7 KiB
CMake
227 lines
8.7 KiB
CMake
# Caffe2 cmake utility to prepare for cuda build.
|
|
# This cmake file is called from Dependencies.cmake. You do not need to
|
|
# manually invoke it.
|
|
|
|
# Known NVIDIA GPU achitectures Caffe2 can be compiled for.
|
|
# Default is set to cuda 9. If we detect the cuda architectores to be less than
|
|
# 9, we will lower it to the corresponding known archs.
|
|
set(Caffe2_known_gpu_archs "30 35 50 52 60 61 70") # for CUDA 9.x
|
|
set(Caffe2_known_gpu_archs8 "20 21(20) 30 35 50 52 60 61") # for CUDA 8.x
|
|
set(Caffe2_known_gpu_archs7 "20 21(20) 30 35 50 52") # for CUDA 7.x
|
|
|
|
|
|
################################################################################################
|
|
# Function for selecting GPU arch flags for nvcc based on CUDA_ARCH_NAME
|
|
# Usage:
|
|
# caffe_select_nvcc_arch_flags(out_variable)
|
|
function(caffe2_select_nvcc_arch_flags out_variable)
|
|
# List of arch names
|
|
set(__archs_names "Kepler" "Maxwell" "Pascal" "Volta" "All")
|
|
set(__archs_name_default "All")
|
|
|
|
# Set CUDA_ARCH_NAME strings (so it will be seen as dropbox in the CMake GUI)
|
|
set(CUDA_ARCH_NAME ${__archs_name_default} CACHE STRING "Select target NVIDIA GPU architecture")
|
|
set_property(CACHE CUDA_ARCH_NAME PROPERTY STRINGS "" ${__archs_names})
|
|
mark_as_advanced(CUDA_ARCH_NAME)
|
|
|
|
# Verify CUDA_ARCH_NAME value
|
|
if(NOT ";${__archs_names};" MATCHES ";${CUDA_ARCH_NAME};")
|
|
string(REPLACE ";" ", " __archs_names "${__archs_names}")
|
|
message(FATAL_ERROR "Invalid CUDA_ARCH_NAME, supported values: ${__archs_names}. Got ${CUDA_ARCH_NAME}")
|
|
endif()
|
|
|
|
if(${CUDA_ARCH_NAME} STREQUAL "Kepler")
|
|
set(__cuda_arch_bin "30 35")
|
|
elseif(${CUDA_ARCH_NAME} STREQUAL "Maxwell")
|
|
set(__cuda_arch_bin "50")
|
|
elseif(${CUDA_ARCH_NAME} STREQUAL "Pascal")
|
|
set(__cuda_arch_bin "60 61")
|
|
elseif(${CUDA_ARCH_NAME} STREQUAL "Volta")
|
|
set(__cuda_arch_bin "70")
|
|
elseif(${CUDA_ARCH_NAME} STREQUAL "All")
|
|
set(__cuda_arch_bin ${Caffe2_known_gpu_archs})
|
|
else()
|
|
message(FATAL_ERROR "Invalid CUDA_ARCH_NAME")
|
|
endif()
|
|
|
|
# Remove dots and convert to lists
|
|
string(REGEX REPLACE "\\." "" __cuda_arch_bin "${__cuda_arch_bin}")
|
|
string(REGEX REPLACE "\\." "" __cuda_arch_ptx "${CUDA_ARCH_PTX}")
|
|
string(REGEX MATCHALL "[0-9()]+" __cuda_arch_bin "${__cuda_arch_bin}")
|
|
string(REGEX MATCHALL "[0-9]+" __cuda_arch_ptx "${__cuda_arch_ptx}")
|
|
list(REMOVE_DUPLICATES __cuda_arch_bin)
|
|
list(REMOVE_DUPLICATES __cuda_arch_ptx)
|
|
|
|
set(__nvcc_flags "")
|
|
set(__nvcc_archs_readable "")
|
|
|
|
# Tell NVCC to add binaries for the specified GPUs
|
|
foreach(__arch ${__cuda_arch_bin})
|
|
if(__arch MATCHES "([0-9]+)\\(([0-9]+)\\)")
|
|
# User explicitly specified PTX for the concrete BIN
|
|
list(APPEND __nvcc_flags -gencode arch=compute_${CMAKE_MATCH_2},code=sm_${CMAKE_MATCH_1})
|
|
list(APPEND __nvcc_archs_readable sm_${CMAKE_MATCH_1})
|
|
else()
|
|
# User didn't explicitly specify PTX for the concrete BIN, we assume PTX=BIN
|
|
list(APPEND __nvcc_flags -gencode arch=compute_${__arch},code=sm_${__arch})
|
|
list(APPEND __nvcc_archs_readable sm_${__arch})
|
|
endif()
|
|
endforeach()
|
|
|
|
# Tell NVCC to add PTX intermediate code for the specified architectures
|
|
foreach(__arch ${__cuda_arch_ptx})
|
|
list(APPEND __nvcc_flags -gencode arch=compute_${__arch},code=compute_${__arch})
|
|
list(APPEND __nvcc_archs_readable compute_${__arch})
|
|
endforeach()
|
|
|
|
string(REPLACE ";" " " __nvcc_archs_readable "${__nvcc_archs_readable}")
|
|
set(${out_variable} ${__nvcc_flags} PARENT_SCOPE)
|
|
set(${out_variable}_readable ${__nvcc_archs_readable} PARENT_SCOPE)
|
|
endfunction()
|
|
|
|
|
|
################################################################################################
|
|
# Short command for cuda compilation
|
|
# Usage:
|
|
# caffe_cuda_compile(<objlist_variable> <cuda_files>)
|
|
macro(caffe2_cuda_compile objlist_variable)
|
|
foreach(var CMAKE_CXX_FLAGS CMAKE_CXX_FLAGS_RELEASE CMAKE_CXX_FLAGS_DEBUG)
|
|
set(${var}_backup_in_cuda_compile_ "${${var}}")
|
|
|
|
# we remove /EHa as it generates warnings under windows
|
|
string(REPLACE "/EHa" "" ${var} "${${var}}")
|
|
|
|
endforeach()
|
|
|
|
if(APPLE)
|
|
list(APPEND CUDA_NVCC_FLAGS -Xcompiler -Wno-unused-function)
|
|
endif()
|
|
|
|
cuda_compile(cuda_objcs ${ARGN})
|
|
|
|
foreach(var CMAKE_CXX_FLAGS CMAKE_CXX_FLAGS_RELEASE CMAKE_CXX_FLAGS_DEBUG)
|
|
set(${var} "${${var}_backup_in_cuda_compile_}")
|
|
unset(${var}_backup_in_cuda_compile_)
|
|
endforeach()
|
|
|
|
set(${objlist_variable} ${cuda_objcs})
|
|
endmacro()
|
|
|
|
################################################################################################
|
|
### Non macro section
|
|
################################################################################################
|
|
|
|
# Special care for windows platform: we know that 32-bit windows does not support cuda.
|
|
if(${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
|
|
if(NOT (CMAKE_SIZEOF_VOID_P EQUAL 8))
|
|
message(FATAL_ERROR
|
|
"CUDA support not available with 32-bit windows. Did you "
|
|
"forget to set Win64 in the generator target?")
|
|
return()
|
|
endif()
|
|
endif()
|
|
|
|
find_package(CUDA 7.0 QUIET)
|
|
find_cuda_helper_libs(curand) # cmake 2.8.7 compartibility which doesn't search for curand
|
|
|
|
if(NOT CUDA_FOUND)
|
|
return()
|
|
endif()
|
|
|
|
set(HAVE_CUDA TRUE)
|
|
message(STATUS "CUDA detected: " ${CUDA_VERSION})
|
|
if (${CUDA_VERSION} LESS 7.0)
|
|
message(FATAL_ERROR "Caffe2 requires CUDA 7.0 or later version")
|
|
elseif (${CUDA_VERSION} LESS 8.0) # CUDA 7.x
|
|
set(Caffe2_known_gpu_archs ${Caffe2_known_gpu_archs7})
|
|
list(APPEND CUDA_NVCC_FLAGS "-D_MWAITXINTRIN_H_INCLUDED")
|
|
list(APPEND CUDA_NVCC_FLAGS "-D__STRICT_ANSI__")
|
|
elseif (${CUDA_VERSION} LESS 9.0) # CUDA 8.x
|
|
set(Caffe2_known_gpu_archs ${Caffe2_known_gpu_archs8})
|
|
list(APPEND CUDA_NVCC_FLAGS "-D_MWAITXINTRIN_H_INCLUDED")
|
|
list(APPEND CUDA_NVCC_FLAGS "-D__STRICT_ANSI__")
|
|
# CUDA 8 may complain that sm_20 is no longer supported. Suppress the
|
|
# warning for now.
|
|
list(APPEND CUDA_NVCC_FLAGS "-Wno-deprecated-gpu-targets")
|
|
endif()
|
|
|
|
caffe2_include_directories(${CUDA_INCLUDE_DIRS})
|
|
list(APPEND Caffe2_CUDA_DEPENDENCY_LIBS ${CUDA_CUDART_LIBRARY}
|
|
${CUDA_curand_LIBRARY} ${CUDA_CUBLAS_LIBRARIES})
|
|
|
|
# find libcuda.so and lbnvrtc.so
|
|
# For libcuda.so, we will find it under lib, lib64, and then the
|
|
# stubs folder, in case we are building on a system that does not
|
|
# have cuda driver installed. On windows, we also search under the
|
|
# folder lib/x64.
|
|
|
|
find_library(CUDA_CUDA_LIB cuda
|
|
PATHS ${CUDA_TOOLKIT_ROOT_DIR}
|
|
PATH_SUFFIXES lib lib64 lib/stubs lib64/stubs lib/x64)
|
|
find_library(CUDA_NVRTC_LIB nvrtc
|
|
PATHS ${CUDA_TOOLKIT_ROOT_DIR}
|
|
PATH_SUFFIXES lib lib64 lib/x64)
|
|
|
|
# setting nvcc arch flags
|
|
caffe2_select_nvcc_arch_flags(NVCC_FLAGS_EXTRA)
|
|
list(APPEND CUDA_NVCC_FLAGS ${NVCC_FLAGS_EXTRA})
|
|
message(STATUS "Added CUDA NVCC flags for: ${NVCC_FLAGS_EXTRA_readable}")
|
|
|
|
if(CUDA_CUDA_LIB)
|
|
message(STATUS "Found libcuda: ${CUDA_CUDA_LIB}")
|
|
list(APPEND Caffe2_CUDA_DEPENDENCY_LIBS ${CUDA_CUDA_LIB})
|
|
else()
|
|
message(FATAL_ERROR "Cannot find libcuda.so. Please file an issue on https://github.com/caffe2/caffe2 with your build output.")
|
|
endif()
|
|
if(CUDA_NVRTC_LIB)
|
|
message(STATUS "Found libnvrtc: ${CUDA_NVRTC_LIB}")
|
|
list(APPEND Caffe2_CUDA_DEPENDENCY_LIBS ${CUDA_NVRTC_LIB})
|
|
else()
|
|
message(FATAL_ERROR "Cannot find libnvrtc.so. Please file an issue on https://github.com/caffe2/caffe2 with your build output.")
|
|
endif()
|
|
|
|
# disable some nvcc diagnostic that apears in boost, glog, glags, opencv, etc.
|
|
foreach(diag cc_clobber_ignored integer_sign_change useless_using_declaration set_but_not_used)
|
|
list(APPEND CUDA_NVCC_FLAGS -Xcudafe --diag_suppress=${diag})
|
|
endforeach()
|
|
|
|
# Set C++11 support
|
|
set(CUDA_PROPAGATE_HOST_FLAGS OFF)
|
|
if (NOT MSVC)
|
|
list(APPEND CUDA_NVCC_FLAGS "-std=c++11")
|
|
list(APPEND CUDA_NVCC_FLAGS "-Xcompiler -fPIC")
|
|
endif()
|
|
|
|
# Debug and Release symbol support
|
|
if (MSVC)
|
|
if (${CMAKE_BUILD_TYPE} MATCHES "Release")
|
|
if (${BUILD_SHARED_LIBS})
|
|
list(APPEND CUDA_NVCC_FLAGS "-Xcompiler -MD")
|
|
else()
|
|
list(APPEND CUDA_NVCC_FLAGS "-Xcompiler -MT")
|
|
endif()
|
|
elseif(${CMAKE_BUILD_TYPE} MATCHES "Debug")
|
|
message(FATAL_ERROR
|
|
"Caffe2 currently does not support the combination of MSVC, Cuda "
|
|
"and Debug mode. Either set USE_CUDA=OFF or set the build type "
|
|
"to Release")
|
|
if (${BUILD_SHARED_LIBS})
|
|
list(APPEND CUDA_NVCC_FLAGS "-Xcompiler -MDd")
|
|
else()
|
|
list(APPEND CUDA_NVCC_FLAGS "-Xcompiler -MTd")
|
|
endif()
|
|
else()
|
|
message(FATAL_ERROR "Unknown cmake build type: " ${CMAKE_BUILD_TYPE})
|
|
endif()
|
|
endif()
|
|
|
|
|
|
if(OpenMP_FOUND)
|
|
list(APPEND CUDA_NVCC_FLAGS "-Xcompiler ${OpenMP_CXX_FLAGS}")
|
|
endif()
|
|
|
|
# Set :expt-relaxed-constexpr to suppress Eigen warnings
|
|
list(APPEND CUDA_NVCC_FLAGS "--expt-relaxed-constexpr")
|
|
|
|
mark_as_advanced(CUDA_BUILD_CUBIN CUDA_BUILD_EMULATION CUDA_VERBOSE_BUILD)
|
|
mark_as_advanced(CUDA_SDK_ROOT_DIR CUDA_SEPARABLE_COMPILATION)
|