X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=CMakeLists.txt;h=ecfc13d0445986e7a0a0d6a0f80d0b13835b2779;hb=refs%2Fheads%2Faccepted%2Ftizen_8.0_unified;hp=97874285be5a32d43e57e7c3710f658bbf95d3c9;hpb=22d7ce9b325028cc6d54450753157029a7cd40a3;p=platform%2Fcore%2Fsecurity%2Fkey-manager.git diff --git a/CMakeLists.txt b/CMakeLists.txt index 9787428..ecfc13d 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,4 +1,4 @@ -# Copyright (c) 2011 - 2018 Samsung Electronics Co., Ltd All Rights Reserved +# Copyright (c) 2011-2020 Samsung Electronics Co., Ltd. All rights reserved # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -29,13 +29,13 @@ INCLUDE(FindPkgConfig) ############################# compiler flags ################################## SET(CMAKE_C_FLAGS_PROFILING "-g -O0 -pg -Wp,-U_FORTIFY_SOURCE") -SET(CMAKE_CXX_FLAGS_PROFILING "-g -std=c++14 -O0 -pg -Wp,-U_FORTIFY_SOURCE") +SET(CMAKE_CXX_FLAGS_PROFILING "-g -std=c++17 -O0 -pg -Wp,-U_FORTIFY_SOURCE -Wno-deprecated-declarations") SET(CMAKE_C_FLAGS_DEBUG "-g -O0 -ggdb -Wp,-U_FORTIFY_SOURCE") -SET(CMAKE_CXX_FLAGS_DEBUG "-g -std=c++14 -O0 -ggdb -Wp,-U_FORTIFY_SOURCE") +SET(CMAKE_CXX_FLAGS_DEBUG "-g -std=c++17 -O0 -ggdb -Wp,-U_FORTIFY_SOURCE -Wshadow -Wno-deprecated-declarations") SET(CMAKE_C_FLAGS_RELEASE "-g -O2") -SET(CMAKE_CXX_FLAGS_RELEASE "-g -std=c++14 -O2") -SET(CMAKE_C_FLAGS_CCOV "-g -O2 --coverage") -SET(CMAKE_CXX_FLAGS_CCOV "-g -std=c++14 -O2 --coverage") +SET(CMAKE_CXX_FLAGS_RELEASE "-g -std=c++17 -O2 -Wshadow -Wno-deprecated-declarations") +SET(CMAKE_C_FLAGS_COVERAGE "-g -O0 -ggdb --coverage -Wp,-U_FORTIFY_SOURCE") +SET(CMAKE_CXX_FLAGS_COVERAGE "-g -std=c++17 -O0 -ggdb --coverage -Wp,-U_FORTIFY_SOURCE -Wno-deprecated-declarations") # Force PIE SET(CMAKE_POSITION_INDEPENDENT_CODE "True") @@ -49,7 +49,9 @@ ADD_DEFINITIONS("-Wextra") # Generate even more extra warni STRING(REGEX MATCH "([^.]*)" API_VERSION "${VERSION}") ADD_DEFINITIONS("-DAPI_VERSION=\"$(API_VERSION)\"") ADD_DEFINITIONS("-DSMACK_ENABLED") -ADD_DEFINITIONS("-DSQLCIPHER_HAS_CODEC") +ADD_DEFINITIONS("-DSQLITE_HAS_CODEC") +ADD_DEFINITIONS("-DDUMP_LEGACY_DB_LIBNAME=\"${DUMP_LEGACY_DB_LIBNAME}\"") +ADD_DEFINITIONS("-DLIB_INSTALL_DIR=\"${LIB_INSTALL_DIR}\"") ADD_DEFINITIONS("-DRUN_DIR=\"${RUN_DIR}\"") ADD_DEFINITIONS("-DSERVICE_NAME=\"${SERVICE_NAME}\"") ADD_DEFINITIONS("-DUSER_NAME=\"${USER_NAME}\"") @@ -65,16 +67,46 @@ ADD_DEFINITIONS("-DINITIAL_VALUES_DIR_RW=\"${INITIAL_VALUES_DIR_RW}\"") ADD_DEFINITIONS("-DCA_CERTS_DIR=\"${CA_CERTS_DIR}\"") ADD_DEFINITIONS("-DSYSTEMD_ENV_FILE=\"${SYSTEMD_ENV_FILE}\"") +SET(KEY_MANAGER_PATH ${PROJECT_SOURCE_DIR}/src/manager) + +IF(NOT DEFINED COVERAGE_DIR) + SET(COVERAGE_DIR + "/opt/data/ckm-coverage" + CACHE PATH + "Read-only coverage data directory") +ENDIF(NOT DEFINED COVERAGE_DIR) +ADD_DEFINITIONS("-DCOVERAGE_DIR=\"${COVERAGE_DIR}\"") + IF (TZ_BACKEND_ENABLED) ADD_DEFINITIONS("-DTZ_BACKEND_ENABLED") + SET(EXTRA_KM_DEPS ${EXTRA_KM_DEPS} tef-libteec) + SET(KM_LINK_EXTRA_DEPS km_serialization) + SET(TZ_BACKEND_SOURCES + ${KEY_MANAGER_PATH}/crypto/tz-backend/internals.cpp + ${KEY_MANAGER_PATH}/crypto/tz-backend/obj.cpp + ${KEY_MANAGER_PATH}/crypto/tz-backend/ctx.cpp + ${KEY_MANAGER_PATH}/crypto/tz-backend/store.cpp + ${KEY_MANAGER_PATH}/crypto/tz-backend/tz-context.cpp + ${KEY_MANAGER_PATH}/crypto/tz-backend/tz-memory.cpp + ${KEY_MANAGER_PATH}/crypto/tz-backend/tz-serializer.cpp + ) +ENDIF() + +IF (SE_BACKEND_ENABLED) + ADD_DEFINITIONS("-DSE_BACKEND_ENABLED") + SET(SE_BACKEND_SOURCES + ${KEY_MANAGER_PATH}/crypto/se-backend/internals.cpp + ) + SET(EXTRA_KM_DEPS ${EXTRA_KM_DEPS} key-manager-se-backend) ENDIF() IF (DEFINED WATCHDOG_ENABLED) - MESSAGE("WATCHDOG ENABELD!") + MESSAGE("WATCHDOG ENABLED!") ADD_DEFINITIONS("-DWATCHDOG_ENABLED") ADD_DEFINITIONS("-DWATCHDOG_TIMEOUT_SEC=${WATCHDOG_TIMEOUT_SEC}") ADD_DEFINITIONS("-DWATCHDOG_NOTIFY_SEC=${WATCHDOG_NOTIFY_SEC}") SET(WATCHDOG_DECLARE "NotifyAccess=main") + SET(EXTRA_KM_DEPS ${EXTRA_KM_DEPS} argos_watchdog) ENDIF (DEFINED WATCHDOG_ENABLED) IF (CMAKE_BUILD_TYPE MATCHES "DEBUG") @@ -90,16 +122,36 @@ SET(TARGET_KEY_MANAGER_CONTROL_CLIENT "key-manager-control-client") SET(TARGET_KEY_MANAGER_COMMON "key-manager-common") SET(TARGET_PAM_KEY_MANAGER_PLUGIN "pam_key_manager_plugin") -SET(TARGET_TEST_MERGED "ckm-tests-internal") - -CONFIGURE_FILE(packaging/key-manager.manifest.in key-manager.manifest @ONLY) -CONFIGURE_FILE(packaging/key-manager-tests.manifest.in key-manager-tests.manifest @ONLY) - +SET(TARGET_UNIT_TESTS "ckm-unit-tests") + +PKG_CHECK_MODULES(KEY_MANAGER_DEP + REQUIRED + dlog + glib-2.0 + openssl3 + libsmack + libsystemd + capi-base-common + capi-system-info + libxml-2.0 + security-manager + cynara-client-async + cynara-creds-socket + pkgmgr + vconf + sqlcipher + capi-system-resource + ${EXTRA_KM_DEPS} +) + +IF (NOT DEFINED COVERAGE_ONLY) ADD_SUBDIRECTORY(data) ADD_SUBDIRECTORY(doc) ADD_SUBDIRECTORY(src) ADD_SUBDIRECTORY(build) ADD_SUBDIRECTORY(systemd) -ADD_SUBDIRECTORY(tests) -ADD_SUBDIRECTORY(tools) +ADD_SUBDIRECTORY(misc) ADD_SUBDIRECTORY(upgrade) +ENDIF (NOT DEFINED COVERAGE_ONLY) + +ADD_SUBDIRECTORY(unit-tests)