2019-04-12 12:58:45 +00:00
|
|
|
#-------------------------------------------------------------------------------
|
2019-09-17 02:51:48 +00:00
|
|
|
# Licensed to the Apache Software Foundation (ASF) under one
|
|
|
|
# or more contributor license agreements. See the NOTICE file
|
|
|
|
# distributed with this work for additional information
|
|
|
|
# regarding copyright ownership. The ASF licenses this file
|
|
|
|
# to you 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.
|
2019-04-12 12:58:45 +00:00
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
|
2019-09-17 02:51:48 +00:00
|
|
|
|
2019-11-07 02:29:00 +00:00
|
|
|
cmake_minimum_required(VERSION 3.12)
|
2019-05-29 04:06:37 +00:00
|
|
|
message(STATUS "Building using CMake version: ${CMAKE_VERSION}")
|
2019-04-12 12:58:45 +00:00
|
|
|
|
2019-09-19 08:25:12 +00:00
|
|
|
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
|
|
|
|
|
2019-11-05 02:23:59 +00:00
|
|
|
MACRO(GET_CURRENT_TIME CURRENT_TIME)
|
2019-06-06 02:24:40 +00:00
|
|
|
execute_process(COMMAND "date" +"%Y-%m-%d %H:%M.%S" OUTPUT_VARIABLE ${CURRENT_TIME})
|
2019-11-05 02:23:59 +00:00
|
|
|
ENDMACRO(GET_CURRENT_TIME)
|
2019-06-06 02:24:40 +00:00
|
|
|
|
|
|
|
GET_CURRENT_TIME(BUILD_TIME)
|
|
|
|
string(REGEX REPLACE "\n" "" BUILD_TIME ${BUILD_TIME})
|
|
|
|
message(STATUS "Build time = ${BUILD_TIME}")
|
|
|
|
|
2019-11-07 07:35:53 +00:00
|
|
|
MACRO(GET_GIT_BRANCH_NAME GIT_BRANCH_NAME)
|
2019-10-30 09:37:44 +00:00
|
|
|
execute_process(COMMAND "git" rev-parse --abbrev-ref HEAD OUTPUT_VARIABLE ${GIT_BRANCH_NAME})
|
2019-11-07 07:35:53 +00:00
|
|
|
if (GIT_BRANCH_NAME STREQUAL "")
|
2019-10-30 09:37:44 +00:00
|
|
|
execute_process(COMMAND "git" symbolic-ref --short -q HEAD OUTPUT_VARIABLE ${GIT_BRANCH_NAME})
|
2019-11-07 07:35:53 +00:00
|
|
|
endif ()
|
|
|
|
ENDMACRO(GET_GIT_BRANCH_NAME)
|
2019-06-06 02:24:40 +00:00
|
|
|
|
|
|
|
GET_GIT_BRANCH_NAME(GIT_BRANCH_NAME)
|
2019-10-30 03:21:28 +00:00
|
|
|
message(STATUS "GIT_BRANCH_NAME = ${GIT_BRANCH_NAME}")
|
2019-11-07 07:35:53 +00:00
|
|
|
if (NOT GIT_BRANCH_NAME STREQUAL "")
|
2019-06-12 03:11:00 +00:00
|
|
|
string(REGEX REPLACE "\n" "" GIT_BRANCH_NAME ${GIT_BRANCH_NAME})
|
2019-11-05 02:23:59 +00:00
|
|
|
endif ()
|
2019-06-06 02:24:40 +00:00
|
|
|
|
2019-11-05 02:23:59 +00:00
|
|
|
set(MILVUS_VERSION "${GIT_BRANCH_NAME}")
|
2019-06-14 09:29:29 +00:00
|
|
|
string(REGEX MATCH "[0-9]+\\.[0-9]+\\.[0-9]" MILVUS_VERSION "${MILVUS_VERSION}")
|
2019-06-06 02:24:40 +00:00
|
|
|
|
2019-11-05 02:23:59 +00:00
|
|
|
if (CMAKE_BUILD_TYPE STREQUAL "Release")
|
2019-09-17 06:14:15 +00:00
|
|
|
set(BUILD_TYPE "Release")
|
2019-11-05 02:23:59 +00:00
|
|
|
else ()
|
2019-09-17 06:14:15 +00:00
|
|
|
set(BUILD_TYPE "Debug")
|
2019-11-05 02:23:59 +00:00
|
|
|
endif ()
|
2019-06-06 02:24:40 +00:00
|
|
|
message(STATUS "Build type = ${BUILD_TYPE}")
|
|
|
|
|
2019-06-14 09:29:29 +00:00
|
|
|
project(milvus VERSION "${MILVUS_VERSION}")
|
2019-11-05 02:23:59 +00:00
|
|
|
project(milvus_engine LANGUAGES CXX)
|
2019-04-19 08:07:45 +00:00
|
|
|
|
2019-09-26 02:27:22 +00:00
|
|
|
unset(CMAKE_EXPORT_COMPILE_COMMANDS CACHE)
|
|
|
|
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
|
|
|
|
|
2019-06-14 09:29:29 +00:00
|
|
|
set(MILVUS_VERSION_MAJOR "${milvus_VERSION_MAJOR}")
|
|
|
|
set(MILVUS_VERSION_MINOR "${milvus_VERSION_MINOR}")
|
|
|
|
set(MILVUS_VERSION_PATCH "${milvus_VERSION_PATCH}")
|
2019-05-29 04:06:37 +00:00
|
|
|
|
2019-11-05 02:23:59 +00:00
|
|
|
if (MILVUS_VERSION_MAJOR STREQUAL ""
|
2019-06-14 09:29:29 +00:00
|
|
|
OR MILVUS_VERSION_MINOR STREQUAL ""
|
|
|
|
OR MILVUS_VERSION_PATCH STREQUAL "")
|
2019-06-23 03:32:20 +00:00
|
|
|
message(WARNING "Failed to determine Milvus version from git branch name")
|
2019-11-06 03:39:30 +00:00
|
|
|
set(MILVUS_VERSION "0.6.0")
|
2019-11-07 07:35:53 +00:00
|
|
|
endif ()
|
2019-05-29 04:06:37 +00:00
|
|
|
|
2019-06-14 09:29:29 +00:00
|
|
|
message(STATUS "Build version = ${MILVUS_VERSION}")
|
2019-11-05 02:23:59 +00:00
|
|
|
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/src/config.h.in ${CMAKE_CURRENT_SOURCE_DIR}/src/config.h @ONLY)
|
2019-06-12 03:11:00 +00:00
|
|
|
|
2019-06-14 09:29:29 +00:00
|
|
|
message(STATUS "Milvus version: "
|
|
|
|
"${MILVUS_VERSION_MAJOR}.${MILVUS_VERSION_MINOR}.${MILVUS_VERSION_PATCH} "
|
|
|
|
"(full: '${MILVUS_VERSION}')")
|
2019-05-29 04:06:37 +00:00
|
|
|
|
2019-04-12 12:58:45 +00:00
|
|
|
set(CMAKE_CXX_STANDARD 14)
|
2019-05-29 04:06:37 +00:00
|
|
|
set(CMAKE_CXX_STANDARD_REQUIRED on)
|
2019-04-12 12:58:45 +00:00
|
|
|
|
2019-11-05 02:23:59 +00:00
|
|
|
if (CMAKE_SYSTEM_PROCESSOR MATCHES "(x86)|(X86)|(amd64)|(AMD64)")
|
2019-09-17 06:14:15 +00:00
|
|
|
message(STATUS "Building milvus_engine on x86 architecture")
|
2019-06-14 09:29:29 +00:00
|
|
|
set(MILVUS_BUILD_ARCH x86_64)
|
2019-11-05 02:23:59 +00:00
|
|
|
elseif (CMAKE_SYSTEM_PROCESSOR MATCHES "(ppc)")
|
2019-09-17 06:14:15 +00:00
|
|
|
message(STATUS "Building milvus_engine on ppc architecture")
|
2019-06-14 09:29:29 +00:00
|
|
|
set(MILVUS_BUILD_ARCH ppc64le)
|
2019-11-05 02:23:59 +00:00
|
|
|
else ()
|
2019-09-17 06:14:15 +00:00
|
|
|
message(WARNING "Unknown processor type")
|
2019-09-03 02:18:55 +00:00
|
|
|
message(WARNING "CMAKE_SYSTEM_PROCESSOR=${CMAKE_SYSTEM_PROCESSOR}")
|
2019-06-14 09:29:29 +00:00
|
|
|
set(MILVUS_BUILD_ARCH unknown)
|
2019-11-05 02:23:59 +00:00
|
|
|
endif ()
|
2019-04-12 12:58:45 +00:00
|
|
|
|
2019-09-18 07:49:47 +00:00
|
|
|
# Ensure that a default make is set
|
2019-11-05 02:23:59 +00:00
|
|
|
if ("${MAKE}" STREQUAL "")
|
|
|
|
if (NOT MSVC)
|
2019-09-18 07:49:47 +00:00
|
|
|
find_program(MAKE make)
|
2019-11-05 02:23:59 +00:00
|
|
|
endif ()
|
|
|
|
endif ()
|
2019-09-18 07:49:47 +00:00
|
|
|
|
|
|
|
find_path(MYSQL_INCLUDE_DIR
|
2019-11-05 02:23:59 +00:00
|
|
|
NAMES "mysql.h"
|
|
|
|
PATH_SUFFIXES "mysql")
|
2019-09-18 07:49:47 +00:00
|
|
|
if (${MYSQL_INCLUDE_DIR} STREQUAL "MYSQL_INCLUDE_DIR-NOTFOUND")
|
|
|
|
message(FATAL_ERROR "Could not found MySQL include directory")
|
2019-11-05 02:23:59 +00:00
|
|
|
else ()
|
2019-09-18 07:49:47 +00:00
|
|
|
include_directories(${MYSQL_INCLUDE_DIR})
|
2019-11-05 02:23:59 +00:00
|
|
|
endif ()
|
2019-09-18 07:49:47 +00:00
|
|
|
|
|
|
|
set(MILVUS_SOURCE_DIR ${PROJECT_SOURCE_DIR})
|
|
|
|
set(MILVUS_BINARY_DIR ${PROJECT_BINARY_DIR})
|
|
|
|
set(MILVUS_ENGINE_SRC ${PROJECT_SOURCE_DIR}/src)
|
|
|
|
|
2019-05-29 04:06:37 +00:00
|
|
|
include(ExternalProject)
|
|
|
|
include(DefineOptions)
|
|
|
|
include(BuildUtils)
|
|
|
|
include(ThirdPartyPackages)
|
|
|
|
|
2019-11-11 03:12:59 +00:00
|
|
|
if(MILVUS_USE_CCACHE)
|
|
|
|
find_program(CCACHE_FOUND ccache)
|
|
|
|
if(CCACHE_FOUND)
|
|
|
|
message(STATUS "Using ccache: ${CCACHE_FOUND}")
|
|
|
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ${CCACHE_FOUND})
|
|
|
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ${CCACHE_FOUND})
|
|
|
|
# let ccache preserve C++ comments, because some of them may be
|
|
|
|
# meaningful to the compiler
|
|
|
|
set(ENV{CCACHE_COMMENTS} "1")
|
|
|
|
endif(CCACHE_FOUND)
|
|
|
|
endif()
|
|
|
|
|
2019-11-07 07:35:53 +00:00
|
|
|
set(MILVUS_CPU_VERSION false)
|
|
|
|
if (MILVUS_GPU_VERSION)
|
2019-11-05 02:23:59 +00:00
|
|
|
message(STATUS "Building Milvus GPU version")
|
|
|
|
add_compile_definitions("MILVUS_GPU_VERSION")
|
|
|
|
enable_language(CUDA)
|
|
|
|
find_package(CUDA 10 REQUIRED)
|
|
|
|
set(CUDA_NVCC_FLAGS "${CUDA_NVCC_FLAGS} -Xcompiler -fPIC -std=c++11 -D_FORCE_INLINES --expt-extended-lambda")
|
2019-11-07 07:35:53 +00:00
|
|
|
else ()
|
|
|
|
message(STATUS "Building Milvus CPU version")
|
|
|
|
set(MILVUS_CPU_VERSION true)
|
|
|
|
add_compile_definitions("MILVUS_CPU_VERSION")
|
2019-11-05 02:23:59 +00:00
|
|
|
endif ()
|
|
|
|
|
|
|
|
if (CMAKE_BUILD_TYPE STREQUAL "Release")
|
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O3 -fPIC -DELPP_THREAD_SAFE -fopenmp")
|
|
|
|
if (MILVUS_GPU_VERSION)
|
|
|
|
set(CUDA_NVCC_FLAGS "${CUDA_NVCC_FLAGS} -O3")
|
|
|
|
endif ()
|
|
|
|
else ()
|
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O0 -g -fPIC -DELPP_THREAD_SAFE -fopenmp")
|
|
|
|
if (MILVUS_GPU_VERSION)
|
|
|
|
set(CUDA_NVCC_FLAGS "${CUDA_NVCC_FLAGS} -O0 -g")
|
|
|
|
endif ()
|
|
|
|
endif ()
|
2019-04-12 12:58:45 +00:00
|
|
|
|
2019-10-15 08:15:39 +00:00
|
|
|
if (CUSTOMIZATION)
|
|
|
|
add_definitions(-DCUSTOMIZATION)
|
|
|
|
endif (CUSTOMIZATION)
|
|
|
|
|
2019-11-05 02:23:59 +00:00
|
|
|
config_summary()
|
2019-05-29 04:06:37 +00:00
|
|
|
add_subdirectory(src)
|
2019-04-12 12:58:45 +00:00
|
|
|
|
2019-06-28 10:25:57 +00:00
|
|
|
if (BUILD_UNIT_TEST STREQUAL "ON")
|
2019-09-17 06:14:15 +00:00
|
|
|
if (BUILD_COVERAGE STREQUAL "ON")
|
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fprofile-arcs -ftest-coverage")
|
2019-11-05 02:23:59 +00:00
|
|
|
endif ()
|
2019-04-14 01:46:12 +00:00
|
|
|
add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/unittest)
|
2019-11-05 02:23:59 +00:00
|
|
|
endif ()
|
2019-05-28 09:50:20 +00:00
|
|
|
|
2019-04-14 08:25:44 +00:00
|
|
|
add_custom_target(Clean-All COMMAND ${CMAKE_BUILD_TOOL} clean)
|
2019-05-09 04:05:35 +00:00
|
|
|
|
2019-11-05 02:23:59 +00:00
|
|
|
if ("${MILVUS_DB_PATH}" STREQUAL "")
|
2019-06-28 03:23:12 +00:00
|
|
|
set(MILVUS_DB_PATH "/tmp/milvus")
|
2019-11-05 02:23:59 +00:00
|
|
|
endif ()
|
2019-11-13 03:15:03 +00:00
|
|
|
|
|
|
|
if (MILVUS_GPU_VERSION)
|
|
|
|
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/conf/server_gpu_config.template ${CMAKE_CURRENT_SOURCE_DIR}/conf/server_config.yaml)
|
|
|
|
else()
|
2019-11-13 05:55:46 +00:00
|
|
|
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/conf/server_cpu_config.template ${CMAKE_CURRENT_SOURCE_DIR}/conf/server_config.yaml)
|
2019-11-13 03:15:03 +00:00
|
|
|
endif()
|
|
|
|
|
2019-06-28 02:52:16 +00:00
|
|
|
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/conf/log_config.template ${CMAKE_CURRENT_SOURCE_DIR}/conf/log_config.conf)
|
|
|
|
|
2019-07-03 08:35:19 +00:00
|
|
|
install(DIRECTORY scripts/
|
2019-07-03 08:11:18 +00:00
|
|
|
DESTINATION scripts
|
2019-07-03 07:54:15 +00:00
|
|
|
FILE_PERMISSIONS OWNER_EXECUTE OWNER_WRITE OWNER_READ
|
2019-07-03 08:11:18 +00:00
|
|
|
GROUP_EXECUTE GROUP_READ
|
|
|
|
WORLD_EXECUTE WORLD_READ
|
|
|
|
FILES_MATCHING PATTERN "*.sh")
|
2019-05-09 04:05:35 +00:00
|
|
|
install(FILES
|
|
|
|
conf/server_config.yaml
|
2019-06-14 09:29:29 +00:00
|
|
|
conf/log_config.conf
|
2019-05-09 04:05:35 +00:00
|
|
|
DESTINATION
|
|
|
|
conf)
|
2019-09-19 08:25:12 +00:00
|
|
|
|
2019-11-05 02:23:59 +00:00
|
|
|
find_package(Python COMPONENTS Interpreter Development)
|
|
|
|
find_package(ClangTools)
|
|
|
|
set(BUILD_SUPPORT_DIR "${CMAKE_SOURCE_DIR}/build-support")
|
2019-09-20 06:57:23 +00:00
|
|
|
|
|
|
|
#
|
|
|
|
# "make lint" target
|
|
|
|
#
|
2019-11-05 02:23:59 +00:00
|
|
|
if (NOT MILVUS_VERBOSE_LINT)
|
|
|
|
set(MILVUS_LINT_QUIET "--quiet")
|
|
|
|
endif ()
|
2019-09-20 06:57:23 +00:00
|
|
|
|
2019-11-05 02:23:59 +00:00
|
|
|
if (NOT LINT_EXCLUSIONS_FILE)
|
|
|
|
# source files matching a glob from a line in this file
|
|
|
|
# will be excluded from linting (cpplint, clang-tidy, clang-format)
|
|
|
|
set(LINT_EXCLUSIONS_FILE ${BUILD_SUPPORT_DIR}/lint_exclusions.txt)
|
|
|
|
endif ()
|
2019-09-20 06:57:23 +00:00
|
|
|
|
2019-09-20 09:14:20 +00:00
|
|
|
find_program(CPPLINT_BIN NAMES cpplint cpplint.py HINTS ${BUILD_SUPPORT_DIR})
|
|
|
|
message(STATUS "Found cpplint executable at ${CPPLINT_BIN}")
|
|
|
|
|
2019-09-25 11:05:08 +00:00
|
|
|
#
|
|
|
|
# "make lint" targets
|
|
|
|
#
|
2019-09-20 09:14:20 +00:00
|
|
|
add_custom_target(lint
|
2019-11-05 02:23:59 +00:00
|
|
|
${PYTHON_EXECUTABLE}
|
|
|
|
${BUILD_SUPPORT_DIR}/run_cpplint.py
|
|
|
|
--cpplint_binary
|
|
|
|
${CPPLINT_BIN}
|
|
|
|
--exclude_globs
|
|
|
|
${LINT_EXCLUSIONS_FILE}
|
|
|
|
--source_dir
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}
|
|
|
|
${MILVUS_LINT_QUIET})
|
2019-09-20 09:14:20 +00:00
|
|
|
|
2019-09-20 06:57:23 +00:00
|
|
|
#
|
2019-09-25 11:05:08 +00:00
|
|
|
# "make clang-format" and "make check-clang-format" targets
|
2019-09-20 06:57:23 +00:00
|
|
|
#
|
2019-11-05 02:23:59 +00:00
|
|
|
if (${CLANG_FORMAT_FOUND})
|
|
|
|
# runs clang format and updates files in place.
|
|
|
|
add_custom_target(clang-format
|
|
|
|
${PYTHON_EXECUTABLE}
|
|
|
|
${BUILD_SUPPORT_DIR}/run_clang_format.py
|
|
|
|
--clang_format_binary
|
|
|
|
${CLANG_FORMAT_BIN}
|
|
|
|
--exclude_globs
|
|
|
|
${LINT_EXCLUSIONS_FILE}
|
|
|
|
--source_dir
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src
|
|
|
|
--fix
|
|
|
|
${MILVUS_LINT_QUIET})
|
|
|
|
|
|
|
|
# runs clang format and exits with a non-zero exit code if any files need to be reformatted
|
|
|
|
add_custom_target(check-clang-format
|
|
|
|
${PYTHON_EXECUTABLE}
|
|
|
|
${BUILD_SUPPORT_DIR}/run_clang_format.py
|
|
|
|
--clang_format_binary
|
|
|
|
${CLANG_FORMAT_BIN}
|
|
|
|
--exclude_globs
|
|
|
|
${LINT_EXCLUSIONS_FILE}
|
|
|
|
--source_dir
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src
|
|
|
|
${MILVUS_LINT_QUIET})
|
|
|
|
endif ()
|
2019-09-19 08:25:12 +00:00
|
|
|
|
2019-09-20 08:59:05 +00:00
|
|
|
#
|
|
|
|
# "make clang-tidy" and "make check-clang-tidy" targets
|
|
|
|
#
|
2019-11-05 02:23:59 +00:00
|
|
|
if (${CLANG_TIDY_FOUND})
|
|
|
|
# runs clang-tidy and attempts to fix any warning automatically
|
|
|
|
add_custom_target(clang-tidy
|
|
|
|
${PYTHON_EXECUTABLE}
|
|
|
|
${BUILD_SUPPORT_DIR}/run_clang_tidy.py
|
|
|
|
--clang_tidy_binary
|
|
|
|
${CLANG_TIDY_BIN}
|
|
|
|
--exclude_globs
|
|
|
|
${LINT_EXCLUSIONS_FILE}
|
|
|
|
--compile_commands
|
|
|
|
${CMAKE_BINARY_DIR}/compile_commands.json
|
|
|
|
--source_dir
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src
|
|
|
|
--fix
|
|
|
|
${MILVUS_LINT_QUIET})
|
|
|
|
|
|
|
|
# runs clang-tidy and exits with a non-zero exit code if any errors are found.
|
|
|
|
add_custom_target(check-clang-tidy
|
|
|
|
${PYTHON_EXECUTABLE}
|
|
|
|
${BUILD_SUPPORT_DIR}/run_clang_tidy.py
|
|
|
|
--clang_tidy_binary
|
|
|
|
${CLANG_TIDY_BIN}
|
|
|
|
--exclude_globs
|
|
|
|
${LINT_EXCLUSIONS_FILE}
|
|
|
|
--compile_commands
|
|
|
|
${CMAKE_BINARY_DIR}/compile_commands.json
|
|
|
|
--source_dir
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src
|
|
|
|
${MILVUS_LINT_QUIET})
|
2019-11-07 02:29:00 +00:00
|
|
|
endif ()
|