2017-06-23 00:08:01 -04:00
|
|
|
# Bootloader component (top-level project parts)
|
2016-08-17 11:08:22 -04:00
|
|
|
#
|
|
|
|
# The bootloader is not a real component that gets linked into the project.
|
2017-06-23 00:08:01 -04:00
|
|
|
# Instead it is an entire standalone project (in subproject/) that gets
|
|
|
|
# built in the upper project's build directory. This Makefile.projbuild provides
|
|
|
|
# the glue to build the bootloader project from the original project. It
|
|
|
|
# basically runs Make in the subproject/ directory but it needs to
|
|
|
|
# zero some variables the ESP-IDF project.mk makefile exports first, to not
|
|
|
|
# let them interfere.
|
2016-08-17 11:08:22 -04:00
|
|
|
#
|
|
|
|
BOOTLOADER_COMPONENT_PATH := $(COMPONENT_PATH)
|
2016-10-06 03:05:51 -04:00
|
|
|
BOOTLOADER_BUILD_DIR=$(abspath $(BUILD_DIR_BASE)/bootloader)
|
2016-08-18 00:36:15 -04:00
|
|
|
BOOTLOADER_BIN=$(BOOTLOADER_BUILD_DIR)/bootloader.bin
|
2016-08-17 11:08:22 -04:00
|
|
|
|
2016-11-04 01:05:00 -04:00
|
|
|
# signing key path is resolved relative to the project directory
|
2016-12-03 17:11:22 -05:00
|
|
|
CONFIG_SECURE_BOOT_SIGNING_KEY ?=
|
2016-11-03 02:33:30 -04:00
|
|
|
SECURE_BOOT_SIGNING_KEY=$(abspath $(call dequote,$(CONFIG_SECURE_BOOT_SIGNING_KEY)))
|
|
|
|
export SECURE_BOOT_SIGNING_KEY # used by bootloader_support component
|
2016-10-31 19:50:16 -04:00
|
|
|
|
2021-04-10 08:45:25 -04:00
|
|
|
BOOTLOADER_SIGNED_BIN ?=
|
|
|
|
|
2016-11-11 01:00:34 -05:00
|
|
|
# Has a matching value in bootloader_support esp_flash_partitions.h
|
|
|
|
BOOTLOADER_OFFSET := 0x1000
|
|
|
|
|
2016-10-04 00:03:48 -04:00
|
|
|
# Custom recursive make for bootloader sub-project
|
2017-06-23 00:08:01 -04:00
|
|
|
#
|
|
|
|
# NB: Some variables are cleared in the environment, not
|
|
|
|
# overriden, because they need to be re-defined in the child
|
|
|
|
# project.
|
|
|
|
BOOTLOADER_MAKE= +\
|
|
|
|
PROJECT_PATH= \
|
|
|
|
COMPONENT_DIRS= \
|
|
|
|
$(MAKE) -C $(BOOTLOADER_COMPONENT_PATH)/subproject \
|
|
|
|
V=$(V) \
|
|
|
|
BUILD_DIR_BASE=$(BOOTLOADER_BUILD_DIR) \
|
|
|
|
TEST_COMPONENTS= \
|
2018-04-28 07:57:00 -04:00
|
|
|
TESTS_ALL= \
|
|
|
|
EXCLUDE_COMPONENTS=
|
2017-06-23 00:08:01 -04:00
|
|
|
|
|
|
|
.PHONY: bootloader-clean bootloader-flash bootloader-list-components bootloader $(BOOTLOADER_BIN)
|
2016-08-17 11:08:22 -04:00
|
|
|
|
2016-11-09 21:20:55 -05:00
|
|
|
$(BOOTLOADER_BIN): $(SDKCONFIG_MAKEFILE)
|
2016-11-10 20:29:38 -05:00
|
|
|
$(BOOTLOADER_MAKE) $@
|
2016-08-17 11:08:22 -04:00
|
|
|
|
2016-08-18 05:11:27 -04:00
|
|
|
clean: bootloader-clean
|
|
|
|
|
2017-06-23 00:08:01 -04:00
|
|
|
bootloader-list-components:
|
|
|
|
$(BOOTLOADER_MAKE) list-components
|
|
|
|
|
2020-02-24 14:51:41 -05:00
|
|
|
ifndef CONFIG_SECURE_BOOT
|
2016-10-31 19:50:16 -04:00
|
|
|
# If secure boot disabled, bootloader flashing is integrated
|
|
|
|
# with 'make flash' and no warnings are printed.
|
|
|
|
|
2018-08-20 05:07:27 -04:00
|
|
|
bootloader: $(BOOTLOADER_BIN) | check_python_dependencies
|
2016-11-10 22:44:10 -05:00
|
|
|
@echo $(SEPARATOR)
|
2016-08-18 04:59:38 -04:00
|
|
|
@echo "Bootloader built. Default flash command is:"
|
2016-11-11 01:00:34 -05:00
|
|
|
@echo "$(ESPTOOLPY_WRITE_FLASH) $(BOOTLOADER_OFFSET) $^"
|
2016-08-17 11:08:22 -04:00
|
|
|
|
2016-11-11 01:00:34 -05:00
|
|
|
ESPTOOL_ALL_FLASH_ARGS += $(BOOTLOADER_OFFSET) $(BOOTLOADER_BIN)
|
2020-12-11 10:28:11 -05:00
|
|
|
UF2_ADD_BINARIES += $(BOOTLOADER_OFFSET) $(BOOTLOADER_BIN)
|
2016-08-18 05:11:27 -04:00
|
|
|
|
2018-09-03 05:42:10 -04:00
|
|
|
bootloader-flash: $(BOOTLOADER_BIN) $(call prereq_if_explicit,erase_flash) | check_python_dependencies
|
2016-11-07 20:00:38 -05:00
|
|
|
$(ESPTOOLPY_WRITE_FLASH) 0x1000 $^
|
2016-10-04 00:03:48 -04:00
|
|
|
|
2016-10-31 19:50:16 -04:00
|
|
|
else ifdef CONFIG_SECURE_BOOTLOADER_ONE_TIME_FLASH
|
2016-11-10 23:40:58 -05:00
|
|
|
|
2016-10-31 19:50:16 -04:00
|
|
|
# One time flashing requires user to run esptool.py command themselves,
|
|
|
|
# and warning is printed about inability to reflash.
|
2016-12-20 02:02:47 -05:00
|
|
|
#
|
|
|
|
# The flashing command is deliberately printed without an auto-reset
|
|
|
|
# step, so the device doesn't immediately reset to flash itself.
|
2016-10-31 19:50:16 -04:00
|
|
|
|
2018-08-20 05:07:27 -04:00
|
|
|
bootloader: $(BOOTLOADER_BIN) | check_python_dependencies
|
2016-10-31 19:50:16 -04:00
|
|
|
@echo $(SEPARATOR)
|
|
|
|
@echo "Bootloader built. One-time flash command is:"
|
2016-12-20 02:02:47 -05:00
|
|
|
@echo "$(subst hard_reset,no_reset,$(ESPTOOLPY_WRITE_FLASH)) $(BOOTLOADER_OFFSET) $(BOOTLOADER_BIN)"
|
2016-10-31 19:50:16 -04:00
|
|
|
@echo $(SEPARATOR)
|
|
|
|
@echo "* IMPORTANT: After first boot, BOOTLOADER CANNOT BE RE-FLASHED on same device"
|
|
|
|
|
|
|
|
else ifdef CONFIG_SECURE_BOOTLOADER_REFLASHABLE
|
2016-11-03 02:33:30 -04:00
|
|
|
# Reflashable secure bootloader
|
|
|
|
# generates a digest binary (bootloader + digest)
|
2016-10-31 19:50:16 -04:00
|
|
|
|
2018-10-02 01:15:32 -04:00
|
|
|
ifdef CONFIG_SECURE_BOOTLOADER_KEY_ENCODING_192BIT
|
|
|
|
KEY_DIGEST_LEN=192
|
|
|
|
else
|
|
|
|
KEY_DIGEST_LEN=256
|
|
|
|
endif
|
|
|
|
|
2016-11-04 01:05:00 -04:00
|
|
|
BOOTLOADER_DIGEST_BIN := $(BOOTLOADER_BUILD_DIR)/bootloader-reflash-digest.bin
|
2018-10-02 01:15:32 -04:00
|
|
|
SECURE_BOOTLOADER_KEY := $(BOOTLOADER_BUILD_DIR)/secure-bootloader-key-$(KEY_DIGEST_LEN).bin
|
2016-11-04 01:05:00 -04:00
|
|
|
|
2016-12-18 21:06:21 -05:00
|
|
|
ifdef CONFIG_SECURE_BOOT_BUILD_SIGNED_BINARIES
|
2018-08-20 03:39:56 -04:00
|
|
|
$(SECURE_BOOTLOADER_KEY): $(SECURE_BOOT_SIGNING_KEY) | check_python_dependencies
|
2018-10-02 01:15:32 -04:00
|
|
|
$(ESPSECUREPY) digest_private_key --keylen $(KEY_DIGEST_LEN) -k $< $@
|
2016-12-18 21:06:21 -05:00
|
|
|
else
|
|
|
|
$(SECURE_BOOTLOADER_KEY):
|
|
|
|
@echo "No pre-generated key for a reflashable secure bootloader is available, due to signing configuration."
|
|
|
|
@echo "To generate one, you can use this command:"
|
|
|
|
@echo "espsecure.py generate_flash_encryption_key $@"
|
|
|
|
@echo "then re-run make."
|
|
|
|
exit 1
|
|
|
|
endif
|
2016-10-31 19:50:16 -04:00
|
|
|
|
|
|
|
bootloader: $(BOOTLOADER_DIGEST_BIN)
|
|
|
|
@echo $(SEPARATOR)
|
|
|
|
@echo "Bootloader built and secure digest generated. First time flash command is:"
|
2020-10-15 04:48:23 -04:00
|
|
|
@echo "$(ESPEFUSEPY) burn_key secure_boot_v1 $(SECURE_BOOTLOADER_KEY)"
|
2016-11-11 01:00:34 -05:00
|
|
|
@echo "$(ESPTOOLPY_WRITE_FLASH) $(BOOTLOADER_OFFSET) $(BOOTLOADER_BIN)"
|
2016-10-31 19:50:16 -04:00
|
|
|
@echo $(SEPARATOR)
|
|
|
|
@echo "To reflash the bootloader after initial flash:"
|
|
|
|
@echo "$(ESPTOOLPY_WRITE_FLASH) 0x0 $(BOOTLOADER_DIGEST_BIN)"
|
|
|
|
@echo $(SEPARATOR)
|
|
|
|
@echo "* After first boot, only re-flashes of this kind (with same key) will be accepted."
|
2016-11-01 02:41:27 -04:00
|
|
|
@echo "* Not recommended to re-use the same secure boot keyfile on multiple production devices."
|
2016-10-31 19:50:16 -04:00
|
|
|
|
2018-08-20 03:39:56 -04:00
|
|
|
$(BOOTLOADER_DIGEST_BIN): $(BOOTLOADER_BIN) $(SECURE_BOOTLOADER_KEY) | check_python_dependencies
|
2016-11-03 02:33:30 -04:00
|
|
|
@echo "DIGEST $(notdir $@)"
|
2018-07-13 01:24:11 -04:00
|
|
|
$(ESPSECUREPY) digest_secure_bootloader -k $(SECURE_BOOTLOADER_KEY) -o $@ $<
|
2016-10-31 19:50:16 -04:00
|
|
|
|
2020-02-24 14:51:41 -05:00
|
|
|
else ifdef CONFIG_SECURE_BOOT_V2_ENABLED
|
|
|
|
BOOTLOADER_SIGNED_BIN := $(BOOTLOADER_BUILD_DIR)/bootloader-signed.bin
|
|
|
|
ifdef CONFIG_SECURE_BOOT_BUILD_SIGNED_BINARIES
|
|
|
|
bootloader: $(BOOTLOADER_BIN) $(SDKCONFIG_MAKEFILE) | check_python_dependencies
|
|
|
|
$(ESPSECUREPY) sign_data --keyfile $(SECURE_BOOT_SIGNING_KEY) --version 2 \
|
|
|
|
-o $(BOOTLOADER_SIGNED_BIN) $(BOOTLOADER_BIN)
|
|
|
|
else
|
|
|
|
bootloader: $(BOOTLOADER_BIN) $(SDKCONFIG_MAKEFILE) | check_python_dependencies
|
|
|
|
@echo "Bootloader not signed. Sign the bootloader before flashing."
|
|
|
|
@echo "To sign the bootloader, you can use this command:"
|
|
|
|
@echo "espsecure.py sign_data --keyfile SECURE_BOOT_SIGNING_KEY --version 2 $(BOOTLOADER_BIN)"
|
|
|
|
endif
|
|
|
|
@echo $(SEPARATOR)
|
|
|
|
@echo "Use the following command to flash the bootloader:"
|
|
|
|
ifdef CONFIG_SECURE_BOOT_BUILD_SIGNED_BINARIES
|
|
|
|
@echo "$(ESPTOOLPY_WRITE_FLASH) $(BOOTLOADER_OFFSET) $(BOOTLOADER_SIGNED_BIN)"
|
|
|
|
else
|
|
|
|
@echo "$(ESPTOOLPY_WRITE_FLASH) $(BOOTLOADER_OFFSET) $(BOOTLOADER_BIN)"
|
|
|
|
endif
|
|
|
|
@echo $(SEPARATOR)
|
|
|
|
|
|
|
|
else # CONFIG_SECURE_BOOT && !CONFIG_SECURE_BOOTLOADER_REFLASHABLE \
|
|
|
|
&& !CONFIG_SECURE_BOOTLOADER_ONE_TIME_FLASH && !CONFIG_SECURE_SIGNED_APPS_RSA_SCHEME
|
2016-11-01 19:41:58 -04:00
|
|
|
bootloader:
|
|
|
|
@echo "Invalid bootloader target: bad sdkconfig?"
|
|
|
|
@exit 1
|
2016-10-31 19:50:16 -04:00
|
|
|
endif
|
|
|
|
|
2020-02-24 14:51:41 -05:00
|
|
|
ifndef CONFIG_SECURE_BOOT
|
2018-07-13 02:18:07 -04:00
|
|
|
# don't build bootloader by default if secure boot is enabled
|
2016-10-31 19:50:16 -04:00
|
|
|
all_binaries: $(BOOTLOADER_BIN)
|
2016-11-24 22:09:26 -05:00
|
|
|
endif
|
2016-10-31 19:50:16 -04:00
|
|
|
|
2017-09-01 03:28:13 -04:00
|
|
|
bootloader-clean: $(SDKCONFIG_MAKEFILE)
|
2016-11-13 22:48:10 -05:00
|
|
|
$(BOOTLOADER_MAKE) app-clean
|
2017-10-20 00:14:41 -04:00
|
|
|
ifdef CONFIG_SECURE_BOOTLOADER_REFLASHABLE
|
2016-11-13 22:48:10 -05:00
|
|
|
rm -f $(SECURE_BOOTLOADER_KEY) $(BOOTLOADER_DIGEST_BIN)
|
2017-10-20 00:14:41 -04:00
|
|
|
endif
|
2020-02-24 14:51:41 -05:00
|
|
|
ifdef CONFIG_SECURE_SIGNED_APPS_RSA_SCHEME
|
|
|
|
ifdef CONFIG_SECURE_BOOT_BUILD_SIGNED_BINARIES
|
|
|
|
rm -f $(BOOTLOADER_SIGNED_BIN)
|
|
|
|
endif
|
2020-11-10 02:40:01 -05:00
|
|
|
endif
|