blob: 19ddf3de65d155f4e44040c25b5ff66201f9ae35 [file] [log] [blame]
Tamas Ban581034a2017-12-19 19:54:37 +00001#------------------------------------------------------------------------------
David Vincze4638b2a2019-05-24 10:14:23 +02002# Copyright (c) 2017-2019, 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
10#Tell cmake where our modules can be found
11list(APPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_LIST_DIR}/../../../cmake)
12
13#Include common stuff to control cmake.
14include("Common/BuildSys")
15
16#Start an embedded project.
17embedded_project_start(CONFIG "${CMAKE_CURRENT_LIST_DIR}/../../../ConfigDefault.cmake")
18project(mcuboot LANGUAGES ASM C)
19embedded_project_fixup()
20
21#Check input variables
22if (NOT DEFINED BL2)
23 message(FATAL ERROR "Incomplete build configuration: BL2 is undefined.")
24elseif(NOT BL2)
25 #If mcuboot is not need to be built then stop further processing.
26 return()
27endif()
28
Tamas Ban581034a2017-12-19 19:54:37 +000029if (NOT DEFINED MBEDTLS_C_FLAGS_BL2)
30 message(FATAL_ERROR "Incomplete build configuration: MBEDTLS_C_FLAGS_BL2 is undefined.")
31endif()
32
33#Set variables to appropriate path
34set(MCUBOOT_DIR ${CMAKE_CURRENT_LIST_DIR})
35get_filename_component(TFM_ROOT_DIR "${MCUBOOT_DIR}/../../.." ABSOLUTE)
36
Marc Moreno Berenguea1f296f2018-01-25 15:21:22 +000037set(BUILD_CMSIS_CORE On)
38set(BUILD_RETARGET On)
39set(BUILD_NATIVE_DRIVERS On)
40set(BUILD_STARTUP On)
41set(BUILD_TARGET_CFG Off)
42set(BUILD_TARGET_HARDWARE_KEYS Off)
David Vincze060968d2019-05-23 01:13:14 +020043set(BUILD_TARGET_NV_COUNTERS On)
Marc Moreno Berenguea1f296f2018-01-25 15:21:22 +000044set(BUILD_CMSIS_DRIVERS On)
45set(BUILD_TIME Off)
46set(BUILD_UART_STDOUT On)
47set(BUILD_FLASH On)
48if(NOT DEFINED PLATFORM_CMAKE_FILE)
49 message (FATAL_ERROR "Platform specific CMake is not defined. Please set PLATFORM_CMAKE_FILE.")
50elseif(NOT EXISTS ${PLATFORM_CMAKE_FILE})
51 message (FATAL_ERROR "Platform specific CMake \"${PLATFORM_CMAKE_FILE}\" file does not exist. Please fix value of PLATFORM_CMAKE_FILE.")
52else()
53 include(${PLATFORM_CMAKE_FILE})
54endif()
55
Tamas Ban581034a2017-12-19 19:54:37 +000056#Append all our source files to global lists.
Tamas Bana9de4a62018-09-18 08:09:45 +010057list(APPEND ALL_SRC_C
58 "${MCUBOOT_DIR}/bl2_main.c"
Tamas Ban581034a2017-12-19 19:54:37 +000059 "${MCUBOOT_DIR}/flash_map.c"
Tamas Ban581034a2017-12-19 19:54:37 +000060 "${MCUBOOT_DIR}/keys.c"
61 "${MCUBOOT_DIR}/bootutil/src/loader.c"
62 "${MCUBOOT_DIR}/bootutil/src/bootutil_misc.c"
63 "${MCUBOOT_DIR}/bootutil/src/image_validate.c"
64 "${MCUBOOT_DIR}/bootutil/src/image_rsa.c"
65 "${MCUBOOT_DIR}/bootutil/src/caps.c"
Tamas Bana9de4a62018-09-18 08:09:45 +010066 "${TFM_ROOT_DIR}/bl2/src/boot_record.c"
David Vincze060968d2019-05-23 01:13:14 +020067 "${TFM_ROOT_DIR}/bl2/src/security_cnt.c"
Tamas Ban581034a2017-12-19 19:54:37 +000068 )
69
70#Define location of mbedtls source, build, and installation directory.
71get_filename_component(MBEDTLS_SOURCE_DIR "${TFM_ROOT_DIR}/../mbedtls" ABSOLUTE)
72if(NOT EXISTS ${MBEDTLS_SOURCE_DIR})
73 message(FATAL_ERROR "Missing mbedtls. Please clone the mbedtls repo to directory \"${MBEDTLS_SOURCE_DIR}\".")
74endif()
75set (MBEDTLS_BINARY_DIR "${CMAKE_CURRENT_BINARY_DIR}/mbedtls")
76set (MBEDTLS_INSTALL_DIR ${MBEDTLS_BINARY_DIR}/mbedtls_install)
77
Tamas Ban581034a2017-12-19 19:54:37 +000078#Build mbedtls as external project.
79#This ensures mbedtls is built with exactly defined settings.
80#mbedtls will be used from is't install location
81set(MBEDTLS_C_FLAGS ${MBEDTLS_C_FLAGS_BL2})
82set(MBEDTLS_TARGET_NAME "mbedtls_mcuboot_lib")
83include(${TFM_ROOT_DIR}/BuildMbedtls.cmake)
84
85#Setting include directories
Tamas Bandb69d522018-03-01 10:04:41 +000086embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR} ABSOLUTE APPEND)
Tamas Bana9de4a62018-09-18 08:09:45 +010087embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR}/bl2/include ABSOLUTE APPEND)
Tamas Bandb69d522018-03-01 10:04:41 +000088embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR}/bl2/ext/mcuboot/include ABSOLUTE APPEND)
89embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${TFM_ROOT_DIR}/bl2/ext/mcuboot/bootutil/include/ ABSOLUTE APPEND)
90embedded_target_include_directories(TARGET ${PROJECT_NAME} PATH ${MBEDTLS_INSTALL_DIR}/include ABSOLUTE APPEND)
Tamas Ban581034a2017-12-19 19:54:37 +000091
92#Define linker file
Mate Toth-Pal48fc6a02018-01-24 09:50:14 +010093if(NOT DEFINED BL2_LINKER_CONFIG)
94 message(FATAL_ERROR "ERROR: Incomplete Configuration: BL2_LINKER_CONFIG is not defined.")
95endif()
Gabor Kerteszd7d7d742018-07-04 11:50:05 +020096embedded_set_target_linker_file(TARGET ${PROJECT_NAME} PATH "${BL2_LINKER_CONFIG}")
97
98if(NOT DEFINED PLATFORM_LINK_INCLUDES)
99 message(FATAL_ERROR "ERROR: Incomplete Configuration: PLATFORM_LINK_INCLUDES is not defined.")
100endif()
101embedded_set_target_link_includes(TARGET ${PROJECT_NAME} INCLUDES "${PLATFORM_LINK_INCLUDES}")
Tamas Ban581034a2017-12-19 19:54:37 +0000102
Mate Toth-Pal48fc6a02018-01-24 09:50:14 +0100103add_executable(${PROJECT_NAME} ${ALL_SRC_ASM_BL2} ${ALL_SRC_C} ${ALL_SRC_CXX})
Tamas Ban581034a2017-12-19 19:54:37 +0000104
Tamas Bandb69d522018-03-01 10:04:41 +0000105#Set common compiler and linker flags
106config_setting_shared_compiler_flags(${PROJECT_NAME})
107config_setting_shared_linker_flags(${PROJECT_NAME})
108
Tamas Ban581034a2017-12-19 19:54:37 +0000109#Add BL2 define to linker to resolve symbols in region_defs.h
Mate Toth-Pal76867262018-03-09 13:15:36 +0100110embedded_set_target_link_defines(TARGET ${PROJECT_NAME} DEFINES "BL2")
Tamas Ban581034a2017-12-19 19:54:37 +0000111
Marc Moreno Berenguecae2c532018-10-09 12:58:46 +0100112if(NOT DEFINED TEST_FRAMEWORK_S)
113 message(FATAL_ERROR "Incomplete build configuration: TEST_FRAMEWORK_S is undefined.")
114elseif(TEST_FRAMEWORK_S)
115 embedded_set_target_link_defines(TARGET ${PROJECT_NAME} DEFINES "TEST_FRAMEWORK_S")
116endif()
117
118if(NOT DEFINED TEST_FRAMEWORK_NS)
119 message(FATAL_ERROR "Incomplete build configuration: TEST_FRAMEWORK_NS is undefined.")
120elseif(TEST_FRAMEWORK_NS)
121 embedded_set_target_link_defines(TARGET ${PROJECT_NAME} DEFINES "TEST_FRAMEWORK_NS")
122endif()
123
Tamas Ban581034a2017-12-19 19:54:37 +0000124#Link mbedcrypto library to project
125target_link_libraries(${PROJECT_NAME} "${MBEDTLS_INSTALL_DIR}/lib/${CMAKE_STATIC_LIBRARY_PREFIX_C}mbedcrypto${CMAKE_STATIC_LIBRARY_SUFFIX_C}")
126add_dependencies(${PROJECT_NAME} ${MBEDTLS_TARGET_NAME}_install)
127
Tamas Ban581034a2017-12-19 19:54:37 +0000128#Generate binary file from axf
129compiler_generate_binary_output(${PROJECT_NAME})
130
131#Set macro definitions for the project.
132target_compile_definitions(${PROJECT_NAME} PRIVATE
Tamas Ban581034a2017-12-19 19:54:37 +0000133 MCUBOOT_VALIDATE_SLOT0
134 MCUBOOT_USE_FLASH_AREA_GET_SECTORS
135 MBEDTLS_CONFIG_FILE="config-boot.h"
Tamas Bandb69d522018-03-01 10:04:41 +0000136 MCUBOOT_TARGET_CONFIG="flash_layout.h")
137
Tamas Ban7801ed42019-05-20 13:21:53 +0100138if (MCUBOOT_SIGNATURE_TYPE STREQUAL "RSA-3072")
139 target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_SIGN_RSA MCUBOOT_SIGN_RSA_LEN=3072)
140elseif(MCUBOOT_SIGNATURE_TYPE STREQUAL "RSA-2048")
141 target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_SIGN_RSA MCUBOOT_SIGN_RSA_LEN=2048)
142else()
143 message(FATAL_ERROR "${MCUBOOT_SIGNATURE_TYPE} is not supported as firmware signing algorithm")
144endif()
145
David Vincze4638b2a2019-05-24 10:14:23 +0200146if (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "OVERWRITE_ONLY")
147 target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_OVERWRITE_ONLY)
148elseif (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "NO_SWAP")
Tamas Bandb69d522018-03-01 10:04:41 +0000149 target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_NO_SWAP)
David Vincze4638b2a2019-05-24 10:14:23 +0200150elseif (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "RAM_LOADING")
Oliver Swedef9982442018-08-24 18:37:44 +0100151 target_compile_definitions(${PROJECT_NAME} PRIVATE MCUBOOT_RAM_LOADING)
David Vincze4638b2a2019-05-24 10:14:23 +0200152elseif (${MCUBOOT_UPGRADE_STRATEGY} STREQUAL "SWAP")
153 #No compile definition needs to be specified for this upgrade strategy
154else()
155 message(FATAL_ERROR "ERROR: MCUBoot supports OVERWRITE_ONLY, SWAP, NO_SWAP and RAM_LOADING upgrade strategies only.")
Oliver Swedef9982442018-08-24 18:37:44 +0100156endif()
157
Tamas Bandb69d522018-03-01 10:04:41 +0000158#Set install location. Keep original value to avoid overriding command line settings.
159if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
160 set(CMAKE_INSTALL_PREFIX "${CMAKE_BINARY_DIR}/install" CACHE PATH "Default install location for MCUBoot." FORCE)
161endif()
162
163#Collect executables to common location: build/install/outputs/
164install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.axf
165 ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.bin
166 DESTINATION outputs/${TARGET_PLATFORM}/)
167
168install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.axf
169 ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.bin
170 DESTINATION outputs/fvp/)
Tamas Ban581034a2017-12-19 19:54:37 +0000171
172#Finally let cmake system apply changes after the whole project is defined.
173embedded_project_end(${PROJECT_NAME})