Merge pull request #9445 from davidsaada/david_nvstore_fix_area_calc

NVStore: fix area calculation function
pull/9021/head
Cruz Monrreal 2019-01-31 10:20:44 -06:00 committed by GitHub
commit 66792b493e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 26 additions and 41 deletions

View File

@ -109,12 +109,12 @@ static void nvstore_basic_functionality_test()
TEST_SKIP_UNLESS_MESSAGE(max_possible_keys >= max_possible_keys_threshold, TEST_SKIP_UNLESS_MESSAGE(max_possible_keys >= max_possible_keys_threshold,
"Max possible keys below threshold. Test skipped."); "Max possible keys below threshold. Test skipped.");
nvstore.set_max_keys(max_test_keys);
TEST_ASSERT_EQUAL(max_test_keys, nvstore.get_max_keys());
result = nvstore.reset(); result = nvstore.reset();
TEST_ASSERT_EQUAL(NVSTORE_SUCCESS, result); TEST_ASSERT_EQUAL(NVSTORE_SUCCESS, result);
nvstore.set_max_keys(max_test_keys);
TEST_ASSERT_EQUAL(max_test_keys, nvstore.get_max_keys());
printf("Max keys %d (out of %d possible ones)\n", nvstore.get_max_keys(), max_possible_keys); printf("Max keys %d (out of %d possible ones)\n", nvstore.get_max_keys(), max_possible_keys);
result = nvstore.set(5, 18, nvstore_testing_buf_set); result = nvstore.set(5, 18, nvstore_testing_buf_set);
@ -503,16 +503,12 @@ static void nvstore_multi_thread_test()
TEST_ASSERT_EQUAL(NVSTORE_SUCCESS, ret); TEST_ASSERT_EQUAL(NVSTORE_SUCCESS, ret);
} }
dummy = new (std::nothrow) char[thr_test_num_threads * thr_test_stack_size];
delete[] dummy;
if (!dummy) {
goto mem_fail;
}
for (i = 0; i < thr_test_num_threads; i++) { for (i = 0; i < thr_test_num_threads; i++) {
threads[i] = new (std::nothrow) rtos::Thread((osPriority_t)((int)osPriorityBelowNormal - thr_test_num_threads + i), threads[i] = new (std::nothrow) rtos::Thread((osPriority_t)((int)osPriorityBelowNormal - thr_test_num_threads + i),
thr_test_stack_size); thr_test_stack_size);
if (!threads[i]) { dummy = new (std::nothrow) char[thr_test_stack_size];
delete[] dummy;
if (!threads[i] || !dummy) {
goto mem_fail; goto mem_fail;
} }
threads[i]->start(mbed::callback(thread_test_worker)); threads[i]->start(mbed::callback(thread_test_worker));

View File

@ -244,32 +244,29 @@ int NVStore::flash_erase_area(uint8_t area)
void NVStore::calc_validate_area_params() void NVStore::calc_validate_area_params()
{ {
int num_sectors = 0; size_t flash_start_addr = _flash->get_flash_start();
size_t flash_addr = _flash->get_flash_start();
size_t flash_size = _flash->get_flash_size(); size_t flash_size = _flash->get_flash_size();
size_t flash_addr;
size_t sector_size; size_t sector_size;
int max_sectors = flash_size / _flash->get_sector_size(flash_addr) + 1;
size_t *sector_map = new size_t[max_sectors];
int area = 0; int area = 0;
size_t left_size = flash_size; size_t left_size = flash_size;
memcpy(_flash_area_params, initial_area_params, sizeof(_flash_area_params)); memcpy(_flash_area_params, initial_area_params, sizeof(_flash_area_params));
int user_config = (_flash_area_params[0].size != 0); bool user_config = (_flash_area_params[0].size != 0);
int in_area = 0; bool in_area = false;
size_t area_size = 0; size_t area_size = 0;
if (user_config) {
flash_addr = flash_start_addr;
while (left_size) { while (left_size) {
sector_size = _flash->get_sector_size(flash_addr); sector_size = _flash->get_sector_size(flash_addr);
sector_map[num_sectors++] = flash_addr;
if (user_config) {
// User configuration - here we validate it // User configuration - here we validate it
// Check that address is on a sector boundary, that size covers complete sector sizes, // Check that address is on a sector boundary, that size covers complete sector sizes,
// and that areas don't overlap. // and that areas don't overlap.
if (_flash_area_params[area].address == flash_addr) { if (_flash_area_params[area].address == flash_addr) {
in_area = 1; in_area = true;
} }
if (in_area) { if (in_area) {
area_size += sector_size; area_size += sector_size;
@ -278,18 +275,13 @@ void NVStore::calc_validate_area_params()
if (area == NVSTORE_NUM_AREAS) { if (area == NVSTORE_NUM_AREAS) {
break; break;
} }
in_area = 0; in_area = false;
area_size = 0; area_size = 0;
} }
} }
}
flash_addr += sector_size; flash_addr += sector_size;
left_size -= sector_size; left_size -= sector_size;
} }
sector_map[num_sectors] = flash_addr;
if (user_config) {
// Valid areas were counted. Assert if not the expected number. // Valid areas were counted. Assert if not the expected number.
MBED_ASSERT(area == NVSTORE_NUM_AREAS); MBED_ASSERT(area == NVSTORE_NUM_AREAS);
} else { } else {
@ -297,23 +289,20 @@ void NVStore::calc_validate_area_params()
// Take last two sectors by default. If their sizes aren't big enough, take // Take last two sectors by default. If their sizes aren't big enough, take
// a few consecutive ones. // a few consecutive ones.
area = 1; area = 1;
_flash_area_params[area].size = 0; flash_addr = flash_start_addr + flash_size;
int i; _flash_area_params[0].size = 0;
for (i = num_sectors - 1; i >= 0; i--) { _flash_area_params[1].size = 0;
sector_size = sector_map[i + 1] - sector_map[i]; while (area >= 0) {
MBED_ASSERT(flash_addr > flash_start_addr);
sector_size = _flash->get_sector_size(flash_addr - 1);
flash_addr -= sector_size;
_flash_area_params[area].size += sector_size; _flash_area_params[area].size += sector_size;
if (_flash_area_params[area].size >= min_area_size) { if (_flash_area_params[area].size >= min_area_size) {
_flash_area_params[area].address = sector_map[i]; _flash_area_params[area].address = flash_addr;
area--; area--;
if (area < 0) {
break;
}
_flash_area_params[area].size = 0;
} }
} }
} }
delete[] sector_map;
} }