Skip to content

Commit

Permalink
Fix Esp32 flashing (#2613)
Browse files Browse the repository at this point in the history
This PR fixes a couple of problems related to ESP32 bootloader flashing.

The `make sdk-configclean` build target which currently does not full clear the SDK configuration information as expected.

The bootloader debug log may show the `SHA-256 comparison failed` message.
The reason for this is that, by default, esptool will auto-detect flash settings and overwrite those values in the bootloader header. Those settings are the mode, speed and flash size settings.

This behaviour is now disabled (by setting CONFIG_ESPTOOLPY_FLASHSIZE_DETECT=n),
and the user-configured parameter values passed to the SDK.

This also fixes the problem for later versions of esptool (4+) which ignores auto-detect unless bootloader checksumming is also disabled. This results in boot failure as the flash chip size is usually too small (default is 2MB).
mikee47 authored Feb 7, 2023
1 parent 4be0f74 commit 309d438
Showing 3 changed files with 10 additions and 1 deletion.
4 changes: 4 additions & 0 deletions Sming/Arch/Esp32/Components/esp32/component.mk
Original file line number Diff line number Diff line change
@@ -365,6 +365,10 @@ $(SDK_CONFIG_DEFAULTS): $(SDK_CUSTOM_CONFIG_PATH)
$(Q) $(foreach f,$(SDK_CONFIG_FILES),\
$(if $(wildcard $f),cat $f >> $@;) \
)
$(Q) printf "\n# ESPTOOL (bootloader) settings\n" >> $@
$(Q) echo "CONFIG_ESPTOOLPY_FLASHMODE_$(SPI_MODE)=y" >> $@
$(Q) echo "CONFIG_ESPTOOLPY_FLASHFREQ_$(SPI_SPEED)M=y" >> $@
$(Q) echo "CONFIG_ESPTOOLPY_FLASHSIZE_$(SPI_SIZE)B=y" >> $@

##@Configuration

4 changes: 4 additions & 0 deletions Sming/Arch/Esp32/Components/esp32/sdk/config/common
Original file line number Diff line number Diff line change
@@ -52,3 +52,7 @@ CONFIG_MBEDTLS_CERTIFICATE_BUNDLE=n

# Debugging
CONFIG_ESP_SYSTEM_PANIC_GDBSTUB=y

# Don't change provided flash configuration information
CONFIG_ESPTOOLPY_FLASHSIZE_DETECT=n

3 changes: 2 additions & 1 deletion Sming/build.mk
Original file line number Diff line number Diff line change
@@ -203,9 +203,10 @@ ifneq ($(STRICT),1)
CXXFLAGS += -Wno-reorder
endif

ifndef MAKE_CLEAN
include $(ARCH_BASE)/build.mk

ifndef MAKE_CLEAN

# Detect compiler version
DEBUG_VARS += GCC_VERSION
GCC_VERSION := $(shell $(CC) -dumpversion)

0 comments on commit 309d438

Please sign in to comment.