blob: 25908c21b0bca58bdc8dce166c7e239ca220b989 [file] [log] [blame]
Raef Coles8efad882020-07-10 09:46:00 +01001#-------------------------------------------------------------------------------
chesun01ea11c822022-12-15 15:53:05 +08002# Copyright (c) 2020-2023, Arm Limited. All rights reserved.
Raef Coles8efad882020-07-10 09:46:00 +01003#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6#-------------------------------------------------------------------------------
7
Raef Coles69817322020-10-19 14:14:14 +01008cmake_minimum_required(VERSION 3.15)
Raef Coles8efad882020-07-10 09:46:00 +01009
10project("Bootloader" VERSION 0.1.0 LANGUAGES C ASM)
11
12add_executable(bl2
Raef Coles8efad882020-07-10 09:46:00 +010013 src/flash_map.c
Mark Horvath8576e382021-03-12 10:24:55 +010014 $<$<BOOL:${DEFAULT_MCUBOOT_SECURITY_COUNTERS}>:src/security_cnt.c>
15 $<$<BOOL:${DEFAULT_MCUBOOT_FLASH_MAP}>:src/default_flash_map.c>
Sherry Zhang07b42412021-01-07 14:19:41 +080016 $<$<BOOL:${MCUBOOT_DATA_SHARING}>:src/shared_data.c>
Raef Colesaefbe082021-06-18 08:53:43 +010017 $<$<BOOL:${PLATFORM_DEFAULT_PROVISIONING}>:src/provisioning.c>
chesun01ea327cb2023-04-12 15:42:56 +080018 $<$<BOOL:${CONFIG_GNU_SYSCALL_STUB_ENABLED}>:${CMAKE_SOURCE_DIR}/platform/ext/common/syscalls_stub.c>
Raef Coles8efad882020-07-10 09:46:00 +010019)
20
21add_subdirectory(ext/mcuboot)
22
23set_target_properties(bl2
24 PROPERTIES
25 SUFFIX ".axf"
26 RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
27)
28
29target_include_directories(bl2
30 PRIVATE
31 $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
Sherry Zhang6e0f3242021-03-08 12:18:31 +080032 $<BUILD_INTERFACE:${MCUBOOT_PATH}/boot/bootutil/src>
Raef Coles8efad882020-07-10 09:46:00 +010033)
34
35target_link_libraries(bl2
36 PRIVATE
Raef Coles8efad882020-07-10 09:46:00 +010037 tfm_boot_status
Raef Colesf77cc172022-01-07 11:05:47 +000038 $<$<BOOL:${TEST_BL2}>:mcuboot_tests>
David Vincze8c95d2a2022-01-19 10:11:58 +010039 platform_bl2
Raef Coles8efad882020-07-10 09:46:00 +010040)
41
Feder Liangd4dbaa92021-09-07 15:34:46 +080042target_compile_options(bl2
43 PRIVATE
44 ${BL2_COMPILER_CP_FLAG}
45)
46
Raef Coles8efad882020-07-10 09:46:00 +010047target_link_options(bl2
48 PRIVATE
49 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/bl2.map>
chesun01ea11c822022-12-15 15:53:05 +080050 $<$<C_COMPILER_ID:ARMClang>:--map;${BL2_LINKER_CP_OPTION}>
TTornblomaf19ae92020-09-29 13:26:29 +020051 $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/bl2.map>
Raef Coles8efad882020-07-10 09:46:00 +010052)
53
Mark Horvath8576e382021-03-12 10:24:55 +010054target_compile_definitions(bl2
55 PRIVATE
56 $<$<BOOL:${DEFAULT_MCUBOOT_FLASH_MAP}>:DEFAULT_MCUBOOT_FLASH_MAP>
Satish Kumara5312fd2021-10-26 07:08:57 +010057 $<$<BOOL:${PLATFORM_PSA_ADAC_SECURE_DEBUG}>:PLATFORM_PSA_ADAC_SECURE_DEBUG>
Raef Colesf77cc172022-01-07 11:05:47 +000058 $<$<BOOL:${TEST_BL2}>:TEST_BL2>
David Vincze8c95d2a2022-01-19 10:11:58 +010059 $<$<BOOL:${TFM_PARTITION_FIRMWARE_UPDATE}>:TFM_PARTITION_FIRMWARE_UPDATE>
Jamie Foxdd7e55f2023-08-01 17:56:39 +010060 $<$<AND:$<BOOL:${CONFIG_TFM_BOOT_STORE_MEASUREMENTS}>,$<NOT:$<BOOL:${CONFIG_TFM_BOOT_STORE_ENCODED_MEASUREMENTS}>>>:TFM_MEASURED_BOOT_API>
Mark Horvath8576e382021-03-12 10:24:55 +010061)
62
Raef Coles8efad882020-07-10 09:46:00 +010063add_convert_to_bin_target(bl2)
64
65############################### BOOT HAL # #####################################
66
67add_library(bl2_hal INTERFACE)
68
69target_include_directories(bl2_hal
70 INTERFACE
71 include
72)
73
74############################### MBEDCRYPTO #####################################
75
Raef Colese82831b2020-10-13 16:52:52 +010076add_library(bl2_mbedcrypto_config INTERFACE)
Raef Coles8efad882020-07-10 09:46:00 +010077
Roland Mikhel3d76ee92023-06-13 11:01:33 +020078if(NOT ${MCUBOOT_SIGNATURE_TYPE} STREQUAL "")
79 string(REGEX MATCH "[0-9]*$" SIG_LEN ${MCUBOOT_SIGNATURE_TYPE})
80 string(REGEX MATCH "^[A-Z]*" SIG_TYPE ${MCUBOOT_SIGNATURE_TYPE})
81endif()
82
Raef Colese82831b2020-10-13 16:52:52 +010083target_compile_definitions(bl2_mbedcrypto_config
Raef Coles8efad882020-07-10 09:46:00 +010084 INTERFACE
Roland Mikhel3d76ee92023-06-13 11:01:33 +020085 $<$<STREQUAL:${SIG_TYPE},RSA>:MCUBOOT_SIGN_RSA>
86 $<$<STREQUAL:${SIG_TYPE},RSA>:MCUBOOT_SIGN_RSA_LEN=${SIG_LEN}>
Antonio de Angelis6867b4d2022-10-18 12:46:37 +010087 $<$<BOOL:${MCUBOOT_USE_PSA_CRYPTO}>:MCUBOOT_USE_PSA_CRYPTO>
Roland Mikhel00cefb02023-06-05 14:38:02 +020088 $<$<STREQUAL:${SIG_TYPE},EC>:MCUBOOT_SIGN_EC${SIG_LEN}>
Ioannis Glaropoulos855321a2021-05-11 12:44:39 +020089 MBEDTLS_CONFIG_FILE="${MCUBOOT_MBEDCRYPTO_CONFIG_FILEPATH}"
Raef Coles8efad882020-07-10 09:46:00 +010090 # Workaround for https://github.com/ARMmbed/mbedtls/issues/1077
Gabor Abonyi866571c2021-10-07 13:56:19 +020091 $<$<OR:$<STREQUAL:${TFM_SYSTEM_ARCHITECTURE},armv8-m.base>,$<STREQUAL:${TFM_SYSTEM_ARCHITECTURE},armv6-m>>:MULADDC_CANNOT_USE_R7>
Summer Qin36f79f72022-07-05 14:53:35 +080092 $<$<BOOL:${CC312_LEGACY_DRIVER_API_ENABLED}>:CC312_LEGACY_DRIVER_API_ENABLED>
Raef Coles8efad882020-07-10 09:46:00 +010093)
94
95cmake_policy(SET CMP0079 NEW)
96
97set(CMAKE_POLICY_DEFAULT_CMP0077 NEW)
98set(CMAKE_POLICY_DEFAULT_CMP0048 NEW)
99set(ENABLE_TESTING OFF)
100set(ENABLE_PROGRAMS OFF)
101set(MBEDTLS_FATAL_WARNINGS OFF)
102set(ENABLE_DOCS OFF)
Raef Coles8efad882020-07-10 09:46:00 +0100103set(INSTALL_MBEDTLS_HEADERS OFF)
Raef Colese82831b2020-10-13 16:52:52 +0100104set(LIB_INSTALL_DIR ${CMAKE_CURRENT_BINARY_DIR}/mbedcrypto/install)
Anton Komlev80c147b2022-06-20 15:48:22 +0100105set(GEN_FILES OFF)
Raef Coles8efad882020-07-10 09:46:00 +0100106
Antonio de Angelis9e7e3782021-10-21 11:39:04 +0100107# Set the prefix to be used by mbedTLS targets
Raef Colese82831b2020-10-13 16:52:52 +0100108set(MBEDTLS_TARGET_PREFIX bl2_)
Raef Coles8efad882020-07-10 09:46:00 +0100109
110# Mbedcrypto is quite a large lib, and it uses too much memory for it to be
111# reasonable to build it in debug info. As a compromise, if `debug` build type
112# is selected mbedcrypto will build under `relwithdebinfo` which preserved debug
113# symbols whild optimizing space.
114set(SAVED_BUILD_TYPE ${CMAKE_BUILD_TYPE})
115set(CMAKE_BUILD_TYPE ${MBEDCRYPTO_BUILD_TYPE})
Antonio de Angelis1598e472021-11-01 10:26:23 +0000116add_subdirectory(${MBEDCRYPTO_PATH} ${CMAKE_CURRENT_BINARY_DIR}/mbedcrypto EXCLUDE_FROM_ALL)
Raef Coles8efad882020-07-10 09:46:00 +0100117set(CMAKE_BUILD_TYPE ${SAVED_BUILD_TYPE} CACHE STRING "Build type: [Debug, Release, RelWithDebInfo, MinSizeRel]" FORCE)
118
Antonio de Angelis126122f2021-10-29 10:55:48 +0100119if(NOT TARGET ${MBEDTLS_TARGET_PREFIX}mbedcrypto)
120 message(FATAL_ERROR "Target ${MBEDTLS_TARGET_PREFIX}mbedcrypto does not exist. Have the patches in ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto been applied to the mbedcrypto repo at ${MBEDCRYPTO_PATH} ?
Raef Coles8efad882020-07-10 09:46:00 +0100121 Hint: The command might be `cd ${MBEDCRYPTO_PATH} && git apply ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/*.patch`")
122endif()
123
Antonio de Angelis126122f2021-10-29 10:55:48 +0100124target_link_libraries(${MBEDTLS_TARGET_PREFIX}mbedcrypto
Raef Coles8efad882020-07-10 09:46:00 +0100125 PUBLIC
Raef Colese82831b2020-10-13 16:52:52 +0100126 bl2_mbedcrypto_config
Raef Coles8efad882020-07-10 09:46:00 +0100127)
Tamas Banf8b0b2d2020-10-26 13:03:13 +0000128
Antonio de Angelis126122f2021-10-29 10:55:48 +0100129target_include_directories(${MBEDTLS_TARGET_PREFIX}mbedcrypto
Sherry Zhangc7baf592021-07-15 14:54:17 +0800130 PUBLIC
131 ${MBEDCRYPTO_PATH}/library
132)
133
Feder Liangd4dbaa92021-09-07 15:34:46 +0800134target_compile_options(bl2_mbedcrypto
135 PRIVATE
136 ${BL2_COMPILER_CP_FLAG}
137)
138
139target_compile_options(bl2_mbedtls
140 PRIVATE
141 ${BL2_COMPILER_CP_FLAG}
142)
143
144target_compile_options(bl2_mbedx509
145 PRIVATE
146 ${BL2_COMPILER_CP_FLAG}
147)
148
Tamas Banf8b0b2d2020-10-26 13:03:13 +0000149############################### CODE SHARING ###################################
150
151if (TFM_CODE_SHARING)
Raef Coles4351ec22021-04-26 09:20:50 +0100152 target_share_symbols(bl2 ${CMAKE_CURRENT_SOURCE_DIR}/bl2_shared_symbols.txt)
Tamas Ban4a5cc972020-10-27 09:03:56 +0000153
154 if (NOT EXISTS ${MBEDCRYPTO_PATH}/library/code_share.c)
155 message(FATAL_ERROR "File ${MBEDCRYPTO_PATH}/library/code_share.c does not exist.
156 Have the patch ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/0005-Enable-crypto-code-sharing-between-independent-binar.patch
157 been applied to the mbedcrypto repo at ${MBEDCRYPTO_PATH}?
158 Hint: The command might be `cd ${MBEDCRYPTO_PATH} && git apply ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/*.patch`")
159 endif()
Tamas Banf8b0b2d2020-10-26 13:03:13 +0000160endif()