X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2FCMakeLists.txt;h=3a94d0db0289aa0e4865a891ca8e31f372baae0f;hb=0083ad3751cd2b088b5c5d0dea727671ea2a3cca;hp=89d4d51fe08e31352081107e90dca8846ce73137;hpb=9549e8c28032c2d1fb578c43f1b340d1457b3c70;p=src%2Fapp-framework-main.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 89d4d51..3a94d0d 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,5 +1,5 @@ ########################################################################### -# Copyright 2015 IoT.bzh +# Copyright (C) 2015-2020 IoT.bzh # # author: José Bollo # @@ -16,44 +16,21 @@ # limitations under the License. ########################################################################### -cmake_minimum_required(VERSION 2.8) - -include(FindPkgConfig) - -pkg_check_modules(EXTRAS REQUIRED - libxml-2.0 - openssl - xmlsec1 xmlsec1-openssl - json-c - dbus-1 - ) - -add_compile_options(${EXTRAS_CFLAGS}) -include_directories(${EXTRAS_INCLUDE_DIRS}) -link_libraries(${EXTRAS_LIBRARIES}) - -if(USE_LIBZIP) - pkg_check_modules(LIBZIP REQUIRED libzip>=0.11) - add_compile_options(${LIBZIP_CFLAGS}) - include_directories(${LIBZIP_INCLUDE_DIRS}) - link_libraries(${LIBZIP_LIBRARIES}) - add_definitions(-DUSE_LIBZIP=1) -else(USE_LIBZIP) - find_program(PATH_TO_ZIP zip) - find_program(PATH_TO_UNZIP unzip) - add_definitions(-DUSE_LIBZIP=0 -DPATH_TO_ZIP="${PATH_TO_ZIP}" -DPATH_TO_UNZIP="${PATH_TO_UNZIP}") -endif(USE_LIBZIP) +cmake_minimum_required(VERSION 3.4.3) ########################################################################### -include_directories(simulation) - -########################################################################### +link_libraries(-Wl,--as-needed -Wl,--gc-sections) -add_compile_options(-Wall -Wno-pointer-sign) +add_compile_options(-Wall -Wextra -Wconversion) +add_compile_options(-Wno-unused-parameter) # frankly not using a parameter does it care? +add_compile_options(-Werror=maybe-uninitialized) +add_compile_options(-Werror=implicit-function-declaration) +add_compile_options(-Wno-pointer-sign) # for XmlChar handling add_compile_options(-ffunction-sections -fdata-sections) +add_compile_options(-Wl,--as-needed -Wl,--gc-sections) add_compile_options(-fPIC) -add_compile_options(-Wl,--gc-sections) +#add_definitions(-DNDEBUG) set(CMAKE_C_FLAGS_PROFILING "-g -O0 -pg -Wp,-U_FORTIFY_SOURCE") set(CMAKE_C_FLAGS_DEBUG "-g -O0 -ggdb -Wp,-U_FORTIFY_SOURCE") @@ -62,59 +39,161 @@ set(CMAKE_C_FLAGS_CCOV "-g -O2 --coverage") ########################################################################### -add_library(wgtpkg +include(FindPkgConfig) + +pkg_check_modules(EXTRAS REQUIRED libxml-2.0 openssl xmlsec1 xmlsec1-openssl json-c) +add_compile_options(${EXTRAS_CFLAGS}) +include_directories(${EXTRAS_INCLUDE_DIRS}) +link_libraries(${EXTRAS_LIBRARIES}) +link_directories(${EXTRAS_LIBRARY_DIRS}) + +pkg_check_modules(libzip libzip>=0.11) +if(libzip_FOUND AND USE_LIBZIP) + add_compile_options(${libzip_CFLAGS}) + include_directories(${libzip_INCLUDE_DIRS}) + link_libraries(${libzip_LIBRARIES}) + link_directories(${libzip_LIBRARY_DIRS}) + add_definitions(-DUSE_LIBZIP=1) +else() + add_definitions(-DUSE_LIBZIP=0) +endif() + +pkg_check_modules(libsystemd libsystemd>=222) +if(libsystemd_FOUND) + add_compile_options(${libsystemd_CFLAGS}) + include_directories(${libsystemd_INCLUDE_DIRS}) + link_libraries(${libsystemd_LIBRARIES}) + link_directories(${libsystemd_LIBRARY_DIRS}) +else() + add_definitions(-DNO_LIBSYSTEMD) +endif() + +pkg_check_modules(AFB afb-daemon>=4.99 libafbwsc>=4.99) +if(AFB_FOUND) + add_compile_options(${AFB_CFLAGS}) + include_directories(${AFB_INCLUDE_DIRS}) + link_libraries(${AFB_LIBRARIES}) + link_directories(${AFB_LIBRARY_DIRS}) +endif() + +########################################################################### + +if(SIMULATE_SECMGR) + add_definitions(-DSIMULATE_SECURITY_MANAGER=1) +else(SIMULATE_SECMGR) + pkg_check_modules(SECMGR REQUIRED security-manager) + add_compile_options(${SECMGR_CFLAGS}) + include_directories(${SECMGR_INCLUDE_DIRS}) + link_libraries(${SECMGR_LIBRARIES}) + link_directories(${SECMGR_LIBRARY_DIRS}) + add_definitions(-DSIMULATE_SECURITY_MANAGER=0) +endif(SIMULATE_SECMGR) + +if(SIMULATE_SMACK) + add_definitions(-DSIMULATE_LIBSMACK=1) +else(SIMULATE_SMACK) + pkg_check_modules(SMACK REQUIRED libsmack) + add_compile_options(${SMACK_CFLAGS}) + include_directories(${SMACK_INCLUDE_DIRS}) + link_libraries(${SMACK_LIBRARIES}) + link_directories(${SMACK_LIBRARY_DIRS}) + add_definitions(-DSIMULATE_LIBSMACK=0) +endif(SIMULATE_SMACK) + +########################################################################### + +add_library(wgtpkg STATIC wgtpkg-base64.c wgtpkg-certs.c wgtpkg-digsig.c wgtpkg-files.c wgtpkg-install.c + wgtpkg-mustach.c wgtpkg-permissions.c + wgtpkg-uninstall.c + wgtpkg-unit.c wgtpkg-workdir.c wgtpkg-xmlsec.c wgtpkg-zip.c ) -add_library(utils +add_library(utils STATIC + mustach.c utils-dir.c - utils-jbus.c + utils-file.c + utils-json.c + utils-systemd.c verbose.c ) -add_library(wgt +add_library(wgt STATIC wgt-config.c wgt-info.c + wgt-strings.c + wgt-json.c wgt.c ) -add_library(secwrp +add_library(secwrp STATIC secmgr-wrap.c ) -add_library(afm - afm-db.c - afm-launch.c - afm-run.c +add_library(afm STATIC + afm-udb.c + afm-urun.c ) -add_executable(wgtpkg-sign wgtpkg-sign.c) +########################################################################### +# off line tools tools + +MESSAGE(STATUS "Creating packaging tools") + +add_executable(wgtpkg-sign main-wgtpkg-sign.c) target_link_libraries(wgtpkg-sign wgtpkg utils) -add_executable(wgtpkg-pack wgtpkg-pack.c) +add_executable(wgtpkg-pack main-wgtpkg-pack.c) target_link_libraries(wgtpkg-pack wgtpkg utils) -add_executable(wgtpkg-info wgtpkg-info.c) +add_executable(wgtpkg-info main-wgtpkg-info.c) target_link_libraries(wgtpkg-info wgtpkg wgt utils) -add_executable(wgtpkg-installer wgtpkg-installer.c) -target_link_libraries(wgtpkg-installer wgtpkg wgt secwrp utils) +add_executable(wgtpkg-install main-wgtpkg-install.c) +target_link_libraries(wgtpkg-install wgtpkg wgt secwrp utils) -add_executable(afm-user-daemon afm-user-daemon.c) -target_link_libraries(afm-user-daemon afm secwrp wgt utils) +install(TARGETS wgtpkg-sign wgtpkg-pack wgtpkg-info wgtpkg-install DESTINATION ${CMAKE_INSTALL_BINDIR}) -add_executable(afm-system-daemon afm-system-daemon.c) -target_link_libraries(afm-system-daemon wgtpkg afm secwrp wgt utils) +########################################################################### +# dynamic tool daemons + +if(libsystemd_FOUND AND AFB_FOUND) + MESSAGE(STATUS "Creating daemons") + + add_library(jbus STATIC utils-jbus.c) + + if(LEGACY_USER_DAEMON) + add_executable(afm-user-daemon afm-user-daemon.c) + target_link_libraries(afm-user-daemon jbus utils) + install(TARGETS afm-user-daemon DESTINATION ${CMAKE_INSTALL_BINDIR}) + endif() + + add_library(afm-binding MODULE afm-binding.c) + target_link_libraries(afm-binding wgtpkg wgt secwrp utils afm) + set_target_properties(afm-binding PROPERTIES + PREFIX "" + LINK_FLAGS "-Wl,--version-script=${CMAKE_CURRENT_SOURCE_DIR}/afm-binding.export-map" + ) + install(TARGETS afm-binding LIBRARY DESTINATION ${afm_libexecdir}) + + add_executable(afm-user-session afm-user-session.c) + install(TARGETS afm-user-session DESTINATION ${afm_libexecdir} + PERMISSIONS SETUID OWNER_READ OWNER_WRITE OWNER_EXECUTE + GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE) +else() + MESSAGE(STATUS "Not creating daemons") +endif() + +########################################################################### +# the tests -install(TARGETS wgtpkg-sign wgtpkg-pack wgtpkg-info wgtpkg-installer DESTINATION ${CMAKE_INSTALL_FULL_BINDIR}) -install(TARGETS afm-user-daemon DESTINATION ${CMAKE_INSTALL_FULL_BINDIR}) -install(TARGETS afm-system-daemon DESTINATION ${CMAKE_INSTALL_FULL_BINDIR}) +add_subdirectory(tests)