rocksdb.cmake 4.9 KB
Newer Older
T
Thunderbrook 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14
# Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

15
include(ExternalProject)
T
Thunderbrook 已提交
16

L
lxsbupt 已提交
17
# find_package(jemalloc REQUIRED)
R
risemeup1 已提交
18

19 20 21
set(ROCKSDB_SOURCE_DIR ${PADDLE_SOURCE_DIR}/third_party/rocksdb)
set(ROCKSDB_TAG 6.19.fb)

L
lxsbupt 已提交
22 23 24 25 26
set(JEMALLOC_INCLUDE_DIR ${THIRD_PARTY_PATH}/install/jemalloc/include)
set(JEMALLOC_LIBRARIES
    ${THIRD_PARTY_PATH}/install/jemalloc/lib/libjemalloc_pic.a)
message(STATUS "rocksdb jemalloc:" ${JEMALLOC_LIBRARIES})

27 28 29 30 31 32 33 34
set(ROCKSDB_PREFIX_DIR ${THIRD_PARTY_PATH}/rocksdb)
set(ROCKSDB_INSTALL_DIR ${THIRD_PARTY_PATH}/install/rocksdb)
set(ROCKSDB_INCLUDE_DIR
    "${ROCKSDB_INSTALL_DIR}/include"
    CACHE PATH "rocksdb include directory." FORCE)
set(ROCKSDB_LIBRARIES
    "${ROCKSDB_INSTALL_DIR}/lib/librocksdb.a"
    CACHE FILEPATH "rocksdb library." FORCE)
L
lxsbupt 已提交
35 36 37 38
set(ROCKSDB_COMMON_FLAGS
    "-g -pipe -O2 -W -Wall -Wno-unused-parameter -fPIC -fno-builtin-memcmp -fno-omit-frame-pointer"
)
set(ROCKSDB_FLAGS
39
    "-DNDEBUG -DROCKSDB_JEMALLOC -DJEMALLOC_NO_DEMANGLE -DROCKSDB_PLATFORM_POSIX -DROCKSDB_LIB_IO_POSIX -DOS_LINUX -DROCKSDB_FALLOCATE_PRESENT -DHAVE_PCLMUL -DZLIB -DROCKSDB_MALLOC_USABLE_SIZE -DROCKSDB_PTHREAD_ADAPTIVE_MUTEX -DROCKSDB_BACKTRACE -DROCKSDB_SUPPORT_THREAD_LOCAL -DROCKSDB_USE_RTTI -DROCKSDB_SCHED_GETCPU_PRESENT -DROCKSDB_RANGESYNC_PRESENT -DROCKSDB_AUXV_GETAUXVAL_PRESENT"
L
lxsbupt 已提交
40 41
)
set(ROCKSDB_CMAKE_CXX_FLAGS
42
    "${ROCKSDB_COMMON_FLAGS} -DROCKSDB_LIBAIO_PRESENT ${ROCKSDB_FLAGS} -fPIC  -I${JEMALLOC_INCLUDE_DIR} -Wl,--no-as-needed -lz -ldl"
L
lxsbupt 已提交
43
)
44 45 46 47 48
if(NOT WITH_ARM)
  set(ROCKSDB_FLAGS "${ROCKSDB_FLAGS} -DHAVE_SSE42")
  set(ROCKSDB_CMAKE_CXX_FLAGS
      "${ROCKSDB_CMAKE_CXX_FLAGS} -msse -msse4.2 -mpclmul")
endif()
L
lxsbupt 已提交
49 50 51
set(ROCKSDB_CMAKE_C_FLAGS
    "${ROCKSDB_COMMON_FLAGS} ${ROCKSDB_FLAGS} -DROCKSDB_LIBAIO_PRESENT -fPIC  -I${JEMALLOC_INCLUDE_DIR}"
)
52
include_directories(${ROCKSDB_INCLUDE_DIR})
T
Thunderbrook 已提交
53

54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
file(GLOB ROCKSDB_SOURCE_FILE_LIST ${ROCKSDB_SOURCE_DIR})
list(LENGTH ROCKSDB_SOURCE_FILE_LIST RES_LEN)
if(RES_LEN EQUAL 0)
  execute_process(
    COMMAND ${GIT_EXECUTABLE} clone -b ${ROCKSDB_TAG}
            "https://github.com/Thunderbrook/rocksdb" ${ROCKSDB_SOURCE_DIR})
else()
  # check git tag
  execute_process(
    COMMAND ${GIT_EXECUTABLE} describe --abbrev=6 --always --tags
    OUTPUT_VARIABLE VERSION
    OUTPUT_STRIP_TRAILING_WHITESPACE ERROR_QUIET
    WORKING_DIRECTORY ${ROCKSDB_SOURCE_DIR})
  if(NOT ${VERSION} STREQUAL ${ROCKSDB_TAG})
    file(REMOVE_RECURSE ${ROCKSDB_PREFIX_DIR})
    file(REMOVE_RECURSE ${ROCKSDB_INSTALL_DIR})
    message(
      WARNING "rocksdb version is not ${VERSION}, checkout to ${ROCKSDB_TAG}")
    execute_process(COMMAND ${GIT_EXECUTABLE} checkout ${ROCKSDB_TAG}
                    WORKING_DIRECTORY ${ROCKSDB_SOURCE_DIR})
  endif()
endif()

L
lxsbupt 已提交
77
set(CMAKE_CXX_LINK_EXECUTABLE
78
    "${CMAKE_CXX_LINK_EXECUTABLE} -pthread -Wl,--no-as-needed -ldl -lrt -lz")
79 80 81 82 83 84 85 86 87
if(WITH_ARM)
  file(TO_NATIVE_PATH ${PADDLE_SOURCE_DIR}/patches/rocksdb/libaio.h.patch
       native_src)
  # See: [Why calling some `git` commands before `patch`?]
  set(ROCKSDB_PATCH_COMMAND
      git checkout -- . && git checkout 6.19.fb && patch -Nd
      ${CMAKE_BINARY_DIR}/third_party/rocksdb/src/extern_rocksdb/env <
      ${native_src})
endif()
T
Thunderbrook 已提交
88
ExternalProject_Add(
89 90 91
  extern_rocksdb
  ${EXTERNAL_PROJECT_LOG_ARGS}
  PREFIX ${ROCKSDB_PREFIX_DIR}
92
  SOURCE_DIR ${ROCKSDB_SOURCE_DIR}
93
  UPDATE_COMMAND ""
94
  PATCH_COMMAND ${ROCKSDB_PATCH_COMMAND}
95 96 97
  CMAKE_ARGS -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}
             -DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}
             -DWITH_BZ2=OFF
Z
zhaocaibei123 已提交
98
             -DPORTABLE=1
99
             -DWITH_GFLAGS=OFF
L
lxsbupt 已提交
100 101 102 103 104
             -DWITH_TESTS=OFF
             -DWITH_JEMALLOC=ON
             -DWITH_BENCHMARK_TOOLS=OFF
             -DJeMalloc_LIBRARIES=${JEMALLOC_LIBRARIES}
             -DJeMalloc_INCLUDE_DIRS=${JEMALLOC_INCLUDE_DIR}
105 106 107 108
             -DCMAKE_CXX_FLAGS=${ROCKSDB_CMAKE_CXX_FLAGS}
             -DCMAKE_C_FLAGS=${CMAKE_C_FLAGS}
  INSTALL_COMMAND
    mkdir -p ${ROCKSDB_INSTALL_DIR}/lib/ && cp
109 110
    ${ROCKSDB_PREFIX_DIR}/src/extern_rocksdb-build/librocksdb.a
    ${ROCKSDB_LIBRARIES} && cp -r ${ROCKSDB_SOURCE_DIR}/include
R
risemeup1 已提交
111
    ${ROCKSDB_INSTALL_DIR}/
H
hong 已提交
112
  BUILD_BYPRODUCTS ${ROCKSDB_LIBRARIES})
T
Thunderbrook 已提交
113

114
add_library(rocksdb STATIC IMPORTED GLOBAL)
H
hong 已提交
115 116

add_dependencies(extern_rocksdb snappy)
L
Leo Chen 已提交
117
add_dependencies(extern_rocksdb extern_jemalloc)
118 119
set_property(TARGET rocksdb PROPERTY IMPORTED_LOCATION ${ROCKSDB_LIBRARIES})
add_dependencies(rocksdb extern_rocksdb)
T
Thunderbrook 已提交
120

121
list(APPEND external_project_dependencies rocksdb)