nccl.cmake 1.5 KB
Newer Older
1
include(ExternalProject)
Y
Yu Yang 已提交
2

3
set(NCCL_SOURCE_DIR ${THIRD_PARTY_PATH}/nccl)
Y
Yu Yang 已提交
4

5
include_directories(${NCCL_SOURCE_DIR}/src/extern_nccl/src)
Y
Yu Yang 已提交
6 7 8 9 10 11 12 13

if(WITH_DSO)
  # If we use DSO, we do not build nccl, just download the dependencies
  set(NCCL_BUILD_COMMAND "")
  set(NCCL_INSTALL_COMMAND "")
  set(NCCL_INSTALL_DIR "")
else()
  # otherwise, we build nccl and link it.
14 15 16
  set(NCCL_INSTALL_DIR ${THIRD_PARTY_PATH}/install/nccl)
  # Note: cuda 8.0 is needed to make nccl
  # When cuda is not installed on the system directory, need to set CUDA_HOME to your cuda root
Y
Yu Yang 已提交
17
  set(NCCL_BUILD_COMMAND "make -j 8")
18
  set(NCCL_INSTALL_COMMAND  "make install PREFIX=${NCCL_INSTALL_DIR}")
Y
Yu Yang 已提交
19 20 21
endif()

ExternalProject_Add(
22 23 24 25 26 27 28 29 30 31 32
    extern_nccl
    ${EXTERNAL_PROJECT_LOG_ARGS}
    GIT_REPOSITORY  "https://github.com/NVIDIA/nccl.git"
    GIT_TAG         "v1.3.4-1"
    PREFIX          "${NCCL_SOURCE_DIR}"
    UPDATE_COMMAND  ""
    CONFIGURE_COMMAND ""
    BUILD_COMMAND     "${NCCL_BUILD_COMMAND}"
    INSTALL_COMMAND   "${NCCL_INSTALL_COMMAND}"
    INSTALL_DIR       "${NCCL_INSTALL_DIR}"
    TEST_COMMAND      ""
Y
Yu Yang 已提交
33 34
)

35 36 37 38
if(WITH_DSO)
  if(${CMAKE_VERSION} VERSION_LESS "3.3.0")
    set(dummyfile ${CMAKE_CURRENT_BINARY_DIR}/lib_nccl_dummy.c)
    file(WRITE ${dummyfile} "const char * dummy_nccl = \"${dummyfile}\";")
Y
Yu Yang 已提交
39 40 41 42 43
    add_library(nccl STATIC ${dummyfile})
  else()
    add_library(nccl INTERFACE)
  endif()
else()
44 45 46
  add_library(nccl STATIC IMPORTED GLOBAL)
  set_property(TARGET nccl PROPERTY IMPORTED_LOCATION
               ${NCCL_INSTALL_DIR}/lib/libnccl_static.a)
Y
Yu Yang 已提交
47 48 49
endif()

add_dependencies(nccl extern_nccl)