blob: 4883f5385380e9b882272eb71be810d6d5dfa5d7 [file] [log] [blame]
Almir Okatoeb6b7bf2021-09-07 17:06:35 -03001# Copyright (c) 2021 Espressif Systems (Shanghai) Co., Ltd.
2#
3# SPDX-License-Identifier: Apache-2.0
4
Shubham Kulkarni052561d2021-07-20 11:42:44 +05305cmake_minimum_required(VERSION 3.13)
6
7if (NOT DEFINED MCUBOOT_TARGET)
8 message(FATAL_ERROR "MCUBOOT_TARGET not defined. Please pass -DMCUBOOT_TARGET flag.")
9endif()
10
11project(mcuboot_${MCUBOOT_TARGET})
12
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +053013add_definitions(-DMCUBOOT_TARGET=${MCUBOOT_TARGET})
14
Almir Okato712fdb52021-08-06 10:22:56 -030015if ("${MCUBOOT_TARGET}" STREQUAL "esp32" OR
16 "${MCUBOOT_TARGET}" STREQUAL "esp32s2")
17 set(MCUBOOT_ARCH "xtensa")
18elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3")
19 set(MCUBOOT_ARCH "riscv")
20endif()
21
Shubham Kulkarni052561d2021-07-20 11:42:44 +053022if (NOT DEFINED IDF_PATH)
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +053023 if (EXISTS "${CMAKE_CURRENT_LIST_DIR}/hal/esp-idf")
24 set(IDF_PATH "${CMAKE_CURRENT_LIST_DIR}/hal/esp-idf")
25 elseif (DEFINED ENV{IDF_PATH})
Shubham Kulkarni052561d2021-07-20 11:42:44 +053026 set(IDF_PATH $ENV{IDF_PATH})
27 else()
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +053028 message(FATAL_ERROR "IDF_PATH not found. Please update submodules or set IDF_PATH environment variable or pass -DIDF_PATH flag.")
Shubham Kulkarni052561d2021-07-20 11:42:44 +053029 endif()
30endif()
31
32execute_process(
33 COMMAND git describe --tags
Shubham Kulkarni8787bb02021-07-20 11:46:03 +053034 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
35 OUTPUT_VARIABLE MCUBOOT_VER
36 OUTPUT_STRIP_TRAILING_WHITESPACE
37 )
38add_definitions(-DMCUBOOT_VER=\"${MCUBOOT_VER}\")
39
40execute_process(
41 COMMAND git describe --tags
Shubham Kulkarni052561d2021-07-20 11:42:44 +053042 WORKING_DIRECTORY ${IDF_PATH}
43 OUTPUT_VARIABLE IDF_VER
44 OUTPUT_STRIP_TRAILING_WHITESPACE
45)
46if (NOT "${IDF_VER}" MATCHES "v4.3")
47 message(FATAL_ERROR "Unsupported ESP-IDF version found in IDF_PATH, please checkout to v4.3")
48endif()
49
50if (DEFINED MCUBOOT_CONFIG_FILE)
51 set(mcuboot_config_file ${MCUBOOT_CONFIG_FILE})
52else()
53 set(mcuboot_config_file "${CMAKE_CURRENT_LIST_DIR}/bootloader.conf")
54endif()
55
56if (NOT EXISTS "${mcuboot_config_file}")
57 message(FATAL_ERROR "MCUboot configuration file does not exist at ${mcuboot_config_file}")
58endif()
59
60configure_file(${mcuboot_config_file} dummy.conf)
61file(STRINGS ${mcuboot_config_file} BOOTLOADER_CONF)
62foreach(config ${BOOTLOADER_CONF})
63 if (NOT (${config} MATCHES "#"))
64 string(REGEX REPLACE "^[ ]+" "" config ${config})
65 string(REGEX MATCH "^[^=]+" CONFIG_NAME ${config})
66 string(REPLACE "${CONFIG_NAME}=" "" CONFIG_VALUE ${config})
Almir Okatoeb6b7bf2021-09-07 17:06:35 -030067 if (NOT ("${CONFIG_VALUE}" STREQUAL "n"
68 OR "${CONFIG_VALUE}" STREQUAL "N"))
69 add_definitions(-D${CONFIG_NAME}=${CONFIG_VALUE})
70 set(${CONFIG_NAME} ${CONFIG_VALUE})
71 endif()
Shubham Kulkarni052561d2021-07-20 11:42:44 +053072 endif()
73endforeach()
74
75set(APP_NAME mcuboot_${MCUBOOT_TARGET})
76set(APP_EXECUTABLE ${APP_NAME}.elf)
77
78set(MCUBOOT_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR}/../..)
79set(BOOTUTIL_DIR ${MCUBOOT_ROOT_DIR}/boot/bootutil)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -030080set(ESPRESSIF_PORT_DIR ${CMAKE_CURRENT_LIST_DIR})
81
82if (DEFINED CONFIG_ESP_SIGN_RSA)
83 if ("${MCUBOOT_TARGET}" STREQUAL "esp32s2" OR
84 "${MCUBOOT_TARGET}" STREQUAL "esp32c3")
85 message(FATAL_ERROR "RSA signature verification is currently not supported on the target")
86 endif()
87 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/rsa.cmake)
88elseif (DEFINED CONFIG_ESP_SIGN_EC256)
89 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ec256.cmake)
90elseif (DEFINED CONFIG_ESP_SIGN_ED25519)
91 if ("${MCUBOOT_TARGET}" STREQUAL "esp32c3")
92 message(FATAL_ERROR "ED25519 signature verification is currently not supported on the target")
93 endif()
94 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ed25519.cmake)
95else()
96 # No signature verification
97 set(TINYCRYPT_DIR ${MCUBOOT_ROOT_DIR}/ext/tinycrypt/lib)
98 set(CRYPTO_INC
99 ${TINYCRYPT_DIR}/include
100 )
101 set(crypto_srcs
102 ${TINYCRYPT_DIR}/source/sha256.c
103 ${TINYCRYPT_DIR}/source/utils.c
104 )
105endif()
106
107if(DEFINED CONFIG_ESP_SIGN_KEY_FILE)
108 if(IS_ABSOLUTE ${CONFIG_ESP_SIGN_KEY_FILE})
109 set(KEY_FILE ${CONFIG_ESP_SIGN_KEY_FILE})
110 else()
111 set(KEY_FILE ${MCUBOOT_ROOT_DIR}/${CONFIG_ESP_SIGN_KEY_FILE})
112 endif()
113 message("MCUBoot bootloader key file: ${KEY_FILE}")
114
115 set(GENERATED_PUBKEY ${CMAKE_CURRENT_BINARY_DIR}/autogen-pubkey.c)
116 add_custom_command(
117 OUTPUT ${GENERATED_PUBKEY}
118 COMMAND
119 ${PYTHON_EXECUTABLE}
120 ${MCUBOOT_ROOT_DIR}/scripts/imgtool.py
121 getpub
122 -k
123 ${KEY_FILE}
124 > ${GENERATED_PUBKEY}
125 DEPENDS ${KEY_FILE}
126 )
127 list(APPEND crypto_srcs ${GENERATED_PUBKEY})
128endif()
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530129
130set(bootutil_srcs
131 ${BOOTUTIL_DIR}/src/boot_record.c
132 ${BOOTUTIL_DIR}/src/bootutil_misc.c
133 ${BOOTUTIL_DIR}/src/bootutil_public.c
134 ${BOOTUTIL_DIR}/src/caps.c
135 ${BOOTUTIL_DIR}/src/encrypted.c
136 ${BOOTUTIL_DIR}/src/fault_injection_hardening.c
137 ${BOOTUTIL_DIR}/src/fault_injection_hardening_delay_rng_mbedtls.c
138 ${BOOTUTIL_DIR}/src/image_ec.c
139 ${BOOTUTIL_DIR}/src/image_ec256.c
140 ${BOOTUTIL_DIR}/src/image_ed25519.c
141 ${BOOTUTIL_DIR}/src/image_rsa.c
142 ${BOOTUTIL_DIR}/src/image_validate.c
143 ${BOOTUTIL_DIR}/src/loader.c
144 ${BOOTUTIL_DIR}/src/swap_misc.c
145 ${BOOTUTIL_DIR}/src/swap_move.c
146 ${BOOTUTIL_DIR}/src/swap_scratch.c
147 ${BOOTUTIL_DIR}/src/tlv.c
148 )
149
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530150set(CFLAGS
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530151 "-Wno-frame-address"
152 "-Wall"
153 "-Wextra"
154 "-W"
155 "-Wdeclaration-after-statement"
156 "-Wwrite-strings"
157 "-Wlogical-op"
158 "-Wshadow"
159 "-ffunction-sections"
160 "-fdata-sections"
161 "-fstrict-volatile-bitfields"
162 "-Werror=all"
163 "-Wno-error=unused-function"
164 "-Wno-error=unused-but-set-variable"
165 "-Wno-error=unused-variable"
166 "-Wno-error=deprecated-declarations"
167 "-Wno-unused-parameter"
168 "-Wno-sign-compare"
169 "-ggdb"
170 "-Os"
171 "-D_GNU_SOURCE"
172 "-std=gnu99"
173 "-Wno-old-style-declaration"
174 "-Wno-implicit-int"
175 "-Wno-declaration-after-statement"
176 )
177
178set(LDFLAGS
179 "-nostdlib"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530180 "-Wno-frame-address"
181 "-Wl,--cref"
182 "-Wl,--Map=${APP_NAME}.map"
183 "-fno-rtti"
184 "-fno-lto"
185 "-Wl,--gc-sections"
186 "-Wl,--undefined=uxTopUsedPriority"
187 "-lm"
188 "-lgcc"
189 "-lgcov"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530190 )
191
Almir Okato712fdb52021-08-06 10:22:56 -0300192if ("${MCUBOOT_ARCH}" STREQUAL "xtensa")
193 list(APPEND CFLAGS
194 "-mlongcalls"
195 )
196 list(APPEND LDFLAGS
197 "-mlongcalls"
198 )
199endif()
200
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530201add_subdirectory(hal)
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530202add_executable(
203 ${APP_EXECUTABLE}
204 ${CMAKE_CURRENT_LIST_DIR}/main.c
205 )
206
207target_compile_options(
208 ${APP_EXECUTABLE}
209 PUBLIC
210 ${CFLAGS}
211 )
212
213target_sources(
214 ${APP_EXECUTABLE}
215 PUBLIC
216 ${bootutil_srcs}
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300217 ${crypto_srcs}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530218 ${CMAKE_CURRENT_LIST_DIR}/port/esp_mcuboot.c
Shubham Kulkarni8787bb02021-07-20 11:46:03 +0530219 ${CMAKE_CURRENT_LIST_DIR}/port/esp_loader.c
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300220 ${CMAKE_CURRENT_LIST_DIR}/os.c
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530221 )
222
223target_include_directories(
224 ${APP_EXECUTABLE}
225 PUBLIC
226 ${BOOTUTIL_DIR}/include
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300227 ${CRYPTO_INC}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530228 ${CMAKE_CURRENT_LIST_DIR}/include
229 )
230
231target_link_libraries(
232 ${APP_EXECUTABLE}
233 PUBLIC
234 -T${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/ld/bootloader.ld
235 ${LDFLAGS}
236 )
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530237
238target_link_libraries(
239 ${APP_EXECUTABLE}
240 PUBLIC
241 hal
242 )