rocksdb.cmake 4.0 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

L
lxsbupt 已提交
19 20 21 22 23
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})

24 25 26 27 28 29 30 31
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 已提交
32 33 34 35
set(ROCKSDB_COMMON_FLAGS
    "-g -pipe -O2 -W -Wall -Wno-unused-parameter -fPIC -fno-builtin-memcmp -fno-omit-frame-pointer"
)
set(ROCKSDB_FLAGS
36
    "-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 已提交
37 38
)
set(ROCKSDB_CMAKE_CXX_FLAGS
39
    "${ROCKSDB_COMMON_FLAGS} -DROCKSDB_LIBAIO_PRESENT ${ROCKSDB_FLAGS} -fPIC  -I${JEMALLOC_INCLUDE_DIR} -Wl,--no-as-needed -lz -ldl"
L
lxsbupt 已提交
40
)
41 42 43 44 45
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 已提交
46 47 48
set(ROCKSDB_CMAKE_C_FLAGS
    "${ROCKSDB_COMMON_FLAGS} ${ROCKSDB_FLAGS} -DROCKSDB_LIBAIO_PRESENT -fPIC  -I${JEMALLOC_INCLUDE_DIR}"
)
49
include_directories(${ROCKSDB_INCLUDE_DIR})
T
Thunderbrook 已提交
50

L
lxsbupt 已提交
51
set(CMAKE_CXX_LINK_EXECUTABLE
52
    "${CMAKE_CXX_LINK_EXECUTABLE} -pthread -Wl,--no-as-needed -ldl -lrt -lz")
53 54 55 56 57 58 59 60 61
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 已提交
62
ExternalProject_Add(
63 64 65
  extern_rocksdb
  ${EXTERNAL_PROJECT_LOG_ARGS}
  PREFIX ${ROCKSDB_PREFIX_DIR}
R
risemeup1 已提交
66 67
  GIT_REPOSITORY "https://github.com/Thunderbrook/rocksdb"
  GIT_TAG 6.19.fb
68
  UPDATE_COMMAND ""
69
  PATCH_COMMAND ${ROCKSDB_PATCH_COMMAND}
70 71 72
  CMAKE_ARGS -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}
             -DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}
             -DWITH_BZ2=OFF
Z
zhaocaibei123 已提交
73
             -DPORTABLE=1
74
             -DWITH_GFLAGS=OFF
L
lxsbupt 已提交
75 76 77 78 79
             -DWITH_TESTS=OFF
             -DWITH_JEMALLOC=ON
             -DWITH_BENCHMARK_TOOLS=OFF
             -DJeMalloc_LIBRARIES=${JEMALLOC_LIBRARIES}
             -DJeMalloc_INCLUDE_DIRS=${JEMALLOC_INCLUDE_DIR}
80 81 82 83
             -DCMAKE_CXX_FLAGS=${ROCKSDB_CMAKE_CXX_FLAGS}
             -DCMAKE_C_FLAGS=${CMAKE_C_FLAGS}
  INSTALL_COMMAND
    mkdir -p ${ROCKSDB_INSTALL_DIR}/lib/ && cp
R
risemeup1 已提交
84 85 86
    ${ROCKSDB_PREFIX_DIR}/src/extern_rocksdb/librocksdb.a ${ROCKSDB_LIBRARIES}
    && cp -r ${ROCKSDB_PREFIX_DIR}/src/extern_rocksdb/include
    ${ROCKSDB_INSTALL_DIR}/
87
  BUILD_IN_SOURCE 1
H
hong 已提交
88
  BUILD_BYPRODUCTS ${ROCKSDB_LIBRARIES})
T
Thunderbrook 已提交
89

90
add_library(rocksdb STATIC IMPORTED GLOBAL)
H
hong 已提交
91 92

add_dependencies(extern_rocksdb snappy)
L
Leo Chen 已提交
93
add_dependencies(extern_rocksdb extern_jemalloc)
94 95
set_property(TARGET rocksdb PROPERTY IMPORTED_LOCATION ${ROCKSDB_LIBRARIES})
add_dependencies(rocksdb extern_rocksdb)
T
Thunderbrook 已提交
96

97
list(APPEND external_project_dependencies rocksdb)