forked from facebookresearch/moolib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
85 lines (67 loc) · 2.38 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
cmake_minimum_required(VERSION 3.12 FATAL_ERROR)
project(moolib)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_FLAGS
"${CMAKE_CXX_FLAGS} -Wfatal-errors -ftemplate-backtrace-limit=0 -Bsymbolic")
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
set(CMAKE_CXX_VISIBILITY_PRESET hidden)
execute_process(
COMMAND python -c "import os, torch; print(os.path.dirname(torch.__file__), end='')"
OUTPUT_VARIABLE TorchPath
)
set(CMAKE_PREFIX_PATH ${TorchPath})
find_package(Torch REQUIRED)
message(STATUS "PyTorch compilation flags: ${TORCH_CXX_FLAGS}")
message(STATUS "PyTorch include dirs: ${TORCH_INCLUDE_DIRS}")
#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${TORCH_CXX_FLAGS}")
find_package(Threads REQUIRED)
option(USE_CUDA "Enable CUDA support" ON)
if (USE_CUDA)
option(TP_USE_CUDA "" ON)
endif()
add_subdirectory(third_party/fmt)
add_subdirectory(third_party/pybind11)
#add_subdirectory(test)
add_library(tensor src/tensor.cc)
target_link_libraries(tensor PRIVATE ${TORCH_LIBRARIES})
target_include_directories(tensor SYSTEM PRIVATE ${TORCH_INCLUDE_DIRS})
target_compile_options(tensor PRIVATE ${TORCH_CXX_FLAGS})
add_library(moorpc OBJECT
src/rpc.cc
src/async.cc
src/transports/socket.cc
src/transports/ipc.cc
src/memory/memfd.cc
)
target_link_libraries(moorpc PUBLIC tensor fmt anl)
target_include_directories(moorpc PRIVATE src)
if (USE_CUDA)
target_compile_definitions(tensor PRIVATE -DUSE_CUDA)
target_compile_definitions(moorpc PRIVATE -DUSE_CUDA)
endif()
pybind11_add_module(_C
$<TARGET_OBJECTS:moorpc>
src/moolib.cc
src/accumulator.cc
src/batch_utils.cc
src/env.cc
src/tensorpython.cc
)
target_link_libraries(
_C
PRIVATE
$<TARGET_PROPERTY:moorpc,LINK_LIBRARIES>
${TorchPath}/lib/libtorch_python${CMAKE_SHARED_LIBRARY_SUFFIX}
)
target_include_directories(_C PRIVATE src)
set_source_files_properties(src/tensorpython.cc PROPERTIES INCLUDE_DIRECTORIES "${TORCH_INCLUDE_DIRS}")
set_source_files_properties(src/tensorpython.cc PROPERTIES COMPILE_FLAGS "${TORCH_CXX_FLAGS}")
if (USE_BACKWARD)
find_library(DW_LIB dw REQUIRED)
find_library(UNWIND_LIB unwind REQUIRED)
find_path(DW_INCLUDE dwarf.h REQUIRED)
target_sources(_C PUBLIC third_party/backward-cpp/backward.cpp)
target_include_directories(_C PRIVATE ${DW_INCLUDE})
target_link_libraries(_C PUBLIC moorpc ${DW_LIB} ${UNWIND_LIB})
target_compile_definitions(_C PRIVATE BACKWARD_HAS_DW BACKWARD_HAS_LIBUNWIND)
endif()