CMakeLists.txt 6.02 KB
Newer Older
1
cmake_minimum_required(VERSION 3.18)
2
project(graphbolt C CXX)
3
set (CMAKE_CXX_STANDARD 17)
4

5
if(USE_CUDA)
6
  message(STATUS "Build graphbolt with CUDA support")
7
  enable_language(CUDA)
8
  add_definitions(-DGRAPHBOLT_USE_CUDA)
9
10
endif()

sangwzh's avatar
sangwzh committed
11
if(USE_HIP)
sangwz's avatar
sangwz committed
12
13
14
  list(APPEND CMAKE_PREFIX_PATH $ENV{ROCM_PATH})
  set(HIP_PATH $ENV{ROCM_PATH}/hip)
 find_package(HIP REQUIRED PATHS ${HIP_PATH} NO_DEFAULT_PATH)
sangwzh's avatar
sangwzh committed
15
16
17
18
19
  message(STATUS "Build graphbolt with CUDA support")
  enable_language(HIP)
  add_definitions(-DGRAPHBOLT_USE_CUDA)
endif()

20
21
22
23
24
# For windows, define NOMINMAX to avoid conflict with std::min/max
if(MSVC)
  add_definitions(-DNOMINMAX)
endif()

25
26
# Find PyTorch cmake files and PyTorch versions with the python interpreter
# $PYTHON_INTERP ("python3" or "python" if empty)
27
28
29
if(NOT PYTHON_INTERP)
  find_program(PYTHON_INTERP NAMES python3 python)
endif()
30

31
message(STATUS "Using Python interpreter: ${PYTHON_INTERP}")
32

33
34
35
36
file(TO_NATIVE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/find_cmake.py FIND_CMAKE_PY)
execute_process(
  COMMAND ${PYTHON_INTERP} ${FIND_CMAKE_PY}
  OUTPUT_VARIABLE TORCH_PREFIX_VER
37
38
39
  OUTPUT_STRIP_TRAILING_WHITESPACE
)

40
41
42
message(STATUS "find_cmake.py output: ${TORCH_PREFIX_VER}")
list(GET TORCH_PREFIX_VER 0 TORCH_PREFIX)
list(GET TORCH_PREFIX_VER 1 TORCH_VER)
43

44
45
46
47
48
message(STATUS "Configuring for PyTorch ${TORCH_VER}")
string(REPLACE "." ";" TORCH_VERSION_LIST ${TORCH_VER})

set(Torch_DIR "${TORCH_PREFIX}/Torch")
message(STATUS "Setting directory to ${Torch_DIR}")
49

sangwz's avatar
sangwz committed
50
find_package(Torch REQUIRED PATH ${Torch_DIR})
51
52
53
54
55
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${TORCH_C_FLAGS}")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${TORCH_CXX_FLAGS}")
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -O0 -g3 -ggdb")

set(LIB_GRAPHBOLT_NAME "graphbolt_pytorch_${TORCH_VER}")
sangwzh's avatar
sangwzh committed
56
# set(LIB_GRAPHBOLT_NAME "graphbolt")
57
58
59
60

set(BOLT_DIR "${CMAKE_CURRENT_SOURCE_DIR}/src")
set(BOLT_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/include")
file(GLOB BOLT_HEADERS ${BOLT_INCLUDE})
61
file(GLOB BOLT_SRC ${BOLT_DIR}/*.cc)
sangwzh's avatar
sangwzh committed
62
if(USE_HIP)
63
  file(GLOB BOLT_CUDA_SRC
sangwzh's avatar
sangwzh committed
64
    ${BOLT_DIR}/cuda/*.hip
65
    ${BOLT_DIR}/cuda/*.cc
66
67
  )
  list(APPEND BOLT_SRC ${BOLT_CUDA_SRC})
68
69
70
  if(DEFINED ENV{CUDAARCHS})
    set(CMAKE_CUDA_ARCHITECTURES $ENV{CUDAARCHS})
  endif()
71
72
73
74
75
76
77
78
79
  set(CMAKE_CUDA_ARCHITECTURES_FILTERED ${CMAKE_CUDA_ARCHITECTURES})
  # CUDA extension supports only sm_70 and up (Volta+).
  list(FILTER CMAKE_CUDA_ARCHITECTURES_FILTERED EXCLUDE REGEX "[2-6][0-9]")
  list(LENGTH CMAKE_CUDA_ARCHITECTURES_FILTERED CMAKE_CUDA_ARCHITECTURES_FILTERED_LEN)
  if(CMAKE_CUDA_ARCHITECTURES_FILTERED_LEN EQUAL 0)
    # Build the CUDA extension at least build for Volta.
    set(CMAKE_CUDA_ARCHITECTURES_FILTERED "70")
  endif()
  set(LIB_GRAPHBOLT_CUDA_NAME "${LIB_GRAPHBOLT_NAME}_cuda")
80
endif()
81

82
add_library(${LIB_GRAPHBOLT_NAME} SHARED ${BOLT_SRC} ${BOLT_HEADERS})
83
include_directories(BEFORE ${BOLT_DIR}
84
85
86
                           ${BOLT_HEADERS}
                           "../third_party/dmlc-core/include"
                           "../third_party/pcg/include")
87
target_link_libraries(${LIB_GRAPHBOLT_NAME} "${TORCH_LIBRARIES}")
88
if(CMAKE_SYSTEM_NAME MATCHES "Linux")
pyynb's avatar
pyynb committed
89
90
91
92
93
  if(USE_LIBURING)
    target_include_directories(${LIB_GRAPHBOLT_NAME} PRIVATE "../third_party/liburing/src/include")
    get_filename_component(PARENT_DIR "${CMAKE_SOURCE_DIR}" DIRECTORY)
    target_link_libraries(${LIB_GRAPHBOLT_NAME} ${PARENT_DIR}/build/third_party/liburing/lib/liburing.a)
  endif(USE_LIBURING)
94
endif()
95

sangwz's avatar
sangwz committed
96
97
98
99
100
101
102
103
104
105
if(USE_HIP)
 file(GLOB BOLT_CUDA_EXTENSION_SRC
   ${BOLT_DIR}/cuda/extension/*.hip
   ${BOLT_DIR}/cuda/extension/*.cc
 )
 # Until https://github.com/NVIDIA/cccl/issues/1083 is resolved, we need to
 # compile the cuda/extension folder with Volta+ CUDA architectures.
 # add_library(${LIB_GRAPHBOLT_CUDA_NAME} STATIC ${BOLT_CUDA_EXTENSION_SRC} ${BOLT_HEADERS})
 #target_link_libraries(${LIB_GRAPHBOLT_CUDA_NAME} "${TORCH_LIBRARIES}")

106
107
108
#  set_target_properties(${LIB_GRAPHBOLT_NAME} PROPERTIES CUDA_STANDARD 17)
#  set_target_properties(${LIB_GRAPHBOLT_CUDA_NAME} PROPERTIES CUDA_STANDARD 17)
#  set_target_properties(${LIB_GRAPHBOLT_CUDA_NAME} PROPERTIES CUDA_ARCHITECTURES "${CMAKE_CUDA_ARCHITECTURES_FILTERED}")
sangwz's avatar
sangwz committed
109
#set_target_properties(${LIB_GRAPHBOLT_CUDA_NAME} PROPERTIES POSITION_INDEPENDENT_CODE TRUE)
110
111
112
113
114
115
#  message(STATUS "Use external CCCL library for a consistent API and performance for graphbolt.")
#  include_directories(BEFORE
#                      "../third_party/cccl/thrust"
#                      "../third_party/cccl/cub"
#                      "../third_party/cccl/libcudacxx/include"
#                      "../third_party/cuco/include")
sangwz's avatar
sangwz committed
116

sangwzh's avatar
sangwzh committed
117
  # set_target_properties(${LIB_GRAPHBOLT_NAME} PROPERTIES CUDA_STANDARD 17)
118
  message(STATUS "Use external CCCL library for a consistent API and performance for graphbolt.")
119
  target_compile_options(${LIB_GRAPHBOLT_NAME} PRIVATE "--gpu-max-threads-per-block=1024")
sangwz's avatar
sangwz committed
120
  include_directories( BEFORE
sangwzh's avatar
sangwzh committed
121
122
123
  #                            "${ROCM_PATH}/include/thrust"
                             "${ROCM_PATH}/include/hipcub"
                             "${ROCM_PATH}/include/rocprim"
sangwz's avatar
sangwz committed
124
			     "../third_party/cuco/include"
sangwzh's avatar
sangwzh committed
125
  )
126
127
128
129
130

  message(STATUS "Use HugeCTR gpu_cache for graphbolt with INCLUDE_DIRS $ENV{GPU_CACHE_INCLUDE_DIRS}.")
  target_include_directories(${LIB_GRAPHBOLT_NAME} PRIVATE $ENV{GPU_CACHE_INCLUDE_DIRS})
  target_link_directories(${LIB_GRAPHBOLT_NAME} PRIVATE ${GPU_CACHE_BUILD_DIR})
  target_link_libraries(${LIB_GRAPHBOLT_NAME} gpu_cache)
131
  
sangwzh's avatar
sangwzh committed
132
  # get_property(archs TARGET ${LIB_GRAPHBOLT_NAME} PROPERTY CUDA_ARCHITECTURES)
133
  message(STATUS "CUDA_ARCHITECTURES for graphbolt: ${archs}")
134

sangwz's avatar
sangwz committed
135
  #get_property(archs TARGET ${LIB_GRAPHBOLT_CUDA_NAME} PROPERTY CUDA_ARCHITECTURES)
136
137
  message(STATUS "CUDA_ARCHITECTURES for graphbolt extension: ${archs}")

sangwz's avatar
sangwz committed
138
  # target_link_libraries(${LIB_GRAPHBOLT_NAME} ${LIB_GRAPHBOLT_CUDA_NAME})
139
140
endif()

141
142
143
144
# The Torch CMake configuration only sets up the path for the MKL library when
# using the conda distribution. The following is a workaround to address this
# when using a standalone installation of MKL.
if(DEFINED MKL_LIBRARIES)
145
146
  target_link_directories(${LIB_GRAPHBOLT_NAME} PRIVATE
                          ${MKL_ROOT}/lib/${MKL_ARCH})
147
endif()