2018-09-25 01:15:04 +02:00
|
|
|
ifneq (,$(filter riotboot,$(FEATURES_USED)))
|
|
|
|
|
2018-10-18 19:09:00 +02:00
|
|
|
.PHONY: riotboot/flash riotboot/flash-bootloader riotboot/flash-slot0 riotboot/flash-slot1 riotboot/bootloader/%
|
2018-09-25 01:15:04 +02:00
|
|
|
|
|
|
|
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_APP = $(BINDIR)/$(APPLICATION)
|
|
|
|
|
|
|
|
# Indicate the reserved space for a header, 256B by default
|
|
|
|
# Notice that it must be 256B aligned. This is restricted by
|
|
|
|
# the Cortex-M0+/3/4/7 architecture
|
|
|
|
RIOTBOOT_HDR_LEN ?= 0x100
|
|
|
|
|
|
|
|
# Export variables for 'riotboot_slot'
|
|
|
|
export SLOT0_LEN
|
2018-10-18 19:09:00 +02:00
|
|
|
export SLOT1_LEN
|
|
|
|
export NUM_SLOTS
|
2018-09-25 01:15:04 +02:00
|
|
|
|
2018-10-18 19:09:00 +02:00
|
|
|
# By default, slot 0 is found just after RIOTBOOT_LEN. Slot 1 after
|
|
|
|
# slot 0. The values might be overridden to add more or less offset
|
|
|
|
# if needed.
|
2018-09-25 01:15:04 +02:00
|
|
|
export SLOT0_OFFSET ?= $(RIOTBOOT_LEN)
|
2018-10-18 19:09:00 +02:00
|
|
|
# export does not work properly with variables using '$(( ))' so evaluate it in a shell
|
|
|
|
export SLOT1_OFFSET ?= $(shell echo $$(($(SLOT0_OFFSET) + $(SLOT0_LEN))))
|
2018-09-25 01:15:04 +02:00
|
|
|
|
|
|
|
# Mandatory APP_VER, set to 0 by default
|
|
|
|
APP_VER ?= 0
|
|
|
|
|
|
|
|
# Final target for slot 0 with riot_hdr
|
|
|
|
SLOT0_RIOT_BIN = $(BINDIR_APP)-slot0.riot.bin
|
2018-10-18 19:09:00 +02:00
|
|
|
SLOT1_RIOT_BIN = $(BINDIR_APP)-slot1.riot.bin
|
|
|
|
SLOT_RIOT_BINS = $(SLOT0_RIOT_BIN) $(SLOT1_RIOT_BIN)
|
2018-09-25 01:15:04 +02:00
|
|
|
|
|
|
|
# For slot generation only link is needed
|
|
|
|
$(BINDIR_APP)-%.elf: link
|
|
|
|
$(Q)$(_LINK) -o $@
|
|
|
|
|
2018-10-18 19:09:00 +02:00
|
|
|
# Slot 0 and 1 firmware offset, after header
|
|
|
|
SLOT0_IMAGE_OFFSET := $$(($(SLOT0_OFFSET) + $(RIOTBOOT_HDR_LEN)))
|
|
|
|
SLOT1_IMAGE_OFFSET := $$(($(SLOT1_OFFSET) + $(RIOTBOOT_HDR_LEN)))
|
2018-09-25 01:15:04 +02:00
|
|
|
|
|
|
|
# Link slots ELF *after* riot_hdr and limit the ROM to the slots length
|
|
|
|
$(BINDIR_APP)-slot0.elf: FW_ROM_LEN=$$((SLOT0_LEN - $(RIOTBOOT_HDR_LEN)))
|
|
|
|
$(BINDIR_APP)-slot0.elf: ROM_OFFSET=$(SLOT0_IMAGE_OFFSET)
|
2018-10-18 19:09:00 +02:00
|
|
|
$(BINDIR_APP)-slot1.elf: FW_ROM_LEN=$$((SLOT1_LEN - $(RIOTBOOT_HDR_LEN)))
|
|
|
|
$(BINDIR_APP)-slot1.elf: ROM_OFFSET=$(SLOT1_IMAGE_OFFSET)
|
2018-09-25 01:15:04 +02:00
|
|
|
|
|
|
|
# Create binary target with RIOT header
|
2018-10-18 19:09:00 +02:00
|
|
|
$(SLOT_RIOT_BINS): %.riot.bin: %.hdr %.bin
|
2018-09-25 01:15:04 +02:00
|
|
|
@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_APP)-slot0.hdr: OFFSET=$(SLOT0_IMAGE_OFFSET)
|
2018-10-18 19:09:00 +02:00
|
|
|
$(BINDIR_APP)-slot1.hdr: OFFSET=$(SLOT1_IMAGE_OFFSET)
|
2018-09-25 01:15:04 +02:00
|
|
|
|
2018-10-18 19:09:00 +02:00
|
|
|
# Generic target to create a binary files for both slots
|
|
|
|
riotboot: $(SLOT_RIOT_BINS)
|
2018-09-25 01:15:04 +02:00
|
|
|
|
|
|
|
# riotboot bootloader compile target
|
|
|
|
riotboot/flash-bootloader: riotboot/bootloader/flash
|
|
|
|
riotboot/bootloader/%:
|
|
|
|
$(Q)/usr/bin/env -i \
|
|
|
|
QUIET=$(QUIET)\
|
|
|
|
PATH=$(PATH) BOARD=$(BOARD) \
|
|
|
|
$(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))
|
|
|
|
$(BOOTLOADER_BIN)/riotboot.bin: riotboot/bootloader/binfile
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Create combined binary booloader + RIOT firmware with header
|
|
|
|
RIOTBOOT_COMBINED_BIN = $(BINDIR_APP)-slot0-combined.bin
|
|
|
|
riotboot/combined-slot0: $(RIOTBOOT_COMBINED_BIN)
|
|
|
|
$(RIOTBOOT_COMBINED_BIN): $(BOOTLOADER_BIN)/riotboot.extended.bin $(SLOT0_RIOT_BIN)
|
|
|
|
$(Q)cat $^ > $@
|
|
|
|
|
2019-01-02 13:49:18 +01:00
|
|
|
RIOTBOOT_EXTENDED_BIN = $(BINDIR_APP)-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 edbg to flash combined/extended binaries
|
2018-09-25 01:15:04 +02:00
|
|
|
riotboot/flash-combined-slot0: HEXFILE=$(RIOTBOOT_COMBINED_BIN)
|
2019-01-02 13:49:18 +01:00
|
|
|
riotboot/flash-extended-slot0: HEXFILE=$(RIOTBOOT_EXTENDED_BIN)
|
|
|
|
# Flashing rule for openocd to flash combined/extended binaries
|
2018-09-25 01:15:04 +02:00
|
|
|
riotboot/flash-combined-slot0: ELFFILE=$(RIOTBOOT_COMBINED_BIN)
|
2019-01-02 13:49:18 +01:00
|
|
|
riotboot/flash-extended-slot0: ELFFILE=$(RIOTBOOT_EXTENDED_BIN)
|
2018-09-25 01:15:04 +02:00
|
|
|
riotboot/flash-combined-slot0: $(RIOTBOOT_COMBINED_BIN) $(FLASHDEPS)
|
|
|
|
$(FLASHER) $(FFLAGS)
|
2019-01-02 13:49:18 +01:00
|
|
|
|
|
|
|
riotboot/flash-extended-slot0: $(RIOTBOOT_EXTENDED_BIN) $(FLASHDEPS)
|
|
|
|
$(FLASHER) $(FFLAGS)
|
2018-09-25 01:15:04 +02:00
|
|
|
|
|
|
|
# Flashing rule for slot 0
|
|
|
|
riotboot/flash-slot0: export IMAGE_OFFSET=$(SLOT0_OFFSET)
|
|
|
|
# Flashing rule for edbg to flash only slot 0
|
|
|
|
riotboot/flash-slot0: HEXFILE=$(SLOT0_RIOT_BIN)
|
|
|
|
# openocd
|
|
|
|
riotboot/flash-slot0: ELFFILE=$(SLOT0_RIOT_BIN)
|
|
|
|
riotboot/flash-slot0: $(SLOT0_RIOT_BIN) $(FLASHDEPS)
|
|
|
|
$(FLASHER) $(FFLAGS)
|
|
|
|
|
2018-10-18 19:09:00 +02:00
|
|
|
# Flashing rule for slot 1
|
|
|
|
riotboot/flash-slot1: export IMAGE_OFFSET=$(SLOT1_OFFSET)
|
|
|
|
# Flashing rule for edbg to flash only slot 1
|
|
|
|
riotboot/flash-slot1: HEXFILE=$(SLOT1_RIOT_BIN)
|
|
|
|
# openocd
|
|
|
|
riotboot/flash-slot1: ELFFILE=$(SLOT1_RIOT_BIN)
|
|
|
|
riotboot/flash-slot1: $(SLOT1_RIOT_BIN) $(FLASHDEPS)
|
|
|
|
$(FLASHER) $(FFLAGS)
|
|
|
|
|
|
|
|
# Targets to generate only slots binary
|
2018-09-25 01:15:04 +02:00
|
|
|
riotboot/slot0: $(SLOT0_RIOT_BIN)
|
2018-10-18 19:09:00 +02:00
|
|
|
riotboot/slot1: $(SLOT1_RIOT_BIN)
|
2018-09-25 01:15:04 +02:00
|
|
|
|
|
|
|
# Default flashing rule for bootloader + slot 0
|
|
|
|
riotboot/flash: riotboot/flash-slot0 riotboot/flash-bootloader
|
|
|
|
|
|
|
|
else
|
|
|
|
riotboot:
|
|
|
|
$(Q)echo "error: riotboot feature not selected! (try FEATURES_REQUIRED += riotboot)"
|
|
|
|
$(Q)false
|
|
|
|
|
|
|
|
endif # (,$(filter riotboot,$(FEATURES_USED)))
|