blob: bc4cd62659d6863286264fcd018fb930d72b52ef [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)
6
Almir Okatofa173df2022-04-19 01:10:30 -03007include(${CMAKE_CURRENT_LIST_DIR}/tools/utils.cmake)
8
Shubham Kulkarni052561d2021-07-20 11:42:44 +05309if (NOT DEFINED MCUBOOT_TARGET)
10 message(FATAL_ERROR "MCUBOOT_TARGET not defined. Please pass -DMCUBOOT_TARGET flag.")
11endif()
12
13project(mcuboot_${MCUBOOT_TARGET})
14
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +053015add_definitions(-DMCUBOOT_TARGET=${MCUBOOT_TARGET})
Almir Okatoe8cbc0d2022-06-13 10:45:39 -030016add_definitions(-D__ESPRESSIF__=1)
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +053017
Almir Okato712fdb52021-08-06 10:22:56 -030018if ("${MCUBOOT_TARGET}" STREQUAL "esp32" OR
Almir Okato42e679d2022-01-18 00:16:58 -030019 "${MCUBOOT_TARGET}" STREQUAL "esp32s2" OR
20 "${MCUBOOT_TARGET}" STREQUAL "esp32s3")
Almir Okato712fdb52021-08-06 10:22:56 -030021 set(MCUBOOT_ARCH "xtensa")
22elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3")
23 set(MCUBOOT_ARCH "riscv")
24endif()
25
Almir Okatofa173df2022-04-19 01:10:30 -030026# Set the minimum revision for each supported chip
27if ("${MCUBOOT_TARGET}" STREQUAL "esp32")
28 set(ESP_MIN_REVISION 3)
29elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s2")
30 set(ESP_MIN_REVISION 0)
31elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s3")
32 set(ESP_MIN_REVISION 0)
33elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3")
34 set(ESP_MIN_REVISION 3)
35else()
36 message(FATAL_ERROR "Unsupported target ${MCUBOOT_TARGET}")
37endif()
38
Shubham Kulkarni052561d2021-07-20 11:42:44 +053039if (NOT DEFINED IDF_PATH)
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +053040 if (EXISTS "${CMAKE_CURRENT_LIST_DIR}/hal/esp-idf")
41 set(IDF_PATH "${CMAKE_CURRENT_LIST_DIR}/hal/esp-idf")
42 elseif (DEFINED ENV{IDF_PATH})
Shubham Kulkarni052561d2021-07-20 11:42:44 +053043 set(IDF_PATH $ENV{IDF_PATH})
44 else()
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +053045 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 +053046 endif()
47endif()
48
49execute_process(
50 COMMAND git describe --tags
Shubham Kulkarni8787bb02021-07-20 11:46:03 +053051 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
52 OUTPUT_VARIABLE MCUBOOT_VER
53 OUTPUT_STRIP_TRAILING_WHITESPACE
54 )
55add_definitions(-DMCUBOOT_VER=\"${MCUBOOT_VER}\")
56
Almir Okatofa173df2022-04-19 01:10:30 -030057if (NOT DEFINED MCUBOOT_CONFIG_FILE)
58 set(MCUBOOT_CONFIG_FILE "${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/bootloader.conf")
Shubham Kulkarni052561d2021-07-20 11:42:44 +053059endif()
60
Almir Okatofa173df2022-04-19 01:10:30 -030061string(REPLACE " " ";" MCUBOOT_CONFIG_FILE_LIST "${MCUBOOT_CONFIG_FILE}")
62foreach(CONFIG_FILE ${MCUBOOT_CONFIG_FILE_LIST})
63 if (NOT EXISTS "${CONFIG_FILE}")
64 message(FATAL_ERROR "MCUboot configuration file does not exist at ${CONFIG_FILE}")
Shubham Kulkarni052561d2021-07-20 11:42:44 +053065 endif()
Almir Okatofa173df2022-04-19 01:10:30 -030066 parse_and_set_config_file(${CONFIG_FILE})
Shubham Kulkarni052561d2021-07-20 11:42:44 +053067endforeach()
68
69set(APP_NAME mcuboot_${MCUBOOT_TARGET})
70set(APP_EXECUTABLE ${APP_NAME}.elf)
71
72set(MCUBOOT_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR}/../..)
73set(BOOTUTIL_DIR ${MCUBOOT_ROOT_DIR}/boot/bootutil)
Almir Okatoe8cbc0d2022-06-13 10:45:39 -030074set(BOOT_SERIAL_DIR ${MCUBOOT_ROOT_DIR}/boot/boot_serial)
Jamie McCraedb6ba462023-05-09 10:30:41 +010075set(ZCBOR_DIR ${MCUBOOT_ROOT_DIR}/boot/zcbor)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -030076set(ESPRESSIF_PORT_DIR ${CMAKE_CURRENT_LIST_DIR})
77
Gustavo Henrique Nihei72627c52021-11-01 18:29:25 -030078# Find imgtool.
79# Go with an explicitly installed imgtool first, falling
80# back to mcuboot/scripts/imgtool.py.
81find_program(IMGTOOL_COMMAND
82 NAMES imgtool imgtool.py
83 )
84if ("${IMGTOOL_COMMAND}" MATCHES "IMGTOOL_COMMAND-NOTFOUND")
85 set(imgtool_path "${MCUBOOT_ROOT_DIR}/scripts/imgtool.py")
86else()
87 set(imgtool_path "${IMGTOOL_COMMAND}")
88endif()
89
Almir Okato26ed3f42023-03-07 16:13:35 -030090# Find installed esptool, if not found falls to IDF's
91find_program(ESPTOOL_COMMAND
92 NAMES esptool esptool.py
93 )
94if ("${ESPTOOL_COMMAND}" MATCHES "ESPTOOL_COMMAND-NOTFOUND")
95 set(esptool_path "${IDF_PATH}/components/esptool_py/esptool/esptool.py")
96else()
97 set(esptool_path "${ESPTOOL_COMMAND}")
98endif()
99
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300100if (DEFINED CONFIG_ESP_SIGN_RSA)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300101 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/rsa.cmake)
102elseif (DEFINED CONFIG_ESP_SIGN_EC256)
103 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ec256.cmake)
104elseif (DEFINED CONFIG_ESP_SIGN_ED25519)
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300105 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ed25519.cmake)
106else()
107 # No signature verification
108 set(TINYCRYPT_DIR ${MCUBOOT_ROOT_DIR}/ext/tinycrypt/lib)
109 set(CRYPTO_INC
110 ${TINYCRYPT_DIR}/include
111 )
112 set(crypto_srcs
113 ${TINYCRYPT_DIR}/source/sha256.c
114 ${TINYCRYPT_DIR}/source/utils.c
115 )
116endif()
117
118if(DEFINED CONFIG_ESP_SIGN_KEY_FILE)
119 if(IS_ABSOLUTE ${CONFIG_ESP_SIGN_KEY_FILE})
120 set(KEY_FILE ${CONFIG_ESP_SIGN_KEY_FILE})
121 else()
122 set(KEY_FILE ${MCUBOOT_ROOT_DIR}/${CONFIG_ESP_SIGN_KEY_FILE})
123 endif()
124 message("MCUBoot bootloader key file: ${KEY_FILE}")
125
126 set(GENERATED_PUBKEY ${CMAKE_CURRENT_BINARY_DIR}/autogen-pubkey.c)
127 add_custom_command(
128 OUTPUT ${GENERATED_PUBKEY}
129 COMMAND
Gustavo Henrique Nihei72627c52021-11-01 18:29:25 -0300130 ${imgtool_path}
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300131 getpub
132 -k
133 ${KEY_FILE}
134 > ${GENERATED_PUBKEY}
135 DEPENDS ${KEY_FILE}
136 )
137 list(APPEND crypto_srcs ${GENERATED_PUBKEY})
138endif()
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530139
140set(bootutil_srcs
141 ${BOOTUTIL_DIR}/src/boot_record.c
142 ${BOOTUTIL_DIR}/src/bootutil_misc.c
143 ${BOOTUTIL_DIR}/src/bootutil_public.c
144 ${BOOTUTIL_DIR}/src/caps.c
145 ${BOOTUTIL_DIR}/src/encrypted.c
146 ${BOOTUTIL_DIR}/src/fault_injection_hardening.c
147 ${BOOTUTIL_DIR}/src/fault_injection_hardening_delay_rng_mbedtls.c
Antonio de Angelis10529d32023-04-21 21:43:14 +0100148 ${BOOTUTIL_DIR}/src/image_ecdsa.c
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530149 ${BOOTUTIL_DIR}/src/image_ed25519.c
150 ${BOOTUTIL_DIR}/src/image_rsa.c
151 ${BOOTUTIL_DIR}/src/image_validate.c
152 ${BOOTUTIL_DIR}/src/loader.c
153 ${BOOTUTIL_DIR}/src/swap_misc.c
154 ${BOOTUTIL_DIR}/src/swap_move.c
155 ${BOOTUTIL_DIR}/src/swap_scratch.c
156 ${BOOTUTIL_DIR}/src/tlv.c
157 )
Jamie McCraedb6ba462023-05-09 10:30:41 +0100158set(bootutil_paths)
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530159
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530160set(CFLAGS
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530161 "-Wno-frame-address"
162 "-Wall"
163 "-Wextra"
164 "-W"
165 "-Wdeclaration-after-statement"
166 "-Wwrite-strings"
167 "-Wlogical-op"
168 "-Wshadow"
169 "-ffunction-sections"
170 "-fdata-sections"
171 "-fstrict-volatile-bitfields"
172 "-Werror=all"
173 "-Wno-error=unused-function"
174 "-Wno-error=unused-but-set-variable"
175 "-Wno-error=unused-variable"
176 "-Wno-error=deprecated-declarations"
177 "-Wno-unused-parameter"
178 "-Wno-sign-compare"
179 "-ggdb"
180 "-Os"
181 "-D_GNU_SOURCE"
182 "-std=gnu99"
183 "-Wno-old-style-declaration"
184 "-Wno-implicit-int"
185 "-Wno-declaration-after-statement"
186 )
187
188set(LDFLAGS
189 "-nostdlib"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530190 "-Wno-frame-address"
191 "-Wl,--cref"
192 "-Wl,--Map=${APP_NAME}.map"
193 "-fno-rtti"
194 "-fno-lto"
195 "-Wl,--gc-sections"
196 "-Wl,--undefined=uxTopUsedPriority"
197 "-lm"
198 "-lgcc"
199 "-lgcov"
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530200 )
201
Almir Okato712fdb52021-08-06 10:22:56 -0300202if ("${MCUBOOT_ARCH}" STREQUAL "xtensa")
203 list(APPEND CFLAGS
204 "-mlongcalls"
205 )
206 list(APPEND LDFLAGS
207 "-mlongcalls"
208 )
209endif()
210
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530211add_subdirectory(hal)
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530212add_executable(
213 ${APP_EXECUTABLE}
214 ${CMAKE_CURRENT_LIST_DIR}/main.c
215 )
216
217target_compile_options(
218 ${APP_EXECUTABLE}
219 PUBLIC
220 ${CFLAGS}
221 )
222
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300223set(port_srcs
224 ${CMAKE_CURRENT_LIST_DIR}/port/esp_mcuboot.c
225 ${CMAKE_CURRENT_LIST_DIR}/port/esp_loader.c
226 ${CMAKE_CURRENT_LIST_DIR}/os.c
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300227 )
228
229if(CONFIG_ESP_MCUBOOT_SERIAL)
230 set(MBEDTLS_DIR "${MCUBOOT_ROOT_DIR}/ext/mbedtls")
231
232 list(APPEND bootutil_srcs
233 ${BOOT_SERIAL_DIR}/src/boot_serial.c
Jamie McCraecb07e882023-04-14 09:28:24 +0100234 ${BOOT_SERIAL_DIR}/src/zcbor_bulk.c
Jamie McCraedb6ba462023-05-09 10:30:41 +0100235 ${ZCBOR_DIR}/src/zcbor_decode.c
236 ${ZCBOR_DIR}/src/zcbor_encode.c
237 ${ZCBOR_DIR}/src/zcbor_common.c
238 )
239 list(APPEND bootutil_paths
240 ${ZCBOR_DIR}/include
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300241 )
242 list(APPEND port_srcs
Almir Okato0dcdbab2022-09-23 15:02:17 -0300243 ${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/serial_adapter.c
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300244 ${MBEDTLS_DIR}/library/base64.c
245 )
246 list(APPEND CRYPTO_INC
247 ${MBEDTLS_DIR}/include
248 )
249endif()
250
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530251target_sources(
252 ${APP_EXECUTABLE}
253 PUBLIC
254 ${bootutil_srcs}
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300255 ${crypto_srcs}
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300256 ${port_srcs}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530257 )
258
259target_include_directories(
260 ${APP_EXECUTABLE}
261 PUBLIC
262 ${BOOTUTIL_DIR}/include
Almir Okato0dcdbab2022-09-23 15:02:17 -0300263 ${BOOTUTIL_DIR}/src
Almir Okatoe8cbc0d2022-06-13 10:45:39 -0300264 ${BOOT_SERIAL_DIR}/include
Almir Okatoeb6b7bf2021-09-07 17:06:35 -0300265 ${CRYPTO_INC}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530266 ${CMAKE_CURRENT_LIST_DIR}/include
Jamie McCraedb6ba462023-05-09 10:30:41 +0100267 ${bootutil_paths}
Shubham Kulkarni052561d2021-07-20 11:42:44 +0530268 )
269
270target_link_libraries(
271 ${APP_EXECUTABLE}
272 PUBLIC
273 -T${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/ld/bootloader.ld
274 ${LDFLAGS}
275 )
Shubham Kulkarnic75b3c72021-07-20 11:43:28 +0530276
277target_link_libraries(
278 ${APP_EXECUTABLE}
279 PUBLIC
280 hal
281 )
Almir Okatofa173df2022-04-19 01:10:30 -0300282
283# This step uses esptool.py for generating the final bootloader binary in
284# Espressif compatible format.
285# Note: Both binary generation and flash steps still have some default arguments
286add_custom_command(TARGET ${APP_EXECUTABLE} POST_BUILD
287 COMMAND
Almir Okato26ed3f42023-03-07 16:13:35 -0300288 ${esptool_path}
Almir Okatofa173df2022-04-19 01:10:30 -0300289 --chip ${MCUBOOT_TARGET} elf2image --min-rev ${ESP_MIN_REVISION}
290 --flash_mode dio --flash_freq 40m --flash_size ${CONFIG_ESP_FLASH_SIZE}
291 -o ${APP_NAME}.bin ${APP_NAME}.elf
292 )
293
294if (DEFINED MCUBOOT_FLASH_PORT)
295 set(FLASH_PORT ${MCUBOOT_FLASH_PORT})
296else()
297 # Defaults to the first USB serial port
298 set(FLASH_PORT "/dev/ttyUSB0")
299endif()
300
301if (NOT EXISTS "${FLASH_PORT}")
302 message(WARNING "Could not open ${FLASH_PORT}, serial port does not exist")
303endif()
304
305add_custom_target(flash DEPENDS ${APP_NAME}.bin)
306add_custom_command(TARGET flash
307 USES_TERMINAL
308 COMMAND
Almir Okato26ed3f42023-03-07 16:13:35 -0300309 ${esptool_path}
Almir Okatofa173df2022-04-19 01:10:30 -0300310 -p ${FLASH_PORT} -b 2000000 --before default_reset --after no_reset
311 --chip ${MCUBOOT_TARGET} write_flash
312 --flash_mode dio --flash_size ${CONFIG_ESP_FLASH_SIZE}
313 --flash_freq 40m ${CONFIG_ESP_BOOTLOADER_OFFSET}
314 ${APP_NAME}.bin
315 )