mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
7855aad7e4
19079: cpu/esp32: add periph_flashpage support r=kaspar030 a=gschorcht ### Contribution description This PR provides the `periph_flashpage` support for ESP32x SoCs. For byte-aligned read access to constant data in the flash, the MMU of all ESP32x SoCs allows to map a certain number of 64 kByte pages of the flash into the data address space of the CPU. This address space is called DROM. Normally the whole DROM address space is assigned to the section `.rodata`. The default flash layout used by all ESP32x SoCs is: | Address in Flash | Content | |:-----------------------|:-----------| | `0x0000` or `0x1000` | bootloader | | `0x8000` | parition table | | `0x9000` | `nvs` parition with WiFi data | | `0xf000` | `phy_init` partition with RF data | | `0x10000` | `factory` partition with the app image | The factory partition consists of a number of 64 kByte pages for the sections `.text`, `.rodata`, `.bss` and others. The `.text` and `rodata` sections are page-aligned and are simply mapped into the instruction address space (IROM) and the data address space (DROM), respectively. All other sections are loaded into RAM. If the `periph_flashpage` module is used, the `periph_flashpage` driver - decreases the size of the `.rodata` section in DROM address space by `CONFIG_ESP_FLASHPAGE_CAPACITY`, - adds a section `.flashpage.writable` of size `CONFIG_ESP_FLASHPAGE_CAPACITY` at the end of DROM address space that is mapped into data address space of the CPU, - reserves a region of size `CONFIG_ESP_FLASHPAGE_CAPACITY` starting from `0x10000` in front of the image partition `factory` and - moves the image partition `factory` by `CONFIG_ESP_FLASHPAGE_CAPACITY` to address `0x10000 + CONFIG_ESP_FLASHPAGE_CAPACITY`. The new flash layout is then: | Address in Flash | Content | |:-----------------------|:-----------| | `0x0000` or `0x1000` | bootloader | | `0x8000` | parition table | | `0x9000` | `nvs` parition with WiFi data | | `0xf000` | `phy_init` partition with RF data | | `0x10000` | flashpage region | | `0x10000 + CONFIG_ESP_FLASHPAGE_CAPACITY` | `factory` partition with the app image | This guarantees that the flash pages are not overwritten if a new app image with changed size is flashed. `CONFIG_ESP_FLASHPAGE_CAPACITY` has to be a multiple of 64 kBytes. ~The PR includes PR #19077 and PR #19078 for the moment to be compilable.~ ### Testing procedure The following tests should pass. ``` USEMODULE='esp_log_startup ps shell_cmds_default' BOARD=esp32-wroom-32 make -j8 -C tests/periph_flashpage flash term ``` ``` USEMODULE='esp_log_startup ps shell_cmds_default' BOARD=esp32-wroom-32 make -j8 -C tests/mtd_flashpage flash term ``` ### Issues/PRs references Depends on PR #19077 Depends on PR #19078 Co-authored-by: Gunar Schorcht <gunar@schorcht.net>
309 lines
11 KiB
Makefile
309 lines
11 KiB
Makefile
# ESP32x specific flashing options
|
|
FLASH_CHIP = $(CPU_FAM)
|
|
|
|
export ESP32_SDK_DIR ?= $(PKGDIRBASE)/esp32_sdk
|
|
|
|
# Serial flasher config as used by the ESP-IDF, be careful when overriding them.
|
|
# They have to be exported to use same values in subsequent makefiles.
|
|
ifeq (esp32,$(CPU_FAM))
|
|
export FLASH_MODE ?= dout
|
|
export FLASH_FREQ ?= 40m
|
|
export FLASH_SIZE ?= 2
|
|
BOOTLOADER_POS = 0x1000
|
|
else ifneq (,$(filter esp32c3 esp32s3,$(CPU_FAM)))
|
|
export FLASH_MODE ?= dio
|
|
export FLASH_FREQ ?= 80m
|
|
export FLASH_SIZE ?= 2
|
|
BOOTLOADER_POS = 0x0000
|
|
else ifneq (,$(filter esp32s2,$(CPU_FAM)))
|
|
export FLASH_MODE ?= qio
|
|
export FLASH_FREQ ?= 80m
|
|
export FLASH_SIZE ?= 4
|
|
BOOTLOADER_POS = 0x1000
|
|
else
|
|
$(error Unkwnown ESP32x SoC variant (family))
|
|
endif
|
|
|
|
ifneq (,$(filter periph_flashpage,$(USEMODULE)))
|
|
ifneq (,$(CONFIG_ESP_FLASHPAGE_CAPACITY_64K))
|
|
FLASHFILE_POS = 0x20000
|
|
FLASHPAGE_CAP = 0x10000
|
|
else ifneq (,$(CONFIG_ESP_FLASHPAGE_CAPACITY_128K))
|
|
FLASHFILE_POS = 0x30000
|
|
FLASHPAGE_CAP = 0x20000
|
|
else ifneq (,$(CONFIG_ESP_FLASHPAGE_CAPACITY_256K))
|
|
FLASHFILE_POS = 0x50000
|
|
FLASHPAGE_CAP = 0x40000
|
|
else ifneq (,$(CONFIG_ESP_FLASHPAGE_CAPACITY_512K))
|
|
FLASHFILE_POS = 0x90000
|
|
FLASHPAGE_CAP = 0x80000
|
|
else ifneq (,$(CONFIG_ESP_FLASHPAGE_CAPACITY_1M))
|
|
FLASHFILE_POS = 0x110000
|
|
FLASHPAGE_CAP = 0x100000
|
|
else ifneq (,$(CONFIG_ESP_FLASHPAGE_CAPACITY_2M))
|
|
FLASHFILE_POS = 0x210000
|
|
FLASHPAGE_CAP = 0x200000
|
|
else
|
|
# use 512 kByte for periph_flashpage by default
|
|
FLASHFILE_POS = 0x90000
|
|
FLASHPAGE_CAP = 0x80000
|
|
CFLAGS += -DCONFIG_ESP_FLASHPAGE_CAPACITY_512K
|
|
endif
|
|
FLASHPAGE_ADDR_START = 0x10000
|
|
FLASHPAGE_ADDR_END = $(FLASHFILE_POS)
|
|
CFLAGS += -DFLASHPAGE_ADDR_START=$(FLASHPAGE_ADDR_START)
|
|
CFLAGS += -DFLASHPAGE_ADDR_END=$(FLASHPAGE_ADDR_END)
|
|
endif
|
|
|
|
FLASHFILE_POS ?= 0x10000
|
|
|
|
ESPTOOL ?= $(RIOTTOOLS)/esptools/esptool_v3.2.py
|
|
|
|
include $(RIOTCPU)/esp_common/Makefile.include
|
|
|
|
# regular Makefile
|
|
|
|
ifeq (xtensa,$(CPU_ARCH))
|
|
TARGET_ARCH ?= xtensa-$(CPU_FAM)-elf
|
|
else ifeq (rv32,$(CPU_ARCH))
|
|
TARGET_ARCH ?= riscv32-esp-elf
|
|
else
|
|
$(error Unkwnown ESP32x SoC architecture)
|
|
endif
|
|
|
|
PSEUDOMODULES += esp_ble
|
|
PSEUDOMODULES += esp_bootloader
|
|
PSEUDOMODULES += esp_gdbstub
|
|
PSEUDOMODULES += esp_hw_counter
|
|
PSEUDOMODULES += esp_idf_gpio_hal
|
|
PSEUDOMODULES += esp_i2c_hw
|
|
PSEUDOMODULES += esp_jtag
|
|
PSEUDOMODULES += esp_rtc_timer_32k
|
|
PSEUDOMODULES += esp_spi_ram
|
|
PSEUDOMODULES += esp_spi_oct
|
|
PSEUDOMODULES += esp_wifi_enterprise
|
|
PSEUDOMODULES += stdio_usb_serial_jtag_rx
|
|
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/esp-idf/include
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/esp-idf/include/log
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/vendor/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/bootloader_support/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/driver/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_common/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_hw_support/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_hw_support/include/soc
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_rom/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_rom/include/$(CPU_FAM)
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_system/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_system/port/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_timer/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/hal/$(CPU_FAM)/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/hal/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/hal/platform_port/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/heap/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/log/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/newlib/platform_include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/soc/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/soc/$(CPU_FAM)/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/spi_flash/include
|
|
|
|
ifneq (,$(filter riscv32%,$(TARGET_ARCH)))
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/riscv/include
|
|
endif
|
|
|
|
ifneq (,$(filter xtensa%,$(TARGET_ARCH)))
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/xtensa/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/xtensa/$(CPU_FAM)/include
|
|
endif
|
|
|
|
ifneq (,$(filter esp_ble,$(USEMODULE)))
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/bt/include/$(CPU_FAM)/include
|
|
endif
|
|
|
|
ifneq (,$(filter esp_ble_nimble,$(USEMODULE)))
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/include/esp_ble_nimble
|
|
INCLUDES += $(NIMIBASE)/nimble/transport/common/hci_h4/include
|
|
endif
|
|
|
|
ifneq (,$(filter esp_spi_ram,$(USEMODULE)))
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_hw_support/include/soc/$(CPU_FAM)
|
|
endif
|
|
|
|
ifneq (,$(filter esp_idf_spi_flash,$(USEMODULE)))
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/spi_flash/include
|
|
endif
|
|
|
|
ifneq (,$(filter esp_idf_usb,$(USEMODULE)))
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/usb/include
|
|
endif
|
|
|
|
ifneq (,$(filter esp_wifi_any,$(USEMODULE)))
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/bootloader_support/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_eth/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_event/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_netif/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_wifi/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/nvs_flash/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/spi_flash/include
|
|
endif
|
|
|
|
ifneq (,$(filter esp_wifi_enterprise,$(USEMODULE)))
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/wpa_supplicant/esp_supplicant/include
|
|
endif
|
|
|
|
ifneq (,$(filter esp_eth,$(USEMODULE)))
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/esp-eth
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_eth/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_event/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_netif/include
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_wifi/include
|
|
endif
|
|
|
|
CFLAGS += -DCPU_FAM_$(call uppercase_and_underscore,$(CPU_FAM))
|
|
|
|
# we use ESP32 only in single core mode
|
|
CFLAGS += -DCONFIG_ESP_SYSTEM_SINGLE_CORE_MODE
|
|
CFLAGS += -DCONFIG_FREERTOS_UNICORE
|
|
|
|
# other ESP-IDF configurations
|
|
CFLAGS += -DCONFIG_IDF_TARGET_$(call uppercase_and_underscore,$(CPU_FAM))
|
|
CFLAGS += -DESP_PLATFORM
|
|
CFLAGS += -DLOG_TAG_IN_BRACKETS
|
|
|
|
# extend CFLAGS by the corresponding FLASH_FREQ
|
|
ifeq (20m,$(FLASH_FREQ))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHFREQ_20M
|
|
else ifeq (26m,$(FLASH_FREQ))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHFREQ_26M
|
|
else ifeq (40m,$(FLASH_FREQ))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHFREQ_40M
|
|
else ifeq (80m,$(FLASH_FREQ))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHFREQ_80M
|
|
else ifeq (120m,$(FLASH_FREQ))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHFREQ_120M
|
|
endif
|
|
|
|
#extend CFLAGS by the corresponding FLASH_SIZE
|
|
ifeq (1,$(FLASH_SIZE))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHSIZE_1MB
|
|
else ifeq (2,$(FLASH_SIZE))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHSIZE_2MB
|
|
else ifeq (4,$(FLASH_SIZE))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHSIZE_4MB
|
|
else ifeq (8,$(FLASH_SIZE))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHSIZE_8MB
|
|
else ifeq (16,$(FLASH_SIZE))
|
|
CFLAGS += -DCONFIG_ESPTOOLPY_FLASHSIZE_16MB
|
|
endif
|
|
|
|
# shortcuts used by ESP-IDF
|
|
CFLAGS += -Dasm=__asm
|
|
CFLAGS += -Dtypeof=__typeof__
|
|
CFLAGS += -D_CONST=const
|
|
|
|
# TODO no relaxation yet
|
|
ifneq (,$(filter riscv%,$(TARGET_ARCH)))
|
|
CFLAGS += -mno-relax -march=rv32imc -mabi=ilp32 -DRISCV_NO_RELAX
|
|
endif
|
|
|
|
ifneq (,$(filter xtensa%,$(TARGET_ARCH)))
|
|
LINKFLAGS += -L$(ESP32_SDK_DIR)/components/xtensa/$(CPU_FAM)
|
|
ARCHIVES += -lxt_hal
|
|
endif
|
|
|
|
LINKFLAGS += -L$(RIOTCPU)/$(CPU)/ld/$(CPU_FAM)/
|
|
|
|
LINKFLAGS += -T$(BINDIR)/memory.ld
|
|
LINKFLAGS += -T$(BINDIR)/sections.ld
|
|
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/soc/$(CPU_FAM)/ld/$(CPU_FAM).peripherals.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.api.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.ld
|
|
|
|
ifneq (,$(filter esp32 esp32s2,$(CPU_FAM)))
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.newlib-data.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.newlib-funcs.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.newlib-time.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.spiflash.ld
|
|
else ifeq (esp32c3,$(CPU_FAM))
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.libgcc.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.newlib.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.version.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.eco3.ld
|
|
else ifeq (esp32s3,$(CPU_FAM))
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.libgcc.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.newlib.ld
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU_FAM)/ld/$(CPU_FAM).rom.version.ld
|
|
else
|
|
$(error Unkwnown ESP32x SoC variant (family))
|
|
endif
|
|
|
|
LINKFLAGS += -nostdlib -lgcc -Wl,-gc-sections
|
|
|
|
# Libraries needed when using esp_wifi_any pseudomodule
|
|
ifneq (,$(filter esp_wifi_any,$(USEMODULE)))
|
|
LINKFLAGS += -L$(ESP32_SDK_LIB_WIFI_DIR)/$(CPU_FAM)
|
|
LINKFLAGS += -L$(ESP32_SDK_LIB_PHY_DIR)/$(CPU_FAM)
|
|
ARCHIVES += -lcoexist -lcore -lmesh -lnet80211 -lpp
|
|
ARCHIVES += -lphy -lstdc++
|
|
ifeq (esp32,$(CPU_FAM))
|
|
ARCHIVES += -lrtc
|
|
endif
|
|
endif
|
|
|
|
# Libraries needed when using esp_now module
|
|
ifneq (,$(filter esp_now,$(USEMODULE)))
|
|
ARCHIVES += -lespnow -lmesh
|
|
endif
|
|
|
|
# Libraries needed when using esp_ble
|
|
ifneq (,$(filter esp_ble,$(USEMODULE)))
|
|
LINKFLAGS += -L$(ESP32_SDK_LIB_PHY_DIR)/$(CPU_FAM)
|
|
LINKFLAGS += -L$(ESP32_SDK_LIB_BT_DIR)/$(CPU_FAM)
|
|
ARCHIVES += -lbtdm_app
|
|
ARCHIVES += -lphy -lstdc++
|
|
ifeq (esp32,$(CPU_FAM))
|
|
ARCHIVES += -lrtc
|
|
else ifneq (,$(filter esp32c3 esp32s3,$(CPU_FAM)))
|
|
ARCHIVES += -lbtbb
|
|
endif
|
|
endif
|
|
|
|
ifneq (,$(filter cpp,$(USEMODULE)))
|
|
ARCHIVES += -lstdc++
|
|
endif
|
|
|
|
ifneq (,$(filter esp_bootloader,$(USEMODULE)))
|
|
# Bootloader file used by esptool.inc.mk
|
|
BOOTLOADER_BIN ?= $(BINDIR)/esp_bootloader/bootloader.bin
|
|
endif
|
|
|
|
ifneq (,$(filter esp_jtag,$(USEMODULE)))
|
|
PROGRAMMERS_SUPPORTED += openocd
|
|
PARTITION_POS = 0x8000
|
|
OPENOCD_PRE_FLASH_CMDS = -c 'echo "Installing Bootloader at $(BOOTLOADER_POS)"' \
|
|
-c 'flash write_image erase "$(BOOTLOADER_BIN)" $(BOOTLOADER_POS) bin' \
|
|
-c 'echo "Installing partition table at $(PARTITION_POS)"' \
|
|
-c 'flash write_image erase "$(BINDIR)/partitions.bin" $(PARTITION_POS) bin'
|
|
IMAGE_OFFSET = $(FLASHFILE_POS)
|
|
# Flash checksumming not supported on xtensa
|
|
OPENOCD_SKIP_VERIFY = yes
|
|
# Without resets debug target fails with 'Target not examined yet'
|
|
OPENOCD_DBG_EXTRA_CMD += -c 'reset halt'
|
|
endif
|
|
|
|
LD_SCRIPTS += $(BINDIR)/memory.ld $(BINDIR)/sections.ld
|
|
|
|
$(BINDIR)/memory.ld: $(RIOTCPU)/$(CPU)/ld/$(CPU_FAM)/memory.ld.in \
|
|
$(BINDIR)/riotbuild/riotbuild.h pkg-prepare
|
|
$(Q)$(CC) -DLD_FILE_GEN $(INCLUDES) -include '$(BINDIR)/riotbuild/riotbuild.h' \
|
|
-I$(RIOTCPU)/$(CPU)/ld -P -x c -E $< -o $@
|
|
$(BINDIR)/sections.ld: $(RIOTCPU)/$(CPU)/ld/$(CPU_FAM)/sections.ld.in \
|
|
$(BINDIR)/riotbuild/riotbuild.h pkg-prepare
|
|
$(Q)$(CC) -DLD_FILE_GEN -include '$(BINDIR)/riotbuild/riotbuild.h' -C -P -x c -E $< -o $@
|
|
|
|
$(BOOTLOADER_BIN):
|