mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
a945ea144f
Individual files need to be converted to uf2 format, targets flashing individual slots or the bootloader will work: - riotboot/flash-slot% - riotboot/flash-bootloader 'flash' also works by flashing both the bootloader and slot0 independently. But not targets flashing combined/extended versions since conversion of the blob is not possible with the uf2conv.py script.
182 lines
6.8 KiB
Makefile
182 lines
6.8 KiB
Makefile
ifneq (,$(filter riotboot,$(FEATURES_USED)))
|
|
ifneq (1,$(RIOTBOOT_BUILD))
|
|
|
|
.PHONY: riotboot/flash riotboot/flash-bootloader riotboot/flash-slot0 riotboot/flash-slot1 riotboot/bootloader/%
|
|
|
|
RIOTBOOT_DIR = $(RIOTBASE)/bootloaders/riotboot
|
|
RIOTBOOT ?= $(RIOTBOOT_DIR)/bin/$(BOARD)/riotboot.elf
|
|
CFLAGS += -I$(BINDIR)/riotbuild
|
|
|
|
HEADER_TOOL_DIR = $(RIOTBASE)/dist/tools/riotboot_gen_hdr
|
|
HEADER_TOOL ?= $(HEADER_TOOL_DIR)/bin/genhdr
|
|
BINDIR_RIOTBOOT = $(BINDIR)/riotboot_files
|
|
|
|
$(BINDIR_RIOTBOOT): $(CLEAN)
|
|
$(Q)mkdir -p $(BINDIR_RIOTBOOT)
|
|
|
|
#
|
|
export SLOT0_OFFSET SLOT0_LEN SLOT1_OFFSET SLOT1_LEN
|
|
|
|
# Mandatory APP_VER, set to epoch by default
|
|
EPOCH = $(call memoized,EPOCH,$(shell date +%s))
|
|
APP_VER ?= $(EPOCH)
|
|
|
|
# Final target for slot 0 with riot_hdr
|
|
SLOT0_RIOT_BIN = $(BINDIR_RIOTBOOT)/slot0.$(APP_VER).bin
|
|
SLOT1_RIOT_BIN = $(BINDIR_RIOTBOOT)/slot1.$(APP_VER).bin
|
|
SLOT_RIOT_BINS = $(SLOT0_RIOT_BIN) $(SLOT1_RIOT_BIN)
|
|
|
|
# if RIOTBOOT_SKIP_COMPILE is set to 1, "make riotboot/slot[01](-flash)"
|
|
# will not depend on the base elf files, thus skipping the compilation step.
|
|
# This results in the equivalent to "make flash-only" for
|
|
# "make riotboot/flash-slot[01]".
|
|
ifneq (1, $(RIOTBOOT_SKIP_COMPILE))
|
|
$(BINDIR_RIOTBOOT)/%.elf: $(BASELIBS) $(ARCHIVES) $(BINDIR_RIOTBOOT)
|
|
$(Q)$(_LINK) -o $@
|
|
endif
|
|
|
|
# Slot 0 and 1 firmware offset, after header
|
|
SLOT0_IMAGE_OFFSET := $$(($(SLOT0_OFFSET) + $(RIOTBOOT_HDR_LEN)))
|
|
SLOT1_IMAGE_OFFSET := $$(($(SLOT1_OFFSET) + $(RIOTBOOT_HDR_LEN)))
|
|
|
|
# Link slots ELF *after* riot_hdr and limit the ROM to the slots length
|
|
$(BINDIR_RIOTBOOT)/slot0.elf: FW_ROM_LEN=$$((SLOT0_LEN - $(RIOTBOOT_HDR_LEN)))
|
|
$(BINDIR_RIOTBOOT)/slot0.elf: ROM_OFFSET=$(SLOT0_IMAGE_OFFSET)
|
|
$(BINDIR_RIOTBOOT)/slot1.elf: FW_ROM_LEN=$$((SLOT1_LEN - $(RIOTBOOT_HDR_LEN)))
|
|
$(BINDIR_RIOTBOOT)/slot1.elf: ROM_OFFSET=$(SLOT1_IMAGE_OFFSET)
|
|
SLOT_RIOT_ELFS = $(BINDIR_RIOTBOOT)/slot0.elf $(BINDIR_RIOTBOOT)/slot1.elf
|
|
|
|
# ensure both slot elf files are always linked
|
|
# this ensures that both "make test" and "make test-murdock" can rely on them
|
|
# being present without having to trigger re-compilation.
|
|
BUILD_FILES += $(SLOT_RIOT_ELFS)
|
|
|
|
# Create binary target with RIOT header
|
|
$(SLOT_RIOT_BINS): %.$(APP_VER).bin: %.hdr %.bin
|
|
@echo "creating $@..."
|
|
$(Q)cat $^ > $@
|
|
|
|
# Compile header tool if it doesn't exist, force its compilation in case
|
|
# some files changed
|
|
$(HEADER_TOOL): FORCE
|
|
@echo "compiling $@..."
|
|
$(Q)/usr/bin/env -i \
|
|
QUIET=$(QUIET) \
|
|
PATH="$(PATH)" \
|
|
$(MAKE) --no-print-directory -C $(HEADER_TOOL_DIR) all
|
|
|
|
# Generate RIOT header and keep the original binary file
|
|
# It must be always regenerated in case of any changes, so FORCE
|
|
.PRECIOUS: %.bin
|
|
%.hdr: $(HEADER_TOOL) %.bin FORCE
|
|
$(Q)$(HEADER_TOOL) generate $< $(APP_VER) $$(($(ROM_START_ADDR)+$(OFFSET))) $(RIOTBOOT_HDR_LEN) - > $@
|
|
|
|
$(BINDIR_RIOTBOOT)/slot0.hdr: OFFSET=$(SLOT0_IMAGE_OFFSET)
|
|
$(BINDIR_RIOTBOOT)/slot1.hdr: OFFSET=$(SLOT1_IMAGE_OFFSET)
|
|
|
|
# Generic target to create a binary files for both slots
|
|
riotboot: $(SLOT_RIOT_BINS)
|
|
|
|
# riotboot bootloader compile target
|
|
riotboot/flash-bootloader: riotboot/bootloader/flash
|
|
# IOTLAB_NODE is passed so that FLASHFILE is also set in the recursive make call
|
|
# when PROGRAMMER=iotlab
|
|
# avoid circular dependency against clean
|
|
riotboot/bootloader/%: $$(if $$(filter riotboot/bootloader/clean,$$@),,$$(BUILDDEPS) pkg-prepare)
|
|
$(Q)/usr/bin/env -i \
|
|
QUIET=$(QUIET) PATH="$(PATH)" USER="$(USER)"\
|
|
EXTERNAL_BOARD_DIRS="$(EXTERNAL_BOARD_DIRS)" BOARD=$(BOARD)\
|
|
DEBUG_ADAPTER_ID=$(DEBUG_ADAPTER_ID) \
|
|
IOTLAB_NODE=$(IOTLAB_NODE) \
|
|
PROGRAMMER=$(PROGRAMMER) PROGRAMMER_QUIET=$(PROGRAMMER_QUIET) \
|
|
$(MAKE) --no-print-directory -C $(RIOTBOOT_DIR) $*
|
|
|
|
# Generate a binary file from the bootloader which fills all the
|
|
# allocated space. This is used afterwards to create a combined
|
|
# binary with both bootloader and RIOT firmware with header
|
|
BOOTLOADER_BIN = $(RIOTBOOT_DIR)/bin/$(BOARD)
|
|
$(BOOTLOADER_BIN)/riotboot.extended.bin: $(BOOTLOADER_BIN)/riotboot.bin
|
|
$(Q)cp $^ $@.tmp
|
|
$(Q)truncate -s $$(($(RIOTBOOT_LEN))) $@.tmp
|
|
$(Q)mv $@.tmp $@
|
|
|
|
# Only call sub make if not already in riotboot
|
|
ifneq ($(BOOTLOADER_BIN)/riotboot.bin,$(BINFILE))
|
|
clean: riotboot/bootloader/clean
|
|
$(BOOTLOADER_BIN)/riotboot.bin: riotboot/bootloader/binfile
|
|
endif
|
|
|
|
# Create combined binary booloader + RIOT firmware with header
|
|
RIOTBOOT_COMBINED_BIN = $(BINDIR_RIOTBOOT)/slot0-combined.bin
|
|
riotboot/combined-slot0: $(RIOTBOOT_COMBINED_BIN)
|
|
$(RIOTBOOT_COMBINED_BIN): $(BOOTLOADER_BIN)/riotboot.extended.bin $(SLOT0_RIOT_BIN)
|
|
$(Q)cat $^ > $@
|
|
|
|
RIOTBOOT_EXTENDED_BIN = $(BINDIR_RIOTBOOT)/slot0-extended.bin
|
|
|
|
# Generate a binary file from slot 0 which covers slot 1 riot_hdr
|
|
# in order to invalidate slot 1
|
|
$(RIOTBOOT_EXTENDED_BIN): $(RIOTBOOT_COMBINED_BIN)
|
|
$(Q)cp $^ $@.tmp
|
|
$(Q)truncate -s $$(($(SLOT0_OFFSET) + $(SLOT0_LEN) + $(RIOTBOOT_HDR_LEN))) $@.tmp
|
|
$(Q)mv $@.tmp $@
|
|
|
|
# Flashing rule for combined binaries
|
|
riotboot/flash-combined-slot0: FLASHFILE=$(RIOTBOOT_COMBINED_BIN)
|
|
riotboot/flash-combined-slot0: $(RIOTBOOT_COMBINED_BIN) $(FLASHDEPS)
|
|
$(flash-recipe)
|
|
|
|
# Flashing rule for extended binaries
|
|
riotboot/flash-extended-slot0: FLASHFILE=$(RIOTBOOT_EXTENDED_BIN)
|
|
riotboot/flash-extended-slot0: $(RIOTBOOT_EXTENDED_BIN) $(FLASHDEPS)
|
|
$(flash-recipe)
|
|
|
|
# Flashing rule for slot 0
|
|
riotboot/flash-slot0: DFU_ALT=0
|
|
riotboot/flash-slot0: export IMAGE_OFFSET=$(SLOT0_OFFSET)
|
|
riotboot/flash-slot0: FLASHFILE=$(SLOT0_RIOT_BIN)
|
|
riotboot/flash-slot0: $(SLOT0_RIOT_BIN) $(FLASHDEPS)
|
|
$(flash-recipe)
|
|
|
|
# Flashing rule for slot 1
|
|
riotboot/flash-slot1: DFU_ALT=1
|
|
riotboot/flash-slot1: export IMAGE_OFFSET=$(SLOT1_OFFSET)
|
|
riotboot/flash-slot1: FLASHFILE=$(SLOT1_RIOT_BIN)
|
|
riotboot/flash-slot1: $(SLOT1_RIOT_BIN) $(FLASHDEPS)
|
|
$(flash-recipe)
|
|
|
|
# Targets to generate only slots binary
|
|
riotboot/slot0: $(SLOT0_RIOT_BIN)
|
|
riotboot/slot1: $(SLOT1_RIOT_BIN)
|
|
|
|
# Default flashing rule for bootloader + slot 0
|
|
riotboot/flash: riotboot/flash-slot0 riotboot/flash-bootloader
|
|
|
|
# make applications that use the riotboot feature default to actually using it
|
|
# Target 'all' will generate the combined file directly.
|
|
# It also makes 'flash' and 'flash-only' work without specific command.
|
|
#
|
|
# Special case for uf2conv where bootloader and slot0 are both flashed
|
|
# independently
|
|
ifneq (,$(filter uf2conv,$(PROGRAMMER)))
|
|
ifneq (,$(filter riotboot/flash-extended-slot0 riotboot/flash-combined-slot0,$(MAKECMDGOALS)))
|
|
$(error riotboot/flash-extended-slot0 riotboot/flash-combined-slot0 are not supported with uf2conv)
|
|
endif
|
|
FLASHFILE = $(BOOTLOADER_BIN)/riotboot.bin
|
|
riotboot/flash-slot0-remount: riotboot/flash-slot0
|
|
sleep $(TERM_DELAY)
|
|
$(PREFLASHER_PREFIX)$(PREFLASHER) $(PREFFLAGS)
|
|
sleep $(PREFLASH_DELAY)
|
|
flash: riotboot/flash-slot0-remount
|
|
else
|
|
FLASHFILE = $(RIOTBOOT_EXTENDED_BIN)
|
|
endif
|
|
|
|
else
|
|
riotboot:
|
|
$(Q)echo "error: riotboot feature not selected! (try FEATURES_REQUIRED += riotboot)"
|
|
$(Q)false
|
|
|
|
endif # (1,$(RIOTBOOT_BUILD))
|
|
endif # (,$(filter riotboot,$(FEATURES_USED)))
|