mirror of https://github.com/milvus-io/milvus.git
Merge branch 'branch-0.3.1' into 'branch-0.3.1'
MS-241: Build Faiss with MKL if using Intel CPU; else build with OpenBlas . MS-242: clean up cmake and change MAKE_BUILD_ARGS to be user defined variable See merge request megasearch/milvus!230 Former-commit-id: 7fc20dbf175a1bd8fef82bf470c6a499b2e35080pull/191/head
commit
8e5e50e47e
|
@ -35,7 +35,7 @@ pipeline {
|
||||||
defaultContainer 'jnlp'
|
defaultContainer 'jnlp'
|
||||||
containerTemplate {
|
containerTemplate {
|
||||||
name 'milvus-build-env'
|
name 'milvus-build-env'
|
||||||
image 'registry.zilliz.com/milvus/milvus-build-env:v0.10'
|
image 'registry.zilliz.com/milvus/milvus-build-env:v0.11'
|
||||||
ttyEnabled true
|
ttyEnabled true
|
||||||
command 'cat'
|
command 'cat'
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,7 +35,7 @@ pipeline {
|
||||||
defaultContainer 'jnlp'
|
defaultContainer 'jnlp'
|
||||||
containerTemplate {
|
containerTemplate {
|
||||||
name 'milvus-build-env'
|
name 'milvus-build-env'
|
||||||
image 'registry.zilliz.com/milvus/milvus-build-env:v0.10'
|
image 'registry.zilliz.com/milvus/milvus-build-env:v0.11'
|
||||||
ttyEnabled true
|
ttyEnabled true
|
||||||
command 'cat'
|
command 'cat'
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,7 +35,7 @@ pipeline {
|
||||||
defaultContainer 'jnlp'
|
defaultContainer 'jnlp'
|
||||||
containerTemplate {
|
containerTemplate {
|
||||||
name 'milvus-build-env'
|
name 'milvus-build-env'
|
||||||
image 'registry.zilliz.com/milvus/milvus-build-env:v0.10'
|
image 'registry.zilliz.com/milvus/milvus-build-env:v0.11'
|
||||||
ttyEnabled true
|
ttyEnabled true
|
||||||
command 'cat'
|
command 'cat'
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,8 @@ Please mark all change in change log and use the ticket from JIRA.
|
||||||
- MS-206 - Support SQ8 index type
|
- MS-206 - Support SQ8 index type
|
||||||
- MS-208 - Add buildinde interface for C++ SDK
|
- MS-208 - Add buildinde interface for C++ SDK
|
||||||
- MS-212 - Support Inner product metric type
|
- MS-212 - Support Inner product metric type
|
||||||
|
- MS-241 - Build Faiss with MKL if using Intel CPU; else build with OpenBlas
|
||||||
|
- MS-242 - clean up cmake and change MAKE_BUILD_ARGS to be user defined variable
|
||||||
|
|
||||||
## New Feature
|
## New Feature
|
||||||
- MS-180 - Add new mem manager
|
- MS-180 - Add new mem manager
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
### Compilation
|
### Compilation
|
||||||
#### Step 1: install necessery tools
|
#### Step 1: install necessery tools
|
||||||
|
|
||||||
Install MySQL
|
|
||||||
|
|
||||||
centos7 :
|
centos7 :
|
||||||
yum install gfortran qt4 flex bison mysql-devel
|
yum install gfortran qt4 flex bison mysql-devel mysql
|
||||||
|
|
||||||
ubuntu16.04 :
|
ubuntu16.04 :
|
||||||
sudo apt-get install gfortran qt4-qmake flex bison libmysqlclient-dev
|
sudo apt-get install gfortran qt4-qmake flex bison libmysqlclient-dev mysql-client
|
||||||
|
|
||||||
|
cd scripts && sudo ./requirements.sh
|
||||||
|
|
||||||
If `libmysqlclient_r.so` does not exist after installing MySQL Development Files, you need to create a symbolic link:
|
If `libmysqlclient_r.so` does not exist after installing MySQL Development Files, you need to create a symbolic link:
|
||||||
|
|
||||||
|
|
|
@ -57,8 +57,6 @@ define_option(MILVUS_VERBOSE_THIRDPARTY_BUILD
|
||||||
|
|
||||||
define_option(MILVUS_WITH_ARROW "Build with ARROW" OFF)
|
define_option(MILVUS_WITH_ARROW "Build with ARROW" OFF)
|
||||||
|
|
||||||
define_option(MILVUS_BOOST_USE_SHARED "Rely on boost shared libraries where relevant" OFF)
|
|
||||||
|
|
||||||
define_option(MILVUS_BOOST_VENDORED "Use vendored Boost instead of existing Boost. \
|
define_option(MILVUS_BOOST_VENDORED "Use vendored Boost instead of existing Boost. \
|
||||||
Note that this requires linking Boost statically" ON)
|
Note that this requires linking Boost statically" ON)
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
# to you under the Apache License, Version 2.0 (the
|
# to you under the Apache License, Version 2.0 (the
|
||||||
# "License"); you may not use this file except in compliance
|
# "License"); you may not use this file except in compliance
|
||||||
# with the License. You may obtain a copy of the License at
|
# with the License. You may obtain a copy of the License at
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
#
|
#
|
||||||
# Unless required by applicable law or agreed to in writing,
|
# Unless required by applicable law or agreed to in writing,
|
||||||
|
@ -96,12 +95,8 @@ endmacro()
|
||||||
|
|
||||||
macro(resolve_dependency DEPENDENCY_NAME)
|
macro(resolve_dependency DEPENDENCY_NAME)
|
||||||
if (${DEPENDENCY_NAME}_SOURCE STREQUAL "AUTO")
|
if (${DEPENDENCY_NAME}_SOURCE STREQUAL "AUTO")
|
||||||
#message(STATUS "Finding ${DEPENDENCY_NAME} package")
|
#disable find_package for now
|
||||||
# find_package(${DEPENDENCY_NAME} QUIET)
|
|
||||||
# if (NOT ${DEPENDENCY_NAME}_FOUND)
|
|
||||||
#message(STATUS "${DEPENDENCY_NAME} package not found")
|
|
||||||
build_dependency(${DEPENDENCY_NAME})
|
build_dependency(${DEPENDENCY_NAME})
|
||||||
# endif ()
|
|
||||||
elseif (${DEPENDENCY_NAME}_SOURCE STREQUAL "BUNDLED")
|
elseif (${DEPENDENCY_NAME}_SOURCE STREQUAL "BUNDLED")
|
||||||
build_dependency(${DEPENDENCY_NAME})
|
build_dependency(${DEPENDENCY_NAME})
|
||||||
elseif (${DEPENDENCY_NAME}_SOURCE STREQUAL "SYSTEM")
|
elseif (${DEPENDENCY_NAME}_SOURCE STREQUAL "SYSTEM")
|
||||||
|
@ -117,11 +112,9 @@ string(TOUPPER ${CMAKE_BUILD_TYPE} UPPERCASE_BUILD_TYPE)
|
||||||
set(EP_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CMAKE_CXX_FLAGS_${UPPERCASE_BUILD_TYPE}}")
|
set(EP_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CMAKE_CXX_FLAGS_${UPPERCASE_BUILD_TYPE}}")
|
||||||
set(EP_C_FLAGS "${CMAKE_C_FLAGS} ${CMAKE_C_FLAGS_${UPPERCASE_BUILD_TYPE}}")
|
set(EP_C_FLAGS "${CMAKE_C_FLAGS} ${CMAKE_C_FLAGS_${UPPERCASE_BUILD_TYPE}}")
|
||||||
|
|
||||||
if(NOT MSVC)
|
# Set -fPIC on all external projects
|
||||||
# Set -fPIC on all external projects
|
set(EP_CXX_FLAGS "${EP_CXX_FLAGS} -fPIC")
|
||||||
set(EP_CXX_FLAGS "${EP_CXX_FLAGS} -fPIC")
|
set(EP_C_FLAGS "${EP_C_FLAGS} -fPIC")
|
||||||
set(EP_C_FLAGS "${EP_C_FLAGS} -fPIC")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# CC/CXX environment variables are captured on the first invocation of the
|
# CC/CXX environment variables are captured on the first invocation of the
|
||||||
# builder (e.g make or ninja) instead of when CMake is invoked into to build
|
# builder (e.g make or ninja) instead of when CMake is invoked into to build
|
||||||
|
@ -159,20 +152,13 @@ endif()
|
||||||
|
|
||||||
# Ensure that a default make is set
|
# Ensure that a default make is set
|
||||||
if("${MAKE}" STREQUAL "")
|
if("${MAKE}" STREQUAL "")
|
||||||
if(NOT MSVC)
|
find_program(MAKE make)
|
||||||
find_program(MAKE make)
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(MAKE_BUILD_ARGS "-j2")
|
if (NOT DEFINED MAKE_BUILD_ARGS)
|
||||||
|
set(MAKE_BUILD_ARGS "-j8")
|
||||||
## Using make -j in sub-make is fragile
|
endif()
|
||||||
#if(${CMAKE_GENERATOR} MATCHES "Makefiles")
|
message(STATUS "Third Party MAKE_BUILD_ARGS = ${MAKE_BUILD_ARGS}")
|
||||||
# set(MAKE_BUILD_ARGS "")
|
|
||||||
#else()
|
|
||||||
# # limit the maximum number of jobs for ninja
|
|
||||||
# set(MAKE_BUILD_ARGS "-j4")
|
|
||||||
#endif()
|
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
# ----------------------------------------------------------------------
|
||||||
# Find pthreads
|
# Find pthreads
|
||||||
|
@ -285,7 +271,6 @@ if (DEFINED ENV{MILVUS_PROMETHEUS_URL})
|
||||||
set(PROMETHEUS_SOURCE_URL "$ENV{PROMETHEUS_OPENBLAS_URL}")
|
set(PROMETHEUS_SOURCE_URL "$ENV{PROMETHEUS_OPENBLAS_URL}")
|
||||||
else ()
|
else ()
|
||||||
set(PROMETHEUS_SOURCE_URL
|
set(PROMETHEUS_SOURCE_URL
|
||||||
#"https://github.com/JinHai-CN/prometheus-cpp/archive/${PROMETHEUS_VERSION}.tar.gz"
|
|
||||||
https://github.com/jupp0r/prometheus-cpp.git)
|
https://github.com/jupp0r/prometheus-cpp.git)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -347,6 +332,7 @@ if(DEFINED ENV{MILVUS_AWS_URL})
|
||||||
else()
|
else()
|
||||||
set(AWS_SOURCE_URL "https://github.com/aws/aws-sdk-cpp/archive/${AWS_VERSION}.tar.gz")
|
set(AWS_SOURCE_URL "https://github.com/aws/aws-sdk-cpp/archive/${AWS_VERSION}.tar.gz")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
# ----------------------------------------------------------------------
|
||||||
# ARROW
|
# ARROW
|
||||||
|
|
||||||
|
@ -354,19 +340,13 @@ macro(build_arrow)
|
||||||
message(STATUS "Building Apache ARROW-${ARROW_VERSION} from source")
|
message(STATUS "Building Apache ARROW-${ARROW_VERSION} from source")
|
||||||
set(ARROW_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/arrow_ep-prefix/src/arrow_ep/cpp")
|
set(ARROW_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/arrow_ep-prefix/src/arrow_ep/cpp")
|
||||||
set(ARROW_STATIC_LIB_NAME arrow)
|
set(ARROW_STATIC_LIB_NAME arrow)
|
||||||
# set(ARROW_CUDA_STATIC_LIB_NAME arrow_cuda)
|
|
||||||
set(ARROW_STATIC_LIB
|
set(ARROW_STATIC_LIB
|
||||||
"${ARROW_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}${ARROW_STATIC_LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX}"
|
"${ARROW_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}${ARROW_STATIC_LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX}"
|
||||||
)
|
)
|
||||||
# set(ARROW_CUDA_STATIC_LIB
|
|
||||||
# "${ARROW_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}${ARROW_CUDA_STATIC_LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX}"
|
|
||||||
# )
|
|
||||||
set(ARROW_INCLUDE_DIR "${ARROW_PREFIX}/include")
|
set(ARROW_INCLUDE_DIR "${ARROW_PREFIX}/include")
|
||||||
|
|
||||||
set(ARROW_CMAKE_ARGS
|
set(ARROW_CMAKE_ARGS
|
||||||
${EP_COMMON_CMAKE_ARGS}
|
${EP_COMMON_CMAKE_ARGS}
|
||||||
# "-DARROW_THRIFT_URL=${THRIFT_SOURCE_URL}"
|
|
||||||
#"env ARROW_THRIFT_URL=${THRIFT_SOURCE_URL}"
|
|
||||||
-DARROW_BUILD_STATIC=ON
|
-DARROW_BUILD_STATIC=ON
|
||||||
-DARROW_BUILD_SHARED=OFF
|
-DARROW_BUILD_SHARED=OFF
|
||||||
-DARROW_PARQUET=ON
|
-DARROW_PARQUET=ON
|
||||||
|
@ -375,8 +355,6 @@ macro(build_arrow)
|
||||||
"-DCMAKE_LIBRARY_PATH=${CUDA_TOOLKIT_ROOT_DIR}/lib64/stubs"
|
"-DCMAKE_LIBRARY_PATH=${CUDA_TOOLKIT_ROOT_DIR}/lib64/stubs"
|
||||||
-DCMAKE_BUILD_TYPE=Release)
|
-DCMAKE_BUILD_TYPE=Release)
|
||||||
|
|
||||||
# set($ENV{ARROW_THRIFT_URL} ${THRIFT_SOURCE_URL})
|
|
||||||
|
|
||||||
externalproject_add(arrow_ep
|
externalproject_add(arrow_ep
|
||||||
GIT_REPOSITORY
|
GIT_REPOSITORY
|
||||||
${ARROW_SOURCE_URL}
|
${ARROW_SOURCE_URL}
|
||||||
|
@ -384,14 +362,8 @@ macro(build_arrow)
|
||||||
${ARROW_VERSION}
|
${ARROW_VERSION}
|
||||||
GIT_SHALLOW
|
GIT_SHALLOW
|
||||||
TRUE
|
TRUE
|
||||||
# SOURCE_DIR
|
|
||||||
# ${ARROW_PREFIX}
|
|
||||||
# BINARY_DIR
|
|
||||||
# ${ARROW_PREFIX}
|
|
||||||
SOURCE_SUBDIR
|
SOURCE_SUBDIR
|
||||||
cpp
|
cpp
|
||||||
# COMMAND
|
|
||||||
# "export \"ARROW_THRIFT_URL=${THRIFT_SOURCE_URL}\""
|
|
||||||
${EP_LOG_OPTIONS}
|
${EP_LOG_OPTIONS}
|
||||||
CMAKE_ARGS
|
CMAKE_ARGS
|
||||||
${ARROW_CMAKE_ARGS}
|
${ARROW_CMAKE_ARGS}
|
||||||
|
@ -400,21 +372,16 @@ macro(build_arrow)
|
||||||
${MAKE_BUILD_ARGS}
|
${MAKE_BUILD_ARGS}
|
||||||
INSTALL_COMMAND
|
INSTALL_COMMAND
|
||||||
${MAKE} install
|
${MAKE} install
|
||||||
# BUILD_IN_SOURCE
|
|
||||||
# 1
|
|
||||||
BUILD_BYPRODUCTS
|
BUILD_BYPRODUCTS
|
||||||
"${ARROW_STATIC_LIB}"
|
"${ARROW_STATIC_LIB}"
|
||||||
# "${ARROW_CUDA_STATIC_LIB}"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
# ExternalProject_Add_StepDependencies(arrow_ep build thrift_ep)
|
|
||||||
|
|
||||||
file(MAKE_DIRECTORY "${ARROW_PREFIX}/include")
|
file(MAKE_DIRECTORY "${ARROW_PREFIX}/include")
|
||||||
add_library(arrow STATIC IMPORTED)
|
add_library(arrow STATIC IMPORTED)
|
||||||
set_target_properties(arrow
|
set_target_properties(arrow
|
||||||
PROPERTIES IMPORTED_LOCATION "${ARROW_STATIC_LIB}"
|
PROPERTIES IMPORTED_LOCATION "${ARROW_STATIC_LIB}"
|
||||||
INTERFACE_INCLUDE_DIRECTORIES "${ARROW_INCLUDE_DIR}")
|
INTERFACE_INCLUDE_DIRECTORIES "${ARROW_INCLUDE_DIR}")
|
||||||
# INTERFACE_LINK_LIBRARIES thrift)
|
|
||||||
add_dependencies(arrow arrow_ep)
|
add_dependencies(arrow arrow_ep)
|
||||||
|
|
||||||
set(JEMALLOC_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/arrow_ep-prefix/src/arrow_ep-build/jemalloc_ep-prefix/src/jemalloc_ep")
|
set(JEMALLOC_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/arrow_ep-prefix/src/arrow_ep-build/jemalloc_ep-prefix/src/jemalloc_ep")
|
||||||
|
@ -438,9 +405,6 @@ endif()
|
||||||
# Add Boost dependencies (code adapted from Apache Kudu (incubating))
|
# Add Boost dependencies (code adapted from Apache Kudu (incubating))
|
||||||
|
|
||||||
set(Boost_USE_MULTITHREADED ON)
|
set(Boost_USE_MULTITHREADED ON)
|
||||||
if(MSVC AND MILVUS_USE_STATIC_CRT)
|
|
||||||
set(Boost_USE_STATIC_RUNTIME ON)
|
|
||||||
endif()
|
|
||||||
set(Boost_ADDITIONAL_VERSIONS
|
set(Boost_ADDITIONAL_VERSIONS
|
||||||
"1.70.0"
|
"1.70.0"
|
||||||
"1.70"
|
"1.70"
|
||||||
|
@ -530,59 +494,8 @@ if(MILVUS_BOOST_VENDORED)
|
||||||
add_dependencies(boost_filesystem_static boost_ep)
|
add_dependencies(boost_filesystem_static boost_ep)
|
||||||
add_dependencies(boost_serialization_static boost_ep)
|
add_dependencies(boost_serialization_static boost_ep)
|
||||||
|
|
||||||
else()
|
|
||||||
if(MSVC)
|
|
||||||
# disable autolinking in boost
|
|
||||||
add_definitions(-DBOOST_ALL_NO_LIB)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# if(DEFINED ENV{BOOST_ROOT} OR DEFINED BOOST_ROOT)
|
|
||||||
# # In older versions of CMake (such as 3.2), the system paths for Boost will
|
|
||||||
# # be looked in first even if we set $BOOST_ROOT or pass -DBOOST_ROOT
|
|
||||||
# set(Boost_NO_SYSTEM_PATHS ON)
|
|
||||||
# endif()
|
|
||||||
|
|
||||||
if(MILVUS_BOOST_USE_SHARED)
|
|
||||||
# Find shared Boost libraries.
|
|
||||||
set(Boost_USE_STATIC_LIBS OFF)
|
|
||||||
set(BUILD_SHARED_LIBS_KEEP ${BUILD_SHARED_LIBS})
|
|
||||||
set(BUILD_SHARED_LIBS ON)
|
|
||||||
|
|
||||||
if(MSVC)
|
|
||||||
# force all boost libraries to dynamic link
|
|
||||||
add_definitions(-DBOOST_ALL_DYN_LINK)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(MILVUS_BOOST_HEADER_ONLY)
|
|
||||||
find_package(Boost REQUIRED)
|
|
||||||
else()
|
|
||||||
find_package(Boost COMPONENTS serialization system filesystem REQUIRED)
|
|
||||||
set(BOOST_SYSTEM_LIBRARY Boost::system)
|
|
||||||
set(BOOST_FILESYSTEM_LIBRARY Boost::filesystem)
|
|
||||||
set(BOOST_SERIALIZATION_LIBRARY Boost::serialization)
|
|
||||||
set(MILVUS_BOOST_LIBS ${BOOST_SYSTEM_LIBRARY} ${BOOST_FILESYSTEM_LIBRARY})
|
|
||||||
endif()
|
|
||||||
set(BUILD_SHARED_LIBS ${BUILD_SHARED_LIBS_KEEP})
|
|
||||||
unset(BUILD_SHARED_LIBS_KEEP)
|
|
||||||
else()
|
|
||||||
# Find static boost headers and libs
|
|
||||||
# TODO Differentiate here between release and debug builds
|
|
||||||
set(Boost_USE_STATIC_LIBS ON)
|
|
||||||
if(MILVUS_BOOST_HEADER_ONLY)
|
|
||||||
find_package(Boost REQUIRED)
|
|
||||||
else()
|
|
||||||
find_package(Boost COMPONENTS serialization system filesystem REQUIRED)
|
|
||||||
set(BOOST_SYSTEM_LIBRARY Boost::system)
|
|
||||||
set(BOOST_FILESYSTEM_LIBRARY Boost::filesystem)
|
|
||||||
set(BOOST_SERIALIZATION_LIBRARY Boost::serialization)
|
|
||||||
set(MILVUS_BOOST_LIBS ${BOOST_SYSTEM_LIBRARY} ${BOOST_FILESYSTEM_LIBRARY})
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
#message(STATUS "Boost include dir: " ${Boost_INCLUDE_DIR})
|
|
||||||
#message(STATUS "Boost libraries: " ${Boost_LIBRARIES})
|
|
||||||
|
|
||||||
include_directories(SYSTEM ${Boost_INCLUDE_DIR})
|
include_directories(SYSTEM ${Boost_INCLUDE_DIR})
|
||||||
link_directories(SYSTEM ${BOOST_LIB_DIR})
|
link_directories(SYSTEM ${BOOST_LIB_DIR})
|
||||||
|
|
||||||
|
@ -726,13 +639,6 @@ macro(build_openblas)
|
||||||
add_dependencies(openblas openblas_ep)
|
add_dependencies(openblas openblas_ep)
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
#if(MILVUS_WITH_OPENBLAS)
|
|
||||||
# resolve_dependency(OpenBLAS)
|
|
||||||
#
|
|
||||||
# get_target_property(OPENBLAS_INCLUDE_DIR openblas INTERFACE_INCLUDE_DIRECTORIES)
|
|
||||||
# include_directories(SYSTEM "${OPENBLAS_INCLUDE_DIR}")
|
|
||||||
#endif()
|
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
# ----------------------------------------------------------------------
|
||||||
# LAPACK
|
# LAPACK
|
||||||
|
|
||||||
|
@ -770,16 +676,23 @@ macro(build_lapack)
|
||||||
add_dependencies(lapack lapack_ep)
|
add_dependencies(lapack lapack_ep)
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
#if(MILVUS_WITH_LAPACK)
|
|
||||||
# resolve_dependency(LAPACK)
|
|
||||||
#
|
|
||||||
# get_target_property(LAPACK_INCLUDE_DIR lapack INTERFACE_INCLUDE_DIRECTORIES)
|
|
||||||
# include_directories(SYSTEM "${LAPACK_INCLUDE_DIR}")
|
|
||||||
#endif()
|
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
# ----------------------------------------------------------------------
|
||||||
# FAISS
|
# FAISS
|
||||||
|
|
||||||
|
set(BUILD_FAISS_WITH_MKL false)
|
||||||
|
|
||||||
|
if(EXISTS "/proc/cpuinfo")
|
||||||
|
FILE(READ /proc/cpuinfo PROC_CPUINFO)
|
||||||
|
|
||||||
|
SET(VENDOR_ID_RX "vendor_id[ \t]*:[ \t]*([a-zA-Z]+)\n")
|
||||||
|
STRING(REGEX MATCH "${VENDOR_ID_RX}" VENDOR_ID "${PROC_CPUINFO}")
|
||||||
|
STRING(REGEX REPLACE "${VENDOR_ID_RX}" "\\1" VENDOR_ID "${VENDOR_ID}")
|
||||||
|
|
||||||
|
if(${VENDOR_ID} STREQUAL "GenuineIntel")
|
||||||
|
set(BUILD_FAISS_WITH_MKL true)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
macro(build_faiss)
|
macro(build_faiss)
|
||||||
message(STATUS "Building FAISS-${FAISS_VERSION} from source")
|
message(STATUS "Building FAISS-${FAISS_VERSION} from source")
|
||||||
set(FAISS_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/faiss_ep-prefix/src/faiss_ep")
|
set(FAISS_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/faiss_ep-prefix/src/faiss_ep")
|
||||||
|
@ -787,33 +700,35 @@ macro(build_faiss)
|
||||||
set(FAISS_STATIC_LIB
|
set(FAISS_STATIC_LIB
|
||||||
"${FAISS_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}faiss${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
"${FAISS_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}faiss${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
||||||
|
|
||||||
# add_custom_target(faiss_dependencies)
|
|
||||||
# add_dependencies(faiss_dependencies openblas_ep)
|
|
||||||
# add_dependencies(faiss_dependencies openblas)
|
|
||||||
# get_target_property(FAISS_OPENBLAS_LIB_DIR openblas IMPORTED_LOCATION)
|
|
||||||
# get_filename_component(FAISS_OPENBLAS_LIB "${FAISS_OPENBLAS_LIB_DIR}" DIRECTORY)
|
|
||||||
|
|
||||||
set(FAISS_CONFIGURE_ARGS
|
set(FAISS_CONFIGURE_ARGS
|
||||||
"--prefix=${FAISS_PREFIX}"
|
"--prefix=${FAISS_PREFIX}"
|
||||||
"CFLAGS=${EP_C_FLAGS}"
|
"CFLAGS=${EP_C_FLAGS}"
|
||||||
"CXXFLAGS=${EP_CXX_FLAGS}"
|
"CXXFLAGS=${EP_CXX_FLAGS}"
|
||||||
"LDFLAGS=-L${OPENBLAS_PREFIX}/lib -L${LAPACK_PREFIX}/lib -lopenblas -llapack"
|
|
||||||
--without-python)
|
--without-python)
|
||||||
|
|
||||||
# if(OPENBLAS_STATIC_LIB)
|
set(FAISS_CFLAGS ${EP_C_FLAGS})
|
||||||
# set(OPENBLAS_LIBRARY ${OPENBLAS_STATIC_LIB})
|
set(FAISS_CXXFLAGS ${EP_CXX_FLAGS})
|
||||||
# else()
|
|
||||||
# set(OPENBLAS_LIBRARY ${OPENBLAS_SHARED_LIB})
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "true")
|
||||||
# endif()
|
message(STATUS "Build Faiss with MKL")
|
||||||
# set(FAISS_DEPENDENCIES ${FAISS_DEPENDENCIES} ${OPENBLAS_LIBRARY})
|
if(NOT DEFINED MKL_LIB_PATH)
|
||||||
|
set(MKL_LIB_PATH "/opt/intel/compilers_and_libraries_${MKL_VERSION}/linux/mkl/lib/intel64")
|
||||||
|
message(STATUS "MKL_LIB_PATH = ${MKL_LIB_PATH}")
|
||||||
|
endif()
|
||||||
|
set(FAISS_CONFIGURE_ARGS ${FAISS_CONFIGURE_ARGS}
|
||||||
|
"CPPFLAGS=-DMKL_ILP64 -m64 -I${MKL_LIB_PATH}/../../include"
|
||||||
|
"LDFLAGS=-L${MKL_LIB_PATH}"
|
||||||
|
"LIBS=-Wl,--start-group ${MKL_LIB_PATH}/libmkl_intel_ilp64.a ${MKL_LIB_PATH}/libmkl_gnu_thread.a ${MKL_LIB_PATH}/libmkl_core.a -Wl,--end-group -lgomp -lpthread -lm -ldl")
|
||||||
|
|
||||||
|
else()
|
||||||
|
message(STATUS "Build Faiss with OpenBlas/LAPACK")
|
||||||
|
set(FAISS_CONFIGURE_ARGS ${FAISS_CONFIGURE_ARGS}
|
||||||
|
"LDFLAGS=-L${OPENBLAS_PREFIX}/lib -L${LAPACK_PREFIX}/lib")
|
||||||
|
endif()
|
||||||
|
|
||||||
if(${MILVUS_WITH_FAISS_GPU_VERSION} STREQUAL "ON")
|
if(${MILVUS_WITH_FAISS_GPU_VERSION} STREQUAL "ON")
|
||||||
set(FAISS_CONFIGURE_ARGS ${FAISS_CONFIGURE_ARGS}
|
set(FAISS_CONFIGURE_ARGS ${FAISS_CONFIGURE_ARGS}
|
||||||
"--with-cuda=${CUDA_TOOLKIT_ROOT_DIR}"
|
"--with-cuda=${CUDA_TOOLKIT_ROOT_DIR}"
|
||||||
# "with_cuda_arch=\"-gencode=arch=compute_35,code=compute_35 \\
|
|
||||||
# -gencode=arch=compute_52,code=compute_52 \\
|
|
||||||
# -gencode=arch=compute_60,code=compute_60 \\
|
|
||||||
# -gencode=arch=compute_61,code=compute_61\""
|
|
||||||
"--with-cuda-arch=\"-gencode=arch=compute_35,code=compute_35\""
|
"--with-cuda-arch=\"-gencode=arch=compute_35,code=compute_35\""
|
||||||
"--with-cuda-arch=\"-gencode=arch=compute_52,code=compute_52\""
|
"--with-cuda-arch=\"-gencode=arch=compute_52,code=compute_52\""
|
||||||
"--with-cuda-arch=\"-gencode=arch=compute_60,code=compute_60\""
|
"--with-cuda-arch=\"-gencode=arch=compute_60,code=compute_60\""
|
||||||
|
@ -830,58 +745,66 @@ macro(build_faiss)
|
||||||
CONFIGURE_COMMAND
|
CONFIGURE_COMMAND
|
||||||
"./configure"
|
"./configure"
|
||||||
${FAISS_CONFIGURE_ARGS}
|
${FAISS_CONFIGURE_ARGS}
|
||||||
# BINARY_DIR
|
|
||||||
# ${FAISS_PREFIX}
|
|
||||||
# INSTALL_DIR
|
|
||||||
# ${FAISS_PREFIX}
|
|
||||||
# BUILD_COMMAND
|
|
||||||
# ${MAKE} ${MAKE_BUILD_ARGS}
|
|
||||||
BUILD_COMMAND
|
BUILD_COMMAND
|
||||||
${MAKE} ${MAKE_BUILD_ARGS} all
|
${MAKE} ${MAKE_BUILD_ARGS} all
|
||||||
COMMAND
|
COMMAND
|
||||||
cd gpu && ${MAKE} ${MAKE_BUILD_ARGS}
|
cd gpu && ${MAKE} ${MAKE_BUILD_ARGS}
|
||||||
BUILD_IN_SOURCE
|
BUILD_IN_SOURCE
|
||||||
1
|
1
|
||||||
# INSTALL_DIR
|
|
||||||
# ${FAISS_PREFIX}
|
|
||||||
INSTALL_COMMAND
|
INSTALL_COMMAND
|
||||||
${MAKE} install
|
${MAKE} install
|
||||||
COMMAND
|
COMMAND
|
||||||
ln -s faiss_ep ../faiss
|
ln -s faiss_ep ../faiss
|
||||||
BUILD_BYPRODUCTS
|
BUILD_BYPRODUCTS
|
||||||
${FAISS_STATIC_LIB})
|
${FAISS_STATIC_LIB})
|
||||||
# DEPENDS
|
|
||||||
# ${faiss_dependencies})
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "false")
|
||||||
|
ExternalProject_Add_StepDependencies(faiss_ep build openblas_ep lapack_ep)
|
||||||
ExternalProject_Add_StepDependencies(faiss_ep build openblas_ep lapack_ep)
|
endif()
|
||||||
|
|
||||||
file(MAKE_DIRECTORY "${FAISS_INCLUDE_DIR}")
|
file(MAKE_DIRECTORY "${FAISS_INCLUDE_DIR}")
|
||||||
add_library(faiss STATIC IMPORTED)
|
add_library(faiss SHARED IMPORTED)
|
||||||
set_target_properties(
|
|
||||||
faiss
|
|
||||||
PROPERTIES IMPORTED_LOCATION "${FAISS_STATIC_LIB}"
|
|
||||||
INTERFACE_INCLUDE_DIRECTORIES "${FAISS_INCLUDE_DIR}"
|
|
||||||
INTERFACE_LINK_LIBRARIES "openblas;lapack" )
|
|
||||||
|
|
||||||
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "true")
|
||||||
|
set(MKL_LIBS ${MKL_LIB_PATH}/libmkl_intel_ilp64.a
|
||||||
|
${MKL_LIB_PATH}/libmkl_gnu_thread.a
|
||||||
|
${MKL_LIB_PATH}/libmkl_core.a)
|
||||||
|
|
||||||
|
set_target_properties(
|
||||||
|
faiss
|
||||||
|
PROPERTIES IMPORTED_LOCATION "${FAISS_STATIC_LIB}"
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${FAISS_INCLUDE_DIR}"
|
||||||
|
INTERFACE_LINK_LIBRARIES "${MKL_LIBS}" )
|
||||||
|
else()
|
||||||
|
set_target_properties(
|
||||||
|
faiss
|
||||||
|
PROPERTIES IMPORTED_LOCATION "${FAISS_STATIC_LIB}"
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${FAISS_INCLUDE_DIR}"
|
||||||
|
INTERFACE_LINK_LIBRARIES "openblas;lapack" )
|
||||||
|
endif()
|
||||||
|
|
||||||
add_dependencies(faiss faiss_ep)
|
add_dependencies(faiss faiss_ep)
|
||||||
#add_dependencies(faiss openblas_ep)
|
|
||||||
#add_dependencies(faiss lapack_ep)
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "false")
|
||||||
#target_link_libraries(faiss ${OPENBLAS_PREFIX}/lib)
|
add_dependencies(faiss openblas_ep)
|
||||||
#target_link_libraries(faiss ${LAPACK_PREFIX}/lib)
|
add_dependencies(faiss lapack_ep)
|
||||||
|
endif()
|
||||||
|
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
if(MILVUS_WITH_FAISS)
|
if(MILVUS_WITH_FAISS)
|
||||||
|
|
||||||
resolve_dependency(OpenBLAS)
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "false")
|
||||||
get_target_property(OPENBLAS_INCLUDE_DIR openblas INTERFACE_INCLUDE_DIRECTORIES)
|
resolve_dependency(OpenBLAS)
|
||||||
include_directories(SYSTEM "${OPENBLAS_INCLUDE_DIR}")
|
get_target_property(OPENBLAS_INCLUDE_DIR openblas INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
link_directories(SYSTEM ${OPENBLAS_PREFIX}/lib)
|
include_directories(SYSTEM "${OPENBLAS_INCLUDE_DIR}")
|
||||||
|
link_directories(SYSTEM ${OPENBLAS_PREFIX}/lib)
|
||||||
|
|
||||||
resolve_dependency(LAPACK)
|
resolve_dependency(LAPACK)
|
||||||
get_target_property(LAPACK_INCLUDE_DIR lapack INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(LAPACK_INCLUDE_DIR lapack INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
include_directories(SYSTEM "${LAPACK_INCLUDE_DIR}")
|
include_directories(SYSTEM "${LAPACK_INCLUDE_DIR}")
|
||||||
link_directories(SYSTEM "${LAPACK_PREFIX}/lib")
|
link_directories(SYSTEM "${LAPACK_PREFIX}/lib")
|
||||||
|
endif()
|
||||||
|
|
||||||
resolve_dependency(FAISS)
|
resolve_dependency(FAISS)
|
||||||
get_target_property(FAISS_INCLUDE_DIR faiss INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(FAISS_INCLUDE_DIR faiss INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
|
@ -926,8 +849,6 @@ macro(build_gtest)
|
||||||
set(GMOCK_STATIC_LIB
|
set(GMOCK_STATIC_LIB
|
||||||
"${GTEST_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}gmock${CMAKE_STATIC_LIBRARY_SUFFIX}"
|
"${GTEST_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}gmock${CMAKE_STATIC_LIBRARY_SUFFIX}"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
ExternalProject_Add(googletest_ep
|
ExternalProject_Add(googletest_ep
|
||||||
URL
|
URL
|
||||||
${GTEST_SOURCE_URL}
|
${GTEST_SOURCE_URL}
|
||||||
|
@ -967,13 +888,11 @@ macro(build_gtest)
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
if (MILVUS_BUILD_TESTS)
|
if (MILVUS_BUILD_TESTS)
|
||||||
#message(STATUS "Resolving gtest dependency")
|
|
||||||
resolve_dependency(GTest)
|
resolve_dependency(GTest)
|
||||||
|
|
||||||
if(NOT GTEST_VENDORED)
|
if(NOT GTEST_VENDORED)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
get_target_property(GTEST_INCLUDE_DIR gtest INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(GTEST_INCLUDE_DIR gtest INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
link_directories(SYSTEM "${GTEST_PREFIX}/lib")
|
link_directories(SYSTEM "${GTEST_PREFIX}/lib")
|
||||||
include_directories(SYSTEM ${GTEST_INCLUDE_DIR})
|
include_directories(SYSTEM ${GTEST_INCLUDE_DIR})
|
||||||
|
@ -1011,32 +930,8 @@ macro(build_lz4)
|
||||||
set(LZ4_BUILD_DIR "${CMAKE_CURRENT_BINARY_DIR}/lz4_ep-prefix/src/lz4_ep")
|
set(LZ4_BUILD_DIR "${CMAKE_CURRENT_BINARY_DIR}/lz4_ep-prefix/src/lz4_ep")
|
||||||
set(LZ4_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/lz4_ep-prefix/")
|
set(LZ4_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/lz4_ep-prefix/")
|
||||||
|
|
||||||
if(MSVC)
|
set(LZ4_STATIC_LIB "${LZ4_BUILD_DIR}/lib/liblz4.a")
|
||||||
if(MILVUS_USE_STATIC_CRT)
|
set(LZ4_BUILD_COMMAND BUILD_COMMAND ${MAKE} ${MAKE_BUILD_ARGS} CFLAGS=${EP_C_FLAGS})
|
||||||
if(${UPPERCASE_BUILD_TYPE} STREQUAL "DEBUG")
|
|
||||||
set(LZ4_RUNTIME_LIBRARY_LINKAGE "/p:RuntimeLibrary=MultiThreadedDebug")
|
|
||||||
else()
|
|
||||||
set(LZ4_RUNTIME_LIBRARY_LINKAGE "/p:RuntimeLibrary=MultiThreaded")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
set(LZ4_STATIC_LIB
|
|
||||||
"${LZ4_BUILD_DIR}/visual/VS2010/bin/x64_${CMAKE_BUILD_TYPE}/liblz4_static.lib")
|
|
||||||
set(LZ4_BUILD_COMMAND
|
|
||||||
BUILD_COMMAND
|
|
||||||
msbuild.exe
|
|
||||||
/m
|
|
||||||
/p:Configuration=${CMAKE_BUILD_TYPE}
|
|
||||||
/p:Platform=x64
|
|
||||||
/p:PlatformToolset=v140
|
|
||||||
${LZ4_RUNTIME_LIBRARY_LINKAGE}
|
|
||||||
/t:Build
|
|
||||||
${LZ4_BUILD_DIR}/visual/VS2010/lz4.sln)
|
|
||||||
else()
|
|
||||||
set(LZ4_STATIC_LIB "${LZ4_BUILD_DIR}/lib/liblz4.a")
|
|
||||||
#set(LZ4_BUILD_COMMAND BUILD_COMMAND ${CMAKE_SOURCE_DIR}/build-support/build-lz4-lib.sh
|
|
||||||
# "AR=${CMAKE_AR}")
|
|
||||||
set(LZ4_BUILD_COMMAND BUILD_COMMAND ${MAKE} ${MAKE_BUILD_ARGS} CFLAGS=${EP_C_FLAGS})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# We need to copy the header in lib to directory outside of the build
|
# We need to copy the header in lib to directory outside of the build
|
||||||
externalproject_add(lz4_ep
|
externalproject_add(lz4_ep
|
||||||
|
@ -1071,7 +966,6 @@ endmacro()
|
||||||
if(MILVUS_WITH_LZ4)
|
if(MILVUS_WITH_LZ4)
|
||||||
resolve_dependency(Lz4)
|
resolve_dependency(Lz4)
|
||||||
|
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
get_target_property(LZ4_INCLUDE_DIR lz4 INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(LZ4_INCLUDE_DIR lz4 INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
link_directories(SYSTEM ${LZ4_BUILD_DIR}/lib/)
|
link_directories(SYSTEM ${LZ4_BUILD_DIR}/lib/)
|
||||||
include_directories(SYSTEM ${LZ4_INCLUDE_DIR})
|
include_directories(SYSTEM ${LZ4_INCLUDE_DIR})
|
||||||
|
@ -1097,16 +991,8 @@ macro(build_mysqlpp)
|
||||||
externalproject_add(mysqlpp_ep
|
externalproject_add(mysqlpp_ep
|
||||||
URL
|
URL
|
||||||
${MYSQLPP_SOURCE_URL}
|
${MYSQLPP_SOURCE_URL}
|
||||||
# GIT_REPOSITORY
|
|
||||||
# ${MYSQLPP_SOURCE_URL}
|
|
||||||
# GIT_TAG
|
|
||||||
# ${MYSQLPP_VERSION}
|
|
||||||
# GIT_SHALLOW
|
|
||||||
# TRUE
|
|
||||||
${EP_LOG_OPTIONS}
|
${EP_LOG_OPTIONS}
|
||||||
CONFIGURE_COMMAND
|
CONFIGURE_COMMAND
|
||||||
# "./bootstrap"
|
|
||||||
# COMMAND
|
|
||||||
"./configure"
|
"./configure"
|
||||||
${MYSQLPP_CONFIGURE_ARGS}
|
${MYSQLPP_CONFIGURE_ARGS}
|
||||||
BUILD_COMMAND
|
BUILD_COMMAND
|
||||||
|
@ -1167,10 +1053,6 @@ macro(build_prometheus)
|
||||||
${PROMETHEUS_VERSION}
|
${PROMETHEUS_VERSION}
|
||||||
GIT_SHALLOW
|
GIT_SHALLOW
|
||||||
TRUE
|
TRUE
|
||||||
# GIT_CONFIG
|
|
||||||
# recurse-submodules=true
|
|
||||||
# URL
|
|
||||||
# ${PROMETHEUS_SOURCE_URL}
|
|
||||||
${EP_LOG_OPTIONS}
|
${EP_LOG_OPTIONS}
|
||||||
CMAKE_ARGS
|
CMAKE_ARGS
|
||||||
${PROMETHEUS_CMAKE_ARGS}
|
${PROMETHEUS_CMAKE_ARGS}
|
||||||
|
@ -1214,21 +1096,15 @@ if(MILVUS_WITH_PROMETHEUS)
|
||||||
|
|
||||||
resolve_dependency(Prometheus)
|
resolve_dependency(Prometheus)
|
||||||
|
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
#get_target_property(PROMETHEUS-core_INCLUDE_DIRS prometheus-core INTERFACE_INCLUDE_DIRECTORIES)
|
|
||||||
|
|
||||||
#get_target_property(PROMETHEUS_PUSH_INCLUDE_DIRS prometheus_push INTERFACE_INCLUDE_DIRECTORIES)
|
|
||||||
link_directories(SYSTEM ${PROMETHEUS_PREFIX}/push/)
|
link_directories(SYSTEM ${PROMETHEUS_PREFIX}/push/)
|
||||||
include_directories(SYSTEM ${PROMETHEUS_PREFIX}/push/include)
|
include_directories(SYSTEM ${PROMETHEUS_PREFIX}/push/include)
|
||||||
|
|
||||||
#get_target_property(PROMETHEUS_PULL_INCLUDE_DIRS prometheus_pull INTERFACE_INCLUDE_DIRECTORIES)
|
|
||||||
link_directories(SYSTEM ${PROMETHEUS_PREFIX}/pull/)
|
link_directories(SYSTEM ${PROMETHEUS_PREFIX}/pull/)
|
||||||
include_directories(SYSTEM ${PROMETHEUS_PREFIX}/pull/include)
|
include_directories(SYSTEM ${PROMETHEUS_PREFIX}/pull/include)
|
||||||
|
|
||||||
link_directories(SYSTEM ${PROMETHEUS_PREFIX}/core/)
|
link_directories(SYSTEM ${PROMETHEUS_PREFIX}/core/)
|
||||||
include_directories(SYSTEM ${PROMETHEUS_PREFIX}/core/include)
|
include_directories(SYSTEM ${PROMETHEUS_PREFIX}/core/include)
|
||||||
|
|
||||||
#link_directories(${PROMETHEUS_PREFIX}/civetweb_ep-prefix/src/civetweb_ep)
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
# ----------------------------------------------------------------------
|
||||||
|
@ -1276,8 +1152,6 @@ if(MILVUS_WITH_ROCKSDB)
|
||||||
|
|
||||||
resolve_dependency(RocksDB)
|
resolve_dependency(RocksDB)
|
||||||
|
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
# get_target_property(ROCKSDB_INCLUDE_DIRS rocksdb INTERFACE_INCLUDE_DIRECTORIES)
|
|
||||||
link_directories(SYSTEM ${ROCKSDB_PREFIX}/lib/lib/)
|
link_directories(SYSTEM ${ROCKSDB_PREFIX}/lib/lib/)
|
||||||
include_directories(SYSTEM ${ROCKSDB_INCLUDE_DIRS})
|
include_directories(SYSTEM ${ROCKSDB_INCLUDE_DIRS})
|
||||||
endif()
|
endif()
|
||||||
|
@ -1326,34 +1200,9 @@ macro(build_snappy)
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
if(MILVUS_WITH_SNAPPY)
|
if(MILVUS_WITH_SNAPPY)
|
||||||
# if(Snappy_SOURCE STREQUAL "AUTO")
|
|
||||||
# # Normally *Config.cmake files reside in /usr/lib/cmake but Snappy
|
|
||||||
# # errornously places them in ${CMAKE_ROOT}/Modules/
|
|
||||||
# # This is fixed in 1.1.7 but fedora (30) still installs into the wrong
|
|
||||||
# # location.
|
|
||||||
# # https://bugzilla.redhat.com/show_bug.cgi?id=1679727
|
|
||||||
# # https://src.fedoraproject.org/rpms/snappy/pull-request/1
|
|
||||||
# find_package(Snappy QUIET HINTS "${CMAKE_ROOT}/Modules/")
|
|
||||||
# if(NOT Snappy_FOUND)
|
|
||||||
# find_package(SnappyAlt)
|
|
||||||
# endif()
|
|
||||||
# if(NOT Snappy_FOUND AND NOT SnappyAlt_FOUND)
|
|
||||||
# build_snappy()
|
|
||||||
# endif()
|
|
||||||
# elseif(Snappy_SOURCE STREQUAL "BUNDLED")
|
|
||||||
# build_snappy()
|
|
||||||
# elseif(Snappy_SOURCE STREQUAL "SYSTEM")
|
|
||||||
# # SnappyConfig.cmake is not installed on Ubuntu/Debian
|
|
||||||
# # TODO: Make a bug report upstream
|
|
||||||
# find_package(Snappy HINTS "${CMAKE_ROOT}/Modules/")
|
|
||||||
# if(NOT Snappy_FOUND)
|
|
||||||
# find_package(SnappyAlt REQUIRED)
|
|
||||||
# endif()
|
|
||||||
# endif()
|
|
||||||
|
|
||||||
resolve_dependency(Snappy)
|
resolve_dependency(Snappy)
|
||||||
|
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
get_target_property(SNAPPY_INCLUDE_DIRS snappy INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(SNAPPY_INCLUDE_DIRS snappy INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
link_directories(SYSTEM ${SNAPPY_PREFIX}/lib/)
|
link_directories(SYSTEM ${SNAPPY_PREFIX}/lib/)
|
||||||
include_directories(SYSTEM ${SNAPPY_INCLUDE_DIRS})
|
include_directories(SYSTEM ${SNAPPY_INCLUDE_DIRS})
|
||||||
|
@ -1425,75 +1274,11 @@ macro(build_sqlite_orm)
|
||||||
|
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
#set(SQLITE_ORM_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/sqlite_orm_ep-prefix/src/sqlite_orm_ep")
|
|
||||||
#set(SQLITE_ORM_INCLUDE_DIR "${SQLITE_ORM_PREFIX}/include/sqlite_orm")
|
|
||||||
|
|
||||||
# set(SQLITE_ORM_STATIC_LIB
|
|
||||||
# "${SQLITE_ORM_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}sqlite_orm${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
|
||||||
#
|
|
||||||
# set(SQLITE_ORM_CMAKE_CXX_FLAGS "${EP_CXX_FLAGS} -std=c++14")
|
|
||||||
# set(SQLITE_ORM_CMAKE_CXX_FLAGS_DEBUG "${EP_CXX_FLAGS} -std=c++14")
|
|
||||||
#
|
|
||||||
# set(SQLITE_ORM_CMAKE_ARGS
|
|
||||||
# ${EP_COMMON_CMAKE_ARGS}
|
|
||||||
# "-DCMAKE_INSTALL_PREFIX=${SQLITE_ORM_PREFIX}"
|
|
||||||
# #"LDFLAGS=-L${SQLITE_PREFIX}"
|
|
||||||
# #"-DCMAKE_PREFIX_PATH=${SQLITE_PREFIX}/include"
|
|
||||||
# "-DCMAKE_INCLUDE_PATH=${SQLITE_PREFIX}/include"
|
|
||||||
# "-DCMAKE_CXX_FLAGS=${SQLITE_ORM_CMAKE_CXX_FLAGS}"
|
|
||||||
# "-DCMAKE_CXX_FLAGS_DEBUG=${SQLITE_ORM_CMAKE_CXX_FLAGS}"
|
|
||||||
# -DSqliteOrm_BuildTests=off
|
|
||||||
# -DBUILD_TESTING=off)
|
|
||||||
# message(STATUS "SQLITE_INCLUDE: ${SQLITE_ORM_CMAKE_ARGS}")
|
|
||||||
#
|
|
||||||
# message(STATUS "SQLITE_ORM_CMAKE_CXX_FLAGS: ${SQLITE_ORM_CMAKE_CXX_FLAGS}")
|
|
||||||
|
|
||||||
# externalproject_add(sqlite_orm_ep
|
|
||||||
# URL
|
|
||||||
# ${SQLITE_ORM_SOURCE_URL}
|
|
||||||
# PREFIX ${CMAKE_CURRENT_BINARY_DIR}/sqlite_orm_ep-prefix
|
|
||||||
# CONFIGURE_COMMAND
|
|
||||||
# ""
|
|
||||||
# BUILD_COMMAND
|
|
||||||
# ""
|
|
||||||
# INSTALL_COMMAND
|
|
||||||
# ""
|
|
||||||
#${EP_LOG_OPTIONS}
|
|
||||||
#${EP_LOG_OPTIONS}
|
|
||||||
# CMAKE_ARGS
|
|
||||||
# ${SQLITE_ORM_CMAKE_ARGS}
|
|
||||||
# BUILD_COMMAND
|
|
||||||
# ${MAKE}
|
|
||||||
# ${MAKE_BUILD_ARGS}
|
|
||||||
# #"LDFLAGS=-L${SQLITE_PREFIX}"
|
|
||||||
# BUILD_IN_SOURCE
|
|
||||||
# 1
|
|
||||||
# BUILD_BYPRODUCTS
|
|
||||||
# "${SQLITE_ORM_STATIC_LIB}"
|
|
||||||
# )
|
|
||||||
# ExternalProject_Add_StepDependencies(sqlite_orm_ep build sqlite_ep)
|
|
||||||
|
|
||||||
#set(SQLITE_ORM_SQLITE_HEADER ${SQLITE_INCLUDE_DIR}/sqlite3.h)
|
|
||||||
# file(MAKE_DIRECTORY "${SQLITE_ORM_INCLUDE_DIR}")
|
|
||||||
# add_library(sqlite_orm STATIC IMPORTED)
|
|
||||||
## message(STATUS "SQLITE_INCLUDE_DIR: ${SQLITE_INCLUDE_DIR}")
|
|
||||||
# set_target_properties(
|
|
||||||
# sqlite_orm
|
|
||||||
# PROPERTIES
|
|
||||||
# IMPORTED_LOCATION "${SQLITE_ORM_STATIC_LIB}"
|
|
||||||
# INTERFACE_INCLUDE_DIRECTORIES "${SQLITE_ORM_INCLUDE_DIR};${SQLITE_INCLUDE_DIR}")
|
|
||||||
# target_include_directories(sqlite_orm INTERFACE ${SQLITE_PREFIX} ${SQLITE_INCLUDE_DIR})
|
|
||||||
# target_link_libraries(sqlite_orm INTERFACE sqlite)
|
|
||||||
#
|
|
||||||
# add_dependencies(sqlite_orm sqlite_orm_ep)
|
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
if(MILVUS_WITH_SQLITE_ORM)
|
if(MILVUS_WITH_SQLITE_ORM)
|
||||||
resolve_dependency(SQLite_ORM)
|
resolve_dependency(SQLite_ORM)
|
||||||
# ExternalProject_Get_Property(sqlite_orm_ep source_dir)
|
|
||||||
# set(SQLITE_ORM_INCLUDE_DIR ${source_dir}/sqlite_orm_ep)
|
|
||||||
include_directories(SYSTEM "${SQLITE_ORM_INCLUDE_DIR}")
|
include_directories(SYSTEM "${SQLITE_ORM_INCLUDE_DIR}")
|
||||||
#message(STATUS "SQLITE_ORM_INCLUDE_DIR: ${SQLITE_ORM_INCLUDE_DIR}")
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
# ----------------------------------------------------------------------
|
||||||
|
@ -1533,18 +1318,7 @@ macro(build_thrift)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(THRIFT_STATIC_LIB_NAME "${CMAKE_STATIC_LIBRARY_PREFIX}thrift")
|
set(THRIFT_STATIC_LIB_NAME "${CMAKE_STATIC_LIBRARY_PREFIX}thrift")
|
||||||
if(MSVC)
|
|
||||||
if(MILVUS_USE_STATIC_CRT)
|
|
||||||
set(THRIFT_STATIC_LIB_NAME "${THRIFT_STATIC_LIB_NAME}")
|
|
||||||
set(THRIFT_CMAKE_ARGS ${THRIFT_CMAKE_ARGS} "-DWITH_MT=ON")
|
|
||||||
else()
|
|
||||||
set(THRIFT_STATIC_LIB_NAME "${THRIFT_STATIC_LIB_NAME}")
|
|
||||||
set(THRIFT_CMAKE_ARGS ${THRIFT_CMAKE_ARGS} "-DWITH_MT=OFF")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
if(${UPPERCASE_BUILD_TYPE} STREQUAL "DEBUG")
|
|
||||||
set(THRIFT_STATIC_LIB_NAME "${THRIFT_STATIC_LIB_NAME}")
|
|
||||||
endif()
|
|
||||||
set(THRIFT_STATIC_LIB
|
set(THRIFT_STATIC_LIB
|
||||||
"${THRIFT_PREFIX}/lib/${THRIFT_STATIC_LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
"${THRIFT_PREFIX}/lib/${THRIFT_STATIC_LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
||||||
|
|
||||||
|
@ -1555,60 +1329,6 @@ macro(build_thrift)
|
||||||
endif()
|
endif()
|
||||||
set(THRIFT_DEPENDENCIES ${THRIFT_DEPENDENCIES} ${ZLIB_LIBRARY})
|
set(THRIFT_DEPENDENCIES ${THRIFT_DEPENDENCIES} ${ZLIB_LIBRARY})
|
||||||
|
|
||||||
if(MSVC)
|
|
||||||
set(WINFLEXBISON_VERSION 2.4.9)
|
|
||||||
set(WINFLEXBISON_PREFIX
|
|
||||||
"${CMAKE_CURRENT_BINARY_DIR}/winflexbison_ep/src/winflexbison_ep-install")
|
|
||||||
externalproject_add(
|
|
||||||
winflexbison_ep
|
|
||||||
URL
|
|
||||||
https://github.com/lexxmark/winflexbison/releases/download/v.${WINFLEXBISON_VERSION}/win_flex_bison-${WINFLEXBISON_VERSION}.zip
|
|
||||||
URL_HASH
|
|
||||||
MD5=a2e979ea9928fbf8567e995e9c0df765
|
|
||||||
SOURCE_DIR
|
|
||||||
${WINFLEXBISON_PREFIX}
|
|
||||||
CONFIGURE_COMMAND
|
|
||||||
""
|
|
||||||
BUILD_COMMAND
|
|
||||||
""
|
|
||||||
INSTALL_COMMAND
|
|
||||||
""
|
|
||||||
${EP_LOG_OPTIONS})
|
|
||||||
set(THRIFT_DEPENDENCIES ${THRIFT_DEPENDENCIES} winflexbison_ep)
|
|
||||||
|
|
||||||
set(THRIFT_CMAKE_ARGS
|
|
||||||
"-DFLEX_EXECUTABLE=${WINFLEXBISON_PREFIX}/win_flex.exe"
|
|
||||||
"-DBISON_EXECUTABLE=${WINFLEXBISON_PREFIX}/win_bison.exe"
|
|
||||||
"-DZLIB_INCLUDE_DIR=${ZLIB_INCLUDE_DIR}"
|
|
||||||
"-DWITH_SHARED_LIB=OFF"
|
|
||||||
"-DWITH_PLUGIN=OFF"
|
|
||||||
${THRIFT_CMAKE_ARGS})
|
|
||||||
elseif(APPLE)
|
|
||||||
# Some other process always resets BISON_EXECUTABLE to the system default,
|
|
||||||
# thus we use our own variable here.
|
|
||||||
if(NOT DEFINED THRIFT_BISON_EXECUTABLE)
|
|
||||||
find_package(BISON 2.5.1)
|
|
||||||
|
|
||||||
# In the case where we cannot find a system-wide installation, look for
|
|
||||||
# homebrew and ask for its bison installation.
|
|
||||||
if(NOT BISON_FOUND)
|
|
||||||
find_program(BREW_BIN brew)
|
|
||||||
if(BREW_BIN)
|
|
||||||
execute_process(COMMAND ${BREW_BIN} --prefix bison
|
|
||||||
OUTPUT_VARIABLE BISON_PREFIX
|
|
||||||
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
||||||
set(BISON_EXECUTABLE "${BISON_PREFIX}/bin/bison")
|
|
||||||
find_package(BISON 2.5.1)
|
|
||||||
set(THRIFT_BISON_EXECUTABLE "${BISON_EXECUTABLE}")
|
|
||||||
endif()
|
|
||||||
else()
|
|
||||||
set(THRIFT_BISON_EXECUTABLE "${BISON_EXECUTABLE}")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
set(THRIFT_CMAKE_ARGS "-DBISON_EXECUTABLE=${THRIFT_BISON_EXECUTABLE}"
|
|
||||||
${THRIFT_CMAKE_ARGS})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
externalproject_add(thrift_ep
|
externalproject_add(thrift_ep
|
||||||
URL
|
URL
|
||||||
${THRIFT_SOURCE_URL}
|
${THRIFT_SOURCE_URL}
|
||||||
|
@ -1637,8 +1357,7 @@ endmacro()
|
||||||
|
|
||||||
if(MILVUS_WITH_THRIFT)
|
if(MILVUS_WITH_THRIFT)
|
||||||
resolve_dependency(Thrift)
|
resolve_dependency(Thrift)
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
# MESSAGE(STATUS ${THRIFT_PREFIX}/lib/)
|
|
||||||
link_directories(SYSTEM ${THRIFT_PREFIX}/lib/)
|
link_directories(SYSTEM ${THRIFT_PREFIX}/lib/)
|
||||||
link_directories(SYSTEM ${CMAKE_CURRENT_BINARY_DIR}/thrift_ep-prefix/src/thrift_ep-build/lib)
|
link_directories(SYSTEM ${CMAKE_CURRENT_BINARY_DIR}/thrift_ep-prefix/src/thrift_ep-build/lib)
|
||||||
include_directories(SYSTEM ${THRIFT_INCLUDE_DIR})
|
include_directories(SYSTEM ${THRIFT_INCLUDE_DIR})
|
||||||
|
@ -1684,8 +1403,7 @@ endmacro()
|
||||||
|
|
||||||
if(MILVUS_WITH_YAMLCPP)
|
if(MILVUS_WITH_YAMLCPP)
|
||||||
resolve_dependency(yaml-cpp)
|
resolve_dependency(yaml-cpp)
|
||||||
|
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
get_target_property(YAMLCPP_INCLUDE_DIR yaml-cpp INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(YAMLCPP_INCLUDE_DIR yaml-cpp INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
link_directories(SYSTEM ${YAMLCPP_PREFIX}/lib/)
|
link_directories(SYSTEM ${YAMLCPP_PREFIX}/lib/)
|
||||||
include_directories(SYSTEM ${YAMLCPP_INCLUDE_DIR})
|
include_directories(SYSTEM ${YAMLCPP_INCLUDE_DIR})
|
||||||
|
@ -1697,15 +1415,7 @@ endif()
|
||||||
macro(build_zlib)
|
macro(build_zlib)
|
||||||
message(STATUS "Building ZLIB-${ZLIB_VERSION} from source")
|
message(STATUS "Building ZLIB-${ZLIB_VERSION} from source")
|
||||||
set(ZLIB_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/zlib_ep-prefix/src/zlib_ep")
|
set(ZLIB_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/zlib_ep-prefix/src/zlib_ep")
|
||||||
if(MSVC)
|
set(ZLIB_STATIC_LIB_NAME libz.a)
|
||||||
if(${UPPERCASE_BUILD_TYPE} STREQUAL "DEBUG")
|
|
||||||
set(ZLIB_STATIC_LIB_NAME zlibstaticd.lib)
|
|
||||||
else()
|
|
||||||
set(ZLIB_STATIC_LIB_NAME zlibstatic.lib)
|
|
||||||
endif()
|
|
||||||
else()
|
|
||||||
set(ZLIB_STATIC_LIB_NAME libz.a)
|
|
||||||
endif()
|
|
||||||
set(ZLIB_STATIC_LIB "${ZLIB_PREFIX}/lib/${ZLIB_STATIC_LIB_NAME}")
|
set(ZLIB_STATIC_LIB "${ZLIB_PREFIX}/lib/${ZLIB_STATIC_LIB_NAME}")
|
||||||
set(ZLIB_CMAKE_ARGS ${EP_COMMON_CMAKE_ARGS} "-DCMAKE_INSTALL_PREFIX=${ZLIB_PREFIX}"
|
set(ZLIB_CMAKE_ARGS ${EP_COMMON_CMAKE_ARGS} "-DCMAKE_INSTALL_PREFIX=${ZLIB_PREFIX}"
|
||||||
-DBUILD_SHARED_LIBS=OFF)
|
-DBUILD_SHARED_LIBS=OFF)
|
||||||
|
@ -1734,8 +1444,7 @@ endmacro()
|
||||||
|
|
||||||
if(MILVUS_WITH_ZLIB)
|
if(MILVUS_WITH_ZLIB)
|
||||||
resolve_dependency(ZLIB)
|
resolve_dependency(ZLIB)
|
||||||
|
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
get_target_property(ZLIB_INCLUDE_DIR zlib INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(ZLIB_INCLUDE_DIR zlib INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
include_directories(SYSTEM ${ZLIB_INCLUDE_DIR})
|
include_directories(SYSTEM ${ZLIB_INCLUDE_DIR})
|
||||||
endif()
|
endif()
|
||||||
|
@ -1757,22 +1466,15 @@ macro(build_zstd)
|
||||||
-DZSTD_BUILD_STATIC=on
|
-DZSTD_BUILD_STATIC=on
|
||||||
-DZSTD_MULTITHREAD_SUPPORT=off)
|
-DZSTD_MULTITHREAD_SUPPORT=off)
|
||||||
|
|
||||||
if(MSVC)
|
|
||||||
set(ZSTD_STATIC_LIB "${ZSTD_PREFIX}/lib/zstd_static.lib")
|
set(ZSTD_STATIC_LIB "${ZSTD_PREFIX}/lib/libzstd.a")
|
||||||
if(MILVUS_USE_STATIC_CRT)
|
|
||||||
set(ZSTD_CMAKE_ARGS ${ZSTD_CMAKE_ARGS} "-DZSTD_USE_STATIC_RUNTIME=on")
|
set(ZSTD_CMAKE_ARGS
|
||||||
endif()
|
${ZSTD_CMAKE_ARGS}
|
||||||
else()
|
-DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}
|
||||||
set(ZSTD_STATIC_LIB "${ZSTD_PREFIX}/lib/libzstd.a")
|
-DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}
|
||||||
# Only pass our C flags on Unix as on MSVC it leads to a
|
-DCMAKE_C_FLAGS=${EP_C_FLAGS}
|
||||||
# "incompatible command-line options" error
|
-DCMAKE_CXX_FLAGS=${EP_CXX_FLAGS})
|
||||||
set(ZSTD_CMAKE_ARGS
|
|
||||||
${ZSTD_CMAKE_ARGS}
|
|
||||||
-DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}
|
|
||||||
-DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}
|
|
||||||
-DCMAKE_C_FLAGS=${EP_C_FLAGS}
|
|
||||||
-DCMAKE_CXX_FLAGS=${EP_CXX_FLAGS})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(CMAKE_VERSION VERSION_LESS 3.7)
|
if(CMAKE_VERSION VERSION_LESS 3.7)
|
||||||
message(FATAL_ERROR "Building zstd using ExternalProject requires at least CMake 3.7")
|
message(FATAL_ERROR "Building zstd using ExternalProject requires at least CMake 3.7")
|
||||||
|
@ -1806,8 +1508,7 @@ endmacro()
|
||||||
|
|
||||||
if(MILVUS_WITH_ZSTD)
|
if(MILVUS_WITH_ZSTD)
|
||||||
resolve_dependency(ZSTD)
|
resolve_dependency(ZSTD)
|
||||||
|
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
get_target_property(ZSTD_INCLUDE_DIR zstd INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(ZSTD_INCLUDE_DIR zstd INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
link_directories(SYSTEM ${ZSTD_PREFIX}/lib)
|
link_directories(SYSTEM ${ZSTD_PREFIX}/lib)
|
||||||
include_directories(SYSTEM ${ZSTD_INCLUDE_DIR})
|
include_directories(SYSTEM ${ZSTD_INCLUDE_DIR})
|
||||||
|
@ -1823,7 +1524,7 @@ macro(build_aws)
|
||||||
${EP_COMMON_TOOLCHAIN}
|
${EP_COMMON_TOOLCHAIN}
|
||||||
"-DCMAKE_INSTALL_PREFIX=${AWS_PREFIX}"
|
"-DCMAKE_INSTALL_PREFIX=${AWS_PREFIX}"
|
||||||
-DCMAKE_BUILD_TYPE=Release
|
-DCMAKE_BUILD_TYPE=Release
|
||||||
-DCMAKE_INSTALL_LIBDIR=lib #${CMAKE_INSTALL_LIBDIR}
|
-DCMAKE_INSTALL_LIBDIR=lib
|
||||||
-DBUILD_ONLY=s3
|
-DBUILD_ONLY=s3
|
||||||
-DBUILD_SHARED_LIBS=off
|
-DBUILD_SHARED_LIBS=off
|
||||||
-DENABLE_TESTING=off
|
-DENABLE_TESTING=off
|
||||||
|
@ -1834,8 +1535,7 @@ macro(build_aws)
|
||||||
"${AWS_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}aws-cpp-sdk-core${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
"${AWS_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}aws-cpp-sdk-core${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
||||||
set(AWS_CPP_SDK_S3_STATIC_LIB
|
set(AWS_CPP_SDK_S3_STATIC_LIB
|
||||||
"${AWS_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}aws-cpp-sdk-s3${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
"${AWS_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}aws-cpp-sdk-s3${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
||||||
# Only pass our C flags on Unix as on MSVC it leads to a
|
|
||||||
# "incompatible command-line options" error
|
|
||||||
set(AWS_CMAKE_ARGS
|
set(AWS_CMAKE_ARGS
|
||||||
${AWS_CMAKE_ARGS}
|
${AWS_CMAKE_ARGS}
|
||||||
-DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}
|
-DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}
|
||||||
|
@ -1843,10 +1543,6 @@ macro(build_aws)
|
||||||
-DCMAKE_C_FLAGS=${EP_C_FLAGS}
|
-DCMAKE_C_FLAGS=${EP_C_FLAGS}
|
||||||
-DCMAKE_CXX_FLAGS=${EP_CXX_FLAGS})
|
-DCMAKE_CXX_FLAGS=${EP_CXX_FLAGS})
|
||||||
|
|
||||||
if(CMAKE_VERSION VERSION_LESS 3.7)
|
|
||||||
message(FATAL_ERROR "Building AWS using ExternalProject requires at least CMake 3.7")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
externalproject_add(aws_ep
|
externalproject_add(aws_ep
|
||||||
${EP_LOG_OPTIONS}
|
${EP_LOG_OPTIONS}
|
||||||
CMAKE_ARGS
|
CMAKE_ARGS
|
||||||
|
@ -1861,8 +1557,6 @@ macro(build_aws)
|
||||||
BUILD_BYPRODUCTS
|
BUILD_BYPRODUCTS
|
||||||
"${AWS_CPP_SDK_S3_STATIC_LIB}"
|
"${AWS_CPP_SDK_S3_STATIC_LIB}"
|
||||||
"${AWS_CPP_SDK_CORE_STATIC_LIB}")
|
"${AWS_CPP_SDK_CORE_STATIC_LIB}")
|
||||||
|
|
||||||
|
|
||||||
file(MAKE_DIRECTORY "${AWS_PREFIX}/include")
|
file(MAKE_DIRECTORY "${AWS_PREFIX}/include")
|
||||||
|
|
||||||
add_library(aws-cpp-sdk-s3 STATIC IMPORTED)
|
add_library(aws-cpp-sdk-s3 STATIC IMPORTED)
|
||||||
|
@ -1885,8 +1579,7 @@ endmacro()
|
||||||
|
|
||||||
if(MILVUS_WITH_AWS)
|
if(MILVUS_WITH_AWS)
|
||||||
resolve_dependency(AWS)
|
resolve_dependency(AWS)
|
||||||
|
|
||||||
# TODO: Don't use global includes but rather target_include_directories
|
|
||||||
link_directories(SYSTEM ${AWS_PREFIX}/lib)
|
link_directories(SYSTEM ${AWS_PREFIX}/lib)
|
||||||
|
|
||||||
get_target_property(AWS_CPP_SDK_S3_INCLUDE_DIR aws-cpp-sdk-s3 INTERFACE_INCLUDE_DIRECTORIES)
|
get_target_property(AWS_CPP_SDK_S3_INCLUDE_DIR aws-cpp-sdk-s3 INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
wget -P /tmp https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS-2019.PUB
|
||||||
|
apt-key add /tmp/GPG-PUB-KEY-INTEL-SW-PRODUCTS-2019.PUB
|
||||||
|
|
||||||
|
sh -c 'echo deb https://apt.repos.intel.com/mkl all main > /etc/apt/sources.list.d/intel-mkl.list'
|
||||||
|
apt -y update && apt-get -y install intel-mkl-gnu-2019.4-243 intel-mkl-core-2019.4-243
|
||||||
|
|
||||||
|
#sh -c 'echo export LD_LIBRARY_PATH=/opt/intel/compilers_and_libraries_2019.4.243/linux/mkl/lib/intel64:\$LD_LIBRARY_PATH > /etc/profile.d/mkl.sh'
|
||||||
|
#source /etc/profile
|
|
@ -48,7 +48,6 @@ set(engine_files
|
||||||
${db_files}
|
${db_files}
|
||||||
${db_scheduler_files}
|
${db_scheduler_files}
|
||||||
${wrapper_files}
|
${wrapper_files}
|
||||||
# metrics/Metrics.cpp
|
|
||||||
${metrics_files}
|
${metrics_files}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -71,8 +70,6 @@ set(third_party_libs
|
||||||
yaml-cpp
|
yaml-cpp
|
||||||
libgpufaiss.a
|
libgpufaiss.a
|
||||||
faiss
|
faiss
|
||||||
lapack
|
|
||||||
openblas
|
|
||||||
prometheus-cpp-push
|
prometheus-cpp-push
|
||||||
prometheus-cpp-pull
|
prometheus-cpp-pull
|
||||||
prometheus-cpp-core
|
prometheus-cpp-core
|
||||||
|
@ -87,9 +84,19 @@ set(third_party_libs
|
||||||
mysqlpp
|
mysqlpp
|
||||||
${CUDA_TOOLKIT_ROOT_DIR}/lib64/stubs/libnvidia-ml.so
|
${CUDA_TOOLKIT_ROOT_DIR}/lib64/stubs/libnvidia-ml.so
|
||||||
)
|
)
|
||||||
|
|
||||||
if (MEGASEARCH_WITH_ARROW STREQUAL "ON")
|
if (MEGASEARCH_WITH_ARROW STREQUAL "ON")
|
||||||
set(third_party_libs ${third_party_libs} arrow)
|
set(third_party_libs ${third_party_libs} arrow)
|
||||||
endif()
|
endif()
|
||||||
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "true")
|
||||||
|
set(third_party_libs ${third_party_libs}
|
||||||
|
${MKL_LIBS}
|
||||||
|
${MKL_LIBS})
|
||||||
|
else()
|
||||||
|
set(third_party_libs ${third_party_libs}
|
||||||
|
lapack
|
||||||
|
openblas)
|
||||||
|
endif()
|
||||||
|
|
||||||
if (GPU_VERSION STREQUAL "ON")
|
if (GPU_VERSION STREQUAL "ON")
|
||||||
link_directories("${CUDA_TOOLKIT_ROOT_DIR}/lib64")
|
link_directories("${CUDA_TOOLKIT_ROOT_DIR}/lib64")
|
||||||
|
@ -187,6 +194,6 @@ install(FILES
|
||||||
${CMAKE_BINARY_DIR}/mysqlpp_ep-prefix/src/mysqlpp_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}mysqlpp${CMAKE_SHARED_LIBRARY_SUFFIX}
|
${CMAKE_BINARY_DIR}/mysqlpp_ep-prefix/src/mysqlpp_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}mysqlpp${CMAKE_SHARED_LIBRARY_SUFFIX}
|
||||||
${CMAKE_BINARY_DIR}/mysqlpp_ep-prefix/src/mysqlpp_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}mysqlpp${CMAKE_SHARED_LIBRARY_SUFFIX}.3
|
${CMAKE_BINARY_DIR}/mysqlpp_ep-prefix/src/mysqlpp_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}mysqlpp${CMAKE_SHARED_LIBRARY_SUFFIX}.3
|
||||||
${CMAKE_BINARY_DIR}/mysqlpp_ep-prefix/src/mysqlpp_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}mysqlpp${CMAKE_SHARED_LIBRARY_SUFFIX}.3.2.4
|
${CMAKE_BINARY_DIR}/mysqlpp_ep-prefix/src/mysqlpp_ep/lib/${CMAKE_SHARED_LIBRARY_PREFIX}mysqlpp${CMAKE_SHARED_LIBRARY_SUFFIX}.3.2.4
|
||||||
DESTINATION lib) #need to copy libmysqlpp.so
|
DESTINATION lib)
|
||||||
|
|
||||||
add_subdirectory(sdk)
|
add_subdirectory(sdk)
|
||||||
|
|
|
@ -3,6 +3,7 @@ BOOST_VERSION=1.70.0
|
||||||
BZIP2_VERSION=1.0.6
|
BZIP2_VERSION=1.0.6
|
||||||
EASYLOGGINGPP_VERSION=v9.96.7
|
EASYLOGGINGPP_VERSION=v9.96.7
|
||||||
FAISS_VERSION=7b07685
|
FAISS_VERSION=7b07685
|
||||||
|
MKL_VERSION=2019.4.243
|
||||||
GTEST_VERSION=1.8.1
|
GTEST_VERSION=1.8.1
|
||||||
JSONCONS_VERSION=0.126.0
|
JSONCONS_VERSION=0.126.0
|
||||||
LAPACK_VERSION=v3.8.0
|
LAPACK_VERSION=v3.8.0
|
||||||
|
|
|
@ -28,7 +28,6 @@ set(unittest_libs
|
||||||
easyloggingpp
|
easyloggingpp
|
||||||
pthread
|
pthread
|
||||||
metrics
|
metrics
|
||||||
openblas
|
|
||||||
gfortran
|
gfortran
|
||||||
prometheus-cpp-pull
|
prometheus-cpp-pull
|
||||||
prometheus-cpp-push
|
prometheus-cpp-push
|
||||||
|
|
|
@ -23,10 +23,7 @@ link_directories("/usr/local/cuda/lib64")
|
||||||
|
|
||||||
include_directories(/usr/include/mysql)
|
include_directories(/usr/include/mysql)
|
||||||
|
|
||||||
#add_definitions(-DBOOST_ERROR_CODE_HEADER_ONLY)
|
|
||||||
|
|
||||||
set(db_test_src
|
set(db_test_src
|
||||||
#${unittest_srcs}
|
|
||||||
${config_files}
|
${config_files}
|
||||||
${cache_srcs}
|
${cache_srcs}
|
||||||
${db_srcs}
|
${db_srcs}
|
||||||
|
@ -49,6 +46,11 @@ set(db_libs
|
||||||
mysqlpp
|
mysqlpp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "true")
|
||||||
|
set(db_libs ${db_libs} ${MKL_LIBS} ${MKL_LIBS})
|
||||||
|
endif()
|
||||||
|
|
||||||
target_link_libraries(db_test ${db_libs} ${unittest_libs})
|
target_link_libraries(db_test ${db_libs} ${unittest_libs})
|
||||||
|
|
||||||
install(TARGETS db_test DESTINATION bin)
|
install(TARGETS db_test DESTINATION bin)
|
||||||
|
|
||||||
|
|
|
@ -35,6 +35,10 @@ set(wrapper_libs
|
||||||
zstd
|
zstd
|
||||||
lz4
|
lz4
|
||||||
)
|
)
|
||||||
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "true")
|
||||||
|
set(wrapper_libs ${wrapper_libs} ${MKL_LIBS} ${MKL_LIBS})
|
||||||
|
endif()
|
||||||
|
|
||||||
target_link_libraries(wrapper_test ${wrapper_libs} ${unittest_libs})
|
target_link_libraries(wrapper_test ${wrapper_libs} ${unittest_libs})
|
||||||
|
|
||||||
set(topk_test_src
|
set(topk_test_src
|
||||||
|
|
|
@ -10,8 +10,6 @@
|
||||||
|
|
||||||
include_directories(../../src)
|
include_directories(../../src)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
aux_source_directory(../../src/db db_srcs)
|
aux_source_directory(../../src/db db_srcs)
|
||||||
aux_source_directory(../../src/config config_files)
|
aux_source_directory(../../src/config config_files)
|
||||||
aux_source_directory(../../src/cache cache_srcs)
|
aux_source_directory(../../src/cache cache_srcs)
|
||||||
|
@ -33,21 +31,10 @@ include_directories(../../third_party/build/include)
|
||||||
link_directories(../../third_party/build/lib)
|
link_directories(../../third_party/build/lib)
|
||||||
include_directories(/usr/local/cuda/include)
|
include_directories(/usr/local/cuda/include)
|
||||||
link_directories("/usr/local/cuda/lib64")
|
link_directories("/usr/local/cuda/lib64")
|
||||||
#include_directories(../db/utils.h)
|
|
||||||
include_directories(../../src/metrics)
|
include_directories(../../src/metrics)
|
||||||
|
|
||||||
include_directories(/usr/include/mysql)
|
include_directories(/usr/include/mysql)
|
||||||
|
|
||||||
#set(metrics_src_files
|
|
||||||
# ../../src/metrics/Metrics.cpp
|
|
||||||
# ../../src/metrics/Metrics.h
|
|
||||||
# ../../src/metrics/PrometheusMetrics.cpp
|
|
||||||
# ../../src/metrics/MetricBase.h
|
|
||||||
# ../../src/server/ServerConfig.cpp
|
|
||||||
# ../../src/utils/CommonUtil.cpp
|
|
||||||
# ../../src/utils/TimeRecorder.cpp
|
|
||||||
# )
|
|
||||||
|
|
||||||
set(count_test_src
|
set(count_test_src
|
||||||
${config_files}
|
${config_files}
|
||||||
${cache_srcs}
|
${cache_srcs}
|
||||||
|
@ -77,5 +64,8 @@ target_link_libraries(metrics_test
|
||||||
mysqlpp
|
mysqlpp
|
||||||
${unittest_libs}
|
${unittest_libs}
|
||||||
)
|
)
|
||||||
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "true")
|
||||||
|
target_link_libraries(metrics_test ${MKL_LIBS} ${MKL_LIBS})
|
||||||
|
endif()
|
||||||
|
|
||||||
install(TARGETS metrics_test DESTINATION bin)
|
install(TARGETS metrics_test DESTINATION bin)
|
|
@ -48,6 +48,10 @@ set(require_libs
|
||||||
pthread
|
pthread
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if(${BUILD_FAISS_WITH_MKL} STREQUAL "true")
|
||||||
|
set(require_libs ${require_libs} ${MKL_LIBS} ${MKL_LIBS})
|
||||||
|
endif()
|
||||||
|
|
||||||
target_link_libraries(server_test
|
target_link_libraries(server_test
|
||||||
${require_libs}
|
${require_libs}
|
||||||
${cuda_library}
|
${cuda_library}
|
||||||
|
|
Loading…
Reference in New Issue