-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
92 lines (80 loc) · 4.19 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
85
86
87
88
89
90
91
92
cmake_minimum_required(VERSION 3.10)
project(hfetch VERSION 1.0.0 DESCRIPTION "Heirarchical Prefetching Platform")
set(CMAKE_CXX_STANDARD 17)
add_subdirectory(external/rpclib)
include_directories(external/rpclib/include)
include_directories(external/rpclib/dependencies/include)
set(INSTALL_DIR $ENV{INSTALL_DIR})
message(INFO " INSTALL_DIR ${INSTALL_DIR}")
set(LIB_FLAGS -L${CMAKE_BINARY_DIR}/external/rpclib/ -lrpc -L${INSTALL_DIR}/lib/ -lmpi -lpthread -lrt -ldl -lboost_filesystem )
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -I${INSTALL_DIR}/include/ -L${CMAKE_BINARY_DIR}/ -w -g")
#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DHERMES_DEBUG")
#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DHERMES_TIMER")
#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DHERMES_TRACE")
include_directories(${INSTALL_DIR}/include/)
include_directories(${PROJECT_SOURCE_DIR}/include/)
include_directories(${PROJECT_SOURCE_DIR})
#HFetch Common
set(HFETCH_COMMON_INT_SRC src/common/singleton.h
src/common/distributed_ds/clock/global_clock.h src/common/distributed_ds/sequencer/global_sequence.h
src/common/distributed_ds/communication/rpc_lib.h
src/common/distributed_ds/map/DistributedMap.h
src/common/distributed_ds/multimap/DistributedMultiMap.h
src/common/distributed_ds/hashmap/DistributedHashMap.h
src/common/distributed_ds/priority_queue/DistributedPriorityQueue.h
src/common/distributed_ds/queue/DistributedMessageQueue.h
src/common/constants.h
src/common/debug.h
src/common/data_structure.h
src/common/configuration_manager.h
src/common/macros.h src/common/typedefs.h
src/common/enumerations.h src/common/data_structures.cpp
src/common/io_clients/io_client_factory.h
src/common/io_clients/shared_file_client.cpp
src/common/io_clients/shared_file_client.h
src/common/io_clients/memory_client.cpp
src/common/io_clients/memory_client.h
src/common/io_clients/io_client.h
src/common/io_clients/data_manager.h
src/common/util.h
src/common/debug.cpp src/common/io_clients/local_file_client.cpp src/common/io_clients/local_file_client.h)
#Hfetch Server
set(HFETCH_SERVER_INT_SRC
src/server/server.h
src/server/file_segment_auditor.cpp src/server/file_segment_auditor.h
src/server/event_manager.cpp src/server/event_manager.h
src/server/hardware_monitor.cpp src/server/hardware_monitor.h
src/server/dpe/dpe_factory.h src/server/dpe/dpe.h
src/server/dpe/max_bw_dpe.cpp src/server/dpe/max_bw_dpe.h
)
#HFetch Library
set(HFETCH_LIB_H_SRC include/hfetch.h)
set(HFETCH_LIB_INT_SRC ${HFETCH_LIB_H_SRC}
src/lib/hfetch.cpp
src/lib/metadata_manager.cpp src/lib/metadata_manager.h)
#Complete hfetch source
set(HFETCH_SRC ${HFETCH_COMMON_INT_SRC} ${HFETCH_LIB_INT_SRC} ${HFETCH_SERVER_INT_SRC})
#lib source
set(HFETCH_LIB_SRC ${HFETCH_SRC})
add_library(hfetch SHARED ${HFETCH_LIB_SRC})
add_dependencies(hfetch rpc)
target_link_libraries(hfetch ${LIB_FLAGS})
set_target_properties(hfetch PROPERTIES VERSION ${PROJECT_VERSION})
set_target_properties(hfetch PROPERTIES SOVERSION 1)
set_target_properties(hfetch PROPERTIES PUBLIC_HEADER ${HFETCH_LIB_H_SRC})
include(GNUInstallDirs)
target_include_directories(hfetch PRIVATE .)
install(TARGETS hfetch LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
#HFetch Server
set(HFETCH_SERVER_SRC ${HFETCH_SRC}
src/server/main.cpp
)
add_executable(hfetch_server ${HFETCH_SERVER_SRC})
set_target_properties(hfetch_server PROPERTIES ENV TEST_ENV="LD_PRELOAD=-L${CMAKE_BINARY_DIR}/external/rpclib/librpc.so")
add_dependencies(hfetch_server rpc)
target_link_libraries(hfetch_server ${LIB_FLAGS})
#HFetch Test Cases
add_subdirectory(test)
add_subdirectory(test/apps)
add_subdirectory(test/synthetic_benchmark)
add_subdirectory(test/library)