diff options
Diffstat (limited to 'src/CMakeLists.txt')
-rw-r--r-- | src/CMakeLists.txt | 158 |
1 files changed, 7 insertions, 151 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index cdf756e1b82..cd028cb7d54 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -17,59 +17,9 @@ project(vpp C) include(CheckCCompilerFlag) -############################################################################## -# Highlight WARNING and ERROR messages -############################################################################## -function(message) - list(GET ARGV 0 type) - string(ASCII 27 esc) - set(red "${esc}[1;31m") - set(yellow "${esc}[1;33m") - set(reset "${esc}[m") - if(type STREQUAL FATAL_ERROR OR type STREQUAL SEND_ERROR) - list(REMOVE_AT ARGV 0) - _message(${type} "${red}${ARGV}${reset}") - elseif(type STREQUAL WARNING) - list(REMOVE_AT ARGV 0) - _message(STATUS "${yellow}${ARGV}${reset}") - elseif(type STREQUAL STATUS) - list(REMOVE_AT ARGV 0) - _message(STATUS "${ARGV}") - else() - _message(${ARGV}) - endif() -endfunction() - -############################################################################## -# CPU optimizations and multiarch support -############################################################################## -if(CMAKE_SYSTEM_PROCESSOR MATCHES "amd64.*|x86_64.*|AMD64.*") - set(CMAKE_C_FLAGS "-march=corei7 -mtune=corei7-avx ${CMAKE_C_FLAGS}") - check_c_compiler_flag("-march=core-avx2" AVX2) - if(AVX2) - list(APPEND MARCH_VARIANTS "avx2\;-march=core-avx2 -mtune=core-avx2") - endif() - check_c_compiler_flag("-march=skylake-avx512" AVX512) - if(AVX512) - list(APPEND MARCH_VARIANTS "avx512\;-march=skylake-avx512 -mtune=skylake-avx512") - endif() -elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^(aarch64.*|AARCH64.*)") - set(CMAKE_C_FLAGS "-march=armv8-a+crc ${CMAKE_C_FLAGS}") -endif() - -macro(vpp_library_set_multiarch_sources lib) - foreach(V ${MARCH_VARIANTS}) - list(GET V 0 VARIANT) - list(GET V 1 VARIANT_FLAGS) - set(l ${lib}_${VARIANT}) - add_library(${l} OBJECT ${ARGN}) - set_target_properties(${l} PROPERTIES POSITION_INDEPENDENT_CODE ON) - target_compile_options(${l} PUBLIC "-DCLIB_MARCH_VARIANT=${VARIANT}") - separate_arguments(VARIANT_FLAGS) - target_compile_options(${l} PUBLIC ${VARIANT_FLAGS}) - target_sources(${lib} PRIVATE $<TARGET_OBJECTS:${l}>) - endforeach() -endmacro() +include(cmake/message.cmake) +include(cmake/cpu.cmake) +include(cmake/ccache.cmake) ############################################################################## # build config @@ -81,22 +31,6 @@ set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} ${CMAKE_C_FLAGS_COMMON} -DCLIB_D set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} ${CMAKE_C_FLAGS_COMMON}") ############################################################################## -# ccache -############################################################################## -option(VPP_USE_CCACHE "Use ccache compiler cache." ON) -if(VPP_USE_CCACHE) - find_program(CCACHE_FOUND ccache) - message(STATUS "Looking for ccache") - if(CCACHE_FOUND) - message(STATUS "Looking for ccache - found") - set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache) - set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ccache) - else(CCACHE_FOUND) - message(STATUS "Looking for ccache - not found") - endif(CCACHE_FOUND) -endif(VPP_USE_CCACHE) - -############################################################################## # install config ############################################################################## set(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_PREFIX}/lib") @@ -116,72 +50,11 @@ set(CMAKE_INSTALL_DEFAULT_COMPONENT_NAME "vpp") set(THREADS_PREFER_PTHREAD_FLAG ON) find_package(Threads REQUIRED) find_package(OpenSSL REQUIRED) -include_directories(${OPENSSL_INCLUDE_DIR}) - -############################################################################## -# Check for memfd_create headers and libs -############################################################################## -check_c_source_compiles(" - #define _GNU_SOURCE - #include <sys/mman.h> - int main() { return memfd_create (\"/dev/false\", 0); } -" HAVE_MEMFD_CREATE) - -if (HAVE_MEMFD_CREATE) - add_definitions(-DHAVE_MEMFD_CREATE) -endif() - -############################################################################## -# API -############################################################################## -function(vpp_generate_api_c_header file) - set (output_name ${CMAKE_CURRENT_BINARY_DIR}/${file}.h) - get_filename_component(output_dir ${output_name} DIRECTORY) - add_custom_command (OUTPUT ${output_name} - COMMAND mkdir -p ${output_dir} - COMMAND ${CMAKE_SOURCE_DIR}/tools/vppapigen/vppapigen - ARGS --includedir ${CMAKE_SOURCE_DIR} --input ${CMAKE_CURRENT_SOURCE_DIR}/${file} --output ${output_name} - DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${file} - COMMENT "Generating API header ${output_name}" - ) -endfunction() - -function(vpp_generate_api_json_header file dir) - set (output_name ${CMAKE_CURRENT_BINARY_DIR}/${file}.json) - get_filename_component(output_dir ${output_name} DIRECTORY) - add_custom_command (OUTPUT ${output_name} - COMMAND mkdir -p ${output_dir} - COMMAND ${CMAKE_SOURCE_DIR}/tools/vppapigen/vppapigen - ARGS --includedir ${CMAKE_SOURCE_DIR} --input ${CMAKE_CURRENT_SOURCE_DIR}/${file} JSON --output ${output_name} - DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${file} - COMMENT "Generating API header ${output_name}" - ) - install(FILES ${output_name} DESTINATION share/vpp/api/${dir}/) -endfunction() - -############################################################################## -# generate the .h and .json files for a .api file -# @param file - the name of the .api -# @param dir - the install directory under ROOT/share/vpp/api to place the -# generated .json file -############################################################################## -function(vpp_generate_api_header file dir) - vpp_generate_api_c_header (${file}) - vpp_generate_api_json_header (${file} ${dir}) -endfunction() - -function(vpp_add_api_files target) - unset(header_files) - foreach(file ${ARGN}) - vpp_generate_api_header (${file} core) - list (APPEND header_files ${file}.h ${file}.json) - endforeach() - add_custom_target(${target} DEPENDS ${header_files}) -endfunction() -add_custom_target(api_headers - DEPENDS vlibmemory_api_headers vnet_api_headers vpp_api_headers -) +include(cmake/memfd.cmake) +include(cmake/api.cmake) +include(cmake/plugin.cmake) +include(cmake/deb.cmake) ############################################################################## # header files @@ -200,20 +73,3 @@ foreach (DIR vppinfra svm vlib vlibmemory vlibapi vnet vpp vpp-api vat vcl plugi add_subdirectory(${DIR}) endforeach () -############################################################################## -# DEB Packaging -############################################################################## -set(CPACK_GENERATOR "DEB") -set(CPACK_DEBIAN_PACKAGE_MAINTAINER "VPP Team") -set(CPACK_PACKAGE_NAME "vpp") -set(CPACK_PACKAGE_VENDOR "fd.io") -set(CPACK_PACKAGE_VERSION "18.08") -set(CPACK_DEB_COMPONENT_INSTALL ON) -set(CPACK_COMPONENTS_IGNORE_GROUPS 1) -set(CPACK_DEBIAN_VPP_PACKAGE_NAME "vpp") -set(CPACK_DEBIAN_VPP_FILE_NAME "vpp.deb") -set(CPACK_DEBIAN_DEV_PACKAGE_NAME "vpp-dev") -set(CPACK_DEBIAN_DEV_FILE_NAME "vpp-dev.deb") -set(CPACK_DEBIAN_PLUGINS_PACKAGE_NAME "vpp-plugins") -set(CPACK_DEBIAN_PLUGINS_FILE_NAME "vpp-plugins.deb") -include(CPack) |