mirror of
https://github.com/betaflight/betaflight.git
synced 2025-07-17 13:25:30 +03:00
Dynamically determine flash size on STM32F10X_MD
This commit is contained in:
parent
6696031520
commit
cbb17dae59
3 changed files with 24 additions and 6 deletions
|
@ -73,7 +73,9 @@ void mixerUseConfigs(servoParam_t *servoConfToUse, flight3DConfig_t *flight3DCon
|
||||||
#define FLASH_PAGE_SIZE ((uint16_t)0x400)
|
#define FLASH_PAGE_SIZE ((uint16_t)0x400)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define FLASH_WRITE_ADDR (0x08000000 + (uint32_t)((FLASH_PAGE_SIZE * FLASH_PAGE_COUNT) - FLASH_TO_RESERVE_FOR_CONFIG)) // use the last flash pages for storage
master_t masterConfig; // master config struct with data independent from profiles
|
// use the last flash pages for storage
|
||||||
|
static uint32_t flashWriteAddress = (0x08000000 + (uint32_t)((FLASH_PAGE_SIZE * FLASH_PAGE_COUNT) - FLASH_TO_RESERVE_FOR_CONFIG));
|
||||||
|
master_t masterConfig; // master config struct with data independent from profiles
|
||||||
profile_t currentProfile; // profile config struct
|
profile_t currentProfile; // profile config struct
|
||||||
|
|
||||||
static const uint8_t EEPROM_CONF_VERSION = 72;
|
static const uint8_t EEPROM_CONF_VERSION = 72;
|
||||||
|
@ -341,7 +343,7 @@ static uint8_t calculateChecksum(const uint8_t *data, uint32_t length)
|
||||||
|
|
||||||
static bool isEEPROMContentValid(void)
|
static bool isEEPROMContentValid(void)
|
||||||
{
|
{
|
||||||
const master_t *temp = (const master_t *) FLASH_WRITE_ADDR;
|
const master_t *temp = (const master_t *) flashWriteAddress;
|
||||||
uint8_t checksum = 0;
|
uint8_t checksum = 0;
|
||||||
|
|
||||||
// check version number
|
// check version number
|
||||||
|
@ -462,6 +464,19 @@ void validateAndFixConfig(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void initEEPROM(void)
|
||||||
|
{
|
||||||
|
#if defined(STM32F103_MD)
|
||||||
|
|
||||||
|
#define FLASH_SIZE_REGISTER 0x1FFFF7E0
|
||||||
|
|
||||||
|
const uint32_t flashSize = *((uint32_t *)FLASH_SIZE_REGISTER) & 0xFFFF;
|
||||||
|
|
||||||
|
// calculate write address based on contents of Flash size register. Use last 2 kbytes for storage
|
||||||
|
flashWriteAddress = 0x08000000 + (FLASH_PAGE_SIZE * (flashSize - 2));
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
void readEEPROM(void)
|
void readEEPROM(void)
|
||||||
{
|
{
|
||||||
// Sanity check
|
// Sanity check
|
||||||
|
@ -469,7 +484,7 @@ void readEEPROM(void)
|
||||||
failureMode(10);
|
failureMode(10);
|
||||||
|
|
||||||
// Read flash
|
// Read flash
|
||||||
memcpy(&masterConfig, (char *) FLASH_WRITE_ADDR, sizeof(master_t));
|
memcpy(&masterConfig, (char *) flashWriteAddress, sizeof(master_t));
|
||||||
// Copy current profile
|
// Copy current profile
|
||||||
if (masterConfig.current_profile_index > 2) // sanity check
|
if (masterConfig.current_profile_index > 2) // sanity check
|
||||||
masterConfig.current_profile_index = 0;
|
masterConfig.current_profile_index = 0;
|
||||||
|
@ -516,18 +531,18 @@ void writeEEPROM(void)
|
||||||
#ifdef STM32F3DISCOVERY
|
#ifdef STM32F3DISCOVERY
|
||||||
FLASH_ClearFlag(FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPERR);
|
FLASH_ClearFlag(FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPERR);
|
||||||
#endif
|
#endif
|
||||||
#ifdef STM32F10X_MD
|
#ifdef STM32F103_MD
|
||||||
FLASH_ClearFlag(FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPRTERR);
|
FLASH_ClearFlag(FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPRTERR);
|
||||||
#endif
|
#endif
|
||||||
for (wordOffset = 0; wordOffset < sizeof(master_t); wordOffset += 4) {
|
for (wordOffset = 0; wordOffset < sizeof(master_t); wordOffset += 4) {
|
||||||
if (wordOffset % FLASH_PAGE_SIZE == 0) {
|
if (wordOffset % FLASH_PAGE_SIZE == 0) {
|
||||||
status = FLASH_ErasePage(FLASH_WRITE_ADDR + wordOffset);
|
status = FLASH_ErasePage(flashWriteAddress + wordOffset);
|
||||||
if (status != FLASH_COMPLETE) {
|
if (status != FLASH_COMPLETE) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
status = FLASH_ProgramWord(FLASH_WRITE_ADDR + wordOffset,
|
status = FLASH_ProgramWord(flashWriteAddress + wordOffset,
|
||||||
*(uint32_t *) ((char *) &masterConfig + wordOffset));
|
*(uint32_t *) ((char *) &masterConfig + wordOffset));
|
||||||
if (status != FLASH_COMPLETE) {
|
if (status != FLASH_COMPLETE) {
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -45,6 +45,7 @@ uint32_t featureMask(void);
|
||||||
|
|
||||||
void copyCurrentProfileToProfileSlot(uint8_t profileSlotIndex);
|
void copyCurrentProfileToProfileSlot(uint8_t profileSlotIndex);
|
||||||
|
|
||||||
|
void initEEPROM(void);
|
||||||
void resetEEPROM(void);
|
void resetEEPROM(void);
|
||||||
void readEEPROM(void);
|
void readEEPROM(void);
|
||||||
void readEEPROMAndNotify(void);
|
void readEEPROMAndNotify(void);
|
||||||
|
|
|
@ -122,6 +122,8 @@ void init(void)
|
||||||
|
|
||||||
initPrintfSupport();
|
initPrintfSupport();
|
||||||
|
|
||||||
|
initEEPROM();
|
||||||
|
|
||||||
ensureEEPROMContainsValidData();
|
ensureEEPROMContainsValidData();
|
||||||
readEEPROM();
|
readEEPROM();
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue