Implement cache-based reads
This commit is contained in:
parent
426d2afe28
commit
83a55f65a4
@ -234,7 +234,7 @@ void supervisor_flash_flush(void) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t convert_block_to_flash_addr(uint32_t block) {
|
static uint32_t convert_block_to_flash_addr(uint32_t block) {
|
||||||
if (0 <= block && block < INTERNAL_FLASH_FILESYSTEM_NUM_BLOCKS) {
|
if (0 <= block && block < INTERNAL_FLASH_FILESYSTEM_NUM_BLOCKS) {
|
||||||
// a block in partition 1
|
// a block in partition 1
|
||||||
return INTERNAL_FLASH_FILESYSTEM_START_ADDR + block * FILESYSTEM_BLOCK_SIZE;
|
return INTERNAL_FLASH_FILESYSTEM_START_ADDR + block * FILESYSTEM_BLOCK_SIZE;
|
||||||
@ -244,15 +244,30 @@ static int32_t convert_block_to_flash_addr(uint32_t block) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
mp_uint_t supervisor_flash_read_blocks(uint8_t *dest, uint32_t block, uint32_t num_blocks) {
|
mp_uint_t supervisor_flash_read_blocks(uint8_t *dest, uint32_t block, uint32_t num_blocks) {
|
||||||
// Must write out anything in cache before trying to read.
|
|
||||||
supervisor_flash_flush();
|
|
||||||
|
|
||||||
int32_t src = convert_block_to_flash_addr(block);
|
int32_t src = convert_block_to_flash_addr(block);
|
||||||
if (src == -1) {
|
if (src == -1) {
|
||||||
// bad block number
|
// bad block number
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Determine whether the read is contained within the sector
|
||||||
|
uint32_t sector_size;
|
||||||
|
uint32_t sector_start_addr;
|
||||||
|
flash_get_sector_info(src, §or_start_addr, §or_size);
|
||||||
|
// Count how many blocks are left in the sector
|
||||||
|
uint32_t count = (sector_size - (src - sector_start_addr))/FILESYSTEM_BLOCK_SIZE;
|
||||||
|
count = MIN(num_blocks, count);
|
||||||
|
|
||||||
|
if (count < num_blocks && _cache_flash_addr == sector_start_addr) {
|
||||||
|
// Read is contained in the cache, so just read cache
|
||||||
|
memcpy(dest, (_flash_cache + (src-sector_start_addr)), FILESYSTEM_BLOCK_SIZE*num_blocks);
|
||||||
|
} else {
|
||||||
|
// The read spans multiple sectors or is in another sector
|
||||||
|
// Must write out anything in cache before trying to read.
|
||||||
|
supervisor_flash_flush();
|
||||||
memcpy(dest, (uint8_t*) src, FILESYSTEM_BLOCK_SIZE*num_blocks);
|
memcpy(dest, (uint8_t*) src, FILESYSTEM_BLOCK_SIZE*num_blocks);
|
||||||
|
}
|
||||||
|
|
||||||
return 0; // success
|
return 0; // success
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -271,7 +286,7 @@ mp_uint_t supervisor_flash_write_blocks(const uint8_t *src, uint32_t block_num,
|
|||||||
uint32_t sector_start_addr;
|
uint32_t sector_start_addr;
|
||||||
flash_get_sector_info(dest, §or_start_addr, §or_size);
|
flash_get_sector_info(dest, §or_start_addr, §or_size);
|
||||||
|
|
||||||
// Fail for any sector outside the 16k ones for now
|
// Fail for any sector outside what's supported by the cache
|
||||||
if (sector_size > sizeof(_flash_cache)) {
|
if (sector_size > sizeof(_flash_cache)) {
|
||||||
reset_into_safe_mode(FLASH_WRITE_FAIL);
|
reset_into_safe_mode(FLASH_WRITE_FAIL);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user