blob: bc7868f8f9104cb157980ec3939d058ffb3e96c7 [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
Almir Okatoc3fe5162023-06-26 22:34:20 -030025 "${MCUBOOT_TARGET}" STREQUAL "esp32c2" OR
Almir Okatod43cf892023-06-26 22:31:31 -030026 "${MCUBOOT_TARGET}" STREQUAL "esp32h2")
Almir Okato712fdb52021-08-06 10:22:56 -030027 set(MCUBOOT_ARCH "riscv")
28endif()
29
Almir Okatofa173df2022-04-19 01:10:30 -030030# Set the minimum revision for each supported chip
31if ("${MCUBOOT_TARGET}" STREQUAL "esp32")
32 set(ESP_MIN_REVISION 3)
33elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s2")
34 set(ESP_MIN_REVISION 0)
35elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s3")
36 set(ESP_MIN_REVISION 0)
37elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3")
38 set(ESP_MIN_REVISION 3)
Almir Okatoecaf8bd2023-06-26 22:22:24 -030039elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c6")
40 set(ESP_MIN_REVISION 0)
Almir Okatoc3fe5162023-06-26 22:34:20 -030041elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c2")
42 set(ESP_MIN_REVISION 0)
Almir Okatod43cf892023-06-26 22:31:31 -030043elseif("${MCUBOOT_TARGET}" STREQUAL "esp32h2")
44 set(ESP_MIN_REVISION 0)
Almir Okatofa173df2022-04-19 01:10:30 -030045else()
46 message(FATAL_ERROR "Unsupported target ${MCUBOOT_TARGET}")
47endif()
48
Almir Okato54ef4842023-03-07 17:56:53 -030049if (NOT DEFINED ESP_HAL_PATH)
50 if (DEFINED ENV{ESP_HAL_PATH})
51 set(ESP_HAL_PATH $ENV{ESP_HAL_PATH})
Shubham Kulkarni052561d2021-07-20 11:42:44 +053052 else()
Almir Okato54ef4842023-03-07 17:56:53 -030053 message(WARNING "ESP_HAL_PATH not found. Please set -DESP_HAL_PATH parameter or define ESP_HAL_PATH environment variable.")
54 if (DEFINED ENV{IDF_PATH})
55 set(ESP_HAL_PATH $ENV{IDF_PATH})
56 message("IDF installation found in the system, using IDF_PATH as ESP_HAL_PATH.")
57 endif()
Shubham Kulkarni052561d2021-07-20 11:42:44 +053058 endif()
59endif()
60
61execute_process(
62 COMMAND git describe --tags
Shubham Kulkarni8787bb02021-07-20 11:46:03 +053063 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
64 OUTPUT_VARIABLE MCUBOOT_VER
65 OUTPUT_STRIP_TRAILING_WHITESPACE
66 )
67add_definitions(-DMCUBOOT_VER=\"${MCUBOOT_VER}\")
68
Almir Okatofa173df2022-04-19 01:10:30 -030069if (NOT DEFINED MCUBOOT_CONFIG_FILE)
70 set(MCUBOOT_CONFIG_FILE "${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/bootloader.conf")
Shubham Kulkarni052561d2021-07-20 11:42:44 +053071endif()
72
Almir Okatofa173df2022-04-19 01:10:30 -030073string(REPLACE " " ";" MCUBOOT_CONFIG_FILE_LIST "${MCUBOOT_CONFIG_FILE}")
74foreach(CONFIG_FILE ${MCUBOOT_CONFIG_FILE_LIST})
75 if (NOT EXISTS "${CONFIG_FILE}")
76 message(FATAL_ERROR "MCUboot configuration file does not exist at ${CONFIG_FILE}")
Shubham Kulkarni052561d2021-07-20 11:42:44 +053077 endif()
Almir Okatofa173df2022-04-19 01:10:30 -030078 parse_and_set_config_file(${CONFIG_FILE})
Shubham Kulkarni052561d2021-07-20 11:42:44 +053079endforeach()
80
81set(APP_NAME mcuboot_${MCUBOOT_TARGET})
82set(APP_EXECUTABLE ${APP_NAME}.elf)
83
84set(MCUBOOT_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR}/../..)
85set(BOOTUTIL_DIR ${MCUBOOT_ROOT_DIR}/boot/bootutil)
Almir Okatoe8cbc0d2022-06-13 10:45:39 -030086set(BOOT_SERIAL_DIR ${MCUBOOT_ROOT_DIR}/boot/boot_serial)
Jamie McCraedb6ba462023-05-09 10:30:41 +010087set(ZCBOR_DIR ${MCUBOOT_ROOT_DIR}/boot/zcbor)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -030088set(ESPRESSIF_PORT_DIR ${CMAKE_CURRENT_LIST_DIR})
89
Gustavo Henrique Nihei72627c52021-11-01 18:29:25 -030090# Find imgtool.
91# Go with an explicitly installed imgtool first, falling
92# back to mcuboot/scripts/imgtool.py.
93find_program(IMGTOOL_COMMAND
94 NAMES imgtool imgtool.py
95 )
96if ("${IMGTOOL_COMMAND}" MATCHES "IMGTOOL_COMMAND-NOTFOUND")
97 set(imgtool_path "${MCUBOOT_ROOT_DIR}/scripts/imgtool.py")
98else()
99 set(imgtool_path "${IMGTOOL_COMMAND}")
100endif()
101
Almir Okato26ed3f42023-03-07 16:13:35 -0300102# Find installed esptool, if not found falls to IDF's
103find_program(ESPTOOL_COMMAND
104 NAMES esptool esptool.py
105 )
106if ("${ESPTOOL_COMMAND}" MATCHES "ESPTOOL_COMMAND-NOTFOUND")
Almir Okato54ef4842023-03-07 17:56:53 -0300107 if (DEFINED ENV{IDF_PATH})
108 set(esptool_path "${IDF_PATH}/components/esptool_py/esptool/esptool.py")
109 else()
110 message(FATAL_ERROR "esptool.py not found. Please install it using \'pip install esptool\'.")
111 endif()
Almir Okato26ed3f42023-03-07 16:13:35 -0300112else()
113 set(esptool_path "${ESPTOOL_COMMAND}")
114endif()
115
Almir Okato3ccc6a62023-06-26 18:09:10 -0300116# Flash frequency parameter for esptool.py, for more information, check `esptool.py -h`
117if (NOT DEFINED ESP_FLASH_FREQ)
118 if ("${MCUBOOT_TARGET}" STREQUAL "esp32" OR
119 "${MCUBOOT_TARGET}" STREQUAL "esp32s2" OR
120 "${MCUBOOT_TARGET}" STREQUAL "esp32s3" OR
Almir Okatoecaf8bd2023-06-26 22:22:24 -0300121 "${MCUBOOT_TARGET}" STREQUAL "esp32c3" OR
122 "${MCUBOOT_TARGET}" STREQUAL "esp32c6")
Almir Okato3ccc6a62023-06-26 18:09:10 -0300123 set(ESP_FLASH_FREQ "40m")
Almir Okatoc3fe5162023-06-26 22:34:20 -0300124 elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c2")
125 set(ESP_FLASH_FREQ "60m")
Almir Okatod43cf892023-06-26 22:31:31 -0300126 elseif("${MCUBOOT_TARGET}" STREQUAL "esp32h2")
127 set(ESP_FLASH_FREQ "24m")
Almir Okato3ccc6a62023-06-26 18:09:10 -0300128 endif()
129endif()
130
131# Flash mode parameter for esptool.py, for more information, check `esptool.py -h`
132if (NOT DEFINED ESP_FLASH_MODE)
133 set(ESP_FLASH_MODE "dio")
134endif()
135
136# Serial baud rate parameter for esptool.py flash use, for more information, check `esptool.py -h`
137if (NOT DEFINED ESP_BAUD_RATE)
138 set(ESP_BAUD_RATE 115200)
139endif()
140
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300141if (DEFINED CONFIG_ESP_SIGN_RSA)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300142 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/rsa.cmake)
143elseif (DEFINED CONFIG_ESP_SIGN_EC256)
144 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ec256.cmake)
145elseif (DEFINED CONFIG_ESP_SIGN_ED25519)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300146 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ed25519.cmake)
147else()
148 # No signature verification
149 set(TINYCRYPT_DIR ${MCUBOOT_ROOT_DIR}/ext/tinycrypt/lib)
150 set(CRYPTO_INC
151 ${TINYCRYPT_DIR}/include
152 )
153 set(crypto_srcs
154 ${TINYCRYPT_DIR}/source/sha256.c
155 ${TINYCRYPT_DIR}/source/utils.c
156 )
157endif()
158
159if(DEFINED CONFIG_ESP_SIGN_KEY_FILE)
160 if(IS_ABSOLUTE ${CONFIG_ESP_SIGN_KEY_FILE})
161 set(KEY_FILE ${CONFIG_ESP_SIGN_KEY_FILE})
162 else()
163 set(KEY_FILE ${MCUBOOT_ROOT_DIR}/${CONFIG_ESP_SIGN_KEY_FILE})
164 endif()
165 message("MCUBoot bootloader key file: ${KEY_FILE}")
166
167 set(GENERATED_PUBKEY ${CMAKE_CURRENT_BINARY_DIR}/autogen-pubkey.c)
168 add_custom_command(
169 OUTPUT ${GENERATED_PUBKEY}
170 COMMAND
Gustavo Henrique Nihei72627c52021-11-01 18:29:25 -0300171 ${imgtool_path}
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300172 getpub
173 -k
174 ${KEY_FILE}
175 > ${GENERATED_PUBKEY}
176 DEPENDS ${KEY_FILE}
177 )
178 list(APPEND crypto_srcs ${GENERATED_PUBKEY})
179endif()
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530180
181set(bootutil_srcs
182 ${BOOTUTIL_DIR}/src/boot_record.c
183 ${BOOTUTIL_DIR}/src/bootutil_misc.c
184 ${BOOTUTIL_DIR}/src/bootutil_public.c
185 ${BOOTUTIL_DIR}/src/caps.c
186 ${BOOTUTIL_DIR}/src/encrypted.c
187 ${BOOTUTIL_DIR}/src/fault_injection_hardening.c
188 ${BOOTUTIL_DIR}/src/fault_injection_hardening_delay_rng_mbedtls.c
Antonio de Angelis10529d32023-04-21 21:43:14 +0100189 ${BOOTUTIL_DIR}/src/image_ecdsa.c
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530190 ${BOOTUTIL_DIR}/src/image_ed25519.c
191 ${BOOTUTIL_DIR}/src/image_rsa.c
192 ${BOOTUTIL_DIR}/src/image_validate.c
193 ${BOOTUTIL_DIR}/src/loader.c
194 ${BOOTUTIL_DIR}/src/swap_misc.c
195 ${BOOTUTIL_DIR}/src/swap_move.c
196 ${BOOTUTIL_DIR}/src/swap_scratch.c
197 ${BOOTUTIL_DIR}/src/tlv.c
198 )
Jamie McCraedb6ba462023-05-09 10:30:41 +0100199set(bootutil_paths)
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530200
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530201set(CFLAGS
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530202 "-Wno-frame-address"
203 "-Wall"
204 "-Wextra"
205 "-W"
206 "-Wdeclaration-after-statement"
207 "-Wwrite-strings"
208 "-Wlogical-op"
209 "-Wshadow"
210 "-ffunction-sections"
211 "-fdata-sections"
212 "-fstrict-volatile-bitfields"
213 "-Werror=all"
214 "-Wno-error=unused-function"
215 "-Wno-error=unused-but-set-variable"
216 "-Wno-error=unused-variable"
217 "-Wno-error=deprecated-declarations"
218 "-Wno-unused-parameter"
219 "-Wno-sign-compare"
220 "-ggdb"
221 "-Os"
222 "-D_GNU_SOURCE"
Almir Okato54ef4842023-03-07 17:56:53 -0300223 "-std=gnu17"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530224 "-Wno-old-style-declaration"
225 "-Wno-implicit-int"
226 "-Wno-declaration-after-statement"
227 )
228
229set(LDFLAGS
230 "-nostdlib"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530231 "-Wno-frame-address"
232 "-Wl,--cref"
233 "-Wl,--Map=${APP_NAME}.map"
234 "-fno-rtti"
235 "-fno-lto"
236 "-Wl,--gc-sections"
237 "-Wl,--undefined=uxTopUsedPriority"
238 "-lm"
239 "-lgcc"
240 "-lgcov"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530241 )
242
Almir Okato712fdb52021-08-06 10:22:56 -0300243if ("${MCUBOOT_ARCH}" STREQUAL "xtensa")
244 list(APPEND CFLAGS
245 "-mlongcalls"
246 )
247 list(APPEND LDFLAGS
248 "-mlongcalls"
249 )
250endif()
251
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530252add_subdirectory(hal)
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530253add_executable(
254 ${APP_EXECUTABLE}
255 ${CMAKE_CURRENT_LIST_DIR}/main.c
256 )
257
258target_compile_options(
259 ${APP_EXECUTABLE}
260 PUBLIC
261 ${CFLAGS}
262 )
263
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300264set(port_srcs
265 ${CMAKE_CURRENT_LIST_DIR}/port/esp_mcuboot.c
266 ${CMAKE_CURRENT_LIST_DIR}/port/esp_loader.c
267 ${CMAKE_CURRENT_LIST_DIR}/os.c
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300268 )
269
270if(CONFIG_ESP_MCUBOOT_SERIAL)
271 set(MBEDTLS_DIR "${MCUBOOT_ROOT_DIR}/ext/mbedtls")
272
273 list(APPEND bootutil_srcs
274 ${BOOT_SERIAL_DIR}/src/boot_serial.c
Jamie McCraecb07e882023-04-14 09:28:24 +0100275 ${BOOT_SERIAL_DIR}/src/zcbor_bulk.c
Jamie McCraedb6ba462023-05-09 10:30:41 +0100276 ${ZCBOR_DIR}/src/zcbor_decode.c
277 ${ZCBOR_DIR}/src/zcbor_encode.c
278 ${ZCBOR_DIR}/src/zcbor_common.c
279 )
280 list(APPEND bootutil_paths
281 ${ZCBOR_DIR}/include
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300282 )
283 list(APPEND port_srcs
Almir Okato0dcdbab2022-09-23 15:02:17 -0300284 ${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/serial_adapter.c
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300285 ${MBEDTLS_DIR}/library/base64.c
286 )
287 list(APPEND CRYPTO_INC
288 ${MBEDTLS_DIR}/include
289 )
290endif()
291
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530292target_sources(
293 ${APP_EXECUTABLE}
294 PUBLIC
295 ${bootutil_srcs}
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300296 ${crypto_srcs}
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300297 ${port_srcs}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530298 )
299
300target_include_directories(
301 ${APP_EXECUTABLE}
302 PUBLIC
303 ${BOOTUTIL_DIR}/include
Almir Okato0dcdbab2022-09-23 15:02:17 -0300304 ${BOOTUTIL_DIR}/src
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300305 ${BOOT_SERIAL_DIR}/include
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300306 ${CRYPTO_INC}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530307 ${CMAKE_CURRENT_LIST_DIR}/include
Jamie McCraedb6ba462023-05-09 10:30:41 +0100308 ${bootutil_paths}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530309 )
310
Almir Okato4a051182023-08-09 14:50:04 -0300311set(ld_input ${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/ld/bootloader.ld)
312set(ld_output ${CMAKE_CURRENT_BINARY_DIR}/ld/bootloader.ld)
313
314file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/ld")
315
316get_directory_property(configs COMPILE_DEFINITIONS)
317foreach(c ${configs})
318 list(APPEND conf_defines "-D${c}")
319endforeach()
320
321# Preprocess linker script
322add_custom_command(
323 TARGET ${APP_EXECUTABLE} PRE_LINK
324 COMMAND ${CMAKE_C_COMPILER} -x c -E -P -o ${ld_output} ${conf_defines} ${ld_input}
325 MAIN_DEPENDENCY ${ld_input}
326 COMMENT "Preprocessing bootloader.ld linker script..."
327 )
328
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530329target_link_libraries(
330 ${APP_EXECUTABLE}
331 PUBLIC
Almir Okato4a051182023-08-09 14:50:04 -0300332 -T${ld_output}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530333 ${LDFLAGS}
334 )
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530335
336target_link_libraries(
337 ${APP_EXECUTABLE}
338 PUBLIC
339 hal
340 )
Almir Okatofa173df2022-04-19 01:10:30 -0300341
342# This step uses esptool.py for generating the final bootloader binary in
343# Espressif compatible format.
344# Note: Both binary generation and flash steps still have some default arguments
345add_custom_command(TARGET ${APP_EXECUTABLE} POST_BUILD
346 COMMAND
Almir Okato26ed3f42023-03-07 16:13:35 -0300347 ${esptool_path}
Almir Okatofa173df2022-04-19 01:10:30 -0300348 --chip ${MCUBOOT_TARGET} elf2image --min-rev ${ESP_MIN_REVISION}
Almir Okato3ccc6a62023-06-26 18:09:10 -0300349 --flash_mode ${ESP_FLASH_MODE} --flash_freq ${ESP_FLASH_FREQ} --flash_size ${CONFIG_ESP_FLASH_SIZE}
Almir Okatofa173df2022-04-19 01:10:30 -0300350 -o ${APP_NAME}.bin ${APP_NAME}.elf
351 )
352
353if (DEFINED MCUBOOT_FLASH_PORT)
354 set(FLASH_PORT ${MCUBOOT_FLASH_PORT})
355else()
356 # Defaults to the first USB serial port
357 set(FLASH_PORT "/dev/ttyUSB0")
358endif()
359
360if (NOT EXISTS "${FLASH_PORT}")
361 message(WARNING "Could not open ${FLASH_PORT}, serial port does not exist")
362endif()
363
364add_custom_target(flash DEPENDS ${APP_NAME}.bin)
365add_custom_command(TARGET flash
366 USES_TERMINAL
367 COMMAND
Almir Okato26ed3f42023-03-07 16:13:35 -0300368 ${esptool_path}
Almir Okato3ccc6a62023-06-26 18:09:10 -0300369 -p ${FLASH_PORT} -b ${ESP_BAUD_RATE} --before default_reset --after no_reset
Almir Okatofa173df2022-04-19 01:10:30 -0300370 --chip ${MCUBOOT_TARGET} write_flash
Almir Okato3ccc6a62023-06-26 18:09:10 -0300371 --flash_mode ${ESP_FLASH_MODE} --flash_size ${CONFIG_ESP_FLASH_SIZE}
372 --flash_freq ${ESP_FLASH_FREQ} ${CONFIG_ESP_BOOTLOADER_OFFSET}
Almir Okatofa173df2022-04-19 01:10:30 -0300373 ${APP_NAME}.bin
374 )