summaryrefslogtreecommitdiffstats
path: root/src/CMakeLists.txt
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 18:45:59 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 18:45:59 +0000
commit19fcec84d8d7d21e796c7624e521b60d28ee21ed (patch)
tree42d26aa27d1e3f7c0b8bd3fd14e7d7082f5008dc /src/CMakeLists.txt
parentInitial commit. (diff)
downloadceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.tar.xz
ceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.zip
Adding upstream version 16.2.11+ds.upstream/16.2.11+dsupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--src/CMakeLists.txt1046
1 files changed, 1046 insertions, 0 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
new file mode 100644
index 000000000..a9aef68ed
--- /dev/null
+++ b/src/CMakeLists.txt
@@ -0,0 +1,1046 @@
+include(GetGitRevisionDescription)
+include(CheckCXXCompilerFlag)
+
+# for erasure and compressor plugins
+set(CEPH_INSTALL_PKGLIBDIR ${CMAKE_INSTALL_LIBDIR}/${PROJECT_NAME})
+set(CEPH_INSTALL_FULL_PKGLIBDIR ${CMAKE_INSTALL_FULL_LIBDIR}/${PROJECT_NAME})
+# for mgr plugins
+set(CEPH_INSTALL_DATADIR ${CMAKE_INSTALL_FULL_DATADIR}/${PROJECT_NAME})
+# so libceph-common can be found
+set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE)
+if(NOT CMAKE_INSTALL_RPATH)
+ set(CMAKE_INSTALL_RPATH "${CEPH_INSTALL_FULL_PKGLIBDIR}")
+endif()
+
+# to be compatible with configure_files shared with autoconfig
+set(bindir ${CMAKE_INSTALL_FULL_BINDIR})
+set(sbindir ${CMAKE_INSTALL_FULL_SBINDIR})
+set(libdir ${CMAKE_INSTALL_FULL_LIBDIR})
+set(sysconfdir ${CMAKE_INSTALL_FULL_SYSCONFDIR})
+set(libexecdir ${CMAKE_INSTALL_FULL_LIBEXECDIR})
+set(pkgdatadir ${CMAKE_INSTALL_FULL_DATADIR})
+set(datadir ${CEPH_INSTALL_DATADIR})
+set(prefix ${CMAKE_INSTALL_PREFIX})
+
+add_definitions(
+ -DHAVE_CONFIG_H
+ -D__CEPH__
+ -D_REENTRANT
+ -D_THREAD_SAFE
+ -D__STDC_FORMAT_MACROS
+ -D_FILE_OFFSET_BITS=64
+ -DBOOST_ASIO_DISABLE_THREAD_KEYWORD_EXTENSION)
+if(Boost_VERSION VERSION_GREATER_EQUAL 1.74)
+ add_definitions(-DBOOST_ASIO_USE_TS_EXECUTOR_AS_DEFAULT)
+endif()
+
+if(LINUX)
+ add_definitions("-D_GNU_SOURCE")
+endif()
+
+add_compile_options(
+ -Wall
+ -fno-strict-aliasing
+ -fsigned-char)
+
+if(NOT MSVC)
+ add_compile_options(
+ -Wtype-limits
+ -Wignored-qualifiers
+ -Wpointer-arith
+ -Werror=format-security
+ -Winit-self
+ -Wno-unknown-pragmas)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wnon-virtual-dtor>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wno-ignored-qualifiers>)
+endif()
+
+add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-ftemplate-depth-1024>)
+
+CHECK_CXX_COMPILER_FLAG("-Wpessimizing-move" COMPILER_SUPPORTS_PESSIMIZING_MOVE)
+if(COMPILER_SUPPORTS_PESSIMIZING_MOVE)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wpessimizing-move>)
+endif()
+CHECK_CXX_COMPILER_FLAG("-Wredundant-move" COMPILER_SUPPORTS_REDUNDANT_MOVE)
+if(COMPILER_SUPPORTS_REDUNDANT_MOVE)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wredundant-move>)
+endif()
+if(CMAKE_CXX_COMPILER_ID STREQUAL GNU)
+ if(MINGW)
+ # The MINGW headers are missing some "const" qualifiers.
+ add_compile_options($<$<OR:$<COMPILE_LANGUAGE:C>,$<COMPILE_LANGUAGE:CXX>>:-fpermissive>)
+ else()
+ string(APPEND CMAKE_EXE_LINKER_FLAGS " -rdynamic")
+ endif()
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wstrict-null-sentinel>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Woverloaded-virtual>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-new-ttp-matching>)
+ # cmake does not add '-pie' for executables even if
+ # CMAKE_POSITION_INDEPENDENT_CODE is TRUE.
+ if(EXE_LINKER_USE_PIE)
+ if (NOT WITH_OSD_INSTRUMENT_FUNCTIONS AND NOT HAVE_SEASTAR)
+ set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -pie")
+ endif()
+ endif()
+elseif(CMAKE_CXX_COMPILER_ID STREQUAL Clang)
+ set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_EXPORTS_C_FLAG}")
+ string(APPEND CMAKE_LINKER_FLAGS " -rdynamic -export-dynamic ${CMAKE_EXE_EXPORTS_C_FLAG}")
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wno-inconsistent-missing-override>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wno-mismatched-tags>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wno-unused-private-field>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wno-address-of-packed-member>)
+ add_compile_options(
+ -Wno-unused-function
+ -Wno-unused-local-typedef
+ -Wno-varargs
+ -Wno-gnu-designator
+ -Wno-missing-braces
+ -Wno-parentheses
+ -Wno-deprecated-register)
+ if(FREEBSD)
+ # Need to use the GNU binutils linker to get versioning right.
+ string(APPEND CMAKE_EXE_LINKER_FLAGS " -fuse-ld=/usr/local/bin/ld -Wno-unused-command-line-argument")
+ string(APPEND CMAKE_SHARED_LINKER_FLAGS " -fuse-ld=/usr/local/bin/ld -Wno-unused-command-line-argument")
+ endif()
+ if(APPLE)
+ string(APPEND CMAKE_SHARED_LINKER_FLAGS " -undefined dynamic_lookup")
+ endif()
+endif(CMAKE_CXX_COMPILER_ID STREQUAL GNU)
+
+if(NOT CMAKE_BUILD_TYPE)
+ if(EXISTS "${CMAKE_SOURCE_DIR}/.git")
+ set(default_build_type "Debug")
+ else()
+ set(default_build_type "RelWithDebInfo")
+ endif()
+ set(CMAKE_BUILD_TYPE "${default_build_type}" CACHE
+ STRING "Default BUILD_TYPE is Debug, other options are: RelWithDebInfo, Release, and MinSizeRel." FORCE)
+endif()
+
+if(WITH_CEPH_DEBUG_MUTEX OR CMAKE_BUILD_TYPE STREQUAL Debug)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-DCEPH_DEBUG_MUTEX>)
+endif()
+
+include(CheckCCompilerFlag)
+if(CMAKE_CXX_COMPILER_ID STREQUAL GNU)
+ CHECK_C_COMPILER_FLAG("-U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=2" HAS_FORTIFY_SOURCE)
+ if(NOT CMAKE_BUILD_TYPE STREQUAL Debug)
+ if(HAS_FORTIFY_SOURCE)
+ add_definitions(
+ -U_FORTIFY_SOURCE
+ -D_FORTIFY_SOURCE=2)
+ endif()
+ endif()
+ if(NOT WIN32)
+ CHECK_C_COMPILER_FLAG(-fstack-protector-strong HAS_STACK_PROTECT)
+ if (HAS_STACK_PROTECT)
+ add_compile_options(-fstack-protector-strong)
+ endif()
+ endif(NOT WIN32)
+endif(CMAKE_CXX_COMPILER_ID STREQUAL GNU)
+
+CHECK_C_COMPILER_FLAG("-D_GLIBCXX_ASSERTIONS" HAS_GLIBCXX_ASSERTIONS)
+if(HAS_GLIBCXX_ASSERTIONS AND CMAKE_BUILD_TYPE STREQUAL Debug)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-D_GLIBCXX_ASSERTIONS>)
+endif()
+
+include(SIMDExt)
+if(HAVE_INTEL)
+ if(APPLE)
+ set(object_format "macho64")
+ else()
+ set(object_format "elf64")
+ endif()
+ set(CMAKE_ASM_FLAGS "-f ${object_format}")
+ set(CMAKE_ASM_COMPILER ${PROJECT_SOURCE_DIR}/src/nasm-wrapper)
+ if(NOT WIN32)
+ # The native tools might be located even when cross compiling, which
+ # might not work in this case (especially when targeting Windows).
+ include(CheckNasm)
+ check_nasm_support(${object_format}
+ HAVE_NASM_X64
+ HAVE_NASM_X64_AVX2
+ HAVE_NASM_X64_AVX512)
+ endif()
+endif()
+
+# require c++17
+set(CMAKE_CXX_STANDARD 17)
+set(CMAKE_CXX_EXTENSIONS OFF)
+set(CMAKE_CXX_STANDARD_REQUIRED ON)
+set(CMAKE_C_STANDARD 99)
+# we use `asm()` to inline assembly, so enable the GNU extension
+set(CMAKE_C_EXTENSIONS ON)
+set(C_STANDARD_REQUIRED ON)
+
+include(CheckCXXSourceCompiles)
+CHECK_CXX_SOURCE_COMPILES("
+#include <map>
+using Map = std::map<int, int>;
+int main() {
+ Map m;
+ m.merge(Map{});
+}
+" HAVE_STDLIB_MAP_SPLICING)
+
+## Handle diagnostics color if compiler supports them.
+CHECK_C_COMPILER_FLAG("-fdiagnostics-color=always"
+ COMPILER_SUPPORTS_DIAGNOSTICS_COLOR)
+
+set(DIAGNOSTICS_COLOR "auto"
+ CACHE STRING "Used if the C/C++ compiler supports the -fdiagnostics-color option. May have one of three values -- 'auto' (default), 'always', or 'never'. If set to 'always' and the compiler supports the option, 'make [...] | less -R' will make visible diagnostics colorization of compiler output.")
+
+if(COMPILER_SUPPORTS_DIAGNOSTICS_COLOR)
+ add_compile_options(-fdiagnostics-color=${DIAGNOSTICS_COLOR})
+endif()
+
+set(EXTRALIBS ${CMAKE_DL_LIBS})
+if(HAVE_POSIX_TIMERS)
+ list(APPEND EXTRALIBS ${RT_LIBRARY})
+endif()
+if(LINUX OR APPLE)
+ set(LIB_RESOLV resolv)
+ list(APPEND EXTRALIBS ${LIB_RESOLV})
+endif()
+
+if(${ENABLE_COVERAGE})
+ find_program(HAVE_GCOV gcov)
+ if(NOT HAVE_GCOV)
+ message(FATAL_ERROR "Coverage Enabled but gcov Not Found")
+ endif()
+ add_compile_options(
+ -fprofile-arcs
+ -ftest-coverage
+ -O0)
+ list(APPEND EXTRALIBS gcov)
+endif(${ENABLE_COVERAGE})
+
+set(GCOV_PREFIX_STRIP 4)
+
+# the src/.git_version file may be written out by make-dist; otherwise
+# we pull the git version from .git
+option(ENABLE_GIT_VERSION "build Ceph with git version string" ON)
+if(${ENABLE_GIT_VERSION})
+ get_git_head_revision(GIT_REFSPEC CEPH_GIT_VER)
+ git_describe(CEPH_GIT_NICE_VER_WITH_V --always)
+ # remove leading 'v'
+ string(SUBSTRING ${CEPH_GIT_NICE_VER_WITH_V} 1 -1 CEPH_GIT_NICE_VER)
+ #if building from a source tarball via make-dist
+ if(${CEPH_GIT_VER} STREQUAL "GITDIR-NOTFOUND")
+ message(STATUS "Ceph/.git directory not found, parsing ${CMAKE_CURRENT_SOURCE_DIR}/.git_version for CEPH_GIT_VER and CEPH_GIT_NICE_VER")
+ file(STRINGS ${CMAKE_CURRENT_SOURCE_DIR}/.git_version CEPH_GIT_SHA_AND_TAG)
+ list(GET CEPH_GIT_SHA_AND_TAG 0 CEPH_GIT_VER)
+ list(GET CEPH_GIT_SHA_AND_TAG 1 CEPH_GIT_NICE_VER)
+ endif(${CEPH_GIT_VER} STREQUAL "GITDIR-NOTFOUND")
+else(${ENABLE_GIT_VERSION})
+ set(CEPH_GIT_VER "no_version")
+ set(CEPH_GIT_NICE_VER "Development")
+endif(${ENABLE_GIT_VERSION})
+
+# the src/ceph_release file is 3 lines,
+# <release number, e.g. '12' for luminous>
+# <release name, e.g. 'luminous'>
+# <release type: 'dev' for x.0.z, 'rc' or x.1.z, or 'stable' or x.2.z>
+# note that the release name is semi-redundant and must match CEPH_RELEASE_*
+# definitions in include/rados.h and common/ceph_strings.c.
+file(STRINGS ${CMAKE_CURRENT_SOURCE_DIR}/ceph_release CEPH_RELEASE_FILE)
+list(GET CEPH_RELEASE_FILE 0 CEPH_RELEASE)
+list(GET CEPH_RELEASE_FILE 1 CEPH_RELEASE_NAME)
+list(GET CEPH_RELEASE_FILE 2 CEPH_RELEASE_TYPE)
+
+option(WITH_OCF "build OCF-compliant cluster resource agent" OFF)
+if(WITH_OCF)
+ add_subdirectory(ocf)
+endif()
+
+option(WITH_CEPHFS_JAVA "build libcephfs Java bindings" OFF)
+if(WITH_CEPHFS_JAVA)
+ add_subdirectory(java)
+endif()
+
+# sort out which allocator to use
+if(ALLOCATOR STREQUAL "tcmalloc")
+ set(ALLOC_LIBS gperftools::tcmalloc)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-malloc>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-calloc>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-realloc>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-free>)
+elseif(ALLOCATOR STREQUAL "tcmalloc_minimal")
+ set(ALLOC_LIBS gperftools::tcmalloc_minimal)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-malloc>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-calloc>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-realloc>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-free>)
+elseif(ALLOCATOR STREQUAL "jemalloc")
+ set(ALLOC_LIBS JeMalloc::JeMalloc)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-malloc>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-calloc>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-realloc>)
+ add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-fno-builtin-free>)
+endif()
+
+if (WITH_BLKIN)
+ add_subdirectory(blkin/blkin-lib)
+endif(WITH_BLKIN)
+
+# Common infrastructure
+configure_file(
+ ${CMAKE_SOURCE_DIR}/src/ceph_ver.h.in.cmake
+ ${CMAKE_BINARY_DIR}/src/include/ceph_ver.h
+ @ONLY)
+
+set(mds_files)
+list(APPEND mds_files
+ mds/MDSMap.cc
+ mds/FSMap.cc
+ mds/FSMapUser.cc
+ mds/inode_backtrace.cc
+ mds/mdstypes.cc
+ mds/flock.cc
+ mds/cephfs_features.cc)
+
+add_subdirectory(json_spirit)
+
+include_directories(SYSTEM "${CMAKE_SOURCE_DIR}/src/xxHash")
+include_directories(SYSTEM "${CMAKE_SOURCE_DIR}/src/rapidjson/include")
+
+option(WITH_FMT_HEADER_ONLY "use header-only version of fmt library" OFF)
+find_package(fmt 6.0.0 QUIET)
+if(fmt_FOUND)
+ include_directories(SYSTEM "${fmt_INCLUDE_DIR}")
+else()
+ message(STATUS "Could not find fmt, will build it")
+ set(old_BUILD_SHARED_LIBS ${BUILD_SHARED_LIBS})
+ set(BUILD_SHARED_LIBS FALSE)
+ add_subdirectory(fmt)
+ set(BUILD_SHARED_LIBS ${old_BUILD_SHARED_LIBS})
+ unset(old_BUILD_SHARED_LIBS)
+ include_directories(SYSTEM "${CMAKE_SOURCE_DIR}/src/fmt/include")
+endif()
+
+# in osd/PeeringState.h, the number of elements in PeeringState::Active::reactions
+# is now 21 which exceeds the default value of BOOST_MPL_LIMIT_VECTOR_SIZE, which
+# is 20. so we need to override it. see
+# https://www.boost.org/doc/libs/1_74_0/libs/mpl/doc/refmanual/limit-list-size.html
+# link with this library, if your code includes osd/PeeringState.h (indirectly)
+add_library(Boost::MPL INTERFACE IMPORTED)
+set_target_properties(Boost::MPL PROPERTIES
+ INTERFACE_COMPILE_DEFINITIONS
+ "BOOST_MPL_CFG_NO_PREPROCESSED_HEADERS;BOOST_MPL_LIMIT_LIST_SIZE=30")
+
+if(WITH_SEASTAR)
+ find_package(c-ares 1.13.0 QUIET)
+ if(NOT c-ares_FOUND)
+ message(STATUS "Could not find c-ares, will build it")
+ include(Buildc-ares)
+ build_c_ares()
+ endif()
+ macro(find_package name)
+ if(NOT TARGET ${name})
+ _find_package(${ARGV})
+ endif()
+ endmacro ()
+ set(Seastar_API_LEVEL "6" CACHE STRING "" FORCE)
+ set(Seastar_HWLOC OFF CACHE BOOL "" FORCE)
+ set(Seastar_STD_OPTIONAL_VARIANT_STRINGVIEW ON CACHE BOOL "" FORCE)
+ if(Seastar_DPDK)
+ find_package(dpdk QUIET)
+ if(NOT DPDK_FOUND)
+ include(BuildDPDK)
+ build_dpdk(${CMAKE_BINARY_DIR}/src/dpdk)
+ endif()
+ endif()
+ list(APPEND Seastar_CXX_FLAGS
+ "-Wno-error"
+ "-Wno-sign-compare"
+ "-Wno-attributes"
+ "-Wno-pessimizing-move"
+ "-Wno-address-of-packed-member"
+ "-Wno-non-virtual-dtor")
+ set(Seastar_CXX_FLAGS "${Seastar_CXX_FLAGS}" CACHE STRING "" FORCE)
+ add_subdirectory(seastar)
+ # create the directory so cmake won't complain when looking at the imported
+ # target: Seastar exports this directory created at build-time
+ file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/seastar/gen/include")
+ add_subdirectory(crimson)
+endif()
+
+function(compile_with_fmt target)
+ get_target_property(fmt_compile_definitions
+ fmt::fmt INTERFACE_COMPILE_DEFINITIONS)
+ if(fmt_compile_definitions)
+ target_compile_definitions(${target} PUBLIC
+ ${fmt_compile_definitions})
+ endif()
+endfunction()
+
+set(libcommon_files
+ ${CMAKE_BINARY_DIR}/src/include/ceph_ver.h
+ ceph_ver.c
+ global/global_context.cc
+ xxHash/xxhash.c
+ common/error_code.cc
+ log/Log.cc
+ mon/MonCap.cc
+ mon/MonClient.cc
+ mon/MonMap.cc
+ mon/MonSub.cc
+ mon/error_code.cc
+ mgr/MgrClient.cc
+ mon/PGMap.cc
+ mgr/ServiceMap.cc
+ osd/ECMsgTypes.cc
+ osd/HitSet.cc
+ osd/OSDMap.cc
+ osd/OSDMapMapping.cc
+ osd/osd_types.cc
+ osd/error_code.cc
+ osd/PGPeeringEvent.cc
+ osd/OpRequest.cc
+ osd/ClassHandler.cc
+ osd/osd_op_util.cc
+ osdc/Striper.cc
+ osdc/Objecter.cc
+ osdc/error_code.cc
+ librbd/Features.cc
+ ${mds_files})
+if(WITH_JAEGER)
+ list(APPEND libcommon_files common/tracer.cc)
+endif()
+set_source_files_properties(ceph_ver.c
+ APPEND PROPERTY OBJECT_DEPENDS ${CMAKE_BINARY_DIR}/src/include/ceph_ver.h)
+add_library(common-objs OBJECT ${libcommon_files})
+compile_with_fmt(common-objs)
+
+if(WITH_JAEGER)
+ find_package(yaml-cpp 0.6.0)
+ if(NOT yaml-cpp_FOUND)
+ set(jaeger_libs ${CMAKE_BINARY_DIR}/external/lib/libyaml-cpp.so
+ ${CMAKE_BINARY_DIR}/external/lib/libyaml-cpp.so.0.6
+ ${CMAKE_BINARY_DIR}/external/lib/libyaml-cpp.so.0.6.2)
+ #customize libjaeger.install
+ execute_process(COMMAND bash -c "sed -i 's/#//' debian/libjaeger.install"
+ WORKING_DIRECTORY ${CMAKE_SOURCE_DIR})
+ execute_process(COMMAND bash -c "grep -q 'yaml-cpp' debian/libjaeger.install || echo 'usr/lib/libyaml-cpp.so.*' >> debian/libjaeger.install"
+ WORKING_DIRECTORY ${CMAKE_SOURCE_DIR})
+ endif()
+ include(IncludeJaeger)
+ add_library(jaeger-base INTERFACE)
+ add_dependencies(common-objs
+ yaml-cpp::yaml-cpp
+ opentracing::libopentracing
+ thrift::libthrift
+ jaegertracing::libjaegertracing)
+ target_link_libraries(jaeger-base INTERFACE
+ yaml-cpp::yaml-cpp
+ opentracing::libopentracing
+ thrift::libthrift
+ jaegertracing::libjaegertracing)
+ include_directories(SYSTEM ${CMAKE_BINARY_DIR}/external/include)
+ #with CMake 3.12+ the following can be replaced by:
+ #target_link_libraries(common-objs jaeger-base)
+ list(APPEND jaeger_libs
+ ${CMAKE_BINARY_DIR}/external/lib/libjaegertracing.so.0
+ ${CMAKE_BINARY_DIR}/external/lib/libjaegertracing.so.0.6.1
+ ${CMAKE_BINARY_DIR}/external/lib/libopentracing.so.1
+ ${CMAKE_BINARY_DIR}/external/lib/libopentracing.so.1.6.0
+ ${CMAKE_BINARY_DIR}/external/lib/libthrift.so.0.13.0)
+ install(FILES ${jaeger_libs}
+ DESTINATION ${CMAKE_INSTALL_LIBDIR})
+endif()
+
+CHECK_C_COMPILER_FLAG("-fvar-tracking-assignments" HAS_VTA)
+add_subdirectory(auth)
+add_subdirectory(common)
+add_subdirectory(crush)
+add_subdirectory(msg)
+add_subdirectory(arch)
+
+set(ceph_common_objs
+ $<TARGET_OBJECTS:common-auth-objs>
+ $<TARGET_OBJECTS:common-common-objs>
+ $<TARGET_OBJECTS:common-msg-objs>
+ $<TARGET_OBJECTS:common_buffer_obj>
+ $<TARGET_OBJECTS:common_texttable_obj>
+ $<TARGET_OBJECTS:compressor_objs>
+ $<TARGET_OBJECTS:common-objs>
+ $<TARGET_OBJECTS:common_mountcephfs_objs>
+ $<TARGET_OBJECTS:crush_objs>)
+set(ceph_common_deps
+ json_spirit erasure_code arch crc32
+ ${LIB_RESOLV}
+ Boost::thread
+ Boost::system
+ Boost::random
+ Boost::program_options
+ Boost::date_time
+ Boost::iostreams
+ fmt::fmt
+ StdFilesystem::filesystem
+ fmt::fmt
+ ${BLKID_LIBRARIES}
+ ${Backtrace_LIBRARIES}
+ ${BLKIN_LIBRARIES}
+ ${CRYPTO_LIBS}
+ ${GSSAPI_LIBRARIES}
+ ${CMAKE_THREAD_LIBS_INIT}
+ ${CMAKE_DL_LIBS})
+if(HAVE_UDEV)
+ list(APPEND ceph_common_deps ${UDEV_LIBRARIES})
+endif()
+
+if(HAVE_VERBS)
+ list(APPEND ceph_common_deps IBVerbs::verbs)
+endif()
+
+if(HAVE_RDMACM)
+ list(APPEND ceph_common_deps RDMA::RDMAcm)
+endif()
+
+if(NOT WITH_SYSTEM_BOOST)
+ list(APPEND ceph_common_deps ${ZLIB_LIBRARIES})
+endif()
+
+if(HAVE_QATZIP)
+ list(APPEND ceph_common_deps ${QATZIP_LIBRARIES})
+endif()
+
+if(WITH_DPDK)
+ list(APPEND ceph_common_deps common_async_dpdk)
+endif()
+
+if(WITH_JAEGER)
+ list(APPEND ceph_common_deps jaeger-base)
+endif()
+
+if(WIN32)
+ list(APPEND ceph_common_deps ws2_32 mswsock iphlpapi bcrypt)
+ list(APPEND ceph_common_deps dlfcn_win32)
+endif()
+
+if(WITH_BLUESTORE_PMEM OR WITH_RBD_RWL)
+ if(WITH_SYSTEM_PMDK)
+ if(WITH_BLUESTORE_PMEM)
+ find_package(pmem REQUIRED COMPONENTS pmem)
+ endif()
+ if(WITH_RBD_RWL)
+ find_package(pmem REQUIRED COMPONENTS pmemobj)
+ endif()
+ find_package(pmem 1.10 REQUIRED COMPONENTS ${pmem_COMPONENTS})
+ else()
+ include(Buildpmem)
+ build_pmem()
+ endif()
+endif()
+
+add_library(common STATIC ${ceph_common_objs})
+target_link_libraries(common ${ceph_common_deps})
+
+add_library(ceph-common SHARED ${ceph_common_objs})
+target_link_libraries(ceph-common ${ceph_common_deps})
+# appease dpkg-shlibdeps
+set_target_properties(ceph-common PROPERTIES
+ SOVERSION 2
+ SKIP_RPATH TRUE)
+if(NOT APPLE AND NOT FREEBSD)
+ # Apple uses Mach-O, not ELF. so this option does not apply to APPLE.
+ #
+ # prefer the local symbol definitions when binding references to global
+ # symbols. otherwise we could reference the symbols defined by the application
+ # with the same name, instead of using the one defined in libceph-common.
+ # in other words, we require libceph-common to use local symbols, even if redefined
+ # in application".
+ set_property(
+ TARGET ceph-common
+ APPEND APPEND_STRING
+ PROPERTY LINK_FLAGS "-Wl,-Bsymbolic -Wl,-Bsymbolic-functions")
+endif()
+
+if(MINGW)
+ install(
+ TARGETS ceph-common
+ RUNTIME
+ DESTINATION ${CEPH_INSTALL_PKGLIBDIR})
+else()
+ install(
+ TARGETS ceph-common
+ LIBRARY
+ DESTINATION ${CEPH_INSTALL_PKGLIBDIR}
+ NAMELINK_SKIP)
+endif()
+
+if(${WITH_LTTNG})
+ add_subdirectory(tracing)
+ add_dependencies(common-objs oprequest-tp)
+endif(${WITH_LTTNG})
+
+add_subdirectory(global)
+
+if(NOT WIN32)
+ find_package(Lua 5.3 REQUIRED)
+endif()
+
+# rados object classes
+add_subdirectory(cls)
+
+# RADOS client/library
+add_subdirectory(osdc)
+
+# heal_profiler
+add_subdirectory(perfglue)
+
+add_library(rados_snap_set_diff_obj OBJECT librados/snap_set_diff.cc)
+
+option(WITH_LIBRADOSSTRIPER "build with libradosstriper support" ON)
+
+add_subdirectory(include)
+add_subdirectory(librados)
+add_subdirectory(neorados)
+
+if(WITH_LIBRADOSSTRIPER)
+ add_subdirectory(libradosstriper)
+endif()
+
+add_subdirectory(mgr)
+
+set(librados_config_srcs
+ librados-config.cc)
+add_executable(librados-config ${librados_config_srcs})
+target_link_libraries(librados-config librados Boost::program_options)
+
+install(TARGETS librados-config DESTINATION bin)
+
+# virtualenv base directory for ceph-disk and ceph-detect-init
+set(CEPH_BUILD_VIRTUALENV $ENV{TMPDIR})
+if(NOT CEPH_BUILD_VIRTUALENV)
+ set(CEPH_BUILD_VIRTUALENV ${CMAKE_BINARY_DIR})
+endif()
+
+if(NOT WIN32)
+add_subdirectory(pybind)
+add_subdirectory(ceph-volume)
+add_subdirectory(python-common)
+add_subdirectory(cephadm)
+endif(NOT WIN32)
+
+# Monitor
+add_subdirectory(mon)
+set(ceph_mon_srcs
+ ceph_mon.cc)
+add_executable(ceph-mon ${ceph_mon_srcs}
+ $<TARGET_OBJECTS:common_texttable_obj>)
+add_dependencies(ceph-mon erasure_code_plugins)
+target_link_libraries(ceph-mon mon os global-static ceph-common
+ ${EXTRALIBS}
+ ${CMAKE_DL_LIBS} ${GSSAPI_LIBRARIES})
+install(TARGETS ceph-mon DESTINATION bin)
+
+# OSD/ObjectStore
+# make rocksdb statically
+
+if(NOT WITH_SYSTEM_ROCKSDB)
+ include(BuildRocksDB)
+ build_rocksdb()
+endif(NOT WITH_SYSTEM_ROCKSDB)
+
+include(TestBigEndian)
+test_big_endian(CEPH_BIG_ENDIAN)
+if(NOT CEPH_BIG_ENDIAN)
+ set(CEPH_LITTLE_ENDIAN 1)
+endif()
+
+add_subdirectory(kv)
+add_subdirectory(os)
+
+if(NOT WIN32)
+add_subdirectory(blk)
+add_subdirectory(osd)
+
+set(ceph_osd_srcs
+ # Link the Object Class API implementation directly as intermediary
+ # static library (like libosd.a) nullifies the effect of `-rdynamic`.
+ osd/objclass.cc
+ objclass/class_api.cc
+ ceph_osd.cc)
+if(WITH_JAEGER)
+ list(APPEND ceph_osd_srcs common/tracer.cc)
+endif()
+add_executable(ceph-osd ${ceph_osd_srcs})
+add_dependencies(ceph-osd erasure_code_plugins)
+target_link_libraries(ceph-osd osd os global-static common
+ ${BLKID_LIBRARIES})
+if(WITH_FUSE)
+ target_link_libraries(ceph-osd FUSE::FUSE)
+endif()
+set_target_properties(ceph-osd PROPERTIES
+ POSITION_INDEPENDENT_CODE ${EXE_LINKER_USE_PIE}
+ INSTALL_RPATH "")
+install(TARGETS ceph-osd DESTINATION bin)
+
+endif(NOT WIN32)
+
+if (WITH_CEPHFS)
+ add_subdirectory(mds)
+ set(ceph_mds_srcs
+ ceph_mds.cc)
+ add_executable(ceph-mds ${ceph_mds_srcs})
+ target_link_libraries(ceph-mds mds ${CMAKE_DL_LIBS} global-static ceph-common
+ Boost::thread)
+ install(TARGETS ceph-mds DESTINATION bin)
+endif()
+
+add_subdirectory(erasure-code)
+
+# Support/Tools
+if(WITH_TESTS)
+ option(WITH_SYSTEM_GTEST "require and build with system gtest and gmock" OFF)
+ if(WITH_SYSTEM_GTEST)
+ find_package(GTest REQUIRED)
+ find_package(GMock REQUIRED)
+ else()
+ set(INSTALL_GTEST OFF CACHE BOOL "" FORCE)
+ add_subdirectory(googletest)
+ add_library(GMock::GMock ALIAS gmock)
+ add_library(GMock::Main ALIAS gmock_main)
+ target_include_directories(gmock INTERFACE
+ $<TARGET_PROPERTY:gtest,INTERFACE_INCLUDE_DIRECTORIES>)
+ target_include_directories(gmock_main INTERFACE
+ $<TARGET_PROPERTY:gtest,INTERFACE_INCLUDE_DIRECTORIES>)
+ add_library(GTest::GTest ALIAS gtest)
+ add_library(GTest::Main ALIAS gtest_main)
+ endif()
+endif(WITH_TESTS)
+
+# dmClock (after gmock)
+option(WITH_DMCLOCK_TESTS
+ "enable the build of dmclock-tests and dmclock-data-struct tests binaries"
+ OFF)
+if(WITH_TESTS AND WITH_DMCLOCK_TESTS)
+ # note: add_test is not being called, so dmclock tests aren't part
+ # of ceph tests
+ set(dmclock_TEST ON CACHE BOOL "" FORCE)
+endif()
+add_subdirectory(dmclock)
+
+add_subdirectory(compressor)
+
+add_subdirectory(tools)
+
+if(WITH_TESTS)
+ add_subdirectory(test)
+endif()
+
+add_subdirectory(crypto)
+
+if(WITH_TESTS)
+ configure_file(${CMAKE_SOURCE_DIR}/src/ceph-coverage.in
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph-coverage @ONLY)
+ configure_file(${CMAKE_SOURCE_DIR}/src/ceph-debugpack.in
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph-debugpack @ONLY)
+endif()
+
+configure_file(${CMAKE_SOURCE_DIR}/src/ceph.in
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph @ONLY)
+
+configure_file(${CMAKE_SOURCE_DIR}/src/init-ceph.in
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/init-ceph @ONLY)
+
+configure_file(ceph-post-file.in
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph-post-file @ONLY)
+
+configure_file(ceph-crash.in
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph-crash @ONLY)
+
+if(WITH_TESTS)
+ install(PROGRAMS
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph-debugpack
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph-coverage
+ DESTINATION bin)
+endif()
+
+install(PROGRAMS
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph-post-file
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/ceph-crash
+ ${CMAKE_SOURCE_DIR}/src/ceph-run
+ ${CMAKE_SOURCE_DIR}/src/ceph-clsinfo
+ DESTINATION bin)
+install(PROGRAMS
+ ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/init-ceph
+ DESTINATION ${CMAKE_INSTALL_SYSCONFDIR}/init.d
+ RENAME ceph)
+
+install(FILES
+ ${CMAKE_SOURCE_DIR}/share/id_rsa_drop.ceph.com
+ ${CMAKE_SOURCE_DIR}/share/id_rsa_drop.ceph.com.pub
+ ${CMAKE_SOURCE_DIR}/share/known_hosts_drop.ceph.com
+ DESTINATION ${CMAKE_INSTALL_DATADIR}/ceph)
+
+install(PROGRAMS
+ ceph_common.sh
+ ceph-osd-prestart.sh
+ DESTINATION ${CMAKE_INSTALL_LIBEXECDIR}/ceph)
+
+install(PROGRAMS
+ ${CMAKE_SOURCE_DIR}/src/ceph-create-keys
+ DESTINATION sbin)
+
+add_subdirectory(bash_completion)
+add_subdirectory(client)
+
+if(WITH_LIBCEPHFS)
+ set(libcephfs_srcs libcephfs.cc)
+ add_library(cephfs ${CEPH_SHARED} ${libcephfs_srcs})
+ target_link_libraries(cephfs PRIVATE client ceph-common
+ ${CRYPTO_LIBS} ${EXTRALIBS})
+ if(ENABLE_SHARED)
+ set_target_properties(cephfs PROPERTIES
+ OUTPUT_NAME cephfs
+ VERSION 2.0.0
+ SOVERSION 2)
+ if(NOT APPLE)
+ foreach(name ceph-common client osdc)
+ set_property(TARGET cephfs APPEND_STRING PROPERTY
+ LINK_FLAGS " -Wl,--exclude-libs,lib${name}.a")
+ endforeach()
+ endif()
+ endif(ENABLE_SHARED)
+ install(TARGETS cephfs DESTINATION ${CMAKE_INSTALL_LIBDIR})
+ install(DIRECTORY
+ "${CMAKE_SOURCE_DIR}/src/include/cephfs"
+ DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
+ set(ceph_syn_srcs
+ ceph_syn.cc
+ client/SyntheticClient.cc)
+ add_executable(ceph-syn ${ceph_syn_srcs})
+ target_link_libraries(ceph-syn client global-static ceph-common)
+ install(TARGETS ceph-syn DESTINATION bin)
+ if(LINUX)
+ add_subdirectory(mount)
+ endif()
+endif(WITH_LIBCEPHFS)
+
+if(WITH_LIBCEPHSQLITE)
+ set(cephsqlite_srcs libcephsqlite.cc SimpleRADOSStriper.cc)
+ add_library(cephsqlite ${CEPH_SHARED} ${cephsqlite_srcs})
+ target_link_libraries(cephsqlite PRIVATE cls_lock_client librados ceph-common SQLite3::SQLite3 ${EXTRALIBS})
+ set_target_properties(cephsqlite PROPERTIES
+ CXX_VISIBILITY_PRESET hidden
+ VISIBILITY_INLINES_HIDDEN ON)
+ if(NOT APPLE AND NOT WIN32)
+ set_property(TARGET cephsqlite APPEND_STRING PROPERTY
+ LINK_FLAGS " -Wl,--exclude-libs,ALL")
+ endif()
+ install(TARGETS cephsqlite DESTINATION ${CMAKE_INSTALL_LIBDIR})
+endif(WITH_LIBCEPHSQLITE)
+
+if(WITH_FUSE)
+ set(ceph_fuse_srcs
+ ceph_fuse.cc
+ client/fuse_ll.cc)
+ add_executable(ceph-fuse ${ceph_fuse_srcs})
+ target_link_libraries(ceph-fuse FUSE::FUSE
+ ${GSSAPI_LIBRARIES} client ceph-common global-static ${EXTRALIBS})
+ set_target_properties(ceph-fuse PROPERTIES
+ POSITION_INDEPENDENT_CODE ${EXE_LINKER_USE_PIE})
+ install(TARGETS ceph-fuse DESTINATION bin)
+ install(PROGRAMS mount.fuse.ceph DESTINATION ${CMAKE_INSTALL_SBINDIR})
+endif(WITH_FUSE)
+
+if(WITH_DOKAN)
+ add_subdirectory(dokan)
+endif(WITH_DOKAN)
+
+add_subdirectory(journal)
+
+if(WITH_RBD)
+ if(WITH_KRBD)
+ add_library(krbd STATIC krbd.cc
+ $<TARGET_OBJECTS:parse_secret_objs>)
+ target_link_libraries(krbd keyutils::keyutils)
+ endif()
+ add_subdirectory(librbd)
+ if(WITH_FUSE)
+ add_subdirectory(rbd_fuse)
+ endif()
+
+ install(PROGRAMS
+ ${CMAKE_SOURCE_DIR}/src/ceph-rbdnamer
+ ${CMAKE_SOURCE_DIR}/src/rbd-replay-many
+ ${CMAKE_SOURCE_DIR}/src/rbdmap
+ DESTINATION ${CMAKE_INSTALL_BINDIR})
+ add_subdirectory(rbd_replay)
+endif(WITH_RBD)
+
+set(SPAWN_BUILD_TESTS OFF CACHE INTERNAL "disable building of spawn unit tests")
+set(SPAWN_INSTALL OFF CACHE INTERNAL "disable installation of spawn headers")
+add_subdirectory(spawn)
+
+# RadosGW
+if(WITH_KVS)
+ add_subdirectory(key_value_store)
+endif(WITH_KVS)
+
+if(WITH_RADOSGW)
+ add_subdirectory(libkmip)
+
+ set(civetweb_common_files civetweb/src/civetweb.c)
+ add_library(civetweb_common_objs OBJECT ${civetweb_common_files})
+ target_include_directories(civetweb_common_objs SYSTEM PRIVATE
+ "${CMAKE_SOURCE_DIR}/src/civetweb/include")
+ set_property(TARGET civetweb_common_objs
+ APPEND PROPERTY COMPILE_DEFINITIONS USE_IPV6=1)
+ if (LIBSSL_SONAME)
+ set_property(TARGET civetweb_common_objs
+ APPEND PROPERTY COMPILE_DEFINITIONS SSL_LIB="${LIBSSL_SONAME}")
+ set_property(TARGET civetweb_common_objs
+ APPEND PROPERTY COMPILE_DEFINITIONS CRYPTO_LIB="${LIBCRYPTO_SONAME}")
+ endif()
+
+ if (OPENSSL_FOUND)
+ # Use cmake to determine openssl version, a TODO is to make
+ # civetweb itself do this based on openssl_api_compat strings
+ if (NOT (OPENSSL_VERSION VERSION_LESS "1.1"))
+ message(STATUS "Setting civetweb to use OPENSSL >= 1.1")
+ set_property(TARGET civetweb_common_objs
+ APPEND PROPERTY COMPILE_DEFINITIONS OPENSSL_API_1_1=1)
+ endif()
+ endif(OPENSSL_FOUND)
+ add_subdirectory(rgw)
+
+endif(WITH_RADOSGW)
+
+install(FILES
+ sample.ceph.conf
+ DESTINATION ${CMAKE_INSTALL_DOCDIR})
+
+# Now create a usable config.h
+configure_file(
+ ${CMAKE_SOURCE_DIR}/src/include/config-h.in.cmake
+ ${CMAKE_BINARY_DIR}/include/acconfig.h
+)
+
+if(NOT WIN32)
+# Everything you need to spin up a cluster with vstart.sh
+add_custom_target(vstart-base DEPENDS
+ ceph-osd
+ ceph-mon
+ ceph-authtool
+ ceph-conf
+ monmaptool
+ crushtool
+ rados
+ cython_rados)
+if (WITH_MGR)
+ add_dependencies(vstart-base ceph-mgr)
+endif()
+
+add_custom_target(vstart DEPENDS vstart-base)
+if(WITH_RBD)
+ add_dependencies(vstart cython_rbd)
+endif()
+if (WITH_CEPHFS)
+ add_dependencies(vstart ceph-mds cephfs cython_cephfs)
+endif()
+if(WITH_RADOSGW)
+ add_dependencies(vstart radosgwd radosgw-admin)
+endif()
+
+if(WITH_LTTNG)
+ add_dependencies(vstart tracepoint_libraries)
+endif(WITH_LTTNG)
+
+if(WITH_MGR AND WITH_MGR_DASHBOARD_FRONTEND AND CMAKE_SYSTEM_PROCESSOR MATCHES "x86_64|amd64")
+ add_dependencies(vstart mgr-dashboard-frontend-build)
+endif()
+
+if(WITH_MGR)
+ add_dependencies(vstart ceph-volume-venv-setup)
+endif()
+endif(NOT WIN32)
+
+# Everything you need to run CephFS tests
+add_custom_target(cephfs_testing DEPENDS
+ vstart
+ rados
+ cython_modules
+ cephfs
+ cls_cephfs
+ ceph-fuse
+ ceph-dencoder
+ ceph-dencoder-modules
+ cephfs-journal-tool
+ cephfs-meta-injection
+ cephfs-data-scan
+ cephfs-table-tool)
+
+if (IS_DIRECTORY "${PROJECT_SOURCE_DIR}/.git")
+ add_custom_target(
+ git-update
+ COMMAND git submodule sync
+ COMMAND git submodule update --force --init --recursive
+ WORKING_DIRECTORY "${PROJECT_SOURCE_DIR}")
+endif()
+
+add_subdirectory(script)
+
+# add doxygen target
+find_package(Doxygen)
+if(DOXYGEN_FOUND)
+ set(DOXYGEN_FILE_PATTERNS *.cc *.c *.cpp *.C *.cxx *.c++ *.CC *.H *.h *.hh *.hpp)
+ set(DOXYGEN_SOURCE_BROWSER YES)
+ set(DOXYGEN_WARN_IF_UNDOCUMENTED NO)
+ # enabling clang slows down doxygen significantly
+ set(DOXYGEN_CLANG_ASSISTED_PARSING NO)
+ set(DOXYGEN_CLANG_DATABASE_PATH "${PROJECT_BINARY_DIR}")
+ set(DOXYGEN_BUILTIN_STL_SUPPORT YES)
+ set(DOXYGEN_RECURSIVE YES)
+ set(DOXYGEN_QUIET YES)
+ set(DOXYGEN_GENERATE_LATEX NO)
+ set(DOXYGEN_GENERATE_XML NO)
+ set(DOXYGEN_GENERATE_HTML YES)
+ set(DOXYGEN_PROJECT_NAME Ceph)
+ set(DOXYGEN_OUTPUT_DIRECTORY "${PROJECT_SOURCE_DIR}/build-doc/doxygen")
+ set(DOXYGEN_STRIP_FROM_PATH "src/")
+ set(DOXYGEN_STRIP_FROM_INC_PATH "src/include")
+ set(DOXYGEN_JAVADOC_AUTOBRIEF YES)
+ set(DOXYGEN_HAVE_DOT NO)
+ set(DOXYGEN_VERBATIM_HEADERS YES)
+ doxygen_add_docs(doxygen
+ auth
+ client
+ cls
+ common
+ compressor
+ crimson
+ crush
+ crypto
+ erasure-code
+ global
+ include
+ journal
+ json_spirit
+ key_value_store
+ kv
+ librados
+ libradosstriper
+ librbd
+ log
+ mds
+ messages
+ mgr
+ mon
+ mount
+ msg
+ objclass
+ objsync
+ os
+ osd
+ osdc
+ perfglue
+ rbd_fuse
+ rbd_replay
+ rgw
+ COMMENT "Generate C++ documentation")
+endif()
+