blob: c839c9aec3f07307297bb3fe04fc2587e7f09651 [file] [log] [blame]
Raef Coles8efad882020-07-10 09:46:00 +01001#-------------------------------------------------------------------------------
2# Copyright (c) 2020, Arm Limited. All rights reserved.
3#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6#-------------------------------------------------------------------------------
7
8cmake_minimum_required(VERSION 3.13)
9
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>
28)
29
30target_link_libraries(bl2
31 PRIVATE
32 platform_bl2
33 tfm_boot_status
34 mbedcrypto_bl2
35)
36
37target_link_options(bl2
38 PRIVATE
39 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/bl2.map>
40 $<$<C_COMPILER_ID:ARMClang>:--map>
41)
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
56add_library(mbedcrypto_bl2_config INTERFACE)
57
58target_compile_definitions(mbedcrypto_bl2_config
59 INTERFACE
60 $<$<STREQUAL:${MCUBOOT_SIGNATURE_TYPE},RSA>:MCUBOOT_SIGN_RSA>
61 $<$<STREQUAL:${MCUBOOT_SIGNATURE_TYPE},RSA>:MCUBOOT_SIGN_RSA_LEN=${MCUBOOT_SIGNATURE_KEY_LEN}>
62 MBEDTLS_CONFIG_FILE="$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/ext/mcuboot/include/config-rsa.h>"
63 # 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)
75set(INSTALL_MBEDTLS OFF)
76set(INSTALL_MBEDTLS_HEADERS OFF)
77
78# Current variables
79set(mbedcrypto_static_target mbedcrypto_bl2)
80set(mbedcrypto_lib_target mbedcrypto_lib_bl2)
81# Future variables
82set(lib_target lib_bl2)
83set(mbedcrypto_target mbedcrypto_bl2)
84set(mbedtls_target mbedtls_bl2)
85set(mbedx509_target mbedx509_bl2)
86
87# Mbedcrypto is quite a large lib, and it uses too much memory for it to be
88# reasonable to build it in debug info. As a compromise, if `debug` build type
89# is selected mbedcrypto will build under `relwithdebinfo` which preserved debug
90# symbols whild optimizing space.
91set(SAVED_BUILD_TYPE ${CMAKE_BUILD_TYPE})
92set(CMAKE_BUILD_TYPE ${MBEDCRYPTO_BUILD_TYPE})
93add_subdirectory(${MBEDCRYPTO_PATH} ${CMAKE_CURRENT_BINARY_DIR}/mbedcrypto)
94set(CMAKE_BUILD_TYPE ${SAVED_BUILD_TYPE} CACHE STRING "Build type: [Debug, Release, RelWithDebInfo, MinSizeRel]" FORCE)
95
96if(NOT TARGET mbedcrypto_bl2)
97 message(FATAL_ERROR "Target mbedcrypto_crypto_service does not exist. Have the patches in ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto been applied to the mbedcrypto repo at ${MBEDCRYPTO_PATH} ?
98 Hint: The command might be `cd ${MBEDCRYPTO_PATH} && git apply ${CMAKE_SOURCE_DIR}/lib/ext/mbedcrypto/*.patch`")
99endif()
100
101set_target_properties(${mbedtls_target} ${mbedx509_target}
102 PROPERTIES
103 EXCLUDE_FROM_ALL TRUE
104)
105
106target_link_libraries(mbedcrypto_bl2
107 PUBLIC
108 mbedcrypto_bl2_config
109)