2020-12-01 10:22:26 +01:00
|
|
|
ifneq (,$(filter esp_log_colored,$(USEMODULE)))
|
|
|
|
BOOTLOADER_COLOR = _colors
|
|
|
|
endif
|
|
|
|
ifneq (,$(filter esp_log_startup,$(USEMODULE)))
|
|
|
|
BOOTLOADER_INFO = _info
|
|
|
|
endif
|
|
|
|
|
|
|
|
BOOTLOADER_BIN = bootloader$(BOOTLOADER_COLOR)$(BOOTLOADER_INFO).bin
|
|
|
|
|
|
|
|
ESPTOOL ?= $(RIOTTOOLS)/esptool/esptool.py
|
|
|
|
|
2021-04-11 02:37:56 +02:00
|
|
|
# The ELFFILE is defined by default in $(RIOTBASE)/Makefile.include but only
|
|
|
|
# after the $(PROGRAMMER).inc.mk file is included, so we need ELFFILE defined
|
|
|
|
# earlier. This is used to create new make rules in this file (based on
|
|
|
|
# FLASHFILE) and can't be deferred.
|
|
|
|
ELFFILE ?= $(BINDIR)/$(APPLICATION).elf
|
|
|
|
FLASHFILE ?= $(ELFFILE).bin
|
2020-12-01 10:22:26 +01:00
|
|
|
|
2021-04-11 02:37:56 +02:00
|
|
|
# Convert .elf and .csv to .bin files at build time, but make them available for
|
|
|
|
# tests at flash time. These can't be added to FLASHDEPS because they depend on
|
|
|
|
# on ELFFILE and would trigger a rebuild with "flash-only".
|
|
|
|
BUILD_FILES += $(FLASHFILE) $(BINDIR)/partitions.bin
|
|
|
|
TEST_EXTRA_FILES += $(FLASHFILE) $(BINDIR)/partitions.bin
|
2020-12-01 10:22:26 +01:00
|
|
|
|
|
|
|
# flasher configuration
|
|
|
|
ifneq (,$(filter esp_qemu,$(USEMODULE)))
|
2021-02-23 10:53:49 +01:00
|
|
|
FLASHER =
|
|
|
|
FFLAGS =
|
|
|
|
FLASHDEPS += esp-qemu
|
2020-12-01 10:22:26 +01:00
|
|
|
else
|
|
|
|
PROGRAMMER_SPEED ?= 460800
|
|
|
|
FLASHER = $(ESPTOOL)
|
|
|
|
FFLAGS += --chip $(FLASH_CHIP) --port $(PROG_DEV) --baud $(PROGRAMMER_SPEED)
|
|
|
|
FFLAGS += --before default_reset write_flash -z
|
|
|
|
FFLAGS += --flash_mode $(FLASH_MODE) --flash_freq $(FLASH_FREQ)
|
|
|
|
FFLAGS += $(BOOTLOADER_POS) $(RIOTCPU)/$(CPU)/bin/$(BOOTLOADER_BIN)
|
|
|
|
FFLAGS += 0x8000 $(BINDIR)/partitions.bin
|
2021-04-11 02:37:56 +02:00
|
|
|
FFLAGS += 0x10000 $(FLASHFILE)
|
2020-12-01 10:22:26 +01:00
|
|
|
endif
|
|
|
|
|
2021-04-11 02:37:56 +02:00
|
|
|
# This is the binary that ends up programmed in the flash.
|
|
|
|
$(ELFFILE).bin: $(ELFFILE)
|
2021-02-23 10:53:49 +01:00
|
|
|
$(Q)$(ESPTOOL) --chip $(FLASH_CHIP) elf2image --flash_mode $(FLASH_MODE) \
|
|
|
|
--flash_size $(FLASH_SIZE)MB --flash_freq $(FLASH_FREQ) $(FLASH_OPTS) \
|
2021-04-11 02:37:56 +02:00
|
|
|
-o $@ $<
|
|
|
|
|
|
|
|
# Default partition table with no OTA. Can be replaced with a custom partition
|
|
|
|
# table setting PARTITION_TABLE_CSV.
|
|
|
|
PARTITION_TABLE_CSV ?= $(BINDIR)/partitions.csv
|
|
|
|
|
|
|
|
$(BINDIR)/partitions.csv: $(FLASHFILE)
|
2021-02-23 10:53:49 +01:00
|
|
|
$(Q)printf "\n" > $(BINDIR)/partitions.csv
|
2021-04-11 02:37:56 +02:00
|
|
|
$(Q)printf "nvs, data, nvs, 0x9000, 0x6000\n" >> $@
|
|
|
|
$(Q)printf "phy_init, data, phy, 0xf000, 0x1000\n" >> $@
|
|
|
|
$(Q)printf "factory, app, factory, 0x10000, " >> $@
|
|
|
|
$(Q)ls -l $< | awk '{ print $$5 }' >> $@
|
|
|
|
|
|
|
|
$(BINDIR)/partitions.bin: $(PARTITION_TABLE_CSV)
|
|
|
|
$(Q)python3 $(RIOTTOOLS)/esptool/gen_esp32part.py --verify $< $@
|
|
|
|
|
|
|
|
.PHONY: esp-qemu
|
2021-02-23 10:53:49 +01:00
|
|
|
|
|
|
|
esp-qemu:
|
|
|
|
$(Q)dd if=/dev/zero bs=1M count=$(FLASH_SIZE) | \
|
|
|
|
tr "\\000" "\\377" > tmp.bin && cat tmp.bin | \
|
|
|
|
head -c $$(($(BOOTLOADER_POS))) | \
|
|
|
|
cat - $(RIOTCPU)/$(CPU)/bin/$(BOOTLOADER_BIN) tmp.bin | \
|
|
|
|
head -c $$((0x8000)) | \
|
|
|
|
cat - $(BINDIR)/partitions.bin tmp.bin | \
|
|
|
|
head -c $$((0x10000)) | \
|
2021-04-11 02:37:56 +02:00
|
|
|
cat - $(FLASHFILE) tmp.bin | \
|
2021-02-23 10:53:49 +01:00
|
|
|
head -c $(FLASH_SIZE)MB > $(BINDIR)/$(CPU)flash.bin && rm tmp.bin
|
|
|
|
ifeq (esp32,$(CPU_FAM))
|
|
|
|
$(Q)cp $(RIOTCPU)/$(CPU)/bin/rom_0x3ff90000_0x00010000.bin $(BINDIR)/rom1.bin
|
|
|
|
$(Q)cp $(RIOTCPU)/$(CPU)/bin/rom_0x40000000_0x000c2000.bin $(BINDIR)/rom.bin
|
|
|
|
endif
|
|
|
|
|
2020-12-01 10:22:26 +01:00
|
|
|
# reset tool configuration
|
|
|
|
RESET ?= $(RIOTTOOLS)/esptool/espreset.py
|
|
|
|
RESET_FLAGS ?= --port $(PROG_DEV)
|