blob: bab9901858a0e3cbc4dce2d642bf5c585c9ae856 [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
13 src/security_cnt.c
14 src/flash_map.c
15)
16
17add_subdirectory(ext/mcuboot)
18
19set_target_properties(bl2
20 PROPERTIES
21 SUFFIX ".axf"
22 RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
23)
24
25target_include_directories(bl2
26 PRIVATE
27 $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
Sherry Zhang6e0f3242021-03-08 12:18:31 +080028 $<BUILD_INTERFACE:${MCUBOOT_PATH}/boot/bootutil/src>
Raef Coles8efad882020-07-10 09:46:00 +010029)
30
31target_link_libraries(bl2
32 PRIVATE
Raef Coles8efad882020-07-10 09:46:00 +010033 tfm_boot_status
Raef Coles8efad882020-07-10 09:46:00 +010034)
35
36target_link_options(bl2
37 PRIVATE
38 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/bl2.map>
39 $<$<C_COMPILER_ID:ARMClang>:--map>
TTornblomaf19ae92020-09-29 13:26:29 +020040 $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/bl2.map>
Raef Coles8efad882020-07-10 09:46:00 +010041)
42
43add_convert_to_bin_target(bl2)
44
45############################### BOOT HAL # #####################################
46
47add_library(bl2_hal INTERFACE)
48
49target_include_directories(bl2_hal
50 INTERFACE
51 include
52)
53
54############################### MBEDCRYPTO #####################################
55
Raef Colese82831b2020-10-13 16:52:52 +010056add_library(bl2_mbedcrypto_config INTERFACE)
Raef Coles8efad882020-07-10 09:46:00 +010057
Raef Colese82831b2020-10-13 16:52:52 +010058target_compile_definitions(bl2_mbedcrypto_config
Raef Coles8efad882020-07-10 09:46:00 +010059 INTERFACE
60 $<$<STREQUAL:${MCUBOOT_SIGNATURE_TYPE},RSA>:MCUBOOT_SIGN_RSA>
61 $<$<STREQUAL:${MCUBOOT_SIGNATURE_TYPE},RSA>:MCUBOOT_SIGN_RSA_LEN=${MCUBOOT_SIGNATURE_KEY_LEN}>
Balint Matyi69e2d2e2020-07-08 10:53:54 +010062 MBEDTLS_CONFIG_FILE="$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/ext/mcuboot/include/mcuboot-mbedtls-cfg.h>"
Raef Coles8efad882020-07-10 09:46:00 +010063 # Workaround for https://github.com/ARMmbed/mbedtls/issues/1077
64 $<$<OR:$<STREQUAL:${CMAKE_SYSTEM_ARCHITECTURE},armv8-m.base>,$<STREQUAL:${CMAKE_SYSTEM_ARCHITECTURE},armv6-m>>:MULADDC_CANNOT_USE_R7>
65)
66
67cmake_policy(SET CMP0079 NEW)
68
69set(CMAKE_POLICY_DEFAULT_CMP0077 NEW)
70set(CMAKE_POLICY_DEFAULT_CMP0048 NEW)
71set(ENABLE_TESTING OFF)
72set(ENABLE_PROGRAMS OFF)
73set(MBEDTLS_FATAL_WARNINGS OFF)
74set(ENABLE_DOCS OFF)
Raef Coles8efad882020-07-10 09:46:00 +010075set(INSTALL_MBEDTLS_HEADERS OFF)
Raef Colese82831b2020-10-13 16:52:52 +010076set(LIB_INSTALL_DIR ${CMAKE_CURRENT_BINARY_DIR}/mbedcrypto/install)
Raef Coles8efad882020-07-10 09:46:00 +010077
Raef Colese82831b2020-10-13 16:52:52 +010078set(lib_target bl2_mbedcrypto_libs)
79set(mbedcrypto_target bl2_mbedcrypto)
80set(mbedtls_target bl2_mbedtls)
81set(mbedx509_target bl2_mbedx509)
82set(MBEDTLS_TARGET_PREFIX bl2_)
Raef Coles8efad882020-07-10 09:46:00 +010083
84# Mbedcrypto is quite a large lib, and it uses too much memory for it to be
85# reasonable to build it in debug info. As a compromise, if `debug` build type
86# is selected mbedcrypto will build under `relwithdebinfo` which preserved debug
87# symbols whild optimizing space.
88set(SAVED_BUILD_TYPE ${CMAKE_BUILD_TYPE})
89set(CMAKE_BUILD_TYPE ${MBEDCRYPTO_BUILD_TYPE})
90add_subdirectory(${MBEDCRYPTO_PATH} ${CMAKE_CURRENT_BINARY_DIR}/mbedcrypto)
91set(CMAKE_BUILD_TYPE ${SAVED_BUILD_TYPE} CACHE STRING "Build type: [Debug, Release, RelWithDebInfo, MinSizeRel]" FORCE)
92
Raef Colese82831b2020-10-13 16:52:52 +010093if(NOT TARGET bl2_mbedcrypto)
94 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 +010095 Hint: The command might be `cd ${MBEDCRYPTO_PATH} && git apply ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/*.patch`")
96endif()
97
Raef Colese82831b2020-10-13 16:52:52 +010098target_link_libraries(bl2_mbedcrypto
Raef Coles8efad882020-07-10 09:46:00 +010099 PUBLIC
Raef Colese82831b2020-10-13 16:52:52 +0100100 bl2_mbedcrypto_config
Raef Coles8efad882020-07-10 09:46:00 +0100101)
Tamas Banf8b0b2d2020-10-26 13:03:13 +0000102
103############################### CODE SHARING ###################################
104
105if (TFM_CODE_SHARING)
106 compiler_create_shared_code(bl2 ${CMAKE_CURRENT_SOURCE_DIR}/src/shared_symbol_template.txt)
Tamas Ban4a5cc972020-10-27 09:03:56 +0000107
108 if (NOT EXISTS ${MBEDCRYPTO_PATH}/library/code_share.c)
109 message(FATAL_ERROR "File ${MBEDCRYPTO_PATH}/library/code_share.c does not exist.
110 Have the patch ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/0005-Enable-crypto-code-sharing-between-independent-binar.patch
111 been applied to the mbedcrypto repo at ${MBEDCRYPTO_PATH}?
112 Hint: The command might be `cd ${MBEDCRYPTO_PATH} && git apply ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/*.patch`")
113 endif()
Tamas Banf8b0b2d2020-10-26 13:03:13 +0000114endif()