blob: 16d2c5b9edd8dc6dc0b649c510b5b2f92b3c83ac [file] [log] [blame]
Raef Coles8efad882020-07-10 09:46:00 +01001#-------------------------------------------------------------------------------
Sherry Zhang6e0f3242021-03-08 12:18:31 +08002# Copyright (c) 2020-2021, 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>
Raef Coles8efad882020-07-10 09:46:00 +010018)
19
20add_subdirectory(ext/mcuboot)
21
22set_target_properties(bl2
23 PROPERTIES
24 SUFFIX ".axf"
25 RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
26)
27
28target_include_directories(bl2
29 PRIVATE
30 $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
Sherry Zhang6e0f3242021-03-08 12:18:31 +080031 $<BUILD_INTERFACE:${MCUBOOT_PATH}/boot/bootutil/src>
Raef Coles8efad882020-07-10 09:46:00 +010032)
33
34target_link_libraries(bl2
35 PRIVATE
Raef Coles8efad882020-07-10 09:46:00 +010036 tfm_boot_status
Raef Coles8efad882020-07-10 09:46:00 +010037)
38
Feder Liangd4dbaa92021-09-07 15:34:46 +080039target_compile_options(bl2
40 PRIVATE
41 ${BL2_COMPILER_CP_FLAG}
42)
43
Raef Coles8efad882020-07-10 09:46:00 +010044target_link_options(bl2
45 PRIVATE
46 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/bl2.map>
47 $<$<C_COMPILER_ID:ARMClang>:--map>
TTornblomaf19ae92020-09-29 13:26:29 +020048 $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/bl2.map>
Raef Coles8efad882020-07-10 09:46:00 +010049)
50
Mark Horvath8576e382021-03-12 10:24:55 +010051target_compile_definitions(bl2
52 PRIVATE
53 $<$<BOOL:${DEFAULT_MCUBOOT_FLASH_MAP}>:DEFAULT_MCUBOOT_FLASH_MAP>
Satish Kumara5312fd2021-10-26 07:08:57 +010054 $<$<BOOL:${PLATFORM_PSA_ADAC_SECURE_DEBUG}>:PLATFORM_PSA_ADAC_SECURE_DEBUG>
Mark Horvath8576e382021-03-12 10:24:55 +010055)
56
Raef Coles8efad882020-07-10 09:46:00 +010057add_convert_to_bin_target(bl2)
58
59############################### BOOT HAL # #####################################
60
61add_library(bl2_hal INTERFACE)
62
63target_include_directories(bl2_hal
64 INTERFACE
65 include
66)
67
68############################### MBEDCRYPTO #####################################
69
Raef Colese82831b2020-10-13 16:52:52 +010070add_library(bl2_mbedcrypto_config INTERFACE)
Raef Coles8efad882020-07-10 09:46:00 +010071
Raef Colese82831b2020-10-13 16:52:52 +010072target_compile_definitions(bl2_mbedcrypto_config
Raef Coles8efad882020-07-10 09:46:00 +010073 INTERFACE
74 $<$<STREQUAL:${MCUBOOT_SIGNATURE_TYPE},RSA>:MCUBOOT_SIGN_RSA>
75 $<$<STREQUAL:${MCUBOOT_SIGNATURE_TYPE},RSA>:MCUBOOT_SIGN_RSA_LEN=${MCUBOOT_SIGNATURE_KEY_LEN}>
Ioannis Glaropoulos855321a2021-05-11 12:44:39 +020076 MBEDTLS_CONFIG_FILE="${MCUBOOT_MBEDCRYPTO_CONFIG_FILEPATH}"
Raef Coles8efad882020-07-10 09:46:00 +010077 # Workaround for https://github.com/ARMmbed/mbedtls/issues/1077
Gabor Abonyi866571c2021-10-07 13:56:19 +020078 $<$<OR:$<STREQUAL:${TFM_SYSTEM_ARCHITECTURE},armv8-m.base>,$<STREQUAL:${TFM_SYSTEM_ARCHITECTURE},armv6-m>>:MULADDC_CANNOT_USE_R7>
Raef Coles8efad882020-07-10 09:46:00 +010079)
80
81cmake_policy(SET CMP0079 NEW)
82
83set(CMAKE_POLICY_DEFAULT_CMP0077 NEW)
84set(CMAKE_POLICY_DEFAULT_CMP0048 NEW)
85set(ENABLE_TESTING OFF)
86set(ENABLE_PROGRAMS OFF)
87set(MBEDTLS_FATAL_WARNINGS OFF)
88set(ENABLE_DOCS OFF)
Raef Coles8efad882020-07-10 09:46:00 +010089set(INSTALL_MBEDTLS_HEADERS OFF)
Raef Colese82831b2020-10-13 16:52:52 +010090set(LIB_INSTALL_DIR ${CMAKE_CURRENT_BINARY_DIR}/mbedcrypto/install)
Raef Coles8efad882020-07-10 09:46:00 +010091
Antonio de Angelis9e7e3782021-10-21 11:39:04 +010092# Set the prefix to be used by mbedTLS targets
Raef Colese82831b2020-10-13 16:52:52 +010093set(MBEDTLS_TARGET_PREFIX bl2_)
Raef Coles8efad882020-07-10 09:46:00 +010094
95# Mbedcrypto is quite a large lib, and it uses too much memory for it to be
96# reasonable to build it in debug info. As a compromise, if `debug` build type
97# is selected mbedcrypto will build under `relwithdebinfo` which preserved debug
98# symbols whild optimizing space.
99set(SAVED_BUILD_TYPE ${CMAKE_BUILD_TYPE})
100set(CMAKE_BUILD_TYPE ${MBEDCRYPTO_BUILD_TYPE})
Antonio de Angelis4bc98212021-11-01 10:26:23 +0000101add_subdirectory(${MBEDCRYPTO_PATH} ${CMAKE_CURRENT_BINARY_DIR}/mbedcrypto EXCLUDE_FROM_ALL)
Raef Coles8efad882020-07-10 09:46:00 +0100102set(CMAKE_BUILD_TYPE ${SAVED_BUILD_TYPE} CACHE STRING "Build type: [Debug, Release, RelWithDebInfo, MinSizeRel]" FORCE)
103
Raef Colese82831b2020-10-13 16:52:52 +0100104if(NOT TARGET bl2_mbedcrypto)
105 message(FATAL_ERROR "Target bl2_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 +0100106 Hint: The command might be `cd ${MBEDCRYPTO_PATH} && git apply ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/*.patch`")
107endif()
108
Raef Colese82831b2020-10-13 16:52:52 +0100109target_link_libraries(bl2_mbedcrypto
Raef Coles8efad882020-07-10 09:46:00 +0100110 PUBLIC
Raef Colese82831b2020-10-13 16:52:52 +0100111 bl2_mbedcrypto_config
Raef Coles8efad882020-07-10 09:46:00 +0100112)
Tamas Banf8b0b2d2020-10-26 13:03:13 +0000113
Sherry Zhangc7baf592021-07-15 14:54:17 +0800114target_include_directories(bl2_mbedcrypto
115 PUBLIC
116 ${MBEDCRYPTO_PATH}/library
117)
118
Feder Liangd4dbaa92021-09-07 15:34:46 +0800119target_compile_options(bl2_mbedcrypto
120 PRIVATE
121 ${BL2_COMPILER_CP_FLAG}
122)
123
124target_compile_options(bl2_mbedtls
125 PRIVATE
126 ${BL2_COMPILER_CP_FLAG}
127)
128
129target_compile_options(bl2_mbedx509
130 PRIVATE
131 ${BL2_COMPILER_CP_FLAG}
132)
133
Tamas Banf8b0b2d2020-10-26 13:03:13 +0000134############################### CODE SHARING ###################################
135
136if (TFM_CODE_SHARING)
137 compiler_create_shared_code(bl2 ${CMAKE_CURRENT_SOURCE_DIR}/src/shared_symbol_template.txt)
Tamas Ban4a5cc972020-10-27 09:03:56 +0000138
139 if (NOT EXISTS ${MBEDCRYPTO_PATH}/library/code_share.c)
140 message(FATAL_ERROR "File ${MBEDCRYPTO_PATH}/library/code_share.c does not exist.
141 Have the patch ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/0005-Enable-crypto-code-sharing-between-independent-binar.patch
142 been applied to the mbedcrypto repo at ${MBEDCRYPTO_PATH}?
143 Hint: The command might be `cd ${MBEDCRYPTO_PATH} && git apply ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/*.patch`")
144 endif()
Tamas Banf8b0b2d2020-10-26 13:03:13 +0000145endif()