X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fcmake%2Fplugin.cmake;h=536ae9c318a35a438907d07b83853e781120e16a;hb=refs%2Fchanges%2F82%2F32182%2F1;hp=e9397a7fa85cd7d7d9b2a258e8f95461eef1ad0c;hpb=d16004d56c22635a0e21b177933dc39b65a3642a;p=vpp.git diff --git a/src/cmake/plugin.cmake b/src/cmake/plugin.cmake index e9397a7fa85..536ae9c318a 100644 --- a/src/cmake/plugin.cmake +++ b/src/cmake/plugin.cmake @@ -14,23 +14,57 @@ macro(add_vpp_plugin name) cmake_parse_arguments(PLUGIN "" - "LINK_FLAGS" - "SOURCES;API_FILES;MULTIARCH_SOURCES;LINK_LIBRARIES;API_TEST_SOURCES" + "LINK_FLAGS;COMPONENT;DEV_COMPONENT" + "SOURCES;API_FILES;MULTIARCH_SOURCES;LINK_LIBRARIES;INSTALL_HEADERS;API_TEST_SOURCES;" ${ARGN} ) set(plugin_name ${name}_plugin) - set(api_headers) + set(api_includes) + if(NOT PLUGIN_COMPONENT) + set(PLUGIN_COMPONENT vpp-plugin-core) + endif() + if(NOT PLUGIN_DEV_COMPONENT) + if(NOT VPP_EXTERNAL_PROJECT) + set(PLUGIN_DEV_COMPONENT vpp-dev) + else() + set(PLUGIN_DEV_COMPONENT ${PLUGIN_COMPONENT}-dev) + endif() + endif() + + vpp_add_api_files(${plugin_name} plugins ${PLUGIN_COMPONENT} ${PLUGIN_API_FILES}) foreach(f ${PLUGIN_API_FILES}) - vpp_generate_api_header(${f} plugins) - list(APPEND api_headers ${f}.h ${f}.json) + get_filename_component(dir ${f} DIRECTORY) + list(APPEND api_includes ${f}.h ${f}_enum.h ${f}_types.h ${f}.json) + install( + FILES + ${CMAKE_CURRENT_BINARY_DIR}/${f}.h + ${CMAKE_CURRENT_BINARY_DIR}/${f}_enum.h + ${CMAKE_CURRENT_BINARY_DIR}/${f}_types.h + DESTINATION include/vpp_plugins/${name}/${dir} + COMPONENT ${PLUGIN_DEV_COMPONENT} + ) endforeach() - add_library(${plugin_name} SHARED ${PLUGIN_SOURCES} ${api_headers}) - add_dependencies(${plugin_name} vpp_version_h api_headers) + add_library(${plugin_name} SHARED ${api_includes} ${PLUGIN_SOURCES}) + set_target_properties(${plugin_name} PROPERTIES NO_SONAME 1) + target_compile_options(${plugin_name} PRIVATE "-fvisibility=hidden") + target_compile_options (${plugin_name} PRIVATE "-ffunction-sections") + target_compile_options (${plugin_name} PRIVATE "-fdata-sections") + target_link_libraries (${plugin_name} "-Wl,--gc-sections") + set(deps "") + if(NOT VPP_EXTERNAL_PROJECT) + list(APPEND deps vpp_version_h api_headers) + endif() + if(PLUGIN_API_FILES) + list(APPEND deps ${plugin_name}_api_headers) + endif() + if(deps) + add_dependencies(${plugin_name} ${deps}) + endif() set_target_properties(${plugin_name} PROPERTIES PREFIX "" LIBRARY_OUTPUT_DIRECTORY ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/vpp_plugins) if(PLUGIN_MULTIARCH_SOURCES) - vpp_library_set_multiarch_sources(${plugin_name} ${PLUGIN_MULTIARCH_SOURCES}) + vpp_library_set_multiarch_sources(${plugin_name} SOURCES ${PLUGIN_MULTIARCH_SOURCES} DEPENDS ${deps}) endif() if(PLUGIN_LINK_LIBRARIES) target_link_libraries(${plugin_name} ${PLUGIN_LINK_LIBRARIES}) @@ -38,16 +72,53 @@ macro(add_vpp_plugin name) if(PLUGIN_LINK_FLAGS) set_target_properties(${plugin_name} PROPERTIES LINK_FLAGS "${PLUGIN_LINK_FLAGS}") endif() + if(PLUGIN_INSTALL_HEADERS) + foreach(file ${PLUGIN_INSTALL_HEADERS}) + get_filename_component(dir ${file} DIRECTORY) + install( + FILES ${file} + DESTINATION include/vpp_plugins/${name}/${dir} + COMPONENT vpp-dev + ) + endforeach() + endif() if(PLUGIN_API_TEST_SOURCES) set(test_plugin_name ${name}_test_plugin) - add_library(${test_plugin_name} SHARED ${PLUGIN_API_TEST_SOURCES} ${api_headers}) - add_dependencies(${test_plugin_name} api_headers) + add_library(${test_plugin_name} SHARED ${PLUGIN_API_TEST_SOURCES} + ${api_includes}) + set_target_properties(${test_plugin_name} PROPERTIES NO_SONAME 1) + if(NOT VPP_EXTERNAL_PROJECT) + add_dependencies(${test_plugin_name} api_headers) + endif() + if(PLUGIN_API_FILES) + add_dependencies(${test_plugin_name} ${plugin_name}_api_headers) + endif() set_target_properties(${test_plugin_name} PROPERTIES PREFIX "" LIBRARY_OUTPUT_DIRECTORY ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/vpp_api_test_plugins) - install(TARGETS ${test_plugin_name} DESTINATION lib/vpp_api_test_plugins COMPONENT - plugins) + install( + TARGETS ${test_plugin_name} + DESTINATION ${VPP_LIBRARY_DIR}/vpp_api_test_plugins + COMPONENT ${PLUGIN_COMPONENT} + ) + endif() + if (PLUGIN_API_FILES) + add_vpp_test_library(${name}_test_plugin ${PLUGIN_API_FILES}) endif() - install(TARGETS ${plugin_name} DESTINATION lib/vpp_plugins COMPONENT plugins) + + install( + TARGETS ${plugin_name} + DESTINATION ${VPP_LIBRARY_DIR}/vpp_plugins + COMPONENT ${PLUGIN_COMPONENT} + ) endmacro() +macro(vpp_plugin_find_library plugin var name) + find_library(${var} NAMES ${name} ${ARGN}) + mark_as_advanced(${var}) +if (NOT ${var}) + message(WARNING "-- ${name} library not found - ${plugin} plugin disabled") + return() +endif() + message(STATUS "${plugin} plugin needs ${name} library - found at ${${var}}") +endmacro()