Added post build script to generate a .factory.bin file
This file can just be flashed to address 0x0 and contains all other required data. No need to flash multiple files anymore.
This commit is contained in:
parent
5fea7ee066
commit
08b44fb2ba
77
pio-scripts/create_factory_bin.py
Normal file
77
pio-scripts/create_factory_bin.py
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
# Part of ESPEasy build toolchain.
|
||||||
|
#
|
||||||
|
# Combines separate bin files with their respective offsets into a single file
|
||||||
|
# This single file must then be flashed to an ESP32 node with 0 offset.
|
||||||
|
#
|
||||||
|
# Original implementation: Bartłomiej Zimoń (@uzi18)
|
||||||
|
# Maintainer: Gijs Noorlander (@TD-er)
|
||||||
|
#
|
||||||
|
# Special thanks to @Jason2866 (Tasmota) for helping debug flashing to >4MB flash
|
||||||
|
# Thanks @jesserockz (esphome) for adapting to use esptool.py with merge_bin
|
||||||
|
#
|
||||||
|
# Typical layout of the generated file:
|
||||||
|
# Offset | File
|
||||||
|
# - 0x1000 | ~\.platformio\packages\framework-arduinoespressif32\tools\sdk\esp32\bin\bootloader_dout_40m.bin
|
||||||
|
# - 0x8000 | ~\ESPEasy\.pio\build\<env name>\partitions.bin
|
||||||
|
# - 0xe000 | ~\.platformio\packages\framework-arduinoespressif32\tools\partitions\boot_app0.bin
|
||||||
|
# - 0x10000 | ~\ESPEasy\.pio\build\<env name>/<built binary>.bin
|
||||||
|
|
||||||
|
Import("env")
|
||||||
|
|
||||||
|
platform = env.PioPlatform()
|
||||||
|
|
||||||
|
import sys
|
||||||
|
from os.path import join
|
||||||
|
|
||||||
|
sys.path.append(join(platform.get_package_dir("tool-esptoolpy")))
|
||||||
|
import esptool
|
||||||
|
|
||||||
|
def esp32_create_combined_bin(source, target, env):
|
||||||
|
print("Generating combined binary for serial flashing")
|
||||||
|
|
||||||
|
# The offset from begin of the file where the app0 partition starts
|
||||||
|
# This is defined in the partition .csv file
|
||||||
|
app_offset = 0x10000
|
||||||
|
|
||||||
|
new_file_name = env.subst("$BUILD_DIR/${PROGNAME}.factory.bin")
|
||||||
|
sections = env.subst(env.get("FLASH_EXTRA_IMAGES"))
|
||||||
|
firmware_name = env.subst("$BUILD_DIR/${PROGNAME}.bin")
|
||||||
|
chip = env.get("BOARD_MCU")
|
||||||
|
flash_size = env.BoardConfig().get("upload.flash_size")
|
||||||
|
flash_freq = env.BoardConfig().get("build.f_flash", '40m')
|
||||||
|
flash_freq = flash_freq.replace('000000L', 'm')
|
||||||
|
flash_mode = env.BoardConfig().get("build.flash_mode", "dio")
|
||||||
|
memory_type = env.BoardConfig().get("build.arduino.memory_type", "qio_qspi")
|
||||||
|
if flash_mode == "qio" or flash_mode == "qout":
|
||||||
|
flash_mode = "dio"
|
||||||
|
if memory_type == "opi_opi" or memory_type == "opi_qspi":
|
||||||
|
flash_mode = "dout"
|
||||||
|
cmd = [
|
||||||
|
"--chip",
|
||||||
|
chip,
|
||||||
|
"merge_bin",
|
||||||
|
"-o",
|
||||||
|
new_file_name,
|
||||||
|
"--flash_mode",
|
||||||
|
flash_mode,
|
||||||
|
"--flash_freq",
|
||||||
|
flash_freq,
|
||||||
|
"--flash_size",
|
||||||
|
flash_size,
|
||||||
|
]
|
||||||
|
|
||||||
|
print(" Offset | File")
|
||||||
|
for section in sections:
|
||||||
|
sect_adr, sect_file = section.split(" ", 1)
|
||||||
|
print(f" - {sect_adr} | {sect_file}")
|
||||||
|
cmd += [sect_adr, sect_file]
|
||||||
|
|
||||||
|
print(f" - {hex(app_offset)} | {firmware_name}")
|
||||||
|
cmd += [hex(app_offset), firmware_name]
|
||||||
|
|
||||||
|
print('Using esptool.py arguments: %s' % ' '.join(cmd))
|
||||||
|
|
||||||
|
esptool.main(cmd)
|
||||||
|
|
||||||
|
|
||||||
|
env.AddPostAction("$BUILD_DIR/${PROGNAME}.bin", esp32_create_combined_bin)
|
||||||
@ -37,6 +37,7 @@ lib_deps =
|
|||||||
extra_scripts =
|
extra_scripts =
|
||||||
pre:pio-scripts/auto_firmware_version.py
|
pre:pio-scripts/auto_firmware_version.py
|
||||||
pre:pio-scripts/patch_apply.py
|
pre:pio-scripts/patch_apply.py
|
||||||
|
post:pio-scripts/create_factory_bin.py
|
||||||
|
|
||||||
board_build.partitions = partitions_custom.csv
|
board_build.partitions = partitions_custom.csv
|
||||||
board_build.filesystem = littlefs
|
board_build.filesystem = littlefs
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user