X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=CMakeLists.txt;h=149a354fc9e18ee90b1b0e033210bec2f9498822;hb=refs%2Fheads%2Fsandbox%2Fjobol%2Fl4sock;hp=541b639890863fa321d8b36272e7a954917e3ab5;hpb=45c8372c2b4137691a38c2a04f4a5759a110f2f7;p=src%2Fapp-framework-binder.git diff --git a/CMakeLists.txt b/CMakeLists.txt index 541b6398..149a354f 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,5 +1,5 @@ ########################################################################### -# Copyright 2015, 2016, 2017 IoT.bzh +# Copyright (C) 2015-2019 "IoT.bzh" # # author: José Bollo # @@ -23,7 +23,8 @@ PROJECT(afb-daemon C CXX) SET(PROJECT_NAME "AFB Daemon") SET(PROJECT_PRETTY_NAME "Application Framework Binder Daemon") SET(PROJECT_DESCRIPTION "Secured binder of API for clients of the Application framework") -SET(PROJECT_VERSION "4.99-EERC1") +set(AGLVERSION "8.0.0" CACHE STRING "Version of AGL") +set(PROJECT_VERSION ${AGLVERSION} CACHE STRING "Version of the project can override AGLVERSION") set(PROJECT_URL "https://gerrit.automotivelinux.org/gerrit/gitweb?p=src/app-framework-binder.git;a=summary") SET(LIBAFBWSC_VERSION "1.1") @@ -37,8 +38,61 @@ INCLUDE(CTest) ########################################################################### # possible settings -set(AGL_DEVEL OFF CACHE BOOL "Activates developping features") -set(INCLUDE_MONITORING OFF CACHE BOOL "Activates installation of monitoring") + +option(ONLY_DEVTOOLS "Produces only development tools" OFF) +option(AGL_DEVEL "Activates developping features" OFF) +option(WITH_SYSTEMD "Require use of libsystemd" ON) + +############################################################################ + +option(WITH_SIG_MONITOR_DUMPSTACK "Activate dump stack on error" ON) +option(WITH_SIG_MONITOR_SIGNALS "Activate handling of signals" ON) +option(WITH_SIG_MONITOR_FOR_CALL "Activate monitoring of calls" ON) +option(WITH_SIG_MONITOR_TIMERS "Activate monitoring of call expiration" ON) +option(WITH_AFB_HOOK "Include hooking" ON) +option(WITH_AFB_TRACE "Include monitoring trace" ON) +option(WITH_SUPERVISOR "Activates installation of supervisor" OFF) +option(WITH_MONITORING "Activates installation of monitoring" OFF) +option(WITH_DBUS_TRANSPARENCY "Allows API transparency over DBUS" OFF) +option(WITH_LEGACY_BINDING_V1 "Includes the legacy Binding API version 1" OFF) +option(WITH_LEGACY_BINDING_V2 "Includes the legacy Binding API version 2" ON) +option(WITH_LEGACY_BINDING_VDYN "Includes the legacy Binding API version dynamic" OFF) +option(WITH_DYNAMIC_BINDING "Allow to load dynamic bindings (shared libraries)" ON) +option(WITH_LIBMICROHTTPD "Activates HTTP server through LIBMICROHTTPD" ON) +option(WITH_FNMATCH "Use fnmatch where possible" ON) +option(WITH_L4VSOCK "Activates L4RE support of VIRTIO-SOCKS" OFF) + +############################################################################ +# legacy options + +option(INCLUDE_SUPERVISOR "Activates installation of supervisor" OFF) +option(INCLUDE_MONITORING "Activates installation of monitoring" OFF) +option(INCLUDE_DBUS_TRANSPARENCY "Allows API transparency over DBUS" OFF) +option(INCLUDE_LEGACY_BINDING_V1 "Includes the legacy Binding API version 1" OFF) +option(INCLUDE_LEGACY_BINDING_VDYN "Includes the legacy Binding API version dynamic" OFF) + +if(INCLUDE_SUPERVISOR) + set(WITH_SUPERVISOR ON) +endif() +if(INCLUDE_MONITORING) + set(WITH_MONITORING ON) +endif() +if(INCLUDE_DBUS_TRANSPARENCY) + set(WITH_DBUS_TRANSPARENCY ON) +endif() +if(INCLUDE_LEGACY_BINDING_V1) + set(WITH_LEGACY_BINDING_V1 ON) +endif() +if(INCLUDE_LEGACY_BINDING_VDYN) + set(WITH_LEGACY_BINDING_VDYN ON) +endif() + +########################################################################### + +set(AFS_SUPERVISION_SOCKET "@urn:AGL:afs:supervision:socket" CACHE STRING "Internal socket for supervision") +set(AFS_SUPERVISOR_PORT 1619 CACHE STRING "Port of service for the supervisor") +set(AFS_SUPERVISOR_TOKEN HELLO CACHE STRING "Secret token for the supervisor") +set(UNITDIR_SYSTEM ${CMAKE_INSTALL_LIBDIR}/systemd/system CACHE STRING "Path to systemd system unit files") ########################################################################### @@ -52,6 +106,7 @@ add_compile_options(-Werror=implicit-function-declaration) add_compile_options(-ffunction-sections -fdata-sections) add_compile_options(-fPIC) add_compile_options(-g) +set (CMAKE_CXX_STANDARD 14) set(CMAKE_C_FLAGS_PROFILING "-g -O2 -pg -Wp,-U_FORTIFY_SOURCE") set(CMAKE_C_FLAGS_DEBUG "-g -ggdb -Wp,-U_FORTIFY_SOURCE") @@ -60,55 +115,51 @@ set(CMAKE_C_FLAGS_CCOV "-g -O2 --coverage") ########################################################################### +if(ONLY_DEVTOOLS) + set(WITH_LIBMICROHTTPD OFF) + set(WITH_SYSTEMD OFF) +endif(ONLY_DEVTOOLS) + +if(NOT WITH_LIBMICROHTTPD) + set(WITH_MONITORING OFF) +endif() +########################################################################### + INCLUDE(FindThreads) FIND_PACKAGE(Threads) PKG_CHECK_MODULES(json-c REQUIRED json-c) - -CHECK_INCLUDE_FILES(magic.h HAVE_MAGIC_H) -CHECK_LIBRARY_EXISTS(magic magic_load "" HAVE_LIBMAGIC_SO) -IF(HAVE_MAGIC_H) - IF(HAVE_LIBMAGIC_SO) - SET(HAVE_LIBMAGIC "1") - SET(LIBMAGIC_LDFLAGS -lmagic) - ENDIF(HAVE_LIBMAGIC_SO) -ENDIF(HAVE_MAGIC_H) - -PKG_CHECK_MODULES(libsystemd libsystemd>=222) -PKG_CHECK_MODULES(libmicrohttpd libmicrohttpd>=0.9.55) -PKG_CHECK_MODULES(openssl openssl) PKG_CHECK_MODULES(uuid uuid) PKG_CHECK_MODULES(cynara cynara-client) -IF(AGL_DEVEL) - ADD_DEFINITIONS(-DAGL_DEVEL) -endif() +if(WITH_LIBMICROHTTPD) -IF(cynara_FOUND) + CHECK_INCLUDE_FILES(magic.h HAVE_MAGIC_H) + CHECK_LIBRARY_EXISTS(magic magic_load "" HAVE_LIBMAGIC_SO) + if(HAVE_MAGIC_H AND HAVE_LIBMAGIC_SO) + SET(HAVE_LIBMAGIC "1") + SET(LIBMAGIC_LDFLAGS -lmagic) + else() + MESSAGE(FATAL_ERROR "\"magic.h\" or \"libmagic.so\" missing. + Please install the \"file-devel\" or \"libmagic-dev\" package !") + endif() + PKG_CHECK_MODULES(libmicrohttpd REQUIRED libmicrohttpd>=0.9.60) + PKG_CHECK_MODULES(openssl REQUIRED openssl) +endif(WITH_LIBMICROHTTPD) + +if(cynara_FOUND) ADD_DEFINITIONS(-DBACKEND_PERMISSION_IS_CYNARA) -ENDIF(cynara_FOUND) +endif(cynara_FOUND) -IF(HAVE_LIBMAGIC AND libsystemd_FOUND AND libmicrohttpd_FOUND AND openssl_FOUND AND uuid_FOUND) - ADD_DEFINITIONS(-DUSE_MAGIC_MIME_TYPE) -ELSE() - IF(NOT HAVE_LIBMAGIC) - MESSAGE(WARNING "\"magic.h\" or \"libmagic.so\" missing. - Please install the \"file-devel\" or \"libmagic-dev\" package !") - ENDIF(NOT HAVE_LIBMAGIC) - IF(NOT libsystemd_FOUND) - MESSAGE(WARNING "Dependency to 'libsystemd' is missing") - ENDIF() - IF(NOT libmicrohttpd_FOUND) - MESSAGE(WARNING "Dependency to 'libmicrohttpd' is missing") - ENDIF() - IF(NOT openssl_FOUND) - MESSAGE(WARNING "Dependency to 'openssl' is missing") - ENDIF() +if(WITH_SYSTEMD) + PKG_CHECK_MODULES(libsystemd REQUIRED libsystemd>=222) +else() + PKG_CHECK_MODULES(libsystemd libsystemd>=222) +endif(WITH_SYSTEMD) + +IF(NOT ONLY_DEVTOOLS) IF(NOT uuid_FOUND) - MESSAGE(WARNING "Dependency to 'uuid' is missing") - ENDIF() - IF(NOT ONLY_DEVTOOLS) - MESSAGE(FATAL_ERROR "Can't compile the binder, either define ONLY_DEVTOOLS or install dependencies") + MESSAGE(FATAL_ERROR "Dependency to 'uuid' is missing") ENDIF() ENDIF() @@ -136,7 +187,7 @@ SET(link_libraries ${LIBMAGIC_LDFLAGS} -ldl -lrt - ) +) ADD_SUBDIRECTORY(src/devtools) @@ -147,8 +198,7 @@ ELSE() ########################################################################### # activates the monitoring by default - if(INCLUDE_MONITORING AND NOT ONLY_DEVTOOLS) - add_definitions(-DWITH_MONITORING_OPTION) + if(WITH_MONITORING) INSTALL(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/test/monitoring DESTINATION @@ -176,3 +226,13 @@ ELSE() ) ENDIF() + +IF(INCLUDE_SUPERVISOR) + CONFIGURE_FILE(afs-supervisor.service.in afs-supervisor.service @ONLY) + INSTALL(FILES + ${CMAKE_CURRENT_BINARY_DIR}/afs-supervisor.service + DESTINATION + ${UNITDIR_SYSTEM} + ) +ENDIF() +