Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 1 | # Copyright (c) 2021 Espressif Systems (Shanghai) Co., Ltd. |
| 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 | |
| 7 | if (NOT DEFINED MCUBOOT_TARGET) |
| 8 | message(FATAL_ERROR "MCUBOOT_TARGET not defined. Please pass -DMCUBOOT_TARGET flag.") |
| 9 | endif() |
| 10 | |
| 11 | project(mcuboot_${MCUBOOT_TARGET}) |
| 12 | |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 13 | add_definitions(-DMCUBOOT_TARGET=${MCUBOOT_TARGET}) |
| 14 | |
Almir Okato | 712fdb5 | 2021-08-06 10:22:56 -0300 | [diff] [blame] | 15 | if ("${MCUBOOT_TARGET}" STREQUAL "esp32" OR |
| 16 | "${MCUBOOT_TARGET}" STREQUAL "esp32s2") |
| 17 | set(MCUBOOT_ARCH "xtensa") |
| 18 | elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3") |
| 19 | set(MCUBOOT_ARCH "riscv") |
| 20 | endif() |
| 21 | |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 22 | if (NOT DEFINED IDF_PATH) |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 23 | if (EXISTS "${CMAKE_CURRENT_LIST_DIR}/hal/esp-idf") |
| 24 | set(IDF_PATH "${CMAKE_CURRENT_LIST_DIR}/hal/esp-idf") |
| 25 | elseif (DEFINED ENV{IDF_PATH}) |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 26 | set(IDF_PATH $ENV{IDF_PATH}) |
| 27 | else() |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 28 | 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] | 29 | endif() |
| 30 | endif() |
| 31 | |
| 32 | execute_process( |
| 33 | COMMAND git describe --tags |
Shubham Kulkarni | 8787bb0 | 2021-07-20 11:46:03 +0530 | [diff] [blame] | 34 | WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR} |
| 35 | OUTPUT_VARIABLE MCUBOOT_VER |
| 36 | OUTPUT_STRIP_TRAILING_WHITESPACE |
| 37 | ) |
| 38 | add_definitions(-DMCUBOOT_VER=\"${MCUBOOT_VER}\") |
| 39 | |
| 40 | execute_process( |
| 41 | COMMAND git describe --tags |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 42 | WORKING_DIRECTORY ${IDF_PATH} |
| 43 | OUTPUT_VARIABLE IDF_VER |
| 44 | OUTPUT_STRIP_TRAILING_WHITESPACE |
| 45 | ) |
| 46 | if (NOT "${IDF_VER}" MATCHES "v4.3") |
| 47 | message(FATAL_ERROR "Unsupported ESP-IDF version found in IDF_PATH, please checkout to v4.3") |
| 48 | endif() |
| 49 | |
| 50 | if (DEFINED MCUBOOT_CONFIG_FILE) |
| 51 | set(mcuboot_config_file ${MCUBOOT_CONFIG_FILE}) |
| 52 | else() |
| 53 | set(mcuboot_config_file "${CMAKE_CURRENT_LIST_DIR}/bootloader.conf") |
| 54 | endif() |
| 55 | |
| 56 | if (NOT EXISTS "${mcuboot_config_file}") |
| 57 | message(FATAL_ERROR "MCUboot configuration file does not exist at ${mcuboot_config_file}") |
| 58 | endif() |
| 59 | |
| 60 | configure_file(${mcuboot_config_file} dummy.conf) |
| 61 | file(STRINGS ${mcuboot_config_file} BOOTLOADER_CONF) |
| 62 | foreach(config ${BOOTLOADER_CONF}) |
| 63 | if (NOT (${config} MATCHES "#")) |
| 64 | string(REGEX REPLACE "^[ ]+" "" config ${config}) |
| 65 | string(REGEX MATCH "^[^=]+" CONFIG_NAME ${config}) |
| 66 | string(REPLACE "${CONFIG_NAME}=" "" CONFIG_VALUE ${config}) |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 67 | if (NOT ("${CONFIG_VALUE}" STREQUAL "n" |
| 68 | OR "${CONFIG_VALUE}" STREQUAL "N")) |
| 69 | add_definitions(-D${CONFIG_NAME}=${CONFIG_VALUE}) |
| 70 | set(${CONFIG_NAME} ${CONFIG_VALUE}) |
| 71 | endif() |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 72 | endif() |
| 73 | endforeach() |
| 74 | |
| 75 | set(APP_NAME mcuboot_${MCUBOOT_TARGET}) |
| 76 | set(APP_EXECUTABLE ${APP_NAME}.elf) |
| 77 | |
| 78 | set(MCUBOOT_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR}/../..) |
| 79 | set(BOOTUTIL_DIR ${MCUBOOT_ROOT_DIR}/boot/bootutil) |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 80 | set(ESPRESSIF_PORT_DIR ${CMAKE_CURRENT_LIST_DIR}) |
| 81 | |
| 82 | if (DEFINED CONFIG_ESP_SIGN_RSA) |
| 83 | if ("${MCUBOOT_TARGET}" STREQUAL "esp32s2" OR |
| 84 | "${MCUBOOT_TARGET}" STREQUAL "esp32c3") |
| 85 | message(FATAL_ERROR "RSA signature verification is currently not supported on the target") |
| 86 | endif() |
| 87 | include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/rsa.cmake) |
| 88 | elseif (DEFINED CONFIG_ESP_SIGN_EC256) |
| 89 | include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ec256.cmake) |
| 90 | elseif (DEFINED CONFIG_ESP_SIGN_ED25519) |
| 91 | if ("${MCUBOOT_TARGET}" STREQUAL "esp32c3") |
| 92 | message(FATAL_ERROR "ED25519 signature verification is currently not supported on the target") |
| 93 | endif() |
| 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 |
| 119 | ${PYTHON_EXECUTABLE} |
| 120 | ${MCUBOOT_ROOT_DIR}/scripts/imgtool.py |
| 121 | getpub |
| 122 | -k |
| 123 | ${KEY_FILE} |
| 124 | > ${GENERATED_PUBKEY} |
| 125 | DEPENDS ${KEY_FILE} |
| 126 | ) |
| 127 | list(APPEND crypto_srcs ${GENERATED_PUBKEY}) |
| 128 | endif() |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 129 | |
| 130 | set(bootutil_srcs |
| 131 | ${BOOTUTIL_DIR}/src/boot_record.c |
| 132 | ${BOOTUTIL_DIR}/src/bootutil_misc.c |
| 133 | ${BOOTUTIL_DIR}/src/bootutil_public.c |
| 134 | ${BOOTUTIL_DIR}/src/caps.c |
| 135 | ${BOOTUTIL_DIR}/src/encrypted.c |
| 136 | ${BOOTUTIL_DIR}/src/fault_injection_hardening.c |
| 137 | ${BOOTUTIL_DIR}/src/fault_injection_hardening_delay_rng_mbedtls.c |
| 138 | ${BOOTUTIL_DIR}/src/image_ec.c |
| 139 | ${BOOTUTIL_DIR}/src/image_ec256.c |
| 140 | ${BOOTUTIL_DIR}/src/image_ed25519.c |
| 141 | ${BOOTUTIL_DIR}/src/image_rsa.c |
| 142 | ${BOOTUTIL_DIR}/src/image_validate.c |
| 143 | ${BOOTUTIL_DIR}/src/loader.c |
| 144 | ${BOOTUTIL_DIR}/src/swap_misc.c |
| 145 | ${BOOTUTIL_DIR}/src/swap_move.c |
| 146 | ${BOOTUTIL_DIR}/src/swap_scratch.c |
| 147 | ${BOOTUTIL_DIR}/src/tlv.c |
| 148 | ) |
| 149 | |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 150 | set(CFLAGS |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 151 | "-Wno-frame-address" |
| 152 | "-Wall" |
| 153 | "-Wextra" |
| 154 | "-W" |
| 155 | "-Wdeclaration-after-statement" |
| 156 | "-Wwrite-strings" |
| 157 | "-Wlogical-op" |
| 158 | "-Wshadow" |
| 159 | "-ffunction-sections" |
| 160 | "-fdata-sections" |
| 161 | "-fstrict-volatile-bitfields" |
| 162 | "-Werror=all" |
| 163 | "-Wno-error=unused-function" |
| 164 | "-Wno-error=unused-but-set-variable" |
| 165 | "-Wno-error=unused-variable" |
| 166 | "-Wno-error=deprecated-declarations" |
| 167 | "-Wno-unused-parameter" |
| 168 | "-Wno-sign-compare" |
| 169 | "-ggdb" |
| 170 | "-Os" |
| 171 | "-D_GNU_SOURCE" |
| 172 | "-std=gnu99" |
| 173 | "-Wno-old-style-declaration" |
| 174 | "-Wno-implicit-int" |
| 175 | "-Wno-declaration-after-statement" |
| 176 | ) |
| 177 | |
| 178 | set(LDFLAGS |
| 179 | "-nostdlib" |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 180 | "-Wno-frame-address" |
| 181 | "-Wl,--cref" |
| 182 | "-Wl,--Map=${APP_NAME}.map" |
| 183 | "-fno-rtti" |
| 184 | "-fno-lto" |
| 185 | "-Wl,--gc-sections" |
| 186 | "-Wl,--undefined=uxTopUsedPriority" |
| 187 | "-lm" |
| 188 | "-lgcc" |
| 189 | "-lgcov" |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 190 | ) |
| 191 | |
Almir Okato | 712fdb5 | 2021-08-06 10:22:56 -0300 | [diff] [blame] | 192 | if ("${MCUBOOT_ARCH}" STREQUAL "xtensa") |
| 193 | list(APPEND CFLAGS |
| 194 | "-mlongcalls" |
| 195 | ) |
| 196 | list(APPEND LDFLAGS |
| 197 | "-mlongcalls" |
| 198 | ) |
| 199 | endif() |
| 200 | |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 201 | add_subdirectory(hal) |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 202 | add_executable( |
| 203 | ${APP_EXECUTABLE} |
| 204 | ${CMAKE_CURRENT_LIST_DIR}/main.c |
| 205 | ) |
| 206 | |
| 207 | target_compile_options( |
| 208 | ${APP_EXECUTABLE} |
| 209 | PUBLIC |
| 210 | ${CFLAGS} |
| 211 | ) |
| 212 | |
| 213 | target_sources( |
| 214 | ${APP_EXECUTABLE} |
| 215 | PUBLIC |
| 216 | ${bootutil_srcs} |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 217 | ${crypto_srcs} |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 218 | ${CMAKE_CURRENT_LIST_DIR}/port/esp_mcuboot.c |
Shubham Kulkarni | 8787bb0 | 2021-07-20 11:46:03 +0530 | [diff] [blame] | 219 | ${CMAKE_CURRENT_LIST_DIR}/port/esp_loader.c |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 220 | ${CMAKE_CURRENT_LIST_DIR}/os.c |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 221 | ) |
| 222 | |
| 223 | target_include_directories( |
| 224 | ${APP_EXECUTABLE} |
| 225 | PUBLIC |
| 226 | ${BOOTUTIL_DIR}/include |
Almir Okato | eb6b7bf | 2021-09-07 17:06:35 -0300 | [diff] [blame] | 227 | ${CRYPTO_INC} |
Shubham Kulkarni | 052561d | 2021-07-20 11:42:44 +0530 | [diff] [blame] | 228 | ${CMAKE_CURRENT_LIST_DIR}/include |
| 229 | ) |
| 230 | |
| 231 | target_link_libraries( |
| 232 | ${APP_EXECUTABLE} |
| 233 | PUBLIC |
| 234 | -T${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/ld/bootloader.ld |
| 235 | ${LDFLAGS} |
| 236 | ) |
Shubham Kulkarni | c75b3c7 | 2021-07-20 11:43:28 +0530 | [diff] [blame] | 237 | |
| 238 | target_link_libraries( |
| 239 | ${APP_EXECUTABLE} |
| 240 | PUBLIC |
| 241 | hal |
| 242 | ) |