blob: 3bfb367f2125338c3f7c687bb9b64e285a69f1ee [file] [log] [blame]
Gustavo Henrique Nihei6a6b8912021-11-12 11:43:10 -03001# SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
Almir Okatoeb6b7bf2021-09-07 17:06:35 -03002#
3# SPDX-License-Identifier: Apache-2.0
4
Shubham Kulkarni052561d2021-07-20 11:42:44 +05305cmake_minimum_required(VERSION 3.13)
Almir Okato54ef4842023-03-07 17:56:53 -03006cmake_policy(SET CMP0109 NEW)
Shubham Kulkarni052561d2021-07-20 11:42:44 +05307
Almir Okatofa173df2022-04-19 01:10:30 -03008include(${CMAKE_CURRENT_LIST_DIR}/tools/utils.cmake)
9
Shubham Kulkarni052561d2021-07-20 11:42:44 +053010if (NOT DEFINED MCUBOOT_TARGET)
11 message(FATAL_ERROR "MCUBOOT_TARGET not defined. Please pass -DMCUBOOT_TARGET flag.")
12endif()
13
14project(mcuboot_${MCUBOOT_TARGET})
15
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +053016add_definitions(-DMCUBOOT_TARGET=${MCUBOOT_TARGET})
Almir Okatoe8cbc0d2022-06-13 10:45:39 -030017add_definitions(-D__ESPRESSIF__=1)
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +053018
Almir Okato712fdb52021-08-06 10:22:56 -030019if ("${MCUBOOT_TARGET}" STREQUAL "esp32" OR
Almir Okato42e679d2022-01-18 00:16:58 -030020 "${MCUBOOT_TARGET}" STREQUAL "esp32s2" OR
21 "${MCUBOOT_TARGET}" STREQUAL "esp32s3")
Almir Okato712fdb52021-08-06 10:22:56 -030022 set(MCUBOOT_ARCH "xtensa")
Almir Okatoecaf8bd2023-06-26 22:22:24 -030023elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3" OR
Almir Okatod43cf892023-06-26 22:31:31 -030024 "${MCUBOOT_TARGET}" STREQUAL "esp32c6" OR
25 "${MCUBOOT_TARGET}" STREQUAL "esp32h2")
Almir Okato712fdb52021-08-06 10:22:56 -030026 set(MCUBOOT_ARCH "riscv")
27endif()
28
Almir Okatofa173df2022-04-19 01:10:30 -030029# Set the minimum revision for each supported chip
30if ("${MCUBOOT_TARGET}" STREQUAL "esp32")
31 set(ESP_MIN_REVISION 3)
32elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s2")
33 set(ESP_MIN_REVISION 0)
34elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s3")
35 set(ESP_MIN_REVISION 0)
36elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3")
37 set(ESP_MIN_REVISION 3)
Almir Okatoecaf8bd2023-06-26 22:22:24 -030038elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c6")
39 set(ESP_MIN_REVISION 0)
Almir Okatod43cf892023-06-26 22:31:31 -030040elseif("${MCUBOOT_TARGET}" STREQUAL "esp32h2")
41 set(ESP_MIN_REVISION 0)
Almir Okatofa173df2022-04-19 01:10:30 -030042else()
43 message(FATAL_ERROR "Unsupported target ${MCUBOOT_TARGET}")
44endif()
45
Almir Okato54ef4842023-03-07 17:56:53 -030046if (NOT DEFINED ESP_HAL_PATH)
47 if (DEFINED ENV{ESP_HAL_PATH})
48 set(ESP_HAL_PATH $ENV{ESP_HAL_PATH})
Shubham Kulkarni052561d2021-07-20 11:42:44 +053049 else()
Almir Okato54ef4842023-03-07 17:56:53 -030050 message(WARNING "ESP_HAL_PATH not found. Please set -DESP_HAL_PATH parameter or define ESP_HAL_PATH environment variable.")
51 if (DEFINED ENV{IDF_PATH})
52 set(ESP_HAL_PATH $ENV{IDF_PATH})
53 message("IDF installation found in the system, using IDF_PATH as ESP_HAL_PATH.")
54 endif()
Shubham Kulkarni052561d2021-07-20 11:42:44 +053055 endif()
56endif()
57
58execute_process(
59 COMMAND git describe --tags
Shubham Kulkarni8787bb02021-07-20 11:46:03 +053060 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
61 OUTPUT_VARIABLE MCUBOOT_VER
62 OUTPUT_STRIP_TRAILING_WHITESPACE
63 )
64add_definitions(-DMCUBOOT_VER=\"${MCUBOOT_VER}\")
65
Almir Okatofa173df2022-04-19 01:10:30 -030066if (NOT DEFINED MCUBOOT_CONFIG_FILE)
67 set(MCUBOOT_CONFIG_FILE "${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/bootloader.conf")
Shubham Kulkarni052561d2021-07-20 11:42:44 +053068endif()
69
Almir Okatofa173df2022-04-19 01:10:30 -030070string(REPLACE " " ";" MCUBOOT_CONFIG_FILE_LIST "${MCUBOOT_CONFIG_FILE}")
71foreach(CONFIG_FILE ${MCUBOOT_CONFIG_FILE_LIST})
72 if (NOT EXISTS "${CONFIG_FILE}")
73 message(FATAL_ERROR "MCUboot configuration file does not exist at ${CONFIG_FILE}")
Shubham Kulkarni052561d2021-07-20 11:42:44 +053074 endif()
Almir Okatofa173df2022-04-19 01:10:30 -030075 parse_and_set_config_file(${CONFIG_FILE})
Shubham Kulkarni052561d2021-07-20 11:42:44 +053076endforeach()
77
78set(APP_NAME mcuboot_${MCUBOOT_TARGET})
79set(APP_EXECUTABLE ${APP_NAME}.elf)
80
81set(MCUBOOT_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR}/../..)
82set(BOOTUTIL_DIR ${MCUBOOT_ROOT_DIR}/boot/bootutil)
Almir Okatoe8cbc0d2022-06-13 10:45:39 -030083set(BOOT_SERIAL_DIR ${MCUBOOT_ROOT_DIR}/boot/boot_serial)
Jamie McCraedb6ba462023-05-09 10:30:41 +010084set(ZCBOR_DIR ${MCUBOOT_ROOT_DIR}/boot/zcbor)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -030085set(ESPRESSIF_PORT_DIR ${CMAKE_CURRENT_LIST_DIR})
86
Gustavo Henrique Nihei72627c52021-11-01 18:29:25 -030087# Find imgtool.
88# Go with an explicitly installed imgtool first, falling
89# back to mcuboot/scripts/imgtool.py.
90find_program(IMGTOOL_COMMAND
91 NAMES imgtool imgtool.py
92 )
93if ("${IMGTOOL_COMMAND}" MATCHES "IMGTOOL_COMMAND-NOTFOUND")
94 set(imgtool_path "${MCUBOOT_ROOT_DIR}/scripts/imgtool.py")
95else()
96 set(imgtool_path "${IMGTOOL_COMMAND}")
97endif()
98
Almir Okato26ed3f42023-03-07 16:13:35 -030099# Find installed esptool, if not found falls to IDF's
100find_program(ESPTOOL_COMMAND
101 NAMES esptool esptool.py
102 )
103if ("${ESPTOOL_COMMAND}" MATCHES "ESPTOOL_COMMAND-NOTFOUND")
Almir Okato54ef4842023-03-07 17:56:53 -0300104 if (DEFINED ENV{IDF_PATH})
105 set(esptool_path "${IDF_PATH}/components/esptool_py/esptool/esptool.py")
106 else()
107 message(FATAL_ERROR "esptool.py not found. Please install it using \'pip install esptool\'.")
108 endif()
Almir Okato26ed3f42023-03-07 16:13:35 -0300109else()
110 set(esptool_path "${ESPTOOL_COMMAND}")
111endif()
112
Almir Okato3ccc6a62023-06-26 18:09:10 -0300113# Flash frequency parameter for esptool.py, for more information, check `esptool.py -h`
114if (NOT DEFINED ESP_FLASH_FREQ)
115 if ("${MCUBOOT_TARGET}" STREQUAL "esp32" OR
116 "${MCUBOOT_TARGET}" STREQUAL "esp32s2" OR
117 "${MCUBOOT_TARGET}" STREQUAL "esp32s3" OR
Almir Okatoecaf8bd2023-06-26 22:22:24 -0300118 "${MCUBOOT_TARGET}" STREQUAL "esp32c3" OR
119 "${MCUBOOT_TARGET}" STREQUAL "esp32c6")
Almir Okato3ccc6a62023-06-26 18:09:10 -0300120 set(ESP_FLASH_FREQ "40m")
Almir Okatod43cf892023-06-26 22:31:31 -0300121 elseif("${MCUBOOT_TARGET}" STREQUAL "esp32h2")
122 set(ESP_FLASH_FREQ "24m")
Almir Okato3ccc6a62023-06-26 18:09:10 -0300123 endif()
124endif()
125
126# Flash mode parameter for esptool.py, for more information, check `esptool.py -h`
127if (NOT DEFINED ESP_FLASH_MODE)
128 set(ESP_FLASH_MODE "dio")
129endif()
130
131# Serial baud rate parameter for esptool.py flash use, for more information, check `esptool.py -h`
132if (NOT DEFINED ESP_BAUD_RATE)
133 set(ESP_BAUD_RATE 115200)
134endif()
135
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300136if (DEFINED CONFIG_ESP_SIGN_RSA)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300137 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/rsa.cmake)
138elseif (DEFINED CONFIG_ESP_SIGN_EC256)
139 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ec256.cmake)
140elseif (DEFINED CONFIG_ESP_SIGN_ED25519)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300141 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ed25519.cmake)
142else()
143 # No signature verification
144 set(TINYCRYPT_DIR ${MCUBOOT_ROOT_DIR}/ext/tinycrypt/lib)
145 set(CRYPTO_INC
146 ${TINYCRYPT_DIR}/include
147 )
148 set(crypto_srcs
149 ${TINYCRYPT_DIR}/source/sha256.c
150 ${TINYCRYPT_DIR}/source/utils.c
151 )
152endif()
153
154if(DEFINED CONFIG_ESP_SIGN_KEY_FILE)
155 if(IS_ABSOLUTE ${CONFIG_ESP_SIGN_KEY_FILE})
156 set(KEY_FILE ${CONFIG_ESP_SIGN_KEY_FILE})
157 else()
158 set(KEY_FILE ${MCUBOOT_ROOT_DIR}/${CONFIG_ESP_SIGN_KEY_FILE})
159 endif()
160 message("MCUBoot bootloader key file: ${KEY_FILE}")
161
162 set(GENERATED_PUBKEY ${CMAKE_CURRENT_BINARY_DIR}/autogen-pubkey.c)
163 add_custom_command(
164 OUTPUT ${GENERATED_PUBKEY}
165 COMMAND
Gustavo Henrique Nihei72627c52021-11-01 18:29:25 -0300166 ${imgtool_path}
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300167 getpub
168 -k
169 ${KEY_FILE}
170 > ${GENERATED_PUBKEY}
171 DEPENDS ${KEY_FILE}
172 )
173 list(APPEND crypto_srcs ${GENERATED_PUBKEY})
174endif()
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530175
176set(bootutil_srcs
177 ${BOOTUTIL_DIR}/src/boot_record.c
178 ${BOOTUTIL_DIR}/src/bootutil_misc.c
179 ${BOOTUTIL_DIR}/src/bootutil_public.c
180 ${BOOTUTIL_DIR}/src/caps.c
181 ${BOOTUTIL_DIR}/src/encrypted.c
182 ${BOOTUTIL_DIR}/src/fault_injection_hardening.c
183 ${BOOTUTIL_DIR}/src/fault_injection_hardening_delay_rng_mbedtls.c
Antonio de Angelis10529d32023-04-21 21:43:14 +0100184 ${BOOTUTIL_DIR}/src/image_ecdsa.c
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530185 ${BOOTUTIL_DIR}/src/image_ed25519.c
186 ${BOOTUTIL_DIR}/src/image_rsa.c
187 ${BOOTUTIL_DIR}/src/image_validate.c
188 ${BOOTUTIL_DIR}/src/loader.c
189 ${BOOTUTIL_DIR}/src/swap_misc.c
190 ${BOOTUTIL_DIR}/src/swap_move.c
191 ${BOOTUTIL_DIR}/src/swap_scratch.c
192 ${BOOTUTIL_DIR}/src/tlv.c
193 )
Jamie McCraedb6ba462023-05-09 10:30:41 +0100194set(bootutil_paths)
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530195
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530196set(CFLAGS
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530197 "-Wno-frame-address"
198 "-Wall"
199 "-Wextra"
200 "-W"
201 "-Wdeclaration-after-statement"
202 "-Wwrite-strings"
203 "-Wlogical-op"
204 "-Wshadow"
205 "-ffunction-sections"
206 "-fdata-sections"
207 "-fstrict-volatile-bitfields"
208 "-Werror=all"
209 "-Wno-error=unused-function"
210 "-Wno-error=unused-but-set-variable"
211 "-Wno-error=unused-variable"
212 "-Wno-error=deprecated-declarations"
213 "-Wno-unused-parameter"
214 "-Wno-sign-compare"
215 "-ggdb"
216 "-Os"
217 "-D_GNU_SOURCE"
Almir Okato54ef4842023-03-07 17:56:53 -0300218 "-std=gnu17"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530219 "-Wno-old-style-declaration"
220 "-Wno-implicit-int"
221 "-Wno-declaration-after-statement"
222 )
223
224set(LDFLAGS
225 "-nostdlib"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530226 "-Wno-frame-address"
227 "-Wl,--cref"
228 "-Wl,--Map=${APP_NAME}.map"
229 "-fno-rtti"
230 "-fno-lto"
231 "-Wl,--gc-sections"
232 "-Wl,--undefined=uxTopUsedPriority"
233 "-lm"
234 "-lgcc"
235 "-lgcov"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530236 )
237
Almir Okato712fdb52021-08-06 10:22:56 -0300238if ("${MCUBOOT_ARCH}" STREQUAL "xtensa")
239 list(APPEND CFLAGS
240 "-mlongcalls"
241 )
242 list(APPEND LDFLAGS
243 "-mlongcalls"
244 )
245endif()
246
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530247add_subdirectory(hal)
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530248add_executable(
249 ${APP_EXECUTABLE}
250 ${CMAKE_CURRENT_LIST_DIR}/main.c
251 )
252
253target_compile_options(
254 ${APP_EXECUTABLE}
255 PUBLIC
256 ${CFLAGS}
257 )
258
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300259set(port_srcs
260 ${CMAKE_CURRENT_LIST_DIR}/port/esp_mcuboot.c
261 ${CMAKE_CURRENT_LIST_DIR}/port/esp_loader.c
262 ${CMAKE_CURRENT_LIST_DIR}/os.c
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300263 )
264
265if(CONFIG_ESP_MCUBOOT_SERIAL)
266 set(MBEDTLS_DIR "${MCUBOOT_ROOT_DIR}/ext/mbedtls")
267
268 list(APPEND bootutil_srcs
269 ${BOOT_SERIAL_DIR}/src/boot_serial.c
Jamie McCraecb07e882023-04-14 09:28:24 +0100270 ${BOOT_SERIAL_DIR}/src/zcbor_bulk.c
Jamie McCraedb6ba462023-05-09 10:30:41 +0100271 ${ZCBOR_DIR}/src/zcbor_decode.c
272 ${ZCBOR_DIR}/src/zcbor_encode.c
273 ${ZCBOR_DIR}/src/zcbor_common.c
274 )
275 list(APPEND bootutil_paths
276 ${ZCBOR_DIR}/include
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300277 )
278 list(APPEND port_srcs
Almir Okato0dcdbab2022-09-23 15:02:17 -0300279 ${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/serial_adapter.c
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300280 ${MBEDTLS_DIR}/library/base64.c
281 )
282 list(APPEND CRYPTO_INC
283 ${MBEDTLS_DIR}/include
284 )
285endif()
286
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530287target_sources(
288 ${APP_EXECUTABLE}
289 PUBLIC
290 ${bootutil_srcs}
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300291 ${crypto_srcs}
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300292 ${port_srcs}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530293 )
294
295target_include_directories(
296 ${APP_EXECUTABLE}
297 PUBLIC
298 ${BOOTUTIL_DIR}/include
Almir Okato0dcdbab2022-09-23 15:02:17 -0300299 ${BOOTUTIL_DIR}/src
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300300 ${BOOT_SERIAL_DIR}/include
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300301 ${CRYPTO_INC}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530302 ${CMAKE_CURRENT_LIST_DIR}/include
Jamie McCraedb6ba462023-05-09 10:30:41 +0100303 ${bootutil_paths}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530304 )
305
306target_link_libraries(
307 ${APP_EXECUTABLE}
308 PUBLIC
309 -T${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/ld/bootloader.ld
310 ${LDFLAGS}
311 )
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530312
313target_link_libraries(
314 ${APP_EXECUTABLE}
315 PUBLIC
316 hal
317 )
Almir Okatofa173df2022-04-19 01:10:30 -0300318
319# This step uses esptool.py for generating the final bootloader binary in
320# Espressif compatible format.
321# Note: Both binary generation and flash steps still have some default arguments
322add_custom_command(TARGET ${APP_EXECUTABLE} POST_BUILD
323 COMMAND
Almir Okato26ed3f42023-03-07 16:13:35 -0300324 ${esptool_path}
Almir Okatofa173df2022-04-19 01:10:30 -0300325 --chip ${MCUBOOT_TARGET} elf2image --min-rev ${ESP_MIN_REVISION}
Almir Okato3ccc6a62023-06-26 18:09:10 -0300326 --flash_mode ${ESP_FLASH_MODE} --flash_freq ${ESP_FLASH_FREQ} --flash_size ${CONFIG_ESP_FLASH_SIZE}
Almir Okatofa173df2022-04-19 01:10:30 -0300327 -o ${APP_NAME}.bin ${APP_NAME}.elf
328 )
329
330if (DEFINED MCUBOOT_FLASH_PORT)
331 set(FLASH_PORT ${MCUBOOT_FLASH_PORT})
332else()
333 # Defaults to the first USB serial port
334 set(FLASH_PORT "/dev/ttyUSB0")
335endif()
336
337if (NOT EXISTS "${FLASH_PORT}")
338 message(WARNING "Could not open ${FLASH_PORT}, serial port does not exist")
339endif()
340
341add_custom_target(flash DEPENDS ${APP_NAME}.bin)
342add_custom_command(TARGET flash
343 USES_TERMINAL
344 COMMAND
Almir Okato26ed3f42023-03-07 16:13:35 -0300345 ${esptool_path}
Almir Okato3ccc6a62023-06-26 18:09:10 -0300346 -p ${FLASH_PORT} -b ${ESP_BAUD_RATE} --before default_reset --after no_reset
Almir Okatofa173df2022-04-19 01:10:30 -0300347 --chip ${MCUBOOT_TARGET} write_flash
Almir Okato3ccc6a62023-06-26 18:09:10 -0300348 --flash_mode ${ESP_FLASH_MODE} --flash_size ${CONFIG_ESP_FLASH_SIZE}
349 --flash_freq ${ESP_FLASH_FREQ} ${CONFIG_ESP_BOOTLOADER_OFFSET}
Almir Okatofa173df2022-04-19 01:10:30 -0300350 ${APP_NAME}.bin
351 )