blob: 15eba34ff5542272f038795bbcf45b225212b94c [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")
23elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3")
24 set(MCUBOOT_ARCH "riscv")
25endif()
26
Almir Okatofa173df2022-04-19 01:10:30 -030027# Set the minimum revision for each supported chip
28if ("${MCUBOOT_TARGET}" STREQUAL "esp32")
29 set(ESP_MIN_REVISION 3)
30elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s2")
31 set(ESP_MIN_REVISION 0)
32elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s3")
33 set(ESP_MIN_REVISION 0)
34elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3")
35 set(ESP_MIN_REVISION 3)
36else()
37 message(FATAL_ERROR "Unsupported target ${MCUBOOT_TARGET}")
38endif()
39
Almir Okato54ef4842023-03-07 17:56:53 -030040if (NOT DEFINED ESP_HAL_PATH)
41 if (DEFINED ENV{ESP_HAL_PATH})
42 set(ESP_HAL_PATH $ENV{ESP_HAL_PATH})
Shubham Kulkarni052561d2021-07-20 11:42:44 +053043 else()
Almir Okato54ef4842023-03-07 17:56:53 -030044 message(WARNING "ESP_HAL_PATH not found. Please set -DESP_HAL_PATH parameter or define ESP_HAL_PATH environment variable.")
45 if (DEFINED ENV{IDF_PATH})
46 set(ESP_HAL_PATH $ENV{IDF_PATH})
47 message("IDF installation found in the system, using IDF_PATH as ESP_HAL_PATH.")
48 endif()
Shubham Kulkarni052561d2021-07-20 11:42:44 +053049 endif()
50endif()
51
52execute_process(
53 COMMAND git describe --tags
Shubham Kulkarni8787bb02021-07-20 11:46:03 +053054 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
55 OUTPUT_VARIABLE MCUBOOT_VER
56 OUTPUT_STRIP_TRAILING_WHITESPACE
57 )
58add_definitions(-DMCUBOOT_VER=\"${MCUBOOT_VER}\")
59
Almir Okatofa173df2022-04-19 01:10:30 -030060if (NOT DEFINED MCUBOOT_CONFIG_FILE)
61 set(MCUBOOT_CONFIG_FILE "${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/bootloader.conf")
Shubham Kulkarni052561d2021-07-20 11:42:44 +053062endif()
63
Almir Okatofa173df2022-04-19 01:10:30 -030064string(REPLACE " " ";" MCUBOOT_CONFIG_FILE_LIST "${MCUBOOT_CONFIG_FILE}")
65foreach(CONFIG_FILE ${MCUBOOT_CONFIG_FILE_LIST})
66 if (NOT EXISTS "${CONFIG_FILE}")
67 message(FATAL_ERROR "MCUboot configuration file does not exist at ${CONFIG_FILE}")
Shubham Kulkarni052561d2021-07-20 11:42:44 +053068 endif()
Almir Okatofa173df2022-04-19 01:10:30 -030069 parse_and_set_config_file(${CONFIG_FILE})
Shubham Kulkarni052561d2021-07-20 11:42:44 +053070endforeach()
71
72set(APP_NAME mcuboot_${MCUBOOT_TARGET})
73set(APP_EXECUTABLE ${APP_NAME}.elf)
74
75set(MCUBOOT_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR}/../..)
76set(BOOTUTIL_DIR ${MCUBOOT_ROOT_DIR}/boot/bootutil)
Almir Okatoe8cbc0d2022-06-13 10:45:39 -030077set(BOOT_SERIAL_DIR ${MCUBOOT_ROOT_DIR}/boot/boot_serial)
Jamie McCraedb6ba462023-05-09 10:30:41 +010078set(ZCBOR_DIR ${MCUBOOT_ROOT_DIR}/boot/zcbor)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -030079set(ESPRESSIF_PORT_DIR ${CMAKE_CURRENT_LIST_DIR})
80
Gustavo Henrique Nihei72627c52021-11-01 18:29:25 -030081# Find imgtool.
82# Go with an explicitly installed imgtool first, falling
83# back to mcuboot/scripts/imgtool.py.
84find_program(IMGTOOL_COMMAND
85 NAMES imgtool imgtool.py
86 )
87if ("${IMGTOOL_COMMAND}" MATCHES "IMGTOOL_COMMAND-NOTFOUND")
88 set(imgtool_path "${MCUBOOT_ROOT_DIR}/scripts/imgtool.py")
89else()
90 set(imgtool_path "${IMGTOOL_COMMAND}")
91endif()
92
Almir Okato26ed3f42023-03-07 16:13:35 -030093# Find installed esptool, if not found falls to IDF's
94find_program(ESPTOOL_COMMAND
95 NAMES esptool esptool.py
96 )
97if ("${ESPTOOL_COMMAND}" MATCHES "ESPTOOL_COMMAND-NOTFOUND")
Almir Okato54ef4842023-03-07 17:56:53 -030098 if (DEFINED ENV{IDF_PATH})
99 set(esptool_path "${IDF_PATH}/components/esptool_py/esptool/esptool.py")
100 else()
101 message(FATAL_ERROR "esptool.py not found. Please install it using \'pip install esptool\'.")
102 endif()
Almir Okato26ed3f42023-03-07 16:13:35 -0300103else()
104 set(esptool_path "${ESPTOOL_COMMAND}")
105endif()
106
Almir Okato3ccc6a62023-06-26 18:09:10 -0300107# Flash frequency parameter for esptool.py, for more information, check `esptool.py -h`
108if (NOT DEFINED ESP_FLASH_FREQ)
109 if ("${MCUBOOT_TARGET}" STREQUAL "esp32" OR
110 "${MCUBOOT_TARGET}" STREQUAL "esp32s2" OR
111 "${MCUBOOT_TARGET}" STREQUAL "esp32s3" OR
112 "${MCUBOOT_TARGET}" STREQUAL "esp32c3")
113 set(ESP_FLASH_FREQ "40m")
114 endif()
115endif()
116
117# Flash mode parameter for esptool.py, for more information, check `esptool.py -h`
118if (NOT DEFINED ESP_FLASH_MODE)
119 set(ESP_FLASH_MODE "dio")
120endif()
121
122# Serial baud rate parameter for esptool.py flash use, for more information, check `esptool.py -h`
123if (NOT DEFINED ESP_BAUD_RATE)
124 set(ESP_BAUD_RATE 115200)
125endif()
126
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300127if (DEFINED CONFIG_ESP_SIGN_RSA)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300128 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/rsa.cmake)
129elseif (DEFINED CONFIG_ESP_SIGN_EC256)
130 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ec256.cmake)
131elseif (DEFINED CONFIG_ESP_SIGN_ED25519)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300132 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ed25519.cmake)
133else()
134 # No signature verification
135 set(TINYCRYPT_DIR ${MCUBOOT_ROOT_DIR}/ext/tinycrypt/lib)
136 set(CRYPTO_INC
137 ${TINYCRYPT_DIR}/include
138 )
139 set(crypto_srcs
140 ${TINYCRYPT_DIR}/source/sha256.c
141 ${TINYCRYPT_DIR}/source/utils.c
142 )
143endif()
144
145if(DEFINED CONFIG_ESP_SIGN_KEY_FILE)
146 if(IS_ABSOLUTE ${CONFIG_ESP_SIGN_KEY_FILE})
147 set(KEY_FILE ${CONFIG_ESP_SIGN_KEY_FILE})
148 else()
149 set(KEY_FILE ${MCUBOOT_ROOT_DIR}/${CONFIG_ESP_SIGN_KEY_FILE})
150 endif()
151 message("MCUBoot bootloader key file: ${KEY_FILE}")
152
153 set(GENERATED_PUBKEY ${CMAKE_CURRENT_BINARY_DIR}/autogen-pubkey.c)
154 add_custom_command(
155 OUTPUT ${GENERATED_PUBKEY}
156 COMMAND
Gustavo Henrique Nihei72627c52021-11-01 18:29:25 -0300157 ${imgtool_path}
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300158 getpub
159 -k
160 ${KEY_FILE}
161 > ${GENERATED_PUBKEY}
162 DEPENDS ${KEY_FILE}
163 )
164 list(APPEND crypto_srcs ${GENERATED_PUBKEY})
165endif()
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530166
167set(bootutil_srcs
168 ${BOOTUTIL_DIR}/src/boot_record.c
169 ${BOOTUTIL_DIR}/src/bootutil_misc.c
170 ${BOOTUTIL_DIR}/src/bootutil_public.c
171 ${BOOTUTIL_DIR}/src/caps.c
172 ${BOOTUTIL_DIR}/src/encrypted.c
173 ${BOOTUTIL_DIR}/src/fault_injection_hardening.c
174 ${BOOTUTIL_DIR}/src/fault_injection_hardening_delay_rng_mbedtls.c
Antonio de Angelis10529d32023-04-21 21:43:14 +0100175 ${BOOTUTIL_DIR}/src/image_ecdsa.c
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530176 ${BOOTUTIL_DIR}/src/image_ed25519.c
177 ${BOOTUTIL_DIR}/src/image_rsa.c
178 ${BOOTUTIL_DIR}/src/image_validate.c
179 ${BOOTUTIL_DIR}/src/loader.c
180 ${BOOTUTIL_DIR}/src/swap_misc.c
181 ${BOOTUTIL_DIR}/src/swap_move.c
182 ${BOOTUTIL_DIR}/src/swap_scratch.c
183 ${BOOTUTIL_DIR}/src/tlv.c
184 )
Jamie McCraedb6ba462023-05-09 10:30:41 +0100185set(bootutil_paths)
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530186
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530187set(CFLAGS
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530188 "-Wno-frame-address"
189 "-Wall"
190 "-Wextra"
191 "-W"
192 "-Wdeclaration-after-statement"
193 "-Wwrite-strings"
194 "-Wlogical-op"
195 "-Wshadow"
196 "-ffunction-sections"
197 "-fdata-sections"
198 "-fstrict-volatile-bitfields"
199 "-Werror=all"
200 "-Wno-error=unused-function"
201 "-Wno-error=unused-but-set-variable"
202 "-Wno-error=unused-variable"
203 "-Wno-error=deprecated-declarations"
204 "-Wno-unused-parameter"
205 "-Wno-sign-compare"
206 "-ggdb"
207 "-Os"
208 "-D_GNU_SOURCE"
Almir Okato54ef4842023-03-07 17:56:53 -0300209 "-std=gnu17"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530210 "-Wno-old-style-declaration"
211 "-Wno-implicit-int"
212 "-Wno-declaration-after-statement"
213 )
214
215set(LDFLAGS
216 "-nostdlib"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530217 "-Wno-frame-address"
218 "-Wl,--cref"
219 "-Wl,--Map=${APP_NAME}.map"
220 "-fno-rtti"
221 "-fno-lto"
222 "-Wl,--gc-sections"
223 "-Wl,--undefined=uxTopUsedPriority"
224 "-lm"
225 "-lgcc"
226 "-lgcov"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530227 )
228
Almir Okato712fdb52021-08-06 10:22:56 -0300229if ("${MCUBOOT_ARCH}" STREQUAL "xtensa")
230 list(APPEND CFLAGS
231 "-mlongcalls"
232 )
233 list(APPEND LDFLAGS
234 "-mlongcalls"
235 )
236endif()
237
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530238add_subdirectory(hal)
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530239add_executable(
240 ${APP_EXECUTABLE}
241 ${CMAKE_CURRENT_LIST_DIR}/main.c
242 )
243
244target_compile_options(
245 ${APP_EXECUTABLE}
246 PUBLIC
247 ${CFLAGS}
248 )
249
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300250set(port_srcs
251 ${CMAKE_CURRENT_LIST_DIR}/port/esp_mcuboot.c
252 ${CMAKE_CURRENT_LIST_DIR}/port/esp_loader.c
253 ${CMAKE_CURRENT_LIST_DIR}/os.c
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300254 )
255
256if(CONFIG_ESP_MCUBOOT_SERIAL)
257 set(MBEDTLS_DIR "${MCUBOOT_ROOT_DIR}/ext/mbedtls")
258
259 list(APPEND bootutil_srcs
260 ${BOOT_SERIAL_DIR}/src/boot_serial.c
Jamie McCraecb07e882023-04-14 09:28:24 +0100261 ${BOOT_SERIAL_DIR}/src/zcbor_bulk.c
Jamie McCraedb6ba462023-05-09 10:30:41 +0100262 ${ZCBOR_DIR}/src/zcbor_decode.c
263 ${ZCBOR_DIR}/src/zcbor_encode.c
264 ${ZCBOR_DIR}/src/zcbor_common.c
265 )
266 list(APPEND bootutil_paths
267 ${ZCBOR_DIR}/include
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300268 )
269 list(APPEND port_srcs
Almir Okato0dcdbab2022-09-23 15:02:17 -0300270 ${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/serial_adapter.c
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300271 ${MBEDTLS_DIR}/library/base64.c
272 )
273 list(APPEND CRYPTO_INC
274 ${MBEDTLS_DIR}/include
275 )
276endif()
277
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530278target_sources(
279 ${APP_EXECUTABLE}
280 PUBLIC
281 ${bootutil_srcs}
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300282 ${crypto_srcs}
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300283 ${port_srcs}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530284 )
285
286target_include_directories(
287 ${APP_EXECUTABLE}
288 PUBLIC
289 ${BOOTUTIL_DIR}/include
Almir Okato0dcdbab2022-09-23 15:02:17 -0300290 ${BOOTUTIL_DIR}/src
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300291 ${BOOT_SERIAL_DIR}/include
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300292 ${CRYPTO_INC}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530293 ${CMAKE_CURRENT_LIST_DIR}/include
Jamie McCraedb6ba462023-05-09 10:30:41 +0100294 ${bootutil_paths}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530295 )
296
297target_link_libraries(
298 ${APP_EXECUTABLE}
299 PUBLIC
300 -T${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/ld/bootloader.ld
301 ${LDFLAGS}
302 )
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530303
304target_link_libraries(
305 ${APP_EXECUTABLE}
306 PUBLIC
307 hal
308 )
Almir Okatofa173df2022-04-19 01:10:30 -0300309
310# This step uses esptool.py for generating the final bootloader binary in
311# Espressif compatible format.
312# Note: Both binary generation and flash steps still have some default arguments
313add_custom_command(TARGET ${APP_EXECUTABLE} POST_BUILD
314 COMMAND
Almir Okato26ed3f42023-03-07 16:13:35 -0300315 ${esptool_path}
Almir Okatofa173df2022-04-19 01:10:30 -0300316 --chip ${MCUBOOT_TARGET} elf2image --min-rev ${ESP_MIN_REVISION}
Almir Okato3ccc6a62023-06-26 18:09:10 -0300317 --flash_mode ${ESP_FLASH_MODE} --flash_freq ${ESP_FLASH_FREQ} --flash_size ${CONFIG_ESP_FLASH_SIZE}
Almir Okatofa173df2022-04-19 01:10:30 -0300318 -o ${APP_NAME}.bin ${APP_NAME}.elf
319 )
320
321if (DEFINED MCUBOOT_FLASH_PORT)
322 set(FLASH_PORT ${MCUBOOT_FLASH_PORT})
323else()
324 # Defaults to the first USB serial port
325 set(FLASH_PORT "/dev/ttyUSB0")
326endif()
327
328if (NOT EXISTS "${FLASH_PORT}")
329 message(WARNING "Could not open ${FLASH_PORT}, serial port does not exist")
330endif()
331
332add_custom_target(flash DEPENDS ${APP_NAME}.bin)
333add_custom_command(TARGET flash
334 USES_TERMINAL
335 COMMAND
Almir Okato26ed3f42023-03-07 16:13:35 -0300336 ${esptool_path}
Almir Okato3ccc6a62023-06-26 18:09:10 -0300337 -p ${FLASH_PORT} -b ${ESP_BAUD_RATE} --before default_reset --after no_reset
Almir Okatofa173df2022-04-19 01:10:30 -0300338 --chip ${MCUBOOT_TARGET} write_flash
Almir Okato3ccc6a62023-06-26 18:09:10 -0300339 --flash_mode ${ESP_FLASH_MODE} --flash_size ${CONFIG_ESP_FLASH_SIZE}
340 --flash_freq ${ESP_FLASH_FREQ} ${CONFIG_ESP_BOOTLOADER_OFFSET}
Almir Okatofa173df2022-04-19 01:10:30 -0300341 ${APP_NAME}.bin
342 )