forked from Scalable-Key-Value/code
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
259 lines (220 loc) · 7.9 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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
cmake_minimum_required(VERSION 2.8 FATAL_ERROR)
project(skv)
list(APPEND CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/CMake
${PROJECT_SOURCE_DIR}/CMake/common)
include(GitExternal)
set(VERSION_MAJOR 0)
set(VERSION_MINOR 1)
set(VERSION_PATCH 0)
set(VERSION_ABI 1)
include(Common)
# pick up any site specific configuration that might differ from default
set(SKV_SITE "default" CACHE STRING
"Select the main target platform {default, CSCS, ykt}")
set_property(CACHE SKV_SITE PROPERTY STRINGS "default" "CSCS" "ykt" "pers_example")
include(Site/${SKV_SITE})
# do default magic
if(NOT SKV_ENV)
if(CMAKE_SYSTEM_PROCESSOR MATCHES "ppc")
set(SKV_ENV "BGAS")
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "x86")
set(SKV_ENV "x86")
else()
set(SKV_ENV ${CMAKE_SYSTEM_PROCESSOR})
endif()
endif()
if(NOT SKV_MPI)
set(SKV_MPI "AUTO")
endif()
# store results
set(SKV_ENV ${SKV_ENV} CACHE STRING
"Select the main target platform {BGAS, BGQCNK, Power, x86}")
set_property(CACHE SKV_ENV
PROPERTY STRINGS "BGAS" "BGQCNK" "Power" "x86")
set(SKV_MPI ${SKV_MPI} CACHE STRING
"MPI configuration {AUTO, MVAPICH2_RHEL65, MPICH_BGQ, BGAS-MVAPICH}")
set_property(CACHE SKV_MPI
PROPERTY STRINGS "AUTO" "MVAPICH2_RHEL65" "MPICH_BGQ" "BGAS-MVAPICH")
include(Platform/${SKV_ENV})
if(SKV_MPI MATCHES "AUTO")
find_package(MPI REQUIRED)
else()
include(MPI/${SKV_MPI})
endif()
#------------------------------------------------------------------------------
# Options
#------------------------------------------------------------------------------
set(COMMON_LIBRARY_TYPE STATIC CACHE STRING
"Library type {any combination of SHARED, STATIC}")
#############################################
# Define the local KV backend to use
# inmem - in-memory version of local kv
# asyncmem - async in-memory version for testing
# rocksdb - rocksdb backend (requires rocksdb build)
# auto - rocksdb or asyncmem
#############################################
set(SKV_LOCAL_KV_BACKEND "auto" CACHE STRING
"Select a database backend {inmem, asyncmem, rocksdb, auto}")
set_property(CACHE SKV_LOCAL_KV_BACKEND
PROPERTY STRINGS "inmem" "asyncmem" "rocksdb" "auto")
set(LOCAL_KV_BACKEND ${SKV_LOCAL_KV_BACKEND})
if(LOCAL_KV_BACKEND MATCHES "rocksdb" OR LOCAL_KV_BACKEND MATCHES "auto")
find_package(ZLIB)
find_package(BZip2)
find_package(rocksdb)
if(NOT ROCKSDB_FOUND)
if(LOCAL_KV_BACKEND MATCHES "rocksdb")
message(FATAL_ERROR "rocksdb not found. Check rocksdb search path (-DROCKSDB_ROOT=) or configure another backend (-DSKV_LOCAL_KV_BACKEND=<inmem|asyncmem>)!")
else()
set(LOCAL_KV_BACKEND asyncmem)
endif()
endif()
endif()
set(SKV_COMM_API_TYPE "sockets" CACHE STRING
"Select a database backend {verbs, sockets, sockets_routed}")
set_property(CACHE SKV_COMM_API_TYPE
PROPERTY STRINGS "verbs" "sockets" "sockets_routed")
if(SKV_COMM_API_TYPE MATCHES "verbs")
find_package(OFED REQUIRED)
set( IT_API_LIBS ${OFED_LIBRARIES} pthread rt )
add_definitions(
# enable workaround for missing RoQ loopback functionality
-DSKV_ROQ_LOOPBACK_WORKAROUND
# enable verbs-implementation specific settings
-DSKV_USE_VERBS
)
set(SKV_DEPENDENT_LIBRARIES OFED)
install(FILES CMake/common/FindOFED.cmake
DESTINATION ${CMAKE_MODULE_INSTALL_PATH})
endif()
if(SKV_COMM_API_TYPE MATCHES "sockets")
set( IT_API_LIBS pthread rt )
endif()
if(SKV_COMM_API_TYPE MATCHES "sockets_routed")
find_package(SPI REQUIRED)
set( IT_API_LIBS pthread rt ${SPI_LIBRARIES} )
endif()
include(logtrace)
set(GLOBAL_DEFS
${PLATFORM_GLOBAL_DEFS}
# use PK_LINUX to pull in several important includes and macros
-DPK_LINUX
# use MSPACES from dlmalloc.h
-DONLY_MSPACES
)
message(STATUS "Environment ${SKV_ENV}; backend ${LOCAL_KV_BACKEND}; comm ${SKV_COMM_API_TYPE}; MPI ${SKV_MPI} (mpicc: ${MPI_C_COMPILER})")
#------------------------------------------------------------------------------
# include dirs
#------------------------------------------------------------------------------
include_directories(it_api FxLogger)
#------------------------------------------------------------------------------
# IT_API library
#------------------------------------------------------------------------------
set(IT_API_DEFS
# use event-based CQ reaping, if undefined it uses polling
-DIT_API_USE_EVENT_CQ
# enable SIW workaround
-DIT_API_USE_SIW_HACK
)
set(IT_API_SOURCES
it_api/it_api_o_${SKV_COMM_API_TYPE}.cpp
it_api/it_api_o_${SKV_COMM_API_TYPE}_thread.cpp
)
set(IT_API_PUBLIC_HEADERS
it_api/it_api.h
it_api/it_api_os_specific.h
)
set(IT_API_LINK_LIBRARIES ${IT_API_LIBS})
#------------------------------------------------------------------------------
# Compile settings
#------------------------------------------------------------------------------
add_definitions(
# default config file
-DDEFAULT_CONFIG_FILE="${CMAKE_CURRENT_SOURCE_DIR}/.skv_server.conf"
# enable command header checksum
-DSKV_HEADER_CHECKSUM
# set the local kv backend for SKV
-DSKV_SERVER_LOCAL_KV=skv_local_kv_${LOCAL_KV_BACKEND}
# data checking in tests
# -DDO_CHECK
# seems to be necessary for the tests to link
${GLOBAL_DEFS}
${IT_API_DEFS}
)
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -w -std=c99")
# Include MPI path last, as it includes mpi-gcc-specific (4.4) headers
# which might clash with the headers used by the actual gcc (4.8)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -w")
include_directories(SYSTEM ${MPI_INCLUDE_PATH})
#------------------------------------------------------------------------------
# Create library targets
#------------------------------------------------------------------------------
add_subdirectory(FxLogger)
common_library(it_api)
set_target_properties(it_api PROPERTIES
COMPILE_DEFINITIONS "${SKV_IT_API_LOGGING}" )
add_subdirectory(skv)
if(WITH_CNK_ROUTER)
# OFED libs required for Router <-> CN communication
find_package(OFED REQUIRED)
add_subdirectory(it_api/cnk_router)
add_definitions(
-DWITH_CNK_ROUTER
)
set(CNK_ROUTER_TEST_SOURCES
unittest/test_skv_cnk_router_connector.cpp
)
endif()
#------------------------------------------------------------------------------
# Define test source files
#------------------------------------------------------------------------------
set(TEST_SOURCES
test/skv_base_test.cpp
test/test_skv_insert_command.cpp
)
set(TEST_C_SOURCES
test/skv_test_clib.c
)
set(TEST_MPI_SOURCES
test/skv_test_bulk.cpp
test/skv_bench.cpp
test/skv_test_insert_retrieve_async.cpp
test/skv_test_insert_retrieve_sync.cpp
test/test_skv_remove_command.cpp
)
set(UNITTEST_SOURCES
unittest/test_skv_rdma_data_buffer.cpp
unittest/test_skv_ringbuffer_ptr.cpp
unittest/test_skv_server_command_buffer.cpp
${CNK_ROUTER_TEST_SOURCES}
)
#------------------------------------------------------------------------------
# tests
foreach(_test ${TEST_SOURCES})
get_filename_component(TEST_NAME ${_test} NAME_WE)
add_executable(${TEST_NAME} ${_test})
set_target_properties(${TEST_NAME} PROPERTIES COMPILE_DEFINITIONS
"SKV_CLIENT_UNI;SKV_NON_MPI")
target_link_libraries(${TEST_NAME} skvc skv_client skv_common it_api fxlogger
${SKV_COMMON_LINK_LIBRARIES})
install(TARGETS ${TEST_NAME} DESTINATION bin)
endforeach()
foreach(_test ${UNITTEST_SOURCES})
get_filename_component(TEST_NAME ${_test} NAME_WE)
add_executable(${TEST_NAME} ${_test})
set_target_properties(${TEST_NAME} PROPERTIES COMPILE_DEFINITIONS
"SKV_UNIT_TEST;SKV_CLIENT_UNI;SKV_NON_MPI")
target_link_libraries(${TEST_NAME} skvc skv_client skv_common it_api fxlogger
${SKV_COMMON_LINK_LIBRARIES})
install(TARGETS ${TEST_NAME} DESTINATION unittest)
endforeach()
foreach(_test ${TEST_MPI_SOURCES})
get_filename_component(TEST_NAME ${_test} NAME_WE)
add_executable(${TEST_NAME} ${_test})
target_link_libraries(${TEST_NAME} skvc_mpi skv_client_mpi skv_common
${IT_API_LINK_LIBRARIES} fxlogger
${MPI_CXX_LIBRARIES} ${SKV_COMMON_LINK_LIBRARIES})
install(TARGETS ${TEST_NAME} DESTINATION bin)
endforeach()
include(CommonPackage)
include(skvCPack)