blob: 0aa9dc2e8d540e17579c642fac90f2f842a08a42 [file] [log] [blame]
Roman Okhrimenkodc0ca082023-06-21 20:49:51 +03001# SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
2#
3# SPDX-License-Identifier: Apache-2.0
4
5cmake_minimum_required(VERSION 3.13)
6
7if (NOT DEFINED MCUBOOT_TARGET)
8 message(FATAL_ERROR "MCUBOOT_TARGET not defined. Please pass -DMCUBOOT_TARGET flag.")
9endif()
10
11project(mcuboot_${MCUBOOT_TARGET})
12
13add_definitions(-DMCUBOOT_TARGET=${MCUBOOT_TARGET})
14
15if ("${MCUBOOT_TARGET}" STREQUAL "esp32" OR
16 "${MCUBOOT_TARGET}" STREQUAL "esp32s2" OR
17 "${MCUBOOT_TARGET}" STREQUAL "esp32s3")
18 set(MCUBOOT_ARCH "xtensa")
19elseif("${MCUBOOT_TARGET}" STREQUAL "esp32c3")
20 set(MCUBOOT_ARCH "riscv")
21endif()
22
23if (NOT DEFINED IDF_PATH)
24 if (EXISTS "${CMAKE_CURRENT_LIST_DIR}/hal/esp-idf")
25 set(IDF_PATH "${CMAKE_CURRENT_LIST_DIR}/hal/esp-idf")
26 elseif (DEFINED ENV{IDF_PATH})
27 set(IDF_PATH $ENV{IDF_PATH})
28 else()
29 message(FATAL_ERROR "IDF_PATH not found. Please update submodules or set IDF_PATH environment variable or pass -DIDF_PATH flag.")
30 endif()
31endif()
32
33execute_process(
34 COMMAND git describe --tags
35 WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
36 OUTPUT_VARIABLE MCUBOOT_VER
37 OUTPUT_STRIP_TRAILING_WHITESPACE
38 )
39add_definitions(-DMCUBOOT_VER=\"${MCUBOOT_VER}\")
40
41if (DEFINED MCUBOOT_CONFIG_FILE)
42 set(mcuboot_config_file ${MCUBOOT_CONFIG_FILE})
43else()
44 set(mcuboot_config_file "${CMAKE_CURRENT_LIST_DIR}/bootloader.conf")
45endif()
46
47if (NOT EXISTS "${mcuboot_config_file}")
48 message(FATAL_ERROR "MCUboot configuration file does not exist at ${mcuboot_config_file}")
49endif()
50
51configure_file(${mcuboot_config_file} dummy.conf)
52file(STRINGS ${mcuboot_config_file} BOOTLOADER_CONF)
53foreach(config ${BOOTLOADER_CONF})
54 if (NOT (${config} MATCHES "#"))
55 string(REGEX REPLACE "^[ ]+" "" config ${config})
56 string(REGEX MATCH "^[^=]+" CONFIG_NAME ${config})
57 string(REPLACE "${CONFIG_NAME}=" "" CONFIG_VALUE ${config})
58 if (NOT ("${CONFIG_VALUE}" STREQUAL "n"
59 OR "${CONFIG_VALUE}" STREQUAL "N"))
60 add_definitions(-D${CONFIG_NAME}=${CONFIG_VALUE})
61 set(${CONFIG_NAME} ${CONFIG_VALUE})
62 endif()
63 endif()
64endforeach()
65
66set(APP_NAME mcuboot_${MCUBOOT_TARGET})
67set(APP_EXECUTABLE ${APP_NAME}.elf)
68
69set(MCUBOOT_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR}/../..)
70set(BOOTUTIL_DIR ${MCUBOOT_ROOT_DIR}/boot/bootutil)
71set(ESPRESSIF_PORT_DIR ${CMAKE_CURRENT_LIST_DIR})
72
73# Find imgtool.
74# Go with an explicitly installed imgtool first, falling
75# back to mcuboot/scripts/imgtool.py.
76find_program(IMGTOOL_COMMAND
77 NAMES imgtool imgtool.py
78 )
79if ("${IMGTOOL_COMMAND}" MATCHES "IMGTOOL_COMMAND-NOTFOUND")
80 set(imgtool_path "${MCUBOOT_ROOT_DIR}/scripts/imgtool.py")
81else()
82 set(imgtool_path "${IMGTOOL_COMMAND}")
83endif()
84
85if (DEFINED CONFIG_ESP_SIGN_RSA)
86 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/rsa.cmake)
87elseif (DEFINED CONFIG_ESP_SIGN_EC256)
88 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ec256.cmake)
89elseif (DEFINED CONFIG_ESP_SIGN_ED25519)
90 include(${CMAKE_CURRENT_LIST_DIR}/include/crypto_config/ed25519.cmake)
91else()
92 # No signature verification
93 set(TINYCRYPT_DIR ${MCUBOOT_ROOT_DIR}/ext/tinycrypt/lib)
94 set(CRYPTO_INC
95 ${TINYCRYPT_DIR}/include
96 )
97 set(crypto_srcs
98 ${TINYCRYPT_DIR}/source/sha256.c
99 ${TINYCRYPT_DIR}/source/utils.c
100 )
101endif()
102
103if(DEFINED CONFIG_ESP_SIGN_KEY_FILE)
104 if(IS_ABSOLUTE ${CONFIG_ESP_SIGN_KEY_FILE})
105 set(KEY_FILE ${CONFIG_ESP_SIGN_KEY_FILE})
106 else()
107 set(KEY_FILE ${MCUBOOT_ROOT_DIR}/${CONFIG_ESP_SIGN_KEY_FILE})
108 endif()
109 message("MCUBoot bootloader key file: ${KEY_FILE}")
110
111 set(GENERATED_PUBKEY ${CMAKE_CURRENT_BINARY_DIR}/autogen-pubkey.c)
112 add_custom_command(
113 OUTPUT ${GENERATED_PUBKEY}
114 COMMAND
115 ${imgtool_path}
116 getpub
117 -k
118 ${KEY_FILE}
119 > ${GENERATED_PUBKEY}
120 DEPENDS ${KEY_FILE}
121 )
122 list(APPEND crypto_srcs ${GENERATED_PUBKEY})
123endif()
124
125set(bootutil_srcs
126 ${BOOTUTIL_DIR}/src/boot_record.c
127 ${BOOTUTIL_DIR}/src/bootutil_misc.c
128 ${BOOTUTIL_DIR}/src/bootutil_public.c
129 ${BOOTUTIL_DIR}/src/caps.c
130 ${BOOTUTIL_DIR}/src/encrypted.c
131 ${BOOTUTIL_DIR}/src/fault_injection_hardening.c
132 ${BOOTUTIL_DIR}/src/fault_injection_hardening_delay_rng_mbedtls.c
133 ${BOOTUTIL_DIR}/src/image_ec.c
134 ${BOOTUTIL_DIR}/src/image_ec256.c
135 ${BOOTUTIL_DIR}/src/image_ed25519.c
136 ${BOOTUTIL_DIR}/src/image_rsa.c
137 ${BOOTUTIL_DIR}/src/image_validate.c
138 ${BOOTUTIL_DIR}/src/loader.c
139 ${BOOTUTIL_DIR}/src/swap_misc.c
140 ${BOOTUTIL_DIR}/src/swap_move.c
141 ${BOOTUTIL_DIR}/src/swap_scratch.c
142 ${BOOTUTIL_DIR}/src/tlv.c
143 )
144
145set(CFLAGS
146 "-Wno-frame-address"
147 "-Wall"
148 "-Wextra"
149 "-W"
150 "-Wdeclaration-after-statement"
151 "-Wwrite-strings"
152 "-Wlogical-op"
153 "-Wshadow"
154 "-ffunction-sections"
155 "-fdata-sections"
156 "-fstrict-volatile-bitfields"
157 "-Werror=all"
158 "-Wno-error=unused-function"
159 "-Wno-error=unused-but-set-variable"
160 "-Wno-error=unused-variable"
161 "-Wno-error=deprecated-declarations"
162 "-Wno-unused-parameter"
163 "-Wno-sign-compare"
164 "-ggdb"
165 "-Os"
166 "-D_GNU_SOURCE"
167 "-std=gnu99"
168 "-Wno-old-style-declaration"
169 "-Wno-implicit-int"
170 "-Wno-declaration-after-statement"
171 )
172
173set(LDFLAGS
174 "-nostdlib"
175 "-Wno-frame-address"
176 "-Wl,--cref"
177 "-Wl,--Map=${APP_NAME}.map"
178 "-fno-rtti"
179 "-fno-lto"
180 "-Wl,--gc-sections"
181 "-Wl,--undefined=uxTopUsedPriority"
182 "-lm"
183 "-lgcc"
184 "-lgcov"
185 )
186
187if ("${MCUBOOT_ARCH}" STREQUAL "xtensa")
188 list(APPEND CFLAGS
189 "-mlongcalls"
190 )
191 list(APPEND LDFLAGS
192 "-mlongcalls"
193 )
194endif()
195
196add_subdirectory(hal)
197add_executable(
198 ${APP_EXECUTABLE}
199 ${CMAKE_CURRENT_LIST_DIR}/main.c
200 )
201
202target_compile_options(
203 ${APP_EXECUTABLE}
204 PUBLIC
205 ${CFLAGS}
206 )
207
208target_sources(
209 ${APP_EXECUTABLE}
210 PUBLIC
211 ${bootutil_srcs}
212 ${crypto_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 )
217
218target_include_directories(
219 ${APP_EXECUTABLE}
220 PUBLIC
221 ${BOOTUTIL_DIR}/include
222 ${CRYPTO_INC}
223 ${CMAKE_CURRENT_LIST_DIR}/include
224 )
225
226target_link_libraries(
227 ${APP_EXECUTABLE}
228 PUBLIC
229 -T${CMAKE_CURRENT_LIST_DIR}/port/${MCUBOOT_TARGET}/ld/bootloader.ld
230 ${LDFLAGS}
231 )
232
233target_link_libraries(
234 ${APP_EXECUTABLE}
235 PUBLIC
236 hal
237 )