summaryrefslogtreecommitdiffstats
path: root/cmake/modules
diff options
context:
space:
mode:
authorKefu Chai <kchai@redhat.com>2021-04-15 10:43:28 +0200
committerGitHub <noreply@github.com>2021-04-15 10:43:28 +0200
commit117838c91d0cadbd4f5126dcfbfb5dfa938176fe (patch)
tree6875b988fd56338fdb6c1fc6e95c4c7a2a7d17e5 /cmake/modules
parentMerge pull request #40862 from ivancich/wip-rgw-reshard-contention-logging (diff)
parentcmake: use src/pmdk for building pmdk if it exists (diff)
downloadceph-117838c91d0cadbd4f5126dcfbfb5dfa938176fe.tar.xz
ceph-117838c91d0cadbd4f5126dcfbfb5dfa938176fe.zip
Merge pull request #40866 from hualongfeng/pmdk_in_dist
make-dist: add pmdk to dist tarball Reviewed-by: Kefu Chai <kchai@redhat.com>
Diffstat (limited to 'cmake/modules')
-rw-r--r--cmake/modules/Buildpmem.cmake42
1 files changed, 26 insertions, 16 deletions
diff --git a/cmake/modules/Buildpmem.cmake b/cmake/modules/Buildpmem.cmake
index 46a246b94e8..7068db85e88 100644
--- a/cmake/modules/Buildpmem.cmake
+++ b/cmake/modules/Buildpmem.cmake
@@ -1,7 +1,18 @@
function(build_pmem)
- include(ExternalProject)
- set(PMDK_SRC "${CMAKE_BINARY_DIR}/src/pmdk/src")
- set(PMDK_INCLUDE "${PMDK_SRC}/include")
+ include(FindMake)
+ find_make("MAKE_EXECUTABLE" "make_cmd")
+
+ if(EXISTS "${PROJECT_SOURCE_DIR}/src/pmdk/Makefile")
+ set(source_dir_args
+ SOURCE_DIR "${PROJECT_SOURCE_DIR}/src/pmdk")
+ else()
+ set(source_dir_args
+ SOURCE_DIR ${CMAKE_BINARY_DIR}/src/pmdk
+ GIT_REPOSITORY https://github.com/ceph/pmdk.git
+ GIT_TAG "1.7"
+ GIT_SHALLOW TRUE
+ GIT_CONFIG advice.detachedHead=false)
+ endif()
# Use debug PMDK libs in debug lib/rbd builds
if(CMAKE_BUILD_TYPE STREQUAL Debug)
@@ -9,29 +20,28 @@ function(build_pmem)
else()
set(PMDK_LIB_DIR "nondebug")
endif()
- set(PMDK_LIB "${PMDK_SRC}/${PMDK_LIB_DIR}")
-
- include(FindMake)
- find_make("MAKE_EXECUTABLE" "make_cmd")
+ include(ExternalProject)
ExternalProject_Add(pmdk_ext
- GIT_REPOSITORY "https://github.com/ceph/pmdk.git"
- GIT_TAG "1.7"
- GIT_SHALLOW TRUE
- GIT_CONFIG advice.detachedHead=false
- SOURCE_DIR ${CMAKE_BINARY_DIR}/src/pmdk
+ ${source_dir_args}
CONFIGURE_COMMAND ""
# Explicitly built w/o NDCTL, otherwise if ndtcl is present on the
# build system tests statically linking to librbd (which uses
# libpmemobj) will not link (because we don't build the ndctl
# static library here).
- BUILD_COMMAND ${make_cmd} CC=${CMAKE_C_COMPILER} NDCTL_ENABLE=n
+ BUILD_COMMAND ${make_cmd} CC=${CMAKE_C_COMPILER} NDCTL_ENABLE=n BUILD_EXAMPLES=n BUILD_BENCHMARKS=n DOC=n
BUILD_IN_SOURCE 1
- BUILD_BYPRODUCTS "${PMDK_LIB}/libpmem.a" "${PMDK_LIB}/libpmemobj.a"
+ BUILD_BYPRODUCTS "<SOURCE_DIR>/src/${PMDK_LIB_DIR}/libpmem.a" "<SOURCE_DIR>/src/${PMDK_LIB_DIR}/libpmemobj.a"
INSTALL_COMMAND "")
+ unset(make_cmd)
+
+ ExternalProject_Get_Property(pmdk_ext source_dir)
+ set(PMDK_SRC "${source_dir}/src")
+ set(PMDK_INCLUDE "${source_dir}/src/include")
+ set(PMDK_LIB "${source_dir}/src/${PMDK_LIB_DIR}")
# libpmem
- add_library(pmem::pmem STATIC IMPORTED)
+ add_library(pmem::pmem STATIC IMPORTED GLOBAL)
add_dependencies(pmem::pmem pmdk_ext)
file(MAKE_DIRECTORY ${PMDK_INCLUDE})
set_target_properties(pmem::pmem PROPERTIES
@@ -40,7 +50,7 @@ function(build_pmem)
INTERFACE_LINK_LIBRARIES ${CMAKE_THREAD_LIBS_INIT})
# libpmemobj
- add_library(pmem::pmemobj STATIC IMPORTED)
+ add_library(pmem::pmemobj STATIC IMPORTED GLOBAL)
add_dependencies(pmem::pmemobj pmdk_ext)
set_target_properties(pmem::pmemobj PROPERTIES
INTERFACE_INCLUDE_DIRECTORIES ${PMDK_INCLUDE}