From 812f10ffad16a8bad012c0648c9cfa847e9fbcf5 Mon Sep 17 00:00:00 2001 From: Kefu Chai Date: Fri, 14 Feb 2020 13:58:32 +0800 Subject: [PATCH] cmake: compile crimson-auth with crimson::cflags * move auth related stuff into crimson/CMakeLists.txt, so we can link them against crimson::cflags, which populates the necessary definitions and other cxx flags when building these source files. * expose crimson::cflags as a public library of crimson, as crimson-osd links against crimson. and the cflags should be populated to crimson-osd, otherwise they are compiled with different compiler options. Signed-off-by: Kefu Chai --- src/auth/CMakeLists.txt | 7 ------- src/crimson/CMakeLists.txt | 17 ++++++++++++++--- 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/src/auth/CMakeLists.txt b/src/auth/CMakeLists.txt index c977acd8b3d..b6ae0c83efd 100644 --- a/src/auth/CMakeLists.txt +++ b/src/auth/CMakeLists.txt @@ -21,10 +21,3 @@ if(HAVE_GSSAPI) endif() add_library(common-auth-objs OBJECT ${auth_srcs}) -if(WITH_SEASTAR) - add_library(crimson-auth OBJECT ${auth_srcs}) - target_compile_definitions(crimson-auth PRIVATE - "WITH_SEASTAR=1") - target_include_directories(crimson-auth PRIVATE - $) -endif() diff --git a/src/crimson/CMakeLists.txt b/src/crimson/CMakeLists.txt index 7f792b64778..3784925bd53 100644 --- a/src/crimson/CMakeLists.txt +++ b/src/crimson/CMakeLists.txt @@ -103,7 +103,6 @@ add_library(crimson-common STATIC ${PROJECT_SOURCE_DIR}/src/osd/OSDMap.cc ${PROJECT_SOURCE_DIR}/src/osd/PGPeeringEvent.cc ${crimson_common_srcs} - $ $ $) @@ -123,14 +122,26 @@ endif() target_link_libraries(crimson-common PUBLIC json_spirit + crimson::cflags PRIVATE crc32 - crimson::cflags ${crimson_common_deps} OpenSSL::Crypto) set(crimson_auth_srcs - auth/KeyRing.cc) + auth/KeyRing.cc + ${PROJECT_SOURCE_DIR}/src/auth/AuthClientHandler.cc + ${PROJECT_SOURCE_DIR}/src/auth/AuthMethodList.cc + ${PROJECT_SOURCE_DIR}/src/auth/AuthRegistry.cc + ${PROJECT_SOURCE_DIR}/src/auth/AuthSessionHandler.cc + ${PROJECT_SOURCE_DIR}/src/auth/Crypto.cc + ${PROJECT_SOURCE_DIR}/src/auth/KeyRing.cc + ${PROJECT_SOURCE_DIR}/src/auth/RotatingKeyRing.cc + ${PROJECT_SOURCE_DIR}/src/auth/cephx/CephxAuthorizeHandler.cc + ${PROJECT_SOURCE_DIR}/src/auth/cephx/CephxClientHandler.cc + ${PROJECT_SOURCE_DIR}/src/auth/cephx/CephxProtocol.cc + ${PROJECT_SOURCE_DIR}/src/auth/cephx/CephxSessionHandler.cc + ${PROJECT_SOURCE_DIR}/src/auth/none/AuthNoneAuthorizeHandler.cc) set(crimson_mgr_srcs mgr/client.cc) set(crimson_mon_srcs