]>
Commit | Line | Data |
---|---|---|
1 | cmake_minimum_required(VERSION 3.16) | |
2 | ||
3 | project(ceph | |
4 | VERSION 18.2.4 | |
5 | LANGUAGES CXX C ASM) | |
6 | ||
7 | cmake_policy(SET CMP0028 NEW) | |
8 | cmake_policy(SET CMP0046 NEW) | |
9 | cmake_policy(SET CMP0048 NEW) | |
10 | cmake_policy(SET CMP0051 NEW) | |
11 | cmake_policy(SET CMP0054 NEW) | |
12 | cmake_policy(SET CMP0056 NEW) | |
13 | cmake_policy(SET CMP0065 NEW) | |
14 | cmake_policy(SET CMP0074 NEW) | |
15 | cmake_policy(SET CMP0075 NEW) | |
16 | cmake_policy(SET CMP0093 NEW) | |
17 | foreach(policy CMP0127 CMP0135) | |
18 | if(POLICY ${policy}) | |
19 | cmake_policy(SET ${policy} NEW) | |
20 | endif() | |
21 | endforeach() | |
22 | ||
23 | list(APPEND CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake/modules/") | |
24 | ||
25 | if(NOT CMAKE_BUILD_TYPE AND EXISTS "${CMAKE_SOURCE_DIR}/.git") | |
26 | set(default_build_type "Debug") | |
27 | set(CMAKE_BUILD_TYPE "${default_build_type}" CACHE | |
28 | STRING "Default BUILD_TYPE is Debug, other options are: RelWithDebInfo, Release, and MinSizeRel." FORCE) | |
29 | endif() | |
30 | ||
31 | if(CMAKE_SYSTEM_NAME MATCHES "Linux") | |
32 | set(LINUX ON) | |
33 | FIND_PACKAGE(Threads) | |
34 | elseif(CMAKE_SYSTEM_NAME MATCHES "FreeBSD") | |
35 | set(FREEBSD ON) | |
36 | FIND_PACKAGE(Threads) | |
37 | endif(CMAKE_SYSTEM_NAME MATCHES "Linux") | |
38 | ||
39 | if(WIN32) | |
40 | # The Windows headers (e.g. coming from mingw or the Windows SDK) check | |
41 | # the targeted Windows version. The availability of certain functions and | |
42 | # structures will depend on it. | |
43 | set(WIN32_WINNT "0x0A00" CACHE STRING "Targeted Windows version.") | |
44 | # In order to avoid known winpthread issues, we're using the boost | |
45 | # shared mutex implementation. | |
46 | # https://github.com/msys2/MINGW-packages/issues/3319 | |
47 | add_definitions( | |
48 | -D_WIN32_WINNT=${WIN32_WINNT} | |
49 | -DBOOST_THREAD_PROVIDES_GENERIC_SHARED_MUTEX_ON_WIN | |
50 | -DBOOST_THREAD_V2_SHARED_MUTEX | |
51 | ) | |
52 | set(Boost_THREADAPI "win32") | |
53 | endif() | |
54 | ||
55 | if(MINGW) | |
56 | string(APPEND CMAKE_SHARED_LINKER_FLAGS " -Wl,-allow-multiple-definition") | |
57 | string(APPEND CMAKE_EXE_LINKER_FLAGS " -Wl,-allow-multiple-definition") | |
58 | ||
59 | # By default, cmake generates import libs for executables. The issue is that | |
60 | # for rados and rbd, the executable import lib overrides the library import lib. | |
61 | # For example, for rados.exe, it will end up generating a librados.dll.a import lib. | |
62 | # We're providing custom rules to disable import libs for executables. | |
63 | set(CMAKE_C_LINK_EXECUTABLE | |
64 | "<CMAKE_C_COMPILER> <FLAGS> <CMAKE_C_LINK_FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> ${CMAKE_GNULD_IMAGE_VERSION} <LINK_LIBRARIES>") | |
65 | set(CMAKE_CXX_LINK_EXECUTABLE | |
66 | "<CMAKE_CXX_COMPILER> <FLAGS> <CMAKE_CXX_LINK_FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> ${CMAKE_GNULD_IMAGE_VERSION} <LINK_LIBRARIES>") | |
67 | ||
68 | link_directories(${MINGW_LINK_DIRECTORIES}) | |
69 | endif() | |
70 | ||
71 | option(WITH_CCACHE "Build with ccache.") | |
72 | if(WITH_CCACHE) | |
73 | if(CMAKE_C_COMPILER_LAUNCHER OR CMAKE_CXX_COMPILER_LAUNCHER) | |
74 | message(WARNING "Compiler launcher already set. stop configuring ccache") | |
75 | else() | |
76 | find_program(CCACHE_EXECUTABLE ccache) | |
77 | if(NOT CCACHE_EXECUTABLE) | |
78 | message(FATAL_ERROR "Can't find ccache. Is it installed?") | |
79 | endif() | |
80 | message(STATUS "Building with ccache: ${CCACHE_EXECUTABLE}, CCACHE_DIR=$ENV{CCACHE_DIR}") | |
81 | set(CMAKE_C_COMPILER_LAUNCHER ${CCACHE_EXECUTABLE}) | |
82 | set(CMAKE_CXX_COMPILER_LAUNCHER ${CCACHE_EXECUTABLE}) | |
83 | endif() | |
84 | endif(WITH_CCACHE) | |
85 | ||
86 | option(WITH_MANPAGE "Build man pages." ON) | |
87 | if(WITH_MANPAGE) | |
88 | find_program(SPHINX_BUILD | |
89 | NAMES sphinx-build sphinx-build-3) | |
90 | if(NOT SPHINX_BUILD) | |
91 | message(FATAL_ERROR "Can't find sphinx-build.") | |
92 | endif(NOT SPHINX_BUILD) | |
93 | endif(WITH_MANPAGE) | |
94 | ||
95 | include_directories( | |
96 | ${PROJECT_BINARY_DIR}/src/include | |
97 | ${PROJECT_SOURCE_DIR}/src) | |
98 | ||
99 | if(WIN32) | |
100 | include_directories( | |
101 | ${PROJECT_SOURCE_DIR}/src/include/win32) | |
102 | # Boost complains if winsock2.h (or windows.h) is included before asio.hpp. | |
103 | add_compile_options("SHELL:-include winsock_wrapper.h") | |
104 | # Boost is also defining some of the errno values, we'll have | |
105 | # to avoid mismatches. | |
106 | add_compile_options("SHELL:-include win32_errno.h") | |
107 | endif() | |
108 | ||
109 | if(FREEBSD) | |
110 | include_directories(SYSTEM /usr/local/include) | |
111 | link_directories(/usr/local/lib) | |
112 | list(APPEND CMAKE_REQUIRED_INCLUDES /usr/local/include) | |
113 | endif(FREEBSD) | |
114 | ||
115 | ||
116 | #put all the libs and binaries in one place | |
117 | set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib) | |
118 | set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib) | |
119 | set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin) | |
120 | ||
121 | include(GNUInstallDirs) | |
122 | include(CephChecks) | |
123 | if(CMAKE_GENERATOR MATCHES Ninja) | |
124 | include(LimitJobs) | |
125 | endif() | |
126 | ||
127 | set(CEPH_MAN_DIR "share/man" CACHE STRING "Install location for man pages (relative to prefix).") | |
128 | ||
129 | option(ENABLE_SHARED "build shared libraries" ON) | |
130 | if(ENABLE_SHARED) | |
131 | set(CEPH_SHARED SHARED) | |
132 | else(ENABLE_SHARED) | |
133 | set(CEPH_SHARED STATIC) | |
134 | endif(ENABLE_SHARED) | |
135 | set(CMAKE_POSITION_INDEPENDENT_CODE ${ENABLE_SHARED}) | |
136 | ||
137 | option(WITH_STATIC_LIBSTDCXX "Link against libstdc++ statically" OFF) | |
138 | if(WITH_STATIC_LIBSTDCXX) | |
139 | if(NOT CMAKE_COMPILER_IS_GNUCXX) | |
140 | message(FATAL_ERROR "Please use GCC to enable WITH_STATIC_LIBSTDCXX") | |
141 | endif() | |
142 | set(static_linker_flags "-static-libstdc++ -static-libgcc") | |
143 | string(APPEND CMAKE_SHARED_LINKER_FLAGS " ${static_linker_flags}") | |
144 | string(APPEND CMAKE_EXE_LINKER_FLAGS " ${static_linker_flags}") | |
145 | unset(static_linker_flags) | |
146 | set(GPERFTOOLS_USE_STATIC_LIBS TRUE) | |
147 | endif() | |
148 | include(CheckCxxAtomic) | |
149 | if(NOT HAVE_CXX11_ATOMIC) | |
150 | string(APPEND CMAKE_CXX_STANDARD_LIBRARIES | |
151 | " ${LIBATOMIC_LINK_FLAGS}") | |
152 | endif() | |
153 | ||
154 | option(WITH_RDMA "Enable RDMA in async messenger" ON) | |
155 | if(WITH_RDMA) | |
156 | find_package(verbs REQUIRED) | |
157 | set(HAVE_VERBS ${VERBS_FOUND}) | |
158 | find_package(rdmacm REQUIRED) | |
159 | set(HAVE_RDMACM ${RDMACM_FOUND}) | |
160 | set(HAVE_RDMA TRUE) | |
161 | endif() | |
162 | ||
163 | find_package(Backtrace) | |
164 | ||
165 | option(WITH_RBD "Enable RADOS Block Device related targets" ON) | |
166 | ||
167 | if(LINUX) | |
168 | find_package(udev REQUIRED) | |
169 | set(HAVE_UDEV ${UDEV_FOUND}) | |
170 | find_package(blkid REQUIRED) | |
171 | set(HAVE_BLKID ${BLKID_FOUND}) | |
172 | find_package(keyutils REQUIRED) | |
173 | set(HAVE_KEYUTILS ${KEYUTILS_FOUND}) | |
174 | elseif(FREEBSD) | |
175 | set(HAVE_UDEV OFF) | |
176 | set(HAVE_LIBAIO OFF) | |
177 | set(HAVE_LIBDML OFF) | |
178 | set(HAVE_BLKID OFF) | |
179 | set(HAVE_KEYUTILS OFF) | |
180 | else() | |
181 | set(HAVE_UDEV OFF) | |
182 | set(HAVE_BLKID OFF) | |
183 | endif(LINUX) | |
184 | ||
185 | option(WITH_OPENLDAP "OPENLDAP is here" ON) | |
186 | if(WITH_OPENLDAP) | |
187 | find_package(OpenLDAP REQUIRED) | |
188 | set(HAVE_OPENLDAP ${OpenLDAP_FOUND}) | |
189 | endif() | |
190 | ||
191 | option(WITH_GSSAPI "GSSAPI/KRB5 is here" OFF) | |
192 | if(WITH_GSSAPI) | |
193 | find_package(GSSApi REQUIRED) | |
194 | set(HAVE_GSSAPI ${GSSApi_FOUND}) | |
195 | endif() | |
196 | ||
197 | option(WITH_FUSE "Fuse is here" ON) | |
198 | if(WITH_FUSE) | |
199 | find_package(FUSE REQUIRED) | |
200 | set(HAVE_LIBFUSE ${FUSE_FOUND}) | |
201 | endif() | |
202 | ||
203 | option(WITH_DOKAN "Dokan is here" OFF) | |
204 | ||
205 | option(WITH_XFS "XFS is here" ON) | |
206 | if(WITH_XFS) | |
207 | find_package(xfs) | |
208 | set(HAVE_LIBXFS ${XFS_FOUND}) | |
209 | endif() | |
210 | ||
211 | option(WITH_ZFS "enable LibZFS if found" OFF) | |
212 | if(WITH_ZFS) | |
213 | find_package(zfs) | |
214 | set(HAVE_LIBZFS ${ZFS_FOUND}) | |
215 | endif() | |
216 | ||
217 | option(WITH_BLUESTORE "Bluestore OSD backend" ON) | |
218 | if(WITH_BLUESTORE) | |
219 | if(LINUX) | |
220 | find_package(aio) | |
221 | set(HAVE_LIBAIO ${AIO_FOUND}) | |
222 | elseif(FREEBSD) | |
223 | # POSIX AIO is integrated into FreeBSD kernel, and exposed by libc. | |
224 | set(HAVE_POSIXAIO ON) | |
225 | endif() | |
226 | endif() | |
227 | ||
228 | # libcryptsetup is only available on linux | |
229 | if(WITH_RBD AND LINUX) | |
230 | find_package(libcryptsetup 2.0.5 REQUIRED) | |
231 | set(HAVE_LIBCRYPTSETUP ${LIBCRYPTSETUP_FOUND}) | |
232 | endif() | |
233 | ||
234 | include(CMakeDependentOption) | |
235 | ||
236 | CMAKE_DEPENDENT_OPTION(WITH_ZBD "Enable libzbd bluestore backend" OFF | |
237 | "WITH_BLUESTORE" OFF) | |
238 | if(WITH_ZBD) | |
239 | find_package(zbd REQUIRED) | |
240 | set(HAVE_LIBZBD ${ZBD_FOUND}) | |
241 | endif() | |
242 | ||
243 | CMAKE_DEPENDENT_OPTION(WITH_LIBURING "Enable io_uring bluestore backend" ON | |
244 | "WITH_BLUESTORE;HAVE_LIBAIO" OFF) | |
245 | set(HAVE_LIBURING ${WITH_LIBURING}) | |
246 | ||
247 | CMAKE_DEPENDENT_OPTION(WITH_SYSTEM_LIBURING "Require and build with system liburing" OFF | |
248 | "HAVE_LIBAIO;WITH_BLUESTORE" OFF) | |
249 | ||
250 | if(WITH_LIBURING) | |
251 | if(WITH_SYSTEM_LIBURING) | |
252 | find_package(uring REQUIRED) | |
253 | else() | |
254 | include(Builduring) | |
255 | build_uring() | |
256 | endif() | |
257 | endif() | |
258 | ||
259 | CMAKE_DEPENDENT_OPTION(WITH_BLUESTORE_PMEM "Enable PMDK libraries" OFF | |
260 | "WITH_BLUESTORE" OFF) | |
261 | if(WITH_BLUESTORE_PMEM) | |
262 | find_package(dml) | |
263 | set(HAVE_LIBDML ${DML_FOUND}) | |
264 | endif() | |
265 | ||
266 | CMAKE_DEPENDENT_OPTION(WITH_RBD_MIRROR "Enable build for rbd-mirror daemon executable" OFF | |
267 | "WITH_RBD" OFF) | |
268 | ||
269 | CMAKE_DEPENDENT_OPTION(WITH_RBD_MIGRATION_FORMAT_QCOW_V1 | |
270 | "Enable librbd QCOW v1 migration format support" ON | |
271 | "WITH_RBD" OFF) | |
272 | ||
273 | CMAKE_DEPENDENT_OPTION(WITH_RBD_RWL "Enable librbd persistent write back cache" OFF | |
274 | "WITH_RBD" OFF) | |
275 | ||
276 | CMAKE_DEPENDENT_OPTION(WITH_RBD_SSD_CACHE "Enable librbd persistent write back cache for SSDs" OFF | |
277 | "WITH_RBD" OFF) | |
278 | ||
279 | CMAKE_DEPENDENT_OPTION(WITH_SYSTEM_PMDK "Require and build with system PMDK" OFF | |
280 | "WITH_RBD_RWL OR WITH_BLUESTORE_PMEM" OFF) | |
281 | ||
282 | if(WITH_BLUESTORE_PMEM) | |
283 | set(HAVE_BLUESTORE_PMEM ON) | |
284 | endif() | |
285 | ||
286 | CMAKE_DEPENDENT_OPTION(WITH_SPDK "Enable SPDK" OFF | |
287 | "CMAKE_SYSTEM_PROCESSOR MATCHES i386|i686|amd64|x86_64|AMD64|aarch64" OFF) | |
288 | if(WITH_SPDK) | |
289 | if(NOT WITH_BLUESTORE) | |
290 | message(SEND_ERROR "Please enable WITH_BLUESTORE for using SPDK") | |
291 | endif() | |
292 | include(BuildSPDK) | |
293 | build_spdk() | |
294 | set(HAVE_SPDK TRUE) | |
295 | endif(WITH_SPDK) | |
296 | ||
297 | if(WITH_BLUESTORE) | |
298 | if(NOT AIO_FOUND AND NOT HAVE_POSIXAIO AND NOT WITH_SPDK AND NOT WITH_BLUESTORE_PMEM) | |
299 | message(SEND_ERROR "WITH_BLUESTORE is ON, " | |
300 | "but none of the bluestore backends is enabled. " | |
301 | "Please install libaio, or enable WITH_SPDK or WITH_BLUESTORE_PMEM (experimental)") | |
302 | endif() | |
303 | endif() | |
304 | ||
305 | option(WITH_BLUEFS "libbluefs library" OFF) | |
306 | ||
307 | option(WITH_QAT "Enable Qat driver" OFF) | |
308 | if(WITH_QAT) | |
309 | find_package(QatDrv REQUIRED COMPONENTS qat_s usdm_drv_s) | |
310 | set(HAVE_QATDRV $(QatDrv_FOUND)) | |
311 | endif() | |
312 | ||
313 | option(WITH_QATZIP "Enable QATZIP" OFF) | |
314 | if(WITH_QATZIP) | |
315 | find_package(qatzip REQUIRED) | |
316 | set(HAVE_QATZIP ${qatzip_FOUND}) | |
317 | endif(WITH_QATZIP) | |
318 | ||
319 | # needs mds and? XXX | |
320 | option(WITH_LIBCEPHFS "libcephfs client library" ON) | |
321 | ||
322 | option(WITH_LIBCEPHSQLITE "libcephsqlite client library" ON) | |
323 | if(WITH_LIBCEPHSQLITE) | |
324 | find_package(SQLite3 REQUIRED) | |
325 | endif() | |
326 | ||
327 | # key-value store | |
328 | option(WITH_KVS "Key value store is here" OFF) | |
329 | ||
330 | option(WITH_KRBD "Enable Linux krbd support of 'rbd' utility" ON) | |
331 | ||
332 | if(WITH_KRBD AND NOT WITH_RBD) | |
333 | message(FATAL_ERROR "Cannot have WITH_KRBD without WITH_RBD.") | |
334 | endif() | |
335 | if(LINUX) | |
336 | if(WITH_LIBCEPHFS OR WITH_KRBD) | |
337 | # keyutils is only used when talking to the Linux Kernel key store | |
338 | find_package(keyutils REQUIRED) | |
339 | set(HAVE_KEYUTILS ${KEYUTILS_FOUND}) | |
340 | endif() | |
341 | endif() | |
342 | ||
343 | find_package(snappy REQUIRED) | |
344 | ||
345 | option(WITH_BROTLI "Brotli compression support" OFF) | |
346 | if(WITH_BROTLI) | |
347 | set(HAVE_BROTLI TRUE) | |
348 | endif() | |
349 | ||
350 | option(WITH_LZ4 "LZ4 compression support" ON) | |
351 | if(WITH_LZ4) | |
352 | find_package(LZ4 1.7 REQUIRED) | |
353 | set(HAVE_LZ4 ${LZ4_FOUND}) | |
354 | endif(WITH_LZ4) | |
355 | ||
356 | CMAKE_DEPENDENT_OPTION(WITH_CEPH_DEBUG_MUTEX "Use debug ceph::mutex with lockdep" ON | |
357 | "CMAKE_BUILD_TYPE STREQUAL Debug" OFF) | |
358 | ||
359 | #if allocator is set on command line make sure it matches below strings | |
360 | set(ALLOCATOR "" CACHE STRING | |
361 | "specify memory allocator to use. currently tcmalloc, tcmalloc_minimal, \ | |
362 | jemalloc, and libc is supported. if not specified, will try to find tcmalloc, \ | |
363 | and then jemalloc. If neither of then is found. use the one in libc.") | |
364 | if(ALLOCATOR) | |
365 | if(${ALLOCATOR} MATCHES "tcmalloc(_minimal)?") | |
366 | find_package(gperftools 2.6.2 REQUIRED) | |
367 | set(ALLOC_LIBS gperftools::${ALLOCATOR}) | |
368 | set(HAVE_LIBTCMALLOC ON) | |
369 | elseif(${ALLOCATOR} STREQUAL "jemalloc") | |
370 | find_package(JeMalloc REQUIRED) | |
371 | set(ALLOC_LIBS JeMalloc::JeMalloc) | |
372 | set(HAVE_JEMALLOC 1) | |
373 | elseif(NOT ALLOCATOR STREQUAL "libc") | |
374 | message(FATAL_ERROR "Unsupported allocator selected: ${ALLOCATOR}") | |
375 | endif() | |
376 | else(ALLOCATOR) | |
377 | find_package(gperftools 2.6.2) | |
378 | set(HAVE_LIBTCMALLOC ${gperftools_FOUND}) | |
379 | if(NOT gperftools_FOUND) | |
380 | find_package(JeMalloc) | |
381 | endif() | |
382 | if(gperftools_FOUND) | |
383 | set(ALLOCATOR tcmalloc) | |
384 | set(ALLOC_LIBS gperftools::tcmalloc) | |
385 | elseif(JeMalloc_FOUND) | |
386 | set(ALLOCATOR jemalloc) | |
387 | set(ALLOC_LIBS JeMalloc::JeMalloc) | |
388 | else() | |
389 | if(NOT FREEBSD) | |
390 | # FreeBSD already has jemalloc as its default allocator | |
391 | message(WARNING "tcmalloc and jemalloc not found, falling back to libc") | |
392 | endif() | |
393 | set(ALLOCATOR "libc") | |
394 | endif(gperftools_FOUND) | |
395 | endif(ALLOCATOR) | |
396 | if(NOT ALLOCATOR STREQUAL "libc") | |
397 | add_compile_options( | |
398 | $<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-malloc> | |
399 | $<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-calloc> | |
400 | $<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-realloc> | |
401 | $<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-free>) | |
402 | endif() | |
403 | ||
404 | # Mingw generates incorrect entry points when using "-pie". | |
405 | if(WIN32 OR (HAVE_LIBTCMALLOC AND WITH_STATIC_LIBSTDCXX)) | |
406 | set(EXE_LINKER_USE_PIE FALSE) | |
407 | else() | |
408 | set(EXE_LINKER_USE_PIE ${ENABLE_SHARED}) | |
409 | endif() | |
410 | ||
411 | if(NOT WIN32) | |
412 | # require libcurl with good curl_multi_wait(), see https://tracker.ceph.com/issues/15915 | |
413 | find_package(CURL 7.32 REQUIRED) | |
414 | endif() | |
415 | ||
416 | find_package(OpenSSL REQUIRED) | |
417 | set(CRYPTO_LIBS OpenSSL::Crypto) | |
418 | ||
419 | option(WITH_DPDK "Enable DPDK messaging" OFF) | |
420 | if(WITH_DPDK) | |
421 | find_package(dpdk) | |
422 | if(NOT DPDK_FOUND) | |
423 | include(BuildDPDK) | |
424 | build_dpdk(${CMAKE_BINARY_DIR}/src/dpdk) | |
425 | endif() | |
426 | set(HAVE_DPDK TRUE) | |
427 | endif() | |
428 | ||
429 | option(WITH_BLKIN "Use blkin to emit LTTng tracepoints for Zipkin" OFF) | |
430 | if(WITH_BLKIN) | |
431 | find_package(LTTngUST REQUIRED) | |
432 | set(BLKIN_LIBRARIES blkin ${LTTNGUST_LIBRARIES} lttng-ust-fork) | |
433 | include_directories(SYSTEM src/blkin/blkin-lib) | |
434 | endif(WITH_BLKIN) | |
435 | ||
436 | option(WITH_JAEGER "Enable jaegertracing and it's dependent libraries" ON) | |
437 | if(WITH_JAEGER) | |
438 | set(HAVE_JAEGER TRUE) | |
439 | endif() | |
440 | ||
441 | #option for RGW | |
442 | option(WITH_RADOSGW "Rados Gateway is enabled" ON) | |
443 | option(WITH_RADOSGW_BEAST_OPENSSL "Rados Gateway's Beast frontend uses OpenSSL" ON) | |
444 | option(WITH_RADOSGW_AMQP_ENDPOINT "Rados Gateway's pubsub support for AMQP push endpoint" ON) | |
445 | option(WITH_RADOSGW_KAFKA_ENDPOINT "Rados Gateway's pubsub support for Kafka push endpoint" ON) | |
446 | option(WITH_RADOSGW_LUA_PACKAGES "Rados Gateway's support for dynamically adding lua packagess" ON) | |
447 | option(WITH_RADOSGW_DBSTORE "DBStore backend for Rados Gateway" ON) | |
448 | option(WITH_RADOSGW_MOTR "CORTX-Motr backend for Rados Gateway" OFF) | |
449 | option(WITH_RADOSGW_DAOS "DAOS backend for RADOS Gateway" OFF) | |
450 | option(WITH_RADOSGW_SELECT_PARQUET "Support for s3 select on parquet objects" ON) | |
451 | option(WITH_RADOSGW_ARROW_FLIGHT "Build arrow flight when not using system-provided arrow" OFF) | |
452 | option(WITH_RADOSGW_BACKTRACE_LOGGING "Enable backtraces in rgw logs" OFF) | |
453 | ||
454 | option(WITH_SYSTEM_ARROW "Use system-provided arrow" OFF) | |
455 | option(WITH_SYSTEM_UTF8PROC "Use system-provided utf8proc" OFF) | |
456 | ||
457 | if(WITH_RADOSGW) | |
458 | find_package(EXPAT REQUIRED) | |
459 | find_package(OATH REQUIRED) | |
460 | ||
461 | # https://curl.haxx.se/docs/install.html mentions the | |
462 | # configure flags for various ssl backends | |
463 | execute_process( | |
464 | COMMAND | |
465 | "sh" "-c" | |
466 | "curl-config --configure | grep with-ssl" | |
467 | RESULT_VARIABLE NO_CURL_SSL_LINK | |
468 | ERROR_VARIABLE CURL_CONFIG_ERRORS | |
469 | ) | |
470 | if (CURL_CONFIG_ERRORS) | |
471 | message(WARNING "unable to run curl-config; rgw cannot make ssl requests to external systems reliably") | |
472 | endif() | |
473 | ||
474 | if (NOT NO_CURL_SSL_LINK) | |
475 | message(STATUS "libcurl is linked with openssl: explicitly setting locks") | |
476 | set(WITH_CURL_OPENSSL ON) | |
477 | endif() # CURL_SSL_LINK | |
478 | execute_process( | |
479 | COMMAND | |
480 | "sh" "-c" | |
481 | "objdump -p ${OPENSSL_SSL_LIBRARY} | sed -n 's/^ SONAME *//p'" | |
482 | OUTPUT_VARIABLE LIBSSL_SONAME | |
483 | ERROR_VARIABLE OBJDUMP_ERRORS | |
484 | RESULT_VARIABLE OBJDUMP_RESULTS | |
485 | OUTPUT_STRIP_TRAILING_WHITESPACE) | |
486 | if (OBJDUMP_RESULTS) | |
487 | message(FATAL_ERROR "can't run objdump: ${OBJDUMP_RESULTS}") | |
488 | endif() | |
489 | if (NOT OBJDUMP_ERRORS STREQUAL "") | |
490 | message(WARNING "message from objdump: ${OBJDUMP_ERRORS}") | |
491 | endif() | |
492 | execute_process( | |
493 | COMMAND | |
494 | "sh" "-c" | |
495 | "objdump -p ${OPENSSL_CRYPTO_LIBRARY} | sed -n 's/^ SONAME *//p'" | |
496 | OUTPUT_VARIABLE LIBCRYPTO_SONAME | |
497 | ERROR_VARIABLE OBJDUMP_ERRORS | |
498 | RESULT_VARIABLE OBJDUMP_RESULTS | |
499 | OUTPUT_STRIP_TRAILING_WHITESPACE) | |
500 | if (OBJDUMP_RESULTS) | |
501 | message(FATAL_ERROR "can't run objdump: ${OBJDUMP_RESULTS}") | |
502 | endif() | |
503 | if (NOT OBJDUMP_ERRORS STREQUAL "") | |
504 | message(WARNING "message from objdump: ${OBJDUMP_ERRORS}") | |
505 | endif() | |
506 | message(STATUS "ssl soname: ${LIBSSL_SONAME}") | |
507 | message(STATUS "crypto soname: ${LIBCRYPTO_SONAME}") | |
508 | endif (WITH_RADOSGW) | |
509 | ||
510 | #option for CephFS | |
511 | option(WITH_CEPHFS "CephFS is enabled" ON) | |
512 | ||
513 | if(NOT WIN32) | |
514 | # Please specify 3.[0-7] if you want to build with a certain version of python3. | |
515 | set(WITH_PYTHON3 "3" CACHE STRING "build with specified python3 version") | |
516 | find_package(Python3 ${WITH_PYTHON3} EXACT REQUIRED | |
517 | COMPONENTS Interpreter Development) | |
518 | ||
519 | option(WITH_MGR "ceph-mgr is enabled" ON) | |
520 | if(WITH_MGR) | |
521 | set(MGR_PYTHON_EXECUTABLE ${Python3_EXECUTABLE}) | |
522 | set(MGR_PYTHON_LIBRARIES ${Python3_LIBRARIES}) | |
523 | set(MGR_PYTHON_VERSION_MAJOR ${Python3_VERSION_MAJOR}) | |
524 | set(MGR_PYTHON_VERSION_MINOR ${Python3_VERSION_MINOR}) | |
525 | # Boost dependency check deferred to Boost section | |
526 | endif(WITH_MGR) | |
527 | endif(NOT WIN32) | |
528 | ||
529 | option(WITH_THREAD_SAFE_RES_QUERY "res_query is thread safe" OFF) | |
530 | if(WITH_THREAD_SAFE_RES_QUERY) | |
531 | set(HAVE_THREAD_SAFE_RES_QUERY 1 CACHE INTERNAL "Thread safe res_query supported.") | |
532 | endif() | |
533 | ||
534 | option(WITH_REENTRANT_STRSIGNAL "strsignal is reentrant" OFF) | |
535 | if(WITH_REENTRANT_STRSIGNAL) | |
536 | set(HAVE_REENTRANT_STRSIGNAL 1 CACHE INTERNAL "Reentrant strsignal is supported.") | |
537 | endif() | |
538 | ||
539 | # -lz link into kv | |
540 | find_package(ZLIB REQUIRED) | |
541 | ||
542 | #option for EventTrace | |
543 | CMAKE_DEPENDENT_OPTION( | |
544 | WITH_EVENTTRACE "Event tracing support, requires WITH_LTTNG" | |
545 | OFF "USE_LTTNG" OFF) | |
546 | ||
547 | #option for LTTng | |
548 | option(WITH_LTTNG "LTTng tracing is enabled" ON) | |
549 | if(${WITH_LTTNG}) | |
550 | find_package(LTTngUST REQUIRED) | |
551 | find_program(LTTNG_GEN_TP | |
552 | lttng-gen-tp) | |
553 | if(NOT LTTNG_GEN_TP) | |
554 | message(FATAL_ERROR "Can't find lttng-gen-tp.") | |
555 | endif() | |
556 | endif(${WITH_LTTNG}) | |
557 | ||
558 | option(WITH_OSD_INSTRUMENT_FUNCTIONS OFF) | |
559 | ||
560 | #option for Babeltrace | |
561 | option(WITH_BABELTRACE "Babeltrace libraries are enabled" ON) | |
562 | if(WITH_BABELTRACE) | |
563 | set(HAVE_BABELTRACE ON) | |
564 | find_package(babeltrace REQUIRED) | |
565 | set(HAVE_BABELTRACE_BABELTRACE_H ${BABELTRACE_FOUND}) | |
566 | set(HAVE_BABELTRACE_CTF_EVENTS_H ${BABELTRACE_FOUND}) | |
567 | set(HAVE_BABELTRACE_CTF_ITERATOR_H ${BABELTRACE_FOUND}) | |
568 | endif(WITH_BABELTRACE) | |
569 | ||
570 | option(DEBUG_GATHER "C_Gather debugging is enabled" ON) | |
571 | option(ENABLE_COVERAGE "Coverage is enabled" OFF) | |
572 | option(PG_DEBUG_REFS "PG Ref debugging is enabled" OFF) | |
573 | ||
574 | option(WITH_TESTS "enable the build of ceph-test package scripts/binaries" ON) | |
575 | set(UNIT_TESTS_BUILT ${WITH_TESTS}) | |
576 | set(CEPH_TEST_TIMEOUT 3600 CACHE STRING | |
577 | "Maximum time before a CTest gets killed" ) | |
578 | ||
579 | # fio | |
580 | option(WITH_FIO "build with fio plugin enabled" OFF) | |
581 | if(WITH_FIO) | |
582 | include(BuildFIO) | |
583 | build_fio() | |
584 | endif() | |
585 | ||
586 | if(LINUX) | |
587 | add_definitions(-D__linux__) | |
588 | endif(LINUX) | |
589 | ||
590 | # ASAN and friends | |
591 | option(WITH_ASAN "build with ASAN" OFF) | |
592 | if(WITH_ASAN) | |
593 | list(APPEND sanitizers "address") | |
594 | endif() | |
595 | ||
596 | option(WITH_ASAN_LEAK "explicitly enable ASAN leak detection" OFF) | |
597 | if(WITH_ASAN_LEAK) | |
598 | list(APPEND sanitizers "leak") | |
599 | endif() | |
600 | ||
601 | option(WITH_TSAN "build with TSAN" OFF) | |
602 | if(WITH_TSAN) | |
603 | list(APPEND sanitizers "thread") | |
604 | endif() | |
605 | ||
606 | option(WITH_UBSAN "build with UBSAN" OFF) | |
607 | if(WITH_UBSAN) | |
608 | list(APPEND sanitizers "undefined_behavior") | |
609 | endif() | |
610 | ||
611 | if(sanitizers) | |
612 | find_package(Sanitizers REQUIRED ${sanitizers}) | |
613 | add_compile_options(${Sanitizers_COMPILE_OPTIONS}) | |
614 | string(REPLACE ";" " " sanitiers_compile_flags "${Sanitizers_COMPILE_OPTIONS}") | |
615 | string(APPEND CMAKE_EXE_LINKER_FLAGS " ${sanitiers_compile_flags}") | |
616 | string(APPEND CMAKE_SHARED_LINKER_FLAGS " ${sanitiers_compile_flags}") | |
617 | endif() | |
618 | ||
619 | # Rocksdb | |
620 | option(WITH_SYSTEM_ROCKSDB "require and build with system rocksdb" OFF) | |
621 | if (WITH_SYSTEM_ROCKSDB) | |
622 | find_package(RocksDB 5.14 REQUIRED) | |
623 | endif() | |
624 | ||
625 | option(WITH_SEASTAR "Build seastar components") | |
626 | set(HAVE_SEASTAR ${WITH_SEASTAR}) | |
627 | ||
628 | # Boost | |
629 | option(WITH_SYSTEM_BOOST "require and build with system Boost" OFF) | |
630 | ||
631 | # Boost::thread depends on Boost::atomic, so list it explicitly. | |
632 | set(BOOST_COMPONENTS | |
633 | atomic chrono thread system regex random program_options date_time | |
634 | iostreams context coroutine) | |
635 | set(BOOST_HEADER_COMPONENTS container) | |
636 | ||
637 | if(WITH_MGR) | |
638 | list(APPEND BOOST_COMPONENTS | |
639 | python${MGR_PYTHON_VERSION_MAJOR}${MGR_PYTHON_VERSION_MINOR}) | |
640 | endif() | |
641 | if(WITH_SEASTAR) | |
642 | list(APPEND BOOST_COMPONENTS timer) | |
643 | endif() | |
644 | ||
645 | if(WITH_RADOSGW AND WITH_RADOSGW_LUA_PACKAGES) | |
646 | list(APPEND BOOST_COMPONENTS filesystem) | |
647 | endif() | |
648 | ||
649 | set(Boost_USE_MULTITHREADED ON) | |
650 | ||
651 | CMAKE_DEPENDENT_OPTION(WITH_BOOST_VALGRIND "Boost support for valgrind" OFF | |
652 | "NOT WITH_SYSTEM_BOOST" OFF) | |
653 | # require minimally the bundled version | |
654 | if(WITH_SYSTEM_BOOST) | |
655 | if(ENABLE_SHARED) | |
656 | set(Boost_USE_STATIC_LIBS OFF) | |
657 | else() | |
658 | set(Boost_USE_STATIC_LIBS ON) | |
659 | endif() | |
660 | if(BOOST_ROOT AND CMAKE_LIBRARY_ARCHITECTURE) | |
661 | set(BOOST_LIBRARYDIR "${BOOST_ROOT}/lib/${CMAKE_LIBRARY_ARCHITECTURE}") | |
662 | endif() | |
663 | find_package(Boost 1.79 COMPONENTS ${BOOST_COMPONENTS} REQUIRED) | |
664 | if(NOT ENABLE_SHARED) | |
665 | set_property(TARGET Boost::iostreams APPEND PROPERTY | |
666 | INTERFACE_LINK_LIBRARIES ZLIB::ZLIB) | |
667 | endif() | |
668 | else() | |
669 | include(ProcessorCount) | |
670 | ProcessorCount(DEFAULT_BOOST_J) | |
671 | if(DEFAULT_BOOST_J EQUAL 0) | |
672 | set(DEFAULT_BOOST_J 1) | |
673 | endif() | |
674 | set(BOOST_J ${DEFAULT_BOOST_J} CACHE STRING "max jobs for Boost build") # override w/-DBOOST_J=<n> | |
675 | set(Boost_USE_STATIC_LIBS ON) | |
676 | include(BuildBoost) | |
677 | build_boost(1.79 | |
678 | COMPONENTS ${BOOST_COMPONENTS} ${BOOST_HEADER_COMPONENTS}) | |
679 | endif() | |
680 | include_directories(BEFORE SYSTEM ${Boost_INCLUDE_DIRS}) | |
681 | ||
682 | # dashboard angular2 frontend | |
683 | option(WITH_MGR_DASHBOARD_FRONTEND "Build the mgr/dashboard frontend using `npm`" ON) | |
684 | option(WITH_SYSTEM_NPM "Assume that dashboard build tools already installed through packages" OFF) | |
685 | if(WITH_SYSTEM_NPM) | |
686 | find_program(NPM_EXECUTABLE npm) | |
687 | if(NOT NPM_EXECUTABLE) | |
688 | message(FATAL_ERROR "Can't find npm.") | |
689 | endif() | |
690 | endif() | |
691 | set(DASHBOARD_FRONTEND_LANGS "ALL" CACHE STRING | |
692 | "List of comma separated ceph-dashboard frontend languages to build. \ | |
693 | Use value `ALL` to build all languages") | |
694 | CMAKE_DEPENDENT_OPTION(WITH_MGR_ROOK_CLIENT "Enable the mgr's Rook support" ON | |
695 | "WITH_MGR" OFF) | |
696 | ||
697 | include_directories(SYSTEM ${PROJECT_BINARY_DIR}/include) | |
698 | ||
699 | find_package(Threads REQUIRED) | |
700 | find_package(StdFilesystem REQUIRED) | |
701 | ||
702 | option(WITH_SELINUX "build SELinux policy" OFF) | |
703 | if(WITH_SELINUX) | |
704 | find_file(SELINUX_MAKEFILE selinux/devel/Makefile | |
705 | PATH /usr/share) | |
706 | if(NOT SELINUX_MAKEFILE) | |
707 | message(FATAL_ERROR "Can't find selinux's Makefile") | |
708 | endif() | |
709 | add_subdirectory(selinux) | |
710 | endif(WITH_SELINUX) | |
711 | ||
712 | # enables testing and creates Make check command | |
713 | add_custom_target(tests | |
714 | COMMENT "Building tests") | |
715 | enable_testing() | |
716 | set(CMAKE_CTEST_COMMAND ctest) | |
717 | add_custom_target(check | |
718 | COMMAND ${CMAKE_CTEST_COMMAND} | |
719 | DEPENDS tests) | |
720 | ||
721 | option(WITH_SYSTEMD "build with systemd support" ON) | |
722 | ||
723 | add_subdirectory(src) | |
724 | ||
725 | add_subdirectory(qa) | |
726 | add_subdirectory(doc) | |
727 | if(WITH_MANPAGE) | |
728 | add_subdirectory(man) | |
729 | endif(WITH_MANPAGE) | |
730 | ||
731 | if(WITH_SYSTEMD) | |
732 | add_subdirectory(systemd) | |
733 | endif() | |
734 | ||
735 | if(LINUX) | |
736 | add_subdirectory(etc/sysctl) | |
737 | endif() | |
738 | ||
739 | option(WITH_GRAFANA "install grafana dashboards" OFF) | |
740 | add_subdirectory(monitoring/ceph-mixin) | |
741 | ||
742 | include(CTags) | |
743 | option(CTAG_EXCLUDES "Exclude files/directories when running ctag.") | |
744 | add_tags(ctags | |
745 | SRC_DIR src | |
746 | TAG_FILE tags | |
747 | EXCLUDE_OPTS ${CTAG_EXCLUDES} | |
748 | EXCLUDES "*.js" "*.css" ".tox" "python-common/build") | |
749 | add_custom_target(tags DEPENDS ctags) |