mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
nvs_flash: Multi-page blob erased using nvs_erase_key should be cleaned properly
Earlier eraseItem function in Storage class would do lazy cleanup of multi-page blobs if called using type "ANY" instead of "BLOB". It used to just delete BLOB data and index would remain as is. Any subsequent read would delete index entry as well. This however would return a valid length without error if nvs_get_blob API was just used for finding length and not reading the complete blob. This change fixes this issue. Closes https://github.com/espressif/esp-idf/issues/3255
This commit is contained in:
parent
038f51ffa6
commit
553725df84
@ -528,6 +528,10 @@ esp_err_t Storage::eraseItem(uint8_t nsIndex, ItemType datatype, const char* key
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (item.datatype == ItemType::BLOB_DATA || item.datatype == ItemType::BLOB_IDX) {
|
||||||
|
return eraseMultiPageBlob(nsIndex, key);
|
||||||
|
}
|
||||||
|
|
||||||
return findPage->eraseItem(nsIndex, datatype, key);
|
return findPage->eraseItem(nsIndex, datatype, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1728,6 +1728,22 @@ TEST_CASE("Modification from multi-page to single page", "[nvs]")
|
|||||||
nvs_close(handle);
|
nvs_close(handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_CASE("Multi-page blob erased using nvs_erase_key should not be found when probed for just length", "[nvs]")
|
||||||
|
{
|
||||||
|
const size_t blob_size = Page::CHUNK_MAX_SIZE *3;
|
||||||
|
uint8_t blob[blob_size] = {0};
|
||||||
|
size_t read_size = blob_size;
|
||||||
|
SpiFlashEmulator emu(5);
|
||||||
|
TEST_ESP_OK(nvs_flash_init_custom(NVS_DEFAULT_PART_NAME, 0, 5));
|
||||||
|
nvs_handle handle;
|
||||||
|
TEST_ESP_OK(nvs_open("Test", NVS_READWRITE, &handle));
|
||||||
|
TEST_ESP_OK(nvs_set_blob(handle, "abc", blob, blob_size));
|
||||||
|
TEST_ESP_OK(nvs_erase_key(handle, "abc"));
|
||||||
|
TEST_ESP_ERR(nvs_get_blob(handle, "abc", NULL, &read_size), ESP_ERR_NVS_NOT_FOUND);
|
||||||
|
TEST_ESP_OK(nvs_commit(handle));
|
||||||
|
nvs_close(handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
TEST_CASE("Check that orphaned blobs are erased during init", "[nvs]")
|
TEST_CASE("Check that orphaned blobs are erased during init", "[nvs]")
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user