supervisor: external_flash: don't call m_free when it's bad

It's extremely dubious that we have these handles that we think
are to GC'd memory at a time when the gc pool may not be initialized.
Hopefully, they WERE valid GC memory and are undisturbed by the teardown
of the interpreter that can lead to this state.

In this case, don't try to m_free them, the memory will become free when
the GC heap is reinitialized.

Closes: #2338 (together with previous commit)
This commit is contained in:
Jeff Epler 2019-12-10 17:05:37 -06:00
parent b22fbcd77d
commit f4a5c17b5e

View File

@ -371,7 +371,7 @@ static void release_ram_cache(void) {
if (supervisor_cache != NULL) { if (supervisor_cache != NULL) {
free_memory(supervisor_cache); free_memory(supervisor_cache);
supervisor_cache = NULL; supervisor_cache = NULL;
} else { } else if (MP_STATE_MEM(gc_pool_start)) {
m_free(MP_STATE_VM(flash_ram_cache)); m_free(MP_STATE_VM(flash_ram_cache));
} }
MP_STATE_VM(flash_ram_cache) = NULL; MP_STATE_VM(flash_ram_cache) = NULL;
@ -419,7 +419,7 @@ static bool flush_ram_cache(bool keep_cache) {
write_flash(current_sector + (i * pages_per_block + j) * SPI_FLASH_PAGE_SIZE, write_flash(current_sector + (i * pages_per_block + j) * SPI_FLASH_PAGE_SIZE,
MP_STATE_VM(flash_ram_cache)[i * pages_per_block + j], MP_STATE_VM(flash_ram_cache)[i * pages_per_block + j],
SPI_FLASH_PAGE_SIZE); SPI_FLASH_PAGE_SIZE);
if (!keep_cache && supervisor_cache == NULL) { if (!keep_cache && supervisor_cache == NULL && MP_STATE_MEM(gc_pool_start)) {
m_free(MP_STATE_VM(flash_ram_cache)[i * pages_per_block + j]); m_free(MP_STATE_VM(flash_ram_cache)[i * pages_per_block + j]);
} }
} }