diff options
author | Feng Hualong <hualong.feng@intel.com> | 2021-04-14 07:20:17 +0200 |
---|---|---|
committer | Feng Hualong <hualong.feng@intel.com> | 2021-04-15 04:40:06 +0200 |
commit | 14c2a2e59fbdc716d35c08735d50bdadfab8300d (patch) | |
tree | 8534d0787c47bcfa1074f7d3c7248fc95ca4170d | |
parent | make-dist: add pmdk to dist tarball (diff) | |
download | ceph-14c2a2e59fbdc716d35c08735d50bdadfab8300d.tar.xz ceph-14c2a2e59fbdc716d35c08735d50bdadfab8300d.zip |
cmake: use src/pmdk for building pmdk if it exists
so we can build with pmdk enabled if the dist tarball
contains pmdk
Signed-off-by: Feng Hualong <hualong.feng@intel.com>
-rw-r--r-- | cmake/modules/Buildpmem.cmake | 42 |
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} |