mirror of
https://github.com/ratspeak/ratdeck.git
synced 2026-05-14 03:15:05 +00:00
Add merged single .bin output for M5Burner compatibility
Add post-build script that produces ratdeck-merged.bin with bootloader, partitions, boot_app0, and firmware at correct offsets. CI now attaches the merged binary as a standalone release asset alongside the existing multi-part ZIP.
This commit is contained in:
@@ -24,6 +24,16 @@ jobs:
|
||||
- name: Build firmware
|
||||
run: pio run -e ratdeck_915
|
||||
|
||||
- name: Merge single .bin for M5Burner
|
||||
run: |
|
||||
esptool.py --chip esp32s3 merge_bin \
|
||||
--flash_mode qio --flash_size 16MB \
|
||||
-o ratdeck-merged.bin \
|
||||
0x0000 .pio/build/ratdeck_915/bootloader.bin \
|
||||
0x8000 .pio/build/ratdeck_915/partitions.bin \
|
||||
0xe000 ~/.platformio/packages/framework-arduinoespressif32/tools/partitions/boot_app0.bin \
|
||||
0x10000 .pio/build/ratdeck_915/firmware.bin
|
||||
|
||||
- name: Package firmware ZIP
|
||||
run: |
|
||||
mkdir -p ratdeck-firmware
|
||||
@@ -31,6 +41,7 @@ jobs:
|
||||
cp .pio/build/ratdeck_915/partitions.bin ratdeck-firmware/
|
||||
cp ~/.platformio/packages/framework-arduinoespressif32/tools/partitions/boot_app0.bin ratdeck-firmware/
|
||||
cp .pio/build/ratdeck_915/firmware.bin ratdeck-firmware/
|
||||
cp ratdeck-merged.bin ratdeck-firmware/
|
||||
cat > ratdeck-firmware/manifest.json << 'MANIFEST'
|
||||
{
|
||||
"chipFamily": "ESP32-S3",
|
||||
@@ -51,7 +62,9 @@ jobs:
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: ratdeck-firmware
|
||||
path: ratdeck-firmware.zip
|
||||
path: |
|
||||
ratdeck-firmware.zip
|
||||
ratdeck-merged.bin
|
||||
|
||||
release:
|
||||
needs: build
|
||||
@@ -73,6 +86,16 @@ jobs:
|
||||
- name: Build firmware
|
||||
run: pio run -e ratdeck_915
|
||||
|
||||
- name: Merge single .bin for M5Burner
|
||||
run: |
|
||||
esptool.py --chip esp32s3 merge_bin \
|
||||
--flash_mode qio --flash_size 16MB \
|
||||
-o ratdeck-merged.bin \
|
||||
0x0000 .pio/build/ratdeck_915/bootloader.bin \
|
||||
0x8000 .pio/build/ratdeck_915/partitions.bin \
|
||||
0xe000 ~/.platformio/packages/framework-arduinoespressif32/tools/partitions/boot_app0.bin \
|
||||
0x10000 .pio/build/ratdeck_915/firmware.bin
|
||||
|
||||
- name: Package firmware ZIP
|
||||
run: |
|
||||
mkdir -p ratdeck-firmware
|
||||
@@ -80,6 +103,7 @@ jobs:
|
||||
cp .pio/build/ratdeck_915/partitions.bin ratdeck-firmware/
|
||||
cp ~/.platformio/packages/framework-arduinoespressif32/tools/partitions/boot_app0.bin ratdeck-firmware/
|
||||
cp .pio/build/ratdeck_915/firmware.bin ratdeck-firmware/
|
||||
cp ratdeck-merged.bin ratdeck-firmware/
|
||||
cat > ratdeck-firmware/manifest.json << 'MANIFEST'
|
||||
{
|
||||
"chipFamily": "ESP32-S3",
|
||||
@@ -99,5 +123,7 @@ jobs:
|
||||
- name: Create Release
|
||||
uses: softprops/action-gh-release@v2
|
||||
with:
|
||||
files: ratdeck-firmware.zip
|
||||
files: |
|
||||
ratdeck-firmware.zip
|
||||
ratdeck-merged.bin
|
||||
generate_release_notes: true
|
||||
|
||||
@@ -0,0 +1,31 @@
|
||||
"""Post-build script: merge bootloader + partitions + boot_app0 + firmware
|
||||
into a single .bin for M5Burner and one-step flashing."""
|
||||
|
||||
Import("env")
|
||||
|
||||
import os
|
||||
|
||||
|
||||
def merge_bin(source, target, env):
|
||||
build_dir = env.subst("$BUILD_DIR")
|
||||
project_dir = env.subst("$PROJECT_DIR")
|
||||
|
||||
# boot_app0.bin lives in the Arduino framework tools
|
||||
framework_dir = env.PioPlatform().get_package_dir("framework-arduinoespressif32")
|
||||
boot_app0 = os.path.join(framework_dir, "tools", "partitions", "boot_app0.bin")
|
||||
|
||||
output = os.path.join(project_dir, "ratdeck-merged.bin")
|
||||
|
||||
env.Execute(
|
||||
"esptool.py --chip esp32s3 merge_bin "
|
||||
"--flash_mode qio --flash_size 16MB "
|
||||
f"-o {output} "
|
||||
f"0x0000 {build_dir}/bootloader.bin "
|
||||
f"0x8000 {build_dir}/partitions.bin "
|
||||
f"0xe000 {boot_app0} "
|
||||
f"0x10000 {build_dir}/firmware.bin"
|
||||
)
|
||||
print(f"\n** Merged firmware written to: {output}")
|
||||
|
||||
|
||||
env.AddPostAction("$BUILD_DIR/firmware.bin", merge_bin)
|
||||
@@ -38,6 +38,8 @@ lib_deps =
|
||||
|
||||
lib_archive = false
|
||||
|
||||
extra_scripts = post:merge_firmware.py
|
||||
|
||||
monitor_speed = 115200
|
||||
upload_speed = 460800
|
||||
upload_flags = --no-stub
|
||||
|
||||
Reference in New Issue
Block a user