-
Notifications
You must be signed in to change notification settings - Fork 233
/
CMakeLists.txt
331 lines (295 loc) · 11.2 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
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
cmake_minimum_required(VERSION 3.12)
# This has to be specified before enable_language according to
# https://gitlab.kitware.com/cmake/cmake/issues/17559
set(CMAKE_CUDA_FLAGS "" CACHE STRING "")
if (CMAKE_CUDA_FLAGS)
list(REMOVE_ITEM CMAKE_CUDA_FLAGS "-cudart static")
endif ()
string(APPEND CMAKE_CUDA_FLAGS -cudart=shared)
project(aresdb LANGUAGES CUDA C CXX VERSION 0.0.1)
include(ExternalProject)
# Also needs to be fixed after the find_package.
# https://gitlab.kitware.com/cmake/cmake/issues/17559
if (CMAKE_CUDA_HOST_IMPLICIT_LINK_LIBRARIES)
list(REMOVE_ITEM CMAKE_CUDA_HOST_IMPLICIT_LINK_LIBRARIES "cudart_static")
endif ()
if (CMAKE_CUDA_IMPLICIT_LINK_LIBRARIES)
list(REMOVE_ITEM CMAKE_CUDA_IMPLICIT_LINK_LIBRARIES "cudart_static")
endif ()
################################
# Options and variables
################################
if (NOT QUERY_MODE)
execute_process(COMMAND which nvidia-smi && nvidia-smi | grep "Driver Version:" RESULT_VARIABLE ret)
if (NOT ${ret})
SET(QUERY_MODE DEVICE)
else ()
SET(QUERY_MODE HOST)
endif ()
endif ()
if(NOT WIN32)
string(ASCII 27 Esc)
set(ColourReset "${Esc}[m")
set(ColourBold "${Esc}[1m")
set(Red "${Esc}[31m")
set(Green "${Esc}[32m")
set(Yellow "${Esc}[33m")
set(Blue "${Esc}[34m")
set(Magenta "${Esc}[35m")
set(Cyan "${Esc}[36m")
set(White "${Esc}[37m")
set(BoldRed "${Esc}[1;31m")
set(BoldGreen "${Esc}[1;32m")
set(BoldYellow "${Esc}[1;33m")
set(BoldBlue "${Esc}[1;34m")
set(BoldMagenta "${Esc}[1;35m")
set(BoldCyan "${Esc}[1;36m")
set(BoldWhite "${Esc}[1;37m")
endif()
################################
# Compiler and linker flags
################################
# Explicitly set the CXX_STANDARD instead of detecting from
# CMAKE_CXX_FEATURES since NVCC has its own way to check whether
# host compiler supports specific CXX_STANDARD.
if (NOT DEFINED CXX_STANDARD)
set(CXX_STANDARD 11)
endif ()
set(CMAKE_CUDA_STANDARD ${CXX_STANDARD})
set(CMAKE_CXX_STANDARD ${CXX_STANDARD})
set(CMAKE_CUDA_STANDARD_REQUIRED ON)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
include_directories(${PROJECT_SOURCE_DIR} ${CMAKE_BINARY_DIR}/include)
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY lib)
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY bin)
# set C_FLAGS and NVCC FLAGS
set(CMAKE_C_FLAGS -fPIC)
set(CMAKE_SHARED_LIBRARY_SUFFIX_C .so)
set(CMAKE_SHARED_LIBRARY_SUFFIX_CXX .so)
set(CMAKE_CUDA_FLAGS " -lineinfo -I. $ENV{NVCCFLAGS} ${CMAKE_CUDA_FLAGS} --expt-extended-lambda --expt-relaxed-constexpr")
set(GENCODE_FLAGS "-gencode arch=compute_60,code=sm_60 -gencode arch=compute_60,code=compute_60")
set(CMAKE_CUDA_SEPARABLE_COMPILATION ON)
link_directories(${CMAKE_BINARY_DIR}/lib)
# HASH_REDUCTION right now is only support in device mode and when CXX standard is C++14.
if ((NOT QUERY_MODE STREQUAL "DEVICE") OR (${CXX_STANDARD} EQUAL 14))
list(APPEND MARCROS "SUPPORT_HASH_REDUCTION=1")
set(SUPPORT_HASH_REDUCTION 1)
message("${Green}Hash reduction is supported${ColourReset}!")
endif ()
################################
# GTest
################################
set(GTEST_SRC_DIR ${CMAKE_CURRENT_LIST_DIR}/thirdparty/googletest)
ExternalProject_Add(googletest
SOURCE_DIR ${GTEST_SRC_DIR}
BUILD_IN_SOURCE 1
CONFIGURE_COMMAND cmake -DCMAKE_INSTALL_PREFIX=${CMAKE_BINARY_DIR} .
# Ignore install command to avoid install lib and include
# files to /usr/local where we might don't have permission to write to.
)
enable_testing()
######################################################
# RMM
# Can only be built in a machine installed with
# cuda driver api.
######################################################
set(RMM_SRC_DIR ${CMAKE_CURRENT_LIST_DIR}/thirdparty/rmm)
set(RMM_LIB_DIR ${RMM_SRC_DIR})
if (QUERY_MODE STREQUAL "DEVICE" AND USE_RMM)
ExternalProject_Add(
project_rmm
SOURCE_DIR ${RMM_SRC_DIR}
BUILD_IN_SOURCE 1
CONFIGURE_COMMAND cmake -DCMAKE_INSTALL_PREFIX=${CMAKE_BINARY_DIR} -DCMAKE_CXX11_ABI=ON -DBUILD_TESTS=OFF .
# librmm.so will be in ${RMM_SRC_DIR} by default.
BUILD_COMMAND make -j
BUILD_BYPRODUCTS ${RMM_LIB_DIR}/librmm.so
BYPRODUCTS ${CMAKE_BINARY_DIR}/librmm.so
)
add_library(rmm SHARED IMPORTED)
set_target_properties(rmm PROPERTIES IMPORTED_LOCATION ${CMAKE_BINARY_DIR}/lib/librmm.so)
add_dependencies(rmm project_rmm)
include_directories(
${RMM_SRC_DIR}/include
${RMM_SRC_DIR}/thirdparty/cnmem/include
)
endif ()
######################################################
# CUDF
# Need cpp/src/hash/concurrent_unordered_map.cuh only
######################################################
if (SUPPORT_HASH_REDUCTION)
set(CUDF_PROJECT_DIR ${CMAKE_CURRENT_LIST_DIR}/thirdparty/cudf)
include_directories(
${CUDF_PROJECT_DIR}/cpp/src
${CUDF_PROJECT_DIR}/cpp/include
${CUDF_PROJECT_DIR}/thirdparty/cub
# cudf need to find rmm/thrust_rmm_allocator.h even it's not actually linking
# TODO(lucafuji) remove this include directory after RMM is default memory management system
${RMM_SRC_DIR}/include
${RMM_SRC_DIR}/thirdparty/cnmem/include
)
endif ()
################################
# Mem
################################
if (QUERY_MODE STREQUAL "DEVICE")
list(APPEND MARCROS "RUN_ON_DEVICE=1")
if (USE_RMM)
list(APPEND MARCROS "USE_RMM=1")
add_library(mem SHARED cgoutils/memory.h cgoutils/memory/rmm_alloc.cu)
target_link_libraries(mem rmm)
else ()
add_library(mem SHARED cgoutils/memory.h cgoutils/memory/cuda_malloc.cu)
endif ()
else ()
add_library(mem SHARED cgoutils/memory.h cgoutils/memory/malloc.c)
endif ()
################################
# Algorithm
################################
# based on DEBUG and QUERY_MODE, transform CMAKE_CUDA_FLAGS
if (DEBUG STREQUAL "y")
set(CMAKE_CUDA_FLAGS "${CMAKE_CUDA_FLAGS} -g -G --compiler-options='-g -ggdb'")
else ()
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O3")
endif ()
string(REPLACE " " ";" CUDA_XCOMPILER_FLAGS ${CMAKE_C_FLAGS})
list(TRANSFORM CUDA_XCOMPILER_FLAGS PREPEND " -Xcompiler ")
string(REPLACE ";" " " CUDA_XCOMPILER_FLAGS ${CUDA_XCOMPILER_FLAGS})
# transform macro to prepend -D prefix
list(TRANSFORM MARCROS PREPEND "-D ")
string(REPLACE ";" " " MARCROS "${MARCROS}")
set(CMAKE_CUDA_FLAGS "${CMAKE_CUDA_FLAGS} ${CUDA_XCOMPILER_FLAGS} ${GENCODE_FLAGS} ${MARCROS}")
file(MAKE_DIRECTORY ${CMAKE_LIBRARY_OUTPUT_DIRECTORY})
file(MAKE_DIRECTORY ${CMAKE_RUNTIME_OUTPUT_DIRECTORY})
add_library(algorithm SHARED
query/algorithm.hpp
query/algorithm.cu
query/binder.hpp
query/dimension_transform.cu
query/filter.cu
query/functor.cu
query/geo_intersects.cu
query/hash_lookup.cu
query/hash_reduction.cu
query/hll.cu
query/concurrent_unordered_map.hpp
query/iterator.hpp
query/iterator.cu
query/memory.cu
query/memory.hpp
query/measure_transform.cu
query/scratch_space_transform.cu
query/sort_reduce.cu
query/time_series_aggregate.h
query/transform.cu
query/transform.hpp
query/utils.cu
query/utils.hpp)
target_link_libraries(algorithm mem)
################################
# Unit Tests
################################
file(GLOB QUERY_UNITTEST_FILES query/*_unittest.cu)
add_executable(all_unittest ${QUERY_UNITTEST_FILES} query/unittest_utils.hpp)
add_dependencies(all_unittest googletest)
# Link test executable against gtest & gtest_main
target_link_libraries(all_unittest gtest gtest_main algorithm mem pthread)
if (USE_RMM)
target_link_libraries(all_unittest rmm)
endif ()
add_test(all_unittest ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/all_unittest)
###############################
# golang
###############################
execute_process(COMMAND bash -c "find . -name '*.go' | grep -v \
-e vendor -e go-build -e CMakeFiles \
-e build \
-e thirdparty \
-e '.*/\\..*' \
-e '.*/_.*' \
-e '.*/mocks.*' | tr \"\n\" \" \""
OUTPUT_VARIABLE ALL_GO_SRC)
execute_process(
COMMAND bash -c "git diff origin/master HEAD --name-only --diff-filter=AMR | grep -e \".*\\.go\" | tr \"\n\" \" \""
OUTPUT_VARIABLE CHANGED_GO_SRC
)
execute_process(COMMAND bash -c "find . -type f \
\\( -iname \\*.cu -o -iname \\*.h -o -iname \\*.hpp -o -iname \\*.c \\) \
| grep -v \
-e vendor -e go-build -e CMakeFiles \
-e build \
-e include \
-e thirdparty \
-e '.*/\\..*' \
-e '.*/_.*' \
-e '.*/mocks.*' | tr \"\n\" \" \""
OUTPUT_VARIABLE ALL_C_SRC)
execute_process(
COMMAND bash -c "git diff HEAD origin/master --name-only | grep -e \".*\\.\\(cu\\|c\\|h\\|hpp\\)\" | tr \"\n\" \" \""
OUTPUT_VARIABLE CHANGED_C_SRC
)
add_custom_target(lint-all
COMMAND ./scripts/clang-lint.sh ${ALL_C_SRC}
COMMAND ./scripts/golang-lint.sh ${ALL_GO_SRC}
VERBATIM)
add_custom_target(lint
COMMAND ./scripts/clang-lint.sh ${CHANGED_C_SRC}
COMMAND ./scripts/golang-lint.sh ${CHANGED_GO_SRC}
VERBATIM)
add_custom_target(lib DEPENDS algorithm mem)
string(REPLACE " " ";" ALL_GO_SRC_LIST ${ALL_GO_SRC})
add_custom_target(aresd DEPENDS lib ${ALL_GO_SRC_LIST}
COMMAND go build -o bin/aresd ./cmd/aresd/main.go
VERBATIM
)
add_custom_target(aresbrokerd DEPENDS ${ALL_GO_SRC_LIST}
COMMAND go build -o bin/aresbrokerd ./cmd/broker/main.go
VERBATIM
)
add_custom_target(ares-subscriber DEPENDS ${ALL_GO_SRC_LIST}
COMMAND go build -tags static -o bin/ares-subscriber ./cmd/subscriber/main.go
VERBATIM
)
add_custom_target(arescontrollerd DEPENDS ${ALL_GO_SRC_LIST}
COMMAND go build -o bin/arescontrollerd ./cmd/controller/main.go
VERBATIM
)
add_custom_target(run_server DEPENDS aresd
COMMAND bash -c 'DYLD_LIBRARY_PATH=$$LIBRARY_PATH ./bin/aresd'
)
add_custom_target(test-golang
COMMAND bash -c 'ARES_ENV=test DYLD_LIBRARY_PATH=$$LIBRARY_PATH ginkgo -r'
)
###############################
# misc
###############################
add_custom_target(travis
COMMAND bash -c 'ARES_ENV=test .travis/run_unittest.sh'
)
add_custom_target(
test-cuda DEPENDS all_unittest
COMMAND bash -c "DYLD_LIBRARY_PATH=$$LIBRARY_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/all_unittest --gtest_output=xml:junit.xml"
)
add_custom_target(swagger-gen
COMMAND swagger generate spec -o api/ui/swagger/swagger.json
VERBATIM)
add_custom_target(npm-install DEPENDS api/ui/npm.updated)
add_custom_command(
OUTPUT api/ui/npm.updated
COMMAND cd api/ui/ && npm install && touch npm.updated
DEPENDS api/ui/package.json
VERBATIM
)
# antlr
set(ANTLR_BIN "${CMAKE_SOURCE_DIR}/.bin/antlr-4.7.1-complete.jar")
set(ANTLR_URL "http://www.antlr.org/download/antlr-4.7.1-complete.jar")
add_custom_target(antlr DEPENDS ANTLR_BIN
COMMAND java -jar ${ANTLR_BIN} -Dlanguage=Go -package antlrgen -Xexact-output-dir -o query/sql/antlrgen -visitor -no-listener query/sql/SqlBase.g4
)
add_custom_command(
OUTPUT ANTLR_BIN
COMMAND mkdir -p .bin && curl -L -o ${ANTLR_BIN} ${ANTLR_URL}
VERBATIM
)