Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 1 | #------------------------------------------------------------------------------ |
David Vincze | c3e313a | 2020-01-06 17:31:11 +0100 | [diff] [blame^] | 2 | # Copyright (c) 2017-2020, Arm Limited. All rights reserved. |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 3 | # |
| 4 | # SPDX-License-Identifier: BSD-3-Clause |
| 5 | # |
| 6 | #------------------------------------------------------------------------------ |
| 7 | |
| 8 | cmake_minimum_required(VERSION 3.7) |
| 9 | |
David Hu | 857bfa5 | 2019-05-21 13:54:50 +0800 | [diff] [blame] | 10 | set(TFM_BUILD_IN_SPE ON) |
| 11 | |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 12 | #Tell cmake where our modules can be found |
| 13 | list(APPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_LIST_DIR}/../../../cmake) |
| 14 | |
| 15 | #Include common stuff to control cmake. |
| 16 | include("Common/BuildSys") |
| 17 | |
| 18 | #Start an embedded project. |
David Vincze | c3e313a | 2020-01-06 17:31:11 +0100 | [diff] [blame^] | 19 | get_filename_component(TFM_ROOT_DIR "${CMAKE_CURRENT_LIST_DIR}/../../.." ABSOLUTE) |
Ken Liu | e40f9a2 | 2019-06-03 16:42:47 +0800 | [diff] [blame] | 20 | embedded_project_start(CONFIG "${TFM_ROOT_DIR}/configs/ConfigDefault.cmake") |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 21 | project(mcuboot LANGUAGES ASM C) |
| 22 | embedded_project_fixup() |
| 23 | |
David Vincze | c3e313a | 2020-01-06 17:31:11 +0100 | [diff] [blame^] | 24 | #Set the appropriate MCUBoot path |
| 25 | if (MCUBOOT_REPO STREQUAL "TF-M") |
| 26 | get_filename_component(MCUBOOT_DIR ${CMAKE_CURRENT_LIST_DIR} ABSOLUTE) |
| 27 | else() |
| 28 | get_filename_component(MCUBOOT_DIR "${TFM_ROOT_DIR}/../mcuboot/boot" ABSOLUTE) |
| 29 | if (NOT EXISTS ${MCUBOOT_DIR}) |
| 30 | message(FATAL_ERROR "Missing MCUBoot. Please clone the MCUBoot repo to directory \"${MCUBOOT_DIR}\".") |
| 31 | endif() |
| 32 | endif() |
| 33 | |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 34 | #Check input variables |
| 35 | if (NOT DEFINED BL2) |
| 36 | message(FATAL ERROR "Incomplete build configuration: BL2 is undefined.") |
| 37 | elseif(NOT BL2) |
| 38 | #If mcuboot is not need to be built then stop further processing. |
| 39 | return() |
| 40 | endif() |
| 41 | |
Raef Coles | 1bb168e | 2019-10-17 09:04:55 +0100 | [diff] [blame] | 42 | if (NOT DEFINED MBEDCRYPTO_C_FLAGS_BL2) |
| 43 | message(FATAL_ERROR "Incomplete build configuration: MBEDCRYPTO_C_FLAGS_BL2 is undefined.") |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 44 | endif() |
| 45 | |
Marc Moreno Berengue | a1f296f | 2018-01-25 15:21:22 +0000 | [diff] [blame] | 46 | set(BUILD_CMSIS_CORE On) |
| 47 | set(BUILD_RETARGET On) |
| 48 | set(BUILD_NATIVE_DRIVERS On) |
| 49 | set(BUILD_STARTUP On) |
| 50 | set(BUILD_TARGET_CFG Off) |
David Vincze | 060968d | 2019-05-23 01:13:14 +0200 | [diff] [blame] | 51 | set(BUILD_TARGET_NV_COUNTERS On) |
Marc Moreno Berengue | a1f296f | 2018-01-25 15:21:22 +0000 | [diff] [blame] | 52 | set(BUILD_CMSIS_DRIVERS On) |
| 53 | set(BUILD_TIME Off) |
| 54 | set(BUILD_UART_STDOUT On) |
| 55 | set(BUILD_FLASH On) |
Mate Toth-Pal | d3c7766 | 2019-02-20 16:23:00 +0100 | [diff] [blame] | 56 | set(BUILD_PLAT_TEST Off) |
Tamas Ban | d4bf347 | 2019-09-06 12:59:56 +0100 | [diff] [blame] | 57 | set(BUILD_BOOT_HAL On) |
Tamas Ban | d0f4e1d | 2019-07-11 09:39:03 +0100 | [diff] [blame] | 58 | |
| 59 | if (MCUBOOT_HW_KEY) |
| 60 | set(BUILD_TARGET_HARDWARE_KEYS On) |
| 61 | else() |
| 62 | set(BUILD_TARGET_HARDWARE_KEYS Off) |
| 63 | endif() |
| 64 | |
Marc Moreno Berengue | a1f296f | 2018-01-25 15:21:22 +0000 | [diff] [blame] | 65 | if(NOT DEFINED PLATFORM_CMAKE_FILE) |
| 66 | message (FATAL_ERROR "Platform specific CMake is not defined. Please set PLATFORM_CMAKE_FILE.") |
| 67 | elseif(NOT EXISTS ${PLATFORM_CMAKE_FILE}) |
| 68 | message (FATAL_ERROR "Platform specific CMake \"${PLATFORM_CMAKE_FILE}\" file does not exist. Please fix value of PLATFORM_CMAKE_FILE.") |
| 69 | else() |
| 70 | include(${PLATFORM_CMAKE_FILE}) |
| 71 | endif() |
| 72 | |
David Hu | 857bfa5 | 2019-05-21 13:54:50 +0800 | [diff] [blame] | 73 | #Add platform specific definitions in SPE |
| 74 | if (DEFINED TFM_PLATFORM_SECURE_DEFS) |
| 75 | embedded_set_target_compile_defines(TARGET ${PROJECT_NAME} LANGUAGE C DEFINES ${TFM_PLATFORM_SECURE_DEFS} APPEND) |
| 76 | embedded_set_target_compile_defines(TARGET ${PROJECT_NAME} LANGUAGE ASM DEFINES ${TFM_PLATFORM_SECURE_DEFS} APPEND) |
| 77 | endif() |
| 78 | |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 79 | #Append all our source files to global lists. |
Tamas Ban | a9de4a6 | 2018-09-18 08:09:45 +0100 | [diff] [blame] | 80 | list(APPEND ALL_SRC_C |
David Vincze | c3e313a | 2020-01-06 17:31:11 +0100 | [diff] [blame^] | 81 | "${TFM_ROOT_DIR}/bl2/ext/mcuboot/bl2_main.c" |
| 82 | "${TFM_ROOT_DIR}/bl2/ext/mcuboot/flash_map_extended.c" |
| 83 | "${TFM_ROOT_DIR}/bl2/ext/mcuboot/flash_map_legacy.c" |
| 84 | "${TFM_ROOT_DIR}/bl2/ext/mcuboot/keys.c" |
| 85 | "${TFM_ROOT_DIR}/bl2/src/flash_map.c" |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 86 | "${MCUBOOT_DIR}/bootutil/src/loader.c" |
| 87 | "${MCUBOOT_DIR}/bootutil/src/bootutil_misc.c" |
| 88 | "${MCUBOOT_DIR}/bootutil/src/image_validate.c" |
| 89 | "${MCUBOOT_DIR}/bootutil/src/image_rsa.c" |
David Vincze | 07706a4 | 2019-12-12 18:20:12 +0100 | [diff] [blame] | 90 | "${MCUBOOT_DIR}/bootutil/src/tlv.c" |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 91 | ) |
| 92 | |
David Vincze | c3e313a | 2020-01-06 17:31:11 +0100 | [diff] [blame^] | 93 | if (MCUBOOT_REPO STREQUAL "TF-M") |
| 94 | list(APPEND ALL_SRC_C |
| 95 | "${TFM_ROOT_DIR}/bl2/src/boot_record.c" |
| 96 | "${TFM_ROOT_DIR}/bl2/src/security_cnt.c" |
| 97 | ) |
| 98 | endif() |
| 99 | |
Raef Coles | 1bb168e | 2019-10-17 09:04:55 +0100 | [diff] [blame] | 100 | #Define location of Mbed Crypto source, build, and installation directory. |
David Vincze | cea8b59 | 2019-10-29 16:09:51 +0100 | [diff] [blame] | 101 | set(MBEDTLS_CONFIG_FILE "config-rsa.h") |
Raef Coles | 0e82adc | 2019-10-17 15:06:26 +0100 | [diff] [blame] | 102 | set(MBEDTLS_CONFIG_PATH "${TFM_ROOT_DIR}/bl2/ext/mcuboot/include") |
Raef Coles | 1bb168e | 2019-10-17 09:04:55 +0100 | [diff] [blame] | 103 | get_filename_component(MBEDCRYPTO_SOURCE_DIR "${TFM_ROOT_DIR}/../mbed-crypto" ABSOLUTE) |
| 104 | if(NOT EXISTS ${MBEDCRYPTO_SOURCE_DIR}) |
| 105 | message(FATAL_ERROR "Missing mbed-crypto. Please clone the mbed-crypto repo to directory \"${MBEDCRYPTO_SOURCE_DIR}\".") |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 106 | endif() |
Raef Coles | 1bb168e | 2019-10-17 09:04:55 +0100 | [diff] [blame] | 107 | set (MBEDCRYPTO_BINARY_DIR "${CMAKE_CURRENT_BINARY_DIR}/mbed-crypto/build") |
| 108 | set (MBEDCRYPTO_INSTALL_DIR ${MBEDCRYPTO_BINARY_DIR}/../install) |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 109 | |
Tamas Ban | f824e74 | 2019-10-25 21:22:26 +0100 | [diff] [blame] | 110 | if (CRYPTO_HW_ACCELERATOR OR CRYPTO_HW_ACCELERATOR_OTP_STATE STREQUAL "PROVISIONING") |
Raef Coles | 0e82adc | 2019-10-17 15:06:26 +0100 | [diff] [blame] | 111 | if(NOT DEFINED CRYPTO_HW_ACCELERATOR_CMAKE_BUILD) |
| 112 | message(FATAL_ERROR "CRYPTO_HW_ACCELERATOR_CMAKE_BUILD not defined.") |
| 113 | endif() |
| 114 | include(${CRYPTO_HW_ACCELERATOR_CMAKE_BUILD}) |
| 115 | endif() |
| 116 | |
Raef Coles | 1bb168e | 2019-10-17 09:04:55 +0100 | [diff] [blame] | 117 | #Build Mbed Crypto as external project. |
| 118 | #This ensures Mbed Crypto is built with exactly defined settings. |
Raef Coles | 0e82adc | 2019-10-17 15:06:26 +0100 | [diff] [blame] | 119 | #Mbed Crypto will be used from its install location |
| 120 | string(APPEND MBEDCRYPTO_C_FLAGS " ${MBEDCRYPTO_C_FLAGS_BL2}") |
Raef Coles | 1bb168e | 2019-10-17 09:04:55 +0100 | [diff] [blame] | 121 | set(MBEDCRYPTO_TARGET_NAME "mbedcrypto_mcuboot_lib") |
| 122 | include(${TFM_ROOT_DIR}/BuildMbedCrypto.cmake) |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 123 | |
| 124 | #Setting include directories |
Tamas Ban | db69d52 | 2018-03-01 10:04:41 +0000 | [diff] [blame] | 125 | embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR} ABSOLUTE APPEND) |
Raef Coles | 4d6ea2f | 2019-10-15 14:30:40 +0100 | [diff] [blame] | 126 | embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR}/interface/include ABSOLUTE APPEND) |
Tamas Ban | a9de4a6 | 2018-09-18 08:09:45 +0100 | [diff] [blame] | 127 | embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR}/bl2/include ABSOLUTE APPEND) |
Tamas Ban | db69d52 | 2018-03-01 10:04:41 +0000 | [diff] [blame] | 128 | embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR}/bl2/ext/mcuboot/include ABSOLUTE APPEND) |
David Vincze | c3e313a | 2020-01-06 17:31:11 +0100 | [diff] [blame^] | 129 | embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${MCUBOOT_DIR}/bootutil/include ABSOLUTE APPEND) |
Raef Coles | 1bb168e | 2019-10-17 09:04:55 +0100 | [diff] [blame] | 130 | embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${MBEDCRYPTO_INSTALL_DIR}/include ABSOLUTE APPEND) |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 131 | |
| 132 | #Define linker file |
Mate Toth-Pal | 48fc6a0 | 2018-01-24 09:50:14 +0100 | [diff] [blame] | 133 | if(NOT DEFINED BL2_LINKER_CONFIG) |
| 134 | message(FATAL_ERROR "ERROR: Incomplete Configuration: BL2_LINKER_CONFIG is not defined.") |
| 135 | endif() |
Gabor Kertesz | d7d7d74 | 2018-07-04 11:50:05 +0200 | [diff] [blame] | 136 | embedded_set_target_linker_file(TARGET ${PROJECT_NAME} PATH "${BL2_LINKER_CONFIG}") |
| 137 | |
| 138 | if(NOT DEFINED PLATFORM_LINK_INCLUDES) |
| 139 | message(FATAL_ERROR "ERROR: Incomplete Configuration: PLATFORM_LINK_INCLUDES is not defined.") |
| 140 | endif() |
| 141 | embedded_set_target_link_includes(TARGET ${PROJECT_NAME} INCLUDES "${PLATFORM_LINK_INCLUDES}") |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 142 | |
David Hu | 857bfa5 | 2019-05-21 13:54:50 +0800 | [diff] [blame] | 143 | add_executable(${PROJECT_NAME} ${ALL_SRC_ASM} ${ALL_SRC_C_BL2} ${ALL_SRC_ASM_BL2} ${ALL_SRC_C} ${ALL_SRC_CXX}) |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 144 | |
Tamas Ban | db69d52 | 2018-03-01 10:04:41 +0000 | [diff] [blame] | 145 | #Set common compiler and linker flags |
| 146 | config_setting_shared_compiler_flags(${PROJECT_NAME}) |
| 147 | config_setting_shared_linker_flags(${PROJECT_NAME}) |
| 148 | |
David Vincze | 63eda7a | 2019-08-09 17:42:51 +0200 | [diff] [blame] | 149 | #Add BL2 and MCUBOOT_IMAGE_NUMBER defines to linker to resolve symbols in region_defs.h and flash_layout.h |
| 150 | embedded_set_target_link_defines(TARGET ${PROJECT_NAME} DEFINES "BL2" "MCUBOOT_IMAGE_NUMBER=${MCUBOOT_IMAGE_NUMBER}") |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 151 | |
Marc Moreno Berengue | cae2c53 | 2018-10-09 12:58:46 +0100 | [diff] [blame] | 152 | if(NOT DEFINED TEST_FRAMEWORK_S) |
| 153 | message(FATAL_ERROR "Incomplete build configuration: TEST_FRAMEWORK_S is undefined.") |
| 154 | elseif(TEST_FRAMEWORK_S) |
| 155 | embedded_set_target_link_defines(TARGET ${PROJECT_NAME} DEFINES "TEST_FRAMEWORK_S") |
| 156 | endif() |
| 157 | |
| 158 | if(NOT DEFINED TEST_FRAMEWORK_NS) |
| 159 | message(FATAL_ERROR "Incomplete build configuration: TEST_FRAMEWORK_NS is undefined.") |
| 160 | elseif(TEST_FRAMEWORK_NS) |
| 161 | embedded_set_target_link_defines(TARGET ${PROJECT_NAME} DEFINES "TEST_FRAMEWORK_NS") |
| 162 | endif() |
| 163 | |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 164 | #Link mbedcrypto library to project |
Raef Coles | 1bb168e | 2019-10-17 09:04:55 +0100 | [diff] [blame] | 165 | target_link_libraries(${PROJECT_NAME} "${MBEDCRYPTO_INSTALL_DIR}/lib/${CMAKE_STATIC_LIBRARY_PREFIX_C}mbedcrypto${CMAKE_STATIC_LIBRARY_SUFFIX_C}") |
| 166 | add_dependencies(${PROJECT_NAME} ${MBEDCRYPTO_TARGET_NAME}_install) |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 167 | |
Raef Coles | 0e82adc | 2019-10-17 15:06:26 +0100 | [diff] [blame] | 168 | #Link crypto accelerator libraries if applicable |
Tamas Ban | f824e74 | 2019-10-25 21:22:26 +0100 | [diff] [blame] | 169 | if (CRYPTO_HW_ACCELERATOR OR CRYPTO_HW_ACCELERATOR_OTP_STATE STREQUAL "PROVISIONING") |
Raef Coles | 0e82adc | 2019-10-17 15:06:26 +0100 | [diff] [blame] | 170 | if(NOT DEFINED CRYPTO_HW_ACCELERATOR_CMAKE_LINK) |
| 171 | message(FATAL_ERROR "CRYPTO_HW_ACCELERATOR_CMAKE_LINK not defined.") |
| 172 | endif() |
| 173 | include(${CRYPTO_HW_ACCELERATOR_CMAKE_LINK}) |
| 174 | endif() |
| 175 | |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 176 | #Generate binary file from axf |
| 177 | compiler_generate_binary_output(${PROJECT_NAME}) |
| 178 | |
David Vincze | c3e313a | 2020-01-06 17:31:11 +0100 | [diff] [blame^] | 179 | message("- MCUBOOT_REPO: '${MCUBOOT_REPO}'.") |
David Vincze | 73dfbc5 | 2019-10-11 13:54:58 +0200 | [diff] [blame] | 180 | message("- MCUBOOT_IMAGE_NUMBER: '${MCUBOOT_IMAGE_NUMBER}'.") |
| 181 | message("- MCUBOOT_UPGRADE_STRATEGY: '${MCUBOOT_UPGRADE_STRATEGY}'.") |
| 182 | message("- MCUBOOT_SIGNATURE_TYPE: '${MCUBOOT_SIGNATURE_TYPE}'.") |
| 183 | message("- MCUBOOT_HW_KEY: '${MCUBOOT_HW_KEY}'.") |
| 184 | message("- MCUBOOT_LOG_LEVEL: '${MCUBOOT_LOG_LEVEL}'.") |
David Vincze | 54d0555 | 2019-08-05 12:58:47 +0200 | [diff] [blame] | 185 | |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 186 | #Set macro definitions for the project. |
| 187 | target_compile_definitions(${PROJECT_NAME} PRIVATE |
David Vincze | 8bdfc2d | 2019-03-18 15:49:23 +0100 | [diff] [blame] | 188 | MCUBOOT_VALIDATE_PRIMARY_SLOT |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 189 | MCUBOOT_USE_FLASH_AREA_GET_SECTORS |
Raef Coles | 0e82adc | 2019-10-17 15:06:26 +0100 | [diff] [blame] | 190 | MBEDTLS_CONFIG_FILE="${MBEDTLS_CONFIG_FILE}" |
Tamas Ban | db69d52 | 2018-03-01 10:04:41 +0000 | [diff] [blame] | 191 | MCUBOOT_TARGET_CONFIG="flash_layout.h") |
| 192 | |
David Vincze | c3e313a | 2020-01-06 17:31:11 +0100 | [diff] [blame^] | 193 | if (MCUBOOT_REPO STREQUAL "UPSTREAM") |
| 194 | target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_USE_UPSTREAM) |
| 195 | endif() |
| 196 | |
Tamas Ban | 7801ed4 | 2019-05-20 13:21:53 +0100 | [diff] [blame] | 197 | if (MCUBOOT_SIGNATURE_TYPE STREQUAL "RSA-3072") |
| 198 | target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_SIGN_RSA MCUBOOT_SIGN_RSA_LEN=3072) |
| 199 | elseif(MCUBOOT_SIGNATURE_TYPE STREQUAL "RSA-2048") |
| 200 | target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_SIGN_RSA MCUBOOT_SIGN_RSA_LEN=2048) |
| 201 | else() |
| 202 | message(FATAL_ERROR "${MCUBOOT_SIGNATURE_TYPE} is not supported as firmware signing algorithm") |
| 203 | endif() |
| 204 | |
David Vincze | 4638b2a | 2019-05-24 10:14:23 +0200 | [diff] [blame] | 205 | if (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "OVERWRITE_ONLY") |
| 206 | target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_OVERWRITE_ONLY) |
| 207 | elseif (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "NO_SWAP") |
Tamas Ban | db69d52 | 2018-03-01 10:04:41 +0000 | [diff] [blame] | 208 | target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_NO_SWAP) |
David Vincze | 4638b2a | 2019-05-24 10:14:23 +0200 | [diff] [blame] | 209 | elseif (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "RAM_LOADING") |
Oliver Swede | f998244 | 2018-08-24 18:37:44 +0100 | [diff] [blame] | 210 | target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_RAM_LOADING) |
David Vincze | 4638b2a | 2019-05-24 10:14:23 +0200 | [diff] [blame] | 211 | elseif (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "SWAP") |
| 212 | #No compile definition needs to be specified for this upgrade strategy |
| 213 | else() |
David Vincze | 54d0555 | 2019-08-05 12:58:47 +0200 | [diff] [blame] | 214 | get_property(_upgrade_strategies CACHE MCUBOOT_UPGRADE_STRATEGY PROPERTY STRINGS) |
| 215 | message(FATAL_ERROR "ERROR: MCUBoot supports the ${_upgrade_strategies} upgrade strategies only.") |
Oliver Swede | f998244 | 2018-08-24 18:37:44 +0100 | [diff] [blame] | 216 | endif() |
| 217 | |
Tamas Ban | d0f4e1d | 2019-07-11 09:39:03 +0100 | [diff] [blame] | 218 | if (MCUBOOT_HW_KEY) |
| 219 | target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_HW_KEY) |
| 220 | endif() |
| 221 | |
David Vincze | 219a175 | 2019-10-14 11:35:09 +0200 | [diff] [blame] | 222 | if (ATTEST_BOOT_INTERFACE STREQUAL "INDIVIDUAL_CLAIMS") |
| 223 | target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_INDIVIDUAL_CLAIMS) |
| 224 | message(WARNING "ATTEST_BOOT_INTERFACE was set to ${ATTEST_BOOT_INTERFACE}. This configuration is " |
| 225 | "deprecated and this feature will probably be removed from MCUBoot in the future.") |
| 226 | endif() |
| 227 | |
David Vincze | 73dfbc5 | 2019-10-11 13:54:58 +0200 | [diff] [blame] | 228 | #Configure log level for MCUBoot. |
| 229 | get_property(_log_levels CACHE MCUBOOT_LOG_LEVEL PROPERTY STRINGS) |
| 230 | list(FIND _log_levels ${MCUBOOT_LOG_LEVEL} LOG_LEVEL_ID) |
David Vincze | 99f1b36 | 2019-12-12 16:17:35 +0100 | [diff] [blame] | 231 | target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_LOG_LEVEL=${LOG_LEVEL_ID}) |
David Vincze | 73dfbc5 | 2019-10-11 13:54:58 +0200 | [diff] [blame] | 232 | |
Tamas Ban | db69d52 | 2018-03-01 10:04:41 +0000 | [diff] [blame] | 233 | #Set install location. Keep original value to avoid overriding command line settings. |
| 234 | if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) |
| 235 | set(CMAKE_INSTALL_PREFIX "${CMAKE_BINARY_DIR}/install" CACHE PATH "Default install location for MCUBoot." FORCE) |
| 236 | endif() |
| 237 | |
| 238 | #Collect executables to common location: build/install/outputs/ |
| 239 | install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.axf |
| 240 | ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.bin |
| 241 | DESTINATION outputs/${TARGET_PLATFORM}/) |
| 242 | |
| 243 | install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.axf |
| 244 | ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.bin |
| 245 | DESTINATION outputs/fvp/) |
Tamas Ban | 581034a | 2017-12-19 19:54:37 +0000 | [diff] [blame] | 246 | |
| 247 | #Finally let cmake system apply changes after the whole project is defined. |
| 248 | embedded_project_end(${PROJECT_NAME}) |