diff --git a/ports/esp8266/makeimg.py b/ports/esp8266/makeimg.py index a81b2d0c27..4d31cc0799 100644 --- a/ports/esp8266/makeimg.py +++ b/ports/esp8266/makeimg.py @@ -2,6 +2,11 @@ import sys import struct import hashlib +# This region at the start of flash contains a small header and then segments +# containing .text, .data and .rodata, and so must be large enough to hold all +# of this. This data is loaded to the appropriate places in RAM by the ROM +# bootloader at boot. After this in flash comes .irom0.text, which must begin +# on a flash erase-page boundary. SEGS_MAX_SIZE = 0x9000 assert len(sys.argv) == 4 @@ -18,6 +23,15 @@ with open(sys.argv[3], "wb") as fout: md5.update(data_flash[4:]) print("flash ", len(data_flash)) + # Print info about segments in this first part of flash + num_segs = struct.unpack_from("