Gustavo Henrique Nihei | 6a6b891 | 2021-11-12 11:43:10 -0300 | [diff] [blame] | 1 | # SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 2 | # |
| 3 | # SPDX-License-Identifier: Apache-2.0 |
| 4 | |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 5 | cmake_minimum_required(VERSION 3.13) |
| 6 | |
Almir Okato | fa173df | 2022-04-19 01:10:30 -0300 | [diff] [blame] | 7 | include(${CMAKE_CURRENT_LIST_DIR}/tools/utils.cmake) |
| 8 | |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 9 | if (NOT DEFINED MCUBOOT_TARGET) |
| 10 | message(FATAL_ERROR "MCUBOOT_TARGET not defined. Please pass -DMCUBOOT_TARGET flag.") |
| 11 | endif() |
| 12 | |
| 13 | project(mcuboot_${MCUBOOT_TARGET}) |
| 14 | |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 15 | add_definitions(-DMCUBOOT_TARGET=${MCUBOOT_TARGET}) |
Almir Okato | e8cbc0d | 2022-06-13 10:45:39 -0300 | [diff] [blame^] | 16 | add_definitions(-D__ESPRESSIF__=1) |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 17 | |
Almir Okato | 712fdb5 | 2021-08-06 10:22:56 -0300 | [diff] [blame] | 18 | if ("${MCUBOOT_TARGET}" STREQUAL "esp32" OR |
Almir Okato | 42e679d | 2022-01-18 00:16:58 -0300 | [diff] [blame] | 19 | "${MCUBOOT_TARGET}" STREQUAL "esp32s2" OR |
| 20 | "${MCUBOOT_TARGET}" STREQUAL "esp32s3") |
Almir Okato | 712fdb5 | 2021-08-06 10:22:56 -0300 | [diff] [blame] | 21 | set(MCUBOOT_ARCH "xtensa") |
| 22 | elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3") |
| 23 | set(MCUBOOT_ARCH "riscv") |
| 24 | endif() |
| 25 | |
Almir Okato | fa173df | 2022-04-19 01:10:30 -0300 | [diff] [blame] | 26 | # Set the minimum revision for each supported chip |
| 27 | if ("${MCUBOOT_TARGET}" STREQUAL "esp32") |
| 28 | set(ESP_MIN_REVISION 3) |
| 29 | elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s2") |
| 30 | set(ESP_MIN_REVISION 0) |
| 31 | elseif("${MCUBOOT_TARGET}" STREQUAL "esp32s3") |
| 32 | set(ESP_MIN_REVISION 0) |
| 33 | elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3") |
| 34 | set(ESP_MIN_REVISION 3) |
| 35 | else() |
| 36 | message(FATAL_ERROR "Unsupported target ${MCUBOOT_TARGET}") |
| 37 | endif() |
| 38 | |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 39 | if (NOT DEFINED IDF_PATH) |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 40 | 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 Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 43 | set(IDF_PATH $ENV{IDF_PATH}) |
| 44 | else() |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 45 | message(FATAL_ERROR "IDF_PATH not found. Please update submodules or set IDF_PATH environment variable or pass -DIDF_PATH flag.") |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 46 | endif() |
| 47 | endif() |
| 48 | |
| 49 | execute_process( |
| 50 | COMMAND git describe --tags |
Shubham Kulkarni | 8787bb0 | 2021-07-20 11:46:03 +0530 | [diff] [blame] | 51 | WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR} |
| 52 | OUTPUT_VARIABLE MCUBOOT_VER |
| 53 | OUTPUT_STRIP_TRAILING_WHITESPACE |
| 54 | ) |
| 55 | add_definitions(-DMCUBOOT_VER=\"${MCUBOOT_VER}\") |
| 56 | |
Almir Okato | fa173df | 2022-04-19 01:10:30 -0300 | [diff] [blame] | 57 | if (NOT DEFINED MCUBOOT_CONFIG_FILE) |
| 58 | set(MCUBOOT_CONFIG_FILE "${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/bootloader.conf") |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 59 | endif() |
| 60 | |
Almir Okato | fa173df | 2022-04-19 01:10:30 -0300 | [diff] [blame] | 61 | string(REPLACE " " ";" MCUBOOT_CONFIG_FILE_LIST "${MCUBOOT_CONFIG_FILE}") |
| 62 | foreach(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 Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 65 | endif() |
Almir Okato | fa173df | 2022-04-19 01:10:30 -0300 | [diff] [blame] | 66 | parse_and_set_config_file(${CONFIG_FILE}) |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 67 | endforeach() |
| 68 | |
| 69 | set(APP_NAME mcuboot_${MCUBOOT_TARGET}) |
| 70 | set(APP_EXECUTABLE ${APP_NAME}.elf) |
| 71 | |
| 72 | set(MCUBOOT_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR}/../..) |
| 73 | set(BOOTUTIL_DIR ${MCUBOOT_ROOT_DIR}/boot/bootutil) |
Almir Okato | e8cbc0d | 2022-06-13 10:45:39 -0300 | [diff] [blame^] | 74 | set(BOOT_SERIAL_DIR ${MCUBOOT_ROOT_DIR}/boot/boot_serial) |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 75 | set(ESPRESSIF_PORT_DIR ${CMAKE_CURRENT_LIST_DIR}) |
| 76 | |
Gustavo Henrique Nihei | 72627c5 | 2021-11-01 18:29:25 -0300 | [diff] [blame] | 77 | # Find imgtool. |
| 78 | # Go with an explicitly installed imgtool first, falling |
| 79 | # back to mcuboot/scripts/imgtool.py. |
| 80 | find_program(IMGTOOL_COMMAND |
| 81 | NAMES imgtool imgtool.py |
| 82 | ) |
| 83 | if ("${IMGTOOL_COMMAND}" MATCHES "IMGTOOL_COMMAND-NOTFOUND") |
| 84 | set(imgtool_path "${MCUBOOT_ROOT_DIR}/scripts/imgtool.py") |
| 85 | else() |
| 86 | set(imgtool_path "${IMGTOOL_COMMAND}") |
| 87 | endif() |
| 88 | |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 89 | if (DEFINED CONFIG_ESP_SIGN_RSA) |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 90 | include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/rsa.cmake) |
| 91 | elseif (DEFINED CONFIG_ESP_SIGN_EC256) |
| 92 | include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ec256.cmake) |
| 93 | elseif (DEFINED CONFIG_ESP_SIGN_ED25519) |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 94 | include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ed25519.cmake) |
| 95 | else() |
| 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 | ) |
| 105 | endif() |
| 106 | |
| 107 | if(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 |
Gustavo Henrique Nihei | 72627c5 | 2021-11-01 18:29:25 -0300 | [diff] [blame] | 119 | ${imgtool_path} |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 120 | getpub |
| 121 | -k |
| 122 | ${KEY_FILE} |
| 123 | > ${GENERATED_PUBKEY} |
| 124 | DEPENDS ${KEY_FILE} |
| 125 | ) |
| 126 | list(APPEND crypto_srcs ${GENERATED_PUBKEY}) |
| 127 | endif() |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 128 | |
| 129 | set(bootutil_srcs |
| 130 | ${BOOTUTIL_DIR}/src/boot_record.c |
| 131 | ${BOOTUTIL_DIR}/src/bootutil_misc.c |
| 132 | ${BOOTUTIL_DIR}/src/bootutil_public.c |
| 133 | ${BOOTUTIL_DIR}/src/caps.c |
| 134 | ${BOOTUTIL_DIR}/src/encrypted.c |
| 135 | ${BOOTUTIL_DIR}/src/fault_injection_hardening.c |
| 136 | ${BOOTUTIL_DIR}/src/fault_injection_hardening_delay_rng_mbedtls.c |
| 137 | ${BOOTUTIL_DIR}/src/image_ec.c |
| 138 | ${BOOTUTIL_DIR}/src/image_ec256.c |
| 139 | ${BOOTUTIL_DIR}/src/image_ed25519.c |
| 140 | ${BOOTUTIL_DIR}/src/image_rsa.c |
| 141 | ${BOOTUTIL_DIR}/src/image_validate.c |
| 142 | ${BOOTUTIL_DIR}/src/loader.c |
| 143 | ${BOOTUTIL_DIR}/src/swap_misc.c |
| 144 | ${BOOTUTIL_DIR}/src/swap_move.c |
| 145 | ${BOOTUTIL_DIR}/src/swap_scratch.c |
| 146 | ${BOOTUTIL_DIR}/src/tlv.c |
| 147 | ) |
| 148 | |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 149 | set(CFLAGS |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 150 | "-Wno-frame-address" |
| 151 | "-Wall" |
| 152 | "-Wextra" |
| 153 | "-W" |
| 154 | "-Wdeclaration-after-statement" |
| 155 | "-Wwrite-strings" |
| 156 | "-Wlogical-op" |
| 157 | "-Wshadow" |
| 158 | "-ffunction-sections" |
| 159 | "-fdata-sections" |
| 160 | "-fstrict-volatile-bitfields" |
| 161 | "-Werror=all" |
| 162 | "-Wno-error=unused-function" |
| 163 | "-Wno-error=unused-but-set-variable" |
| 164 | "-Wno-error=unused-variable" |
| 165 | "-Wno-error=deprecated-declarations" |
| 166 | "-Wno-unused-parameter" |
| 167 | "-Wno-sign-compare" |
| 168 | "-ggdb" |
| 169 | "-Os" |
| 170 | "-D_GNU_SOURCE" |
| 171 | "-std=gnu99" |
| 172 | "-Wno-old-style-declaration" |
| 173 | "-Wno-implicit-int" |
| 174 | "-Wno-declaration-after-statement" |
| 175 | ) |
| 176 | |
| 177 | set(LDFLAGS |
| 178 | "-nostdlib" |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 179 | "-Wno-frame-address" |
| 180 | "-Wl,--cref" |
| 181 | "-Wl,--Map=${APP_NAME}.map" |
| 182 | "-fno-rtti" |
| 183 | "-fno-lto" |
| 184 | "-Wl,--gc-sections" |
| 185 | "-Wl,--undefined=uxTopUsedPriority" |
| 186 | "-lm" |
| 187 | "-lgcc" |
| 188 | "-lgcov" |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 189 | ) |
| 190 | |
Almir Okato | 712fdb5 | 2021-08-06 10:22:56 -0300 | [diff] [blame] | 191 | if ("${MCUBOOT_ARCH}" STREQUAL "xtensa") |
| 192 | list(APPEND CFLAGS |
| 193 | "-mlongcalls" |
| 194 | ) |
| 195 | list(APPEND LDFLAGS |
| 196 | "-mlongcalls" |
| 197 | ) |
| 198 | endif() |
| 199 | |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 200 | add_subdirectory(hal) |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 201 | add_executable( |
| 202 | ${APP_EXECUTABLE} |
| 203 | ${CMAKE_CURRENT_LIST_DIR}/main.c |
| 204 | ) |
| 205 | |
| 206 | target_compile_options( |
| 207 | ${APP_EXECUTABLE} |
| 208 | PUBLIC |
| 209 | ${CFLAGS} |
| 210 | ) |
| 211 | |
Almir Okato | e8cbc0d | 2022-06-13 10:45:39 -0300 | [diff] [blame^] | 212 | set(port_srcs |
| 213 | ${CMAKE_CURRENT_LIST_DIR}/port/esp_mcuboot.c |
| 214 | ${CMAKE_CURRENT_LIST_DIR}/port/esp_loader.c |
| 215 | ${CMAKE_CURRENT_LIST_DIR}/os.c |
| 216 | ${CMAKE_CURRENT_LIST_DIR}/serial_adapter.c |
| 217 | ) |
| 218 | |
| 219 | if(CONFIG_ESP_MCUBOOT_SERIAL) |
| 220 | set(MBEDTLS_DIR "${MCUBOOT_ROOT_DIR}/ext/mbedtls") |
| 221 | |
| 222 | list(APPEND bootutil_srcs |
| 223 | ${BOOT_SERIAL_DIR}/src/boot_serial.c |
| 224 | ${BOOT_SERIAL_DIR}/src/serial_recovery_cbor.c |
| 225 | ${BOOT_SERIAL_DIR}/src/zcbor_decode.c |
| 226 | ${BOOT_SERIAL_DIR}/src/zcbor_encode.c |
| 227 | ${BOOT_SERIAL_DIR}/src/zcbor_common.c |
| 228 | ) |
| 229 | list(APPEND port_srcs |
| 230 | ${CMAKE_CURRENT_LIST_DIR}/serial_adapter.c |
| 231 | ${MBEDTLS_DIR}/library/base64.c |
| 232 | ) |
| 233 | list(APPEND CRYPTO_INC |
| 234 | ${MBEDTLS_DIR}/include |
| 235 | ) |
| 236 | endif() |
| 237 | |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 238 | target_sources( |
| 239 | ${APP_EXECUTABLE} |
| 240 | PUBLIC |
| 241 | ${bootutil_srcs} |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 242 | ${crypto_srcs} |
Almir Okato | e8cbc0d | 2022-06-13 10:45:39 -0300 | [diff] [blame^] | 243 | ${port_srcs} |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 244 | ) |
| 245 | |
| 246 | target_include_directories( |
| 247 | ${APP_EXECUTABLE} |
| 248 | PUBLIC |
| 249 | ${BOOTUTIL_DIR}/include |
Almir Okato | e8cbc0d | 2022-06-13 10:45:39 -0300 | [diff] [blame^] | 250 | ${BOOT_SERIAL_DIR}/include |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 251 | ${CRYPTO_INC} |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 252 | ${CMAKE_CURRENT_LIST_DIR}/include |
| 253 | ) |
| 254 | |
| 255 | target_link_libraries( |
| 256 | ${APP_EXECUTABLE} |
| 257 | PUBLIC |
| 258 | -T${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/ld/bootloader.ld |
| 259 | ${LDFLAGS} |
| 260 | ) |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 261 | |
| 262 | target_link_libraries( |
| 263 | ${APP_EXECUTABLE} |
| 264 | PUBLIC |
| 265 | hal |
| 266 | ) |
Almir Okato | fa173df | 2022-04-19 01:10:30 -0300 | [diff] [blame] | 267 | |
| 268 | # This step uses esptool.py for generating the final bootloader binary in |
| 269 | # Espressif compatible format. |
| 270 | # Note: Both binary generation and flash steps still have some default arguments |
| 271 | add_custom_command(TARGET ${APP_EXECUTABLE} POST_BUILD |
| 272 | COMMAND |
| 273 | ${IDF_PATH}/components/esptool_py/esptool/esptool.py |
| 274 | --chip ${MCUBOOT_TARGET} elf2image --min-rev ${ESP_MIN_REVISION} |
| 275 | --flash_mode dio --flash_freq 40m --flash_size ${CONFIG_ESP_FLASH_SIZE} |
| 276 | -o ${APP_NAME}.bin ${APP_NAME}.elf |
| 277 | ) |
| 278 | |
| 279 | if (DEFINED MCUBOOT_FLASH_PORT) |
| 280 | set(FLASH_PORT ${MCUBOOT_FLASH_PORT}) |
| 281 | else() |
| 282 | # Defaults to the first USB serial port |
| 283 | set(FLASH_PORT "/dev/ttyUSB0") |
| 284 | endif() |
| 285 | |
| 286 | if (NOT EXISTS "${FLASH_PORT}") |
| 287 | message(WARNING "Could not open ${FLASH_PORT}, serial port does not exist") |
| 288 | endif() |
| 289 | |
| 290 | add_custom_target(flash DEPENDS ${APP_NAME}.bin) |
| 291 | add_custom_command(TARGET flash |
| 292 | USES_TERMINAL |
| 293 | COMMAND |
| 294 | ${IDF_PATH}/components/esptool_py/esptool/esptool.py |
| 295 | -p ${FLASH_PORT} -b 2000000 --before default_reset --after no_reset |
| 296 | --chip ${MCUBOOT_TARGET} write_flash |
| 297 | --flash_mode dio --flash_size ${CONFIG_ESP_FLASH_SIZE} |
| 298 | --flash_freq 40m ${CONFIG_ESP_BOOTLOADER_OFFSET} |
| 299 | ${APP_NAME}.bin |
| 300 | ) |