HAL_ChibiOS: support flash storage with 8k sectors
this allows for doubling up sectors to give an effective sector size of 16k, allowing for flash storage with a useful storage size
This commit is contained in:
parent
07d0418cf9
commit
3171b5321a
@ -330,7 +330,11 @@ void Storage::_flash_load(void)
|
|||||||
#ifdef STORAGE_FLASH_PAGE
|
#ifdef STORAGE_FLASH_PAGE
|
||||||
_flash_page = STORAGE_FLASH_PAGE;
|
_flash_page = STORAGE_FLASH_PAGE;
|
||||||
|
|
||||||
|
#if AP_FLASH_STORAGE_DOUBLE_PAGE
|
||||||
|
::printf("Storage: Using flash pages %u to %u\n", _flash_page, _flash_page+3);
|
||||||
|
#else
|
||||||
::printf("Storage: Using flash pages %u and %u\n", _flash_page, _flash_page+1);
|
::printf("Storage: Using flash pages %u and %u\n", _flash_page, _flash_page+1);
|
||||||
|
#endif
|
||||||
|
|
||||||
if (!_flash.init()) {
|
if (!_flash.init()) {
|
||||||
AP_HAL::panic("Unable to init flash storage");
|
AP_HAL::panic("Unable to init flash storage");
|
||||||
@ -359,6 +363,9 @@ bool Storage::_flash_write(uint16_t line)
|
|||||||
bool Storage::_flash_write_data(uint8_t sector, uint32_t offset, const uint8_t *data, uint16_t length)
|
bool Storage::_flash_write_data(uint8_t sector, uint32_t offset, const uint8_t *data, uint16_t length)
|
||||||
{
|
{
|
||||||
#ifdef STORAGE_FLASH_PAGE
|
#ifdef STORAGE_FLASH_PAGE
|
||||||
|
#if AP_FLASH_STORAGE_DOUBLE_PAGE
|
||||||
|
sector *= 2;
|
||||||
|
#endif
|
||||||
size_t base_address = hal.flash->getpageaddr(_flash_page+sector);
|
size_t base_address = hal.flash->getpageaddr(_flash_page+sector);
|
||||||
for (uint8_t i=0; i<STORAGE_FLASH_RETRIES; i++) {
|
for (uint8_t i=0; i<STORAGE_FLASH_RETRIES; i++) {
|
||||||
EXPECT_DELAY_MS(1);
|
EXPECT_DELAY_MS(1);
|
||||||
@ -390,6 +397,9 @@ bool Storage::_flash_write_data(uint8_t sector, uint32_t offset, const uint8_t *
|
|||||||
bool Storage::_flash_read_data(uint8_t sector, uint32_t offset, uint8_t *data, uint16_t length)
|
bool Storage::_flash_read_data(uint8_t sector, uint32_t offset, uint8_t *data, uint16_t length)
|
||||||
{
|
{
|
||||||
#ifdef STORAGE_FLASH_PAGE
|
#ifdef STORAGE_FLASH_PAGE
|
||||||
|
#if AP_FLASH_STORAGE_DOUBLE_PAGE
|
||||||
|
sector *= 2;
|
||||||
|
#endif
|
||||||
size_t base_address = hal.flash->getpageaddr(_flash_page+sector);
|
size_t base_address = hal.flash->getpageaddr(_flash_page+sector);
|
||||||
const uint8_t *b = ((const uint8_t *)base_address)+offset;
|
const uint8_t *b = ((const uint8_t *)base_address)+offset;
|
||||||
memcpy(data, b, length);
|
memcpy(data, b, length);
|
||||||
@ -405,6 +415,9 @@ bool Storage::_flash_read_data(uint8_t sector, uint32_t offset, uint8_t *data, u
|
|||||||
bool Storage::_flash_erase_sector(uint8_t sector)
|
bool Storage::_flash_erase_sector(uint8_t sector)
|
||||||
{
|
{
|
||||||
#ifdef STORAGE_FLASH_PAGE
|
#ifdef STORAGE_FLASH_PAGE
|
||||||
|
#if AP_FLASH_STORAGE_DOUBLE_PAGE
|
||||||
|
sector *= 2;
|
||||||
|
#endif
|
||||||
// erasing a page can take long enough that USB may not initialise properly if it happens
|
// erasing a page can take long enough that USB may not initialise properly if it happens
|
||||||
// while the host is connecting. Only do a flash erase if we have been up for more than 4s
|
// while the host is connecting. Only do a flash erase if we have been up for more than 4s
|
||||||
for (uint8_t i=0; i<STORAGE_FLASH_RETRIES; i++) {
|
for (uint8_t i=0; i<STORAGE_FLASH_RETRIES; i++) {
|
||||||
@ -415,9 +428,15 @@ bool Storage::_flash_erase_sector(uint8_t sector)
|
|||||||
in the main thread
|
in the main thread
|
||||||
*/
|
*/
|
||||||
EXPECT_DELAY_MS(1000);
|
EXPECT_DELAY_MS(1000);
|
||||||
|
#if AP_FLASH_STORAGE_DOUBLE_PAGE
|
||||||
|
if (hal.flash->erasepage(_flash_page+sector) && hal.flash->erasepage(_flash_page+sector+1)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
#else
|
||||||
if (hal.flash->erasepage(_flash_page+sector)) {
|
if (hal.flash->erasepage(_flash_page+sector)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
hal.scheduler->delay(1);
|
hal.scheduler->delay(1);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -47,6 +47,13 @@
|
|||||||
static_assert(CH_STORAGE_SIZE % CH_STORAGE_LINE_SIZE == 0,
|
static_assert(CH_STORAGE_SIZE % CH_STORAGE_LINE_SIZE == 0,
|
||||||
"Storage is not multiple of line size");
|
"Storage is not multiple of line size");
|
||||||
|
|
||||||
|
/*
|
||||||
|
on boards with 8k sector sizes we double up to treat pairs of sectors as one
|
||||||
|
*/
|
||||||
|
#ifndef AP_FLASH_STORAGE_DOUBLE_PAGE
|
||||||
|
#define AP_FLASH_STORAGE_DOUBLE_PAGE 0
|
||||||
|
#endif
|
||||||
|
|
||||||
class ChibiOS::Storage : public AP_HAL::Storage {
|
class ChibiOS::Storage : public AP_HAL::Storage {
|
||||||
public:
|
public:
|
||||||
void init() override {}
|
void init() override {}
|
||||||
@ -86,7 +93,11 @@ private:
|
|||||||
|
|
||||||
#ifdef STORAGE_FLASH_PAGE
|
#ifdef STORAGE_FLASH_PAGE
|
||||||
AP_FlashStorage _flash{_buffer,
|
AP_FlashStorage _flash{_buffer,
|
||||||
|
#if AP_FLASH_STORAGE_DOUBLE_PAGE
|
||||||
|
stm32_flash_getpagesize(STORAGE_FLASH_PAGE)*2,
|
||||||
|
#else
|
||||||
stm32_flash_getpagesize(STORAGE_FLASH_PAGE),
|
stm32_flash_getpagesize(STORAGE_FLASH_PAGE),
|
||||||
|
#endif
|
||||||
FUNCTOR_BIND_MEMBER(&Storage::_flash_write_data, bool, uint8_t, uint32_t, const uint8_t *, uint16_t),
|
FUNCTOR_BIND_MEMBER(&Storage::_flash_write_data, bool, uint8_t, uint32_t, const uint8_t *, uint16_t),
|
||||||
FUNCTOR_BIND_MEMBER(&Storage::_flash_read_data, bool, uint8_t, uint32_t, uint8_t *, uint16_t),
|
FUNCTOR_BIND_MEMBER(&Storage::_flash_read_data, bool, uint8_t, uint32_t, uint8_t *, uint16_t),
|
||||||
FUNCTOR_BIND_MEMBER(&Storage::_flash_erase_sector, bool, uint8_t),
|
FUNCTOR_BIND_MEMBER(&Storage::_flash_erase_sector, bool, uint8_t),
|
||||||
|
Loading…
Reference in New Issue
Block a user