-
• #2
I wonder what is meant by 512/512 in the message area on line 11? I also believe that the latest Espruino is 1v87 ... something might have improved in a later release?
-
• #3
can you post what
save()
prints? there is a marker at the end of the save area IIRC and perhaps the calculation is incorrect and it overwrites it. -
• #4
Successful save prints:
>save() =undefined Erasing Flash..... Writing................... ERROR: Too big to save to flash (16984 vs 12284 bytes) Deleting command history and trying again... Erasing Flash..... Writing.............. Compressed 27200 bytes to 11492 Checking... Running onInit()...
Unsuccessful save prints:
>save() =undefined Erasing Flash..... Writing.................... ERROR: Too big to save to flash (18205 vs 12284 bytes) Deleting command history and trying again... Erasing Flash..... Writing............... ERROR: Too Running onInit()...
-
• #5
Hmm, looks like it might be crashing after failing the second time.
On ESP8266 there are only a few pages reserved for saved code in the first 512kB flash though (I guess to make it work the same with all ESP8266 boards). It looks like there's too much code to fit into what's available (3 x 4k pages?). It might be possible to shift stuff around but it looks like memory is tight at the moment as-is.
-
• #6
Yup, looks like there is a bug when the save size is too big. You are correct about the 3x 4KB pages.
-
• #7
Will it survive? :)
I came across a few times with the same error: "No code in Flash" when I toggle power of ESP-12. This time root of the problem is the code size. If I remove some part of application code, it loads and executes well, and it starts on power toggle. If I re-add that part of (unimportant) code, my application works OK, but it doesn't start when power is toggled. If
load()
function is executed, it prints "No code in Flash":Since ESP-12 has 4MB of flash memory, it shouldn't related with memory or application size, right?