blob: ababed199ccdc7176377d810dfc955be4aed3613 [file] [log] [blame]
Tamas Ban581034a2017-12-19 19:54:37 +00001#------------------------------------------------------------------------------
David Vinczec3e313a2020-01-06 17:31:11 +01002# Copyright (c) 2017-2020, Arm Limited. All rights reserved.
Tamas Ban581034a2017-12-19 19:54:37 +00003#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6#------------------------------------------------------------------------------
7
8cmake_minimum_required(VERSION 3.7)
9
David Hu857bfa52019-05-21 13:54:50 +080010set(TFM_BUILD_IN_SPE ON)
11
Tamas Ban581034a2017-12-19 19:54:37 +000012#Tell cmake where our modules can be found
13list(APPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_LIST_DIR}/../../../cmake)
14
15#Include common stuff to control cmake.
16include("Common/BuildSys")
17
18#Start an embedded project.
David Vinczec3e313a2020-01-06 17:31:11 +010019get_filename_component(TFM_ROOT_DIR "${CMAKE_CURRENT_LIST_DIR}/../../.." ABSOLUTE)
Ken Liue40f9a22019-06-03 16:42:47 +080020embedded_project_start(CONFIG "${TFM_ROOT_DIR}/configs/ConfigDefault.cmake")
Tamas Ban581034a2017-12-19 19:54:37 +000021project(mcuboot LANGUAGES ASM C)
22embedded_project_fixup()
23
Raymond Ngune3593c62020-06-25 09:47:36 -070024#Check input variables
25if (NOT DEFINED BL2)
26 message(FATAL ERROR "Incomplete build configuration: BL2 is undefined.")
27elseif(NOT BL2)
28 #If mcuboot is not need to be built then stop further processing.
29 return()
30endif()
31
David Vinczec3e313a2020-01-06 17:31:11 +010032#Set the appropriate MCUBoot path
33if (MCUBOOT_REPO STREQUAL "TF-M")
34 get_filename_component(MCUBOOT_DIR ${CMAKE_CURRENT_LIST_DIR} ABSOLUTE)
35else()
36 get_filename_component(MCUBOOT_DIR "${TFM_ROOT_DIR}/../mcuboot/boot" ABSOLUTE)
37 if (NOT EXISTS ${MCUBOOT_DIR})
38 message(FATAL_ERROR "Missing MCUBoot. Please clone the MCUBoot repo to directory \"${MCUBOOT_DIR}\".")
39 endif()
40endif()
41
Raef Coles1bb168e2019-10-17 09:04:55 +010042if (NOT DEFINED MBEDCRYPTO_C_FLAGS_BL2)
43 message(FATAL_ERROR "Incomplete build configuration: MBEDCRYPTO_C_FLAGS_BL2 is undefined.")
Tamas Ban581034a2017-12-19 19:54:37 +000044endif()
45
Marc Moreno Berenguea1f296f2018-01-25 15:21:22 +000046set(BUILD_CMSIS_CORE On)
47set(BUILD_RETARGET On)
48set(BUILD_NATIVE_DRIVERS On)
49set(BUILD_STARTUP On)
50set(BUILD_TARGET_CFG Off)
David Vincze060968d2019-05-23 01:13:14 +020051set(BUILD_TARGET_NV_COUNTERS On)
Marc Moreno Berenguea1f296f2018-01-25 15:21:22 +000052set(BUILD_CMSIS_DRIVERS On)
53set(BUILD_TIME Off)
54set(BUILD_UART_STDOUT On)
55set(BUILD_FLASH On)
Mate Toth-Pald3c77662019-02-20 16:23:00 +010056set(BUILD_PLAT_TEST Off)
Tamas Band4bf3472019-09-06 12:59:56 +010057set(BUILD_BOOT_HAL On)
Tamas Band0f4e1d2019-07-11 09:39:03 +010058
59if (MCUBOOT_HW_KEY)
60 set(BUILD_TARGET_HARDWARE_KEYS On)
61else()
62 set(BUILD_TARGET_HARDWARE_KEYS Off)
63endif()
64
Marc Moreno Berenguea1f296f2018-01-25 15:21:22 +000065if(NOT DEFINED PLATFORM_CMAKE_FILE)
66 message (FATAL_ERROR "Platform specific CMake is not defined. Please set PLATFORM_CMAKE_FILE.")
67elseif(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.")
69else()
70 include(${PLATFORM_CMAKE_FILE})
71endif()
72
David Hu857bfa52019-05-21 13:54:50 +080073#Add platform specific definitions in SPE
74if (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)
77endif()
78
Mate Toth-Pal8f17a712020-03-02 16:22:19 +010079if (DEFINED CMSE_FLAGS)
80 embedded_set_target_compile_flags(TARGET ${PROJECT_NAME} LANGUAGE C APPEND FLAGS ${CMSE_FLAGS})
81endif()
82
Tamas Ban581034a2017-12-19 19:54:37 +000083#Append all our source files to global lists.
Tamas Bana9de4a62018-09-18 08:09:45 +010084list(APPEND ALL_SRC_C
David Vinczec3e313a2020-01-06 17:31:11 +010085 "${TFM_ROOT_DIR}/bl2/ext/mcuboot/bl2_main.c"
86 "${TFM_ROOT_DIR}/bl2/ext/mcuboot/flash_map_extended.c"
87 "${TFM_ROOT_DIR}/bl2/ext/mcuboot/flash_map_legacy.c"
88 "${TFM_ROOT_DIR}/bl2/ext/mcuboot/keys.c"
89 "${TFM_ROOT_DIR}/bl2/src/flash_map.c"
David Vinczeabb527c2020-01-10 11:19:05 +010090 "${TFM_ROOT_DIR}/bl2/src/security_cnt.c"
Tamas Ban581034a2017-12-19 19:54:37 +000091 "${MCUBOOT_DIR}/bootutil/src/loader.c"
92 "${MCUBOOT_DIR}/bootutil/src/bootutil_misc.c"
93 "${MCUBOOT_DIR}/bootutil/src/image_validate.c"
94 "${MCUBOOT_DIR}/bootutil/src/image_rsa.c"
David Vincze07706a42019-12-12 18:20:12 +010095 "${MCUBOOT_DIR}/bootutil/src/tlv.c"
Tamas Ban581034a2017-12-19 19:54:37 +000096 )
97
David Vinczec3e313a2020-01-06 17:31:11 +010098if (MCUBOOT_REPO STREQUAL "TF-M")
99 list(APPEND ALL_SRC_C
100 "${TFM_ROOT_DIR}/bl2/src/boot_record.c"
David Vinczec3e313a2020-01-06 17:31:11 +0100101 )
Balint Matyi761ebaf2020-03-16 09:12:12 +0100102else()
103 list(APPEND ALL_SRC_C
David Vincze141f2152020-02-19 09:42:07 +0100104 "${MCUBOOT_DIR}/bootutil/src/boot_record.c"
Balint Matyi761ebaf2020-03-16 09:12:12 +0100105 "${MCUBOOT_DIR}/bootutil/src/swap_scratch.c"
106 "${MCUBOOT_DIR}/bootutil/src/swap_move.c"
107 "${MCUBOOT_DIR}/bootutil/src/swap_misc.c"
108 )
David Vinczec3e313a2020-01-06 17:31:11 +0100109endif()
110
Raef Coles1bb168e2019-10-17 09:04:55 +0100111#Define location of Mbed Crypto source, build, and installation directory.
David Vinczecea8b592019-10-29 16:09:51 +0100112set(MBEDTLS_CONFIG_FILE "config-rsa.h")
Raef Coles0e82adc2019-10-17 15:06:26 +0100113set(MBEDTLS_CONFIG_PATH "${TFM_ROOT_DIR}/bl2/ext/mcuboot/include")
Raef Coles1bb168e2019-10-17 09:04:55 +0100114get_filename_component(MBEDCRYPTO_SOURCE_DIR "${TFM_ROOT_DIR}/../mbed-crypto" ABSOLUTE)
115if(NOT EXISTS ${MBEDCRYPTO_SOURCE_DIR})
116 message(FATAL_ERROR "Missing mbed-crypto. Please clone the mbed-crypto repo to directory \"${MBEDCRYPTO_SOURCE_DIR}\".")
Tamas Ban581034a2017-12-19 19:54:37 +0000117endif()
Raef Coles1bb168e2019-10-17 09:04:55 +0100118set (MBEDCRYPTO_BINARY_DIR "${CMAKE_CURRENT_BINARY_DIR}/mbed-crypto/build")
119set (MBEDCRYPTO_INSTALL_DIR ${MBEDCRYPTO_BINARY_DIR}/../install)
Tamas Ban581034a2017-12-19 19:54:37 +0000120
Tamas Banf824e742019-10-25 21:22:26 +0100121if (CRYPTO_HW_ACCELERATOR OR CRYPTO_HW_ACCELERATOR_OTP_STATE STREQUAL "PROVISIONING")
Raef Coles0e82adc2019-10-17 15:06:26 +0100122 if(NOT DEFINED CRYPTO_HW_ACCELERATOR_CMAKE_BUILD)
123 message(FATAL_ERROR "CRYPTO_HW_ACCELERATOR_CMAKE_BUILD not defined.")
124 endif()
125 include(${CRYPTO_HW_ACCELERATOR_CMAKE_BUILD})
126endif()
127
Raef Coles1bb168e2019-10-17 09:04:55 +0100128#Build Mbed Crypto as external project.
129#This ensures Mbed Crypto is built with exactly defined settings.
Raef Coles0e82adc2019-10-17 15:06:26 +0100130#Mbed Crypto will be used from its install location
131string(APPEND MBEDCRYPTO_C_FLAGS " ${MBEDCRYPTO_C_FLAGS_BL2}")
Raef Coles1bb168e2019-10-17 09:04:55 +0100132set(MBEDCRYPTO_TARGET_NAME "mbedcrypto_mcuboot_lib")
133include(${TFM_ROOT_DIR}/BuildMbedCrypto.cmake)
Tamas Ban581034a2017-12-19 19:54:37 +0000134
135#Setting include directories
Tamas Bandb69d522018-03-01 10:04:41 +0000136embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR} ABSOLUTE APPEND)
Raef Coles4d6ea2f2019-10-15 14:30:40 +0100137embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR}/interface/include ABSOLUTE APPEND)
Tamas Bana9de4a62018-09-18 08:09:45 +0100138embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR}/bl2/include ABSOLUTE APPEND)
Tamas Bandb69d522018-03-01 10:04:41 +0000139embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR}/bl2/ext/mcuboot/include ABSOLUTE APPEND)
David Vinczec3e313a2020-01-06 17:31:11 +0100140embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${MCUBOOT_DIR}/bootutil/include ABSOLUTE APPEND)
Raef Coles1bb168e2019-10-17 09:04:55 +0100141embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${MBEDCRYPTO_INSTALL_DIR}/include ABSOLUTE APPEND)
Balint Matyi2fe04922020-02-18 12:27:38 +0000142embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${CMAKE_CURRENT_BINARY_DIR} ABSOLUTE APPEND)
Tamas Ban581034a2017-12-19 19:54:37 +0000143
144#Define linker file
Mate Toth-Pal48fc6a02018-01-24 09:50:14 +0100145if(NOT DEFINED BL2_LINKER_CONFIG)
146 message(FATAL_ERROR "ERROR: Incomplete Configuration: BL2_LINKER_CONFIG is not defined.")
147endif()
Gabor Kerteszd7d7d742018-07-04 11:50:05 +0200148embedded_set_target_linker_file(TARGET ${PROJECT_NAME} PATH "${BL2_LINKER_CONFIG}")
149
150if(NOT DEFINED PLATFORM_LINK_INCLUDES)
151 message(FATAL_ERROR "ERROR: Incomplete Configuration: PLATFORM_LINK_INCLUDES is not defined.")
152endif()
153embedded_set_target_link_includes(TARGET ${PROJECT_NAME} INCLUDES "${PLATFORM_LINK_INCLUDES}")
Tamas Ban581034a2017-12-19 19:54:37 +0000154
David Hu857bfa52019-05-21 13:54:50 +0800155add_executable(${PROJECT_NAME} ${ALL_SRC_ASM} ${ALL_SRC_C_BL2} ${ALL_SRC_ASM_BL2} ${ALL_SRC_C} ${ALL_SRC_CXX})
Tamas Ban581034a2017-12-19 19:54:37 +0000156
Tamas Bandb69d522018-03-01 10:04:41 +0000157#Set common compiler and linker flags
158config_setting_shared_compiler_flags(${PROJECT_NAME})
159config_setting_shared_linker_flags(${PROJECT_NAME})
160
David Vincze63eda7a2019-08-09 17:42:51 +0200161#Add BL2 and MCUBOOT_IMAGE_NUMBER defines to linker to resolve symbols in region_defs.h and flash_layout.h
162embedded_set_target_link_defines(TARGET ${PROJECT_NAME} DEFINES "BL2" "MCUBOOT_IMAGE_NUMBER=${MCUBOOT_IMAGE_NUMBER}")
Tamas Ban581034a2017-12-19 19:54:37 +0000163
Marc Moreno Berenguecae2c532018-10-09 12:58:46 +0100164if(NOT DEFINED TEST_FRAMEWORK_S)
165 message(FATAL_ERROR "Incomplete build configuration: TEST_FRAMEWORK_S is undefined.")
166elseif(TEST_FRAMEWORK_S)
167 embedded_set_target_link_defines(TARGET ${PROJECT_NAME} DEFINES "TEST_FRAMEWORK_S")
168endif()
169
170if(NOT DEFINED TEST_FRAMEWORK_NS)
171 message(FATAL_ERROR "Incomplete build configuration: TEST_FRAMEWORK_NS is undefined.")
172elseif(TEST_FRAMEWORK_NS)
173 embedded_set_target_link_defines(TARGET ${PROJECT_NAME} DEFINES "TEST_FRAMEWORK_NS")
174endif()
175
Tamas Ban581034a2017-12-19 19:54:37 +0000176#Link mbedcrypto library to project
Raef Coles1bb168e2019-10-17 09:04:55 +0100177target_link_libraries(${PROJECT_NAME} "${MBEDCRYPTO_INSTALL_DIR}/lib/${CMAKE_STATIC_LIBRARY_PREFIX_C}mbedcrypto${CMAKE_STATIC_LIBRARY_SUFFIX_C}")
178add_dependencies(${PROJECT_NAME} ${MBEDCRYPTO_TARGET_NAME}_install)
Tamas Ban581034a2017-12-19 19:54:37 +0000179
Raef Coles0e82adc2019-10-17 15:06:26 +0100180#Link crypto accelerator libraries if applicable
Tamas Banf824e742019-10-25 21:22:26 +0100181if (CRYPTO_HW_ACCELERATOR OR CRYPTO_HW_ACCELERATOR_OTP_STATE STREQUAL "PROVISIONING")
Raef Coles0e82adc2019-10-17 15:06:26 +0100182 if(NOT DEFINED CRYPTO_HW_ACCELERATOR_CMAKE_LINK)
183 message(FATAL_ERROR "CRYPTO_HW_ACCELERATOR_CMAKE_LINK not defined.")
184 endif()
185 include(${CRYPTO_HW_ACCELERATOR_CMAKE_LINK})
186endif()
187
Tamas Ban581034a2017-12-19 19:54:37 +0000188#Generate binary file from axf
189compiler_generate_binary_output(${PROJECT_NAME})
190
Øyvind Rønningstad762415c2020-04-02 15:34:50 +0200191#Generate intel hex file from axf
192compiler_generate_hex_output(${PROJECT_NAME})
193
194#Generate elf file from axf
195compiler_generate_elf_output(${PROJECT_NAME})
196
David Vinczec3e313a2020-01-06 17:31:11 +0100197message("- MCUBOOT_REPO: '${MCUBOOT_REPO}'.")
David Vincze73dfbc52019-10-11 13:54:58 +0200198message("- MCUBOOT_IMAGE_NUMBER: '${MCUBOOT_IMAGE_NUMBER}'.")
199message("- MCUBOOT_UPGRADE_STRATEGY: '${MCUBOOT_UPGRADE_STRATEGY}'.")
200message("- MCUBOOT_SIGNATURE_TYPE: '${MCUBOOT_SIGNATURE_TYPE}'.")
201message("- MCUBOOT_HW_KEY: '${MCUBOOT_HW_KEY}'.")
202message("- MCUBOOT_LOG_LEVEL: '${MCUBOOT_LOG_LEVEL}'.")
David Vincze54d05552019-08-05 12:58:47 +0200203
Balint Matyi2fe04922020-02-18 12:27:38 +0000204get_property(_log_levels CACHE MCUBOOT_LOG_LEVEL PROPERTY STRINGS)
205list(FIND _log_levels ${MCUBOOT_LOG_LEVEL} LOG_LEVEL_ID)
Tamas Bandb69d522018-03-01 10:04:41 +0000206
David Vinczec3e313a2020-01-06 17:31:11 +0100207if (MCUBOOT_REPO STREQUAL "UPSTREAM")
David Vinczeabb527c2020-01-10 11:19:05 +0100208 set(MCUBOOT_HW_ROLLBACK_PROT On)
David Vincze141f2152020-02-19 09:42:07 +0100209 set(MCUBOOT_MEASURED_BOOT On)
David Vinczef5c1e062020-03-31 17:05:34 +0200210
211 #FixMe: This becomes unnecessary and can be deleted once the sign_key.c file
212 #in upstream MCUboot includes the mcuboot_config.h file and starts "reading"
213 #the configuration macros from there.
214 if (MCUBOOT_HW_KEY)
215 target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_HW_KEY)
216 endif()
David Vinczec3e313a2020-01-06 17:31:11 +0100217endif()
218
Balint Matyi2fe04922020-02-18 12:27:38 +0000219if(MCUBOOT_SIGNATURE_TYPE STREQUAL "RSA-3072")
220 set(MCUBOOT_SIGN_RSA On)
221 set(MCUBOOT_SIGN_RSA_LEN 3072)
Tamas Ban7801ed42019-05-20 13:21:53 +0100222elseif(MCUBOOT_SIGNATURE_TYPE STREQUAL "RSA-2048")
Balint Matyi2fe04922020-02-18 12:27:38 +0000223 set(MCUBOOT_SIGN_RSA On)
224 set(MCUBOOT_SIGN_RSA_LEN 2048)
Tamas Ban7801ed42019-05-20 13:21:53 +0100225endif()
226
David Vincze4638b2a2019-05-24 10:14:23 +0200227if (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "OVERWRITE_ONLY")
Balint Matyi2fe04922020-02-18 12:27:38 +0000228 set(MCUBOOT_OVERWRITE_ONLY On)
229elseif(${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "NO_SWAP")
230 set(MCUBOOT_NO_SWAP On)
David Vincze4638b2a2019-05-24 10:14:23 +0200231elseif (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "RAM_LOADING")
Balint Matyi2fe04922020-02-18 12:27:38 +0000232 set(MCUBOOT_RAM_LOADING On)
Tamas Band0f4e1d2019-07-11 09:39:03 +0100233endif()
234
David Vinczef5c1e062020-03-31 17:05:34 +0200235#FixMe: This becomes unnecessary and can be deleted once the sign_key.c file
236#in upstream MCUboot includes the mcuboot_config.h file and starts "reading"
237#the configuration macros from there.
238if (MCUBOOT_REPO STREQUAL "UPSTREAM" AND MCUBOOT_HW_KEY)
239 set(MCUBOOT_HW_KEY Off)
240 configure_file("${CMAKE_CURRENT_LIST_DIR}/include/mcuboot_config/mcuboot_config.h.in"
241 "${CMAKE_CURRENT_BINARY_DIR}/mcuboot_config/mcuboot_config.h"
242 @ONLY)
243 set(MCUBOOT_HW_KEY On)
244else()
245 configure_file("${CMAKE_CURRENT_LIST_DIR}/include/mcuboot_config/mcuboot_config.h.in"
246 "${CMAKE_CURRENT_BINARY_DIR}/mcuboot_config/mcuboot_config.h"
247 @ONLY)
248endif()
Balint Matyi2fe04922020-02-18 12:27:38 +0000249
250target_compile_definitions(${PROJECT_NAME} PRIVATE MBEDTLS_CONFIG_FILE="${MBEDTLS_CONFIG_FILE}")
251
252if (NOT MCUBOOT_SIGNATURE_TYPE STREQUAL "RSA-3072" AND NOT MCUBOOT_SIGNATURE_TYPE STREQUAL "RSA-2048")
253 message(FATAL_ERROR "${MCUBOOT_SIGNATURE_TYPE} is not supported as firmware signing algorithm")
254endif()
255
256validate_cache_value(MCUBOOT_UPGRADE_STRATEGY)
257
Tamas Bandb69d522018-03-01 10:04:41 +0000258#Set install location. Keep original value to avoid overriding command line settings.
259if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
260 set(CMAKE_INSTALL_PREFIX "${CMAKE_BINARY_DIR}/install" CACHE PATH "Default install location for MCUBoot." FORCE)
261endif()
262
263#Collect executables to common location: build/install/outputs/
264install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.axf
265 ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.bin
Øyvind Rønningstad762415c2020-04-02 15:34:50 +0200266 ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.hex
267 ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.elf
Tamas Bandb69d522018-03-01 10:04:41 +0000268 DESTINATION outputs/${TARGET_PLATFORM}/)
269
270install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.axf
271 ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.bin
Øyvind Rønningstad762415c2020-04-02 15:34:50 +0200272 ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.hex
273 ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.elf
Tamas Bandb69d522018-03-01 10:04:41 +0000274 DESTINATION outputs/fvp/)
Tamas Ban581034a2017-12-19 19:54:37 +0000275
276#Finally let cmake system apply changes after the whole project is defined.
277embedded_project_end(${PROJECT_NAME})