1
0
mirror of https://github.com/esphome/esphome.git synced 2025-10-24 04:33:49 +01:00
This commit is contained in:
J. Nick Koston
2025-10-20 15:17:49 -10:00
parent 5b56807329
commit ce6d0cd846
2 changed files with 43 additions and 48 deletions

View File

@@ -79,57 +79,56 @@ def patch_linker_script_file(filepath, description):
return False return False
def patch_sdk_linker_script_immediately(env): def patch_local_linker_script(source, target, env):
"""Patch SDK linker scripts immediately when script loads. """Patch the local.eagle.app.v6.common.ld in build directory for IRAM."""
# Check if we're in testing mode
This must happen BEFORE PlatformIO's builder calculates sizes.
"""
# Get the SDK linker script path
ldscript = env.GetProjectOption("board_build.ldscript", "")
if not ldscript:
return
# Get the framework directory
framework_dir = env.PioPlatform().get_package_dir("framework-arduinoespressif8266")
if not framework_dir:
return
# Patch the main SDK linker script (flash layout)
sdk_ld = os.path.join(framework_dir, "tools", "sdk", "ld", ldscript)
if os.path.exists(sdk_ld):
patch_linker_script_file(sdk_ld, f"SDK {ldscript}")
# Also patch the local.eagle.app.v6.common.ld in SDK (contains IRAM and DRAM)
local_common = os.path.join(framework_dir, "tools", "sdk", "ld", "local.eagle.app.v6.common.ld")
if os.path.exists(local_common):
patch_linker_script_file(local_common, "SDK local.eagle.app.v6.common.ld")
def patch_linker_script_after_preprocess(source, target, env):
"""Patch linker scripts after PlatformIO preprocesses them."""
# Check if we're in testing mode by looking for the define
build_flags = env.get("BUILD_FLAGS", []) build_flags = env.get("BUILD_FLAGS", [])
testing_mode = any("-DESPHOME_TESTING_MODE" in flag for flag in build_flags) testing_mode = any("-DESPHOME_TESTING_MODE" in flag for flag in build_flags)
if not testing_mode: if not testing_mode:
return return
# Patch SDK linker scripts first (for size calculation) # Patch the local linker script if it exists
patch_sdk_linker_script_immediately(env)
# Patch build directory scripts
build_dir = env.subst("$BUILD_DIR") build_dir = env.subst("$BUILD_DIR")
ld_dir = os.path.join(build_dir, "ld") ld_dir = os.path.join(build_dir, "ld")
if os.path.exists(ld_dir):
if not os.path.exists(ld_dir):
return
# Patch the local linker script (contains IRAM and DRAM definitions)
local_ld = os.path.join(ld_dir, "local.eagle.app.v6.common.ld") local_ld = os.path.join(ld_dir, "local.eagle.app.v6.common.ld")
if os.path.exists(local_ld): if os.path.exists(local_ld):
patch_linker_script_file(local_ld, "build local.eagle.app.v6.common.ld") patch_linker_script_file(local_ld, "local.eagle.app.v6.common.ld")
# Hook into the build process right before linking # Check if we're in testing mode
# This runs after PlatformIO has already preprocessed the linker scripts build_flags = env.get("BUILD_FLAGS", [])
env.AddPreAction("$BUILD_DIR/${PROGNAME}.elf", patch_linker_script_after_preprocess) testing_mode = any("-DESPHOME_TESTING_MODE" in flag for flag in build_flags)
if testing_mode:
# Create custom linker script immediately (before linker command is built)
build_dir = env.subst("$BUILD_DIR")
ldscript = env.GetProjectOption("board_build.ldscript", "")
if ldscript:
framework_dir = env.PioPlatform().get_package_dir("framework-arduinoespressif8266")
if framework_dir:
sdk_ld = os.path.join(framework_dir, "tools", "sdk", "ld", ldscript)
custom_ld = os.path.join(build_dir, f"testing_{ldscript}")
if os.path.exists(sdk_ld) and not os.path.exists(custom_ld):
# Read and patch the SDK linker script
with open(sdk_ld, "r") as f:
content = f.read()
patched_content = apply_memory_patches(content)
# Write custom linker script
with open(custom_ld, "w") as f:
f.write(patched_content)
print(f"ESPHome: Created custom linker script: {custom_ld}")
# Tell the linker to use our custom script
if os.path.exists(custom_ld):
env.Replace(LDSCRIPT_PATH=custom_ld)
print(f"ESPHome: Using custom linker script with patched memory limits")
# Hook to patch local.eagle.app.v6.common.ld after it's created
env.AddPreAction("$BUILD_DIR/${PROGNAME}.elf", patch_local_linker_script)

View File

@@ -1,10 +1,6 @@
esphome: esphome:
name: componenttestesp8266ard name: componenttestesp8266ard
friendly_name: $component_name friendly_name: $component_name
platformio_options:
board_upload.flash_size: 16MB
board_upload.maximum_size: 16777216
board_build.ldscript: eagle.flash.16m14m.ld
esp8266: esp8266:
board: d1_mini_pro board: d1_mini_pro