Cleanup save flash code, more simple savearea settings

pull/4/head
DiSlord 5 years ago committed by erikkaashoek
parent 1167bdec16
commit b7be1adf4b

@ -75,16 +75,11 @@ checksum(const void *start, size_t len)
return value; return value;
} }
#define FLASH_PAGESIZE 0x800
const uint32_t save_config_area = SAVE_CONFIG_ADDR;
int int
config_save(void) config_save(void)
{ {
uint16_t *src = (uint16_t*)&config; uint16_t *src = (uint16_t*)&config;
uint16_t *dst = (uint16_t*)save_config_area; uint16_t *dst = (uint16_t*)SAVE_CONFIG_ADDR;
int count = sizeof(config_t) / sizeof(uint16_t); int count = sizeof(config_t) / sizeof(uint16_t);
config.magic = CONFIG_MAGIC; config.magic = CONFIG_MAGIC;
@ -107,7 +102,7 @@ config_save(void)
int int
config_recall(void) config_recall(void)
{ {
const config_t *src = (const config_t*)save_config_area; const config_t *src = (const config_t*)SAVE_CONFIG_ADDR;
void *dst = &config; void *dst = &config;
if (src->magic != CONFIG_MAGIC) if (src->magic != CONFIG_MAGIC)
@ -120,31 +115,19 @@ config_recall(void)
return 0; return 0;
} }
const uint32_t saveareas[SAVEAREA_MAX] =
{ //int16_t lastsaveid = 0;
SAVE_PROP_CONFIG_0_ADDR,
SAVE_PROP_CONFIG_1_ADDR,
SAVE_PROP_CONFIG_2_ADDR,
SAVE_PROP_CONFIG_3_ADDR,
SAVE_PROP_CONFIG_4_ADDR,
SAVE_PROP_CONFIG_5_ADDR,
SAVE_PROP_CONFIG_6_ADDR,
SAVE_PROP_CONFIG_7_ADDR,
SAVE_PROP_CONFIG_8_ADDR,
};
int16_t lastsaveid = 0;
int int
caldata_save(int id) caldata_save(uint16_t id)
{ {
if (id >= SAVEAREA_MAX)
return -1;
uint16_t *src = (uint16_t*)&setting; uint16_t *src = (uint16_t*)&setting;
uint16_t *dst; uint16_t *dst;
int count = sizeof(setting_t) / sizeof(uint16_t); int count = sizeof(setting_t) / sizeof(uint16_t);
if (id < 0 || id >= SAVEAREA_MAX) dst = (uint16_t*)(SAVE_PROP_CONFIG_ADDR + id * SAVE_PROP_CONFIG_SIZE);
return -1;
dst = (uint16_t*)saveareas[id];
setting.magic = CONFIG_MAGIC; setting.magic = CONFIG_MAGIC;
setting.checksum = checksum( setting.checksum = checksum(
@ -160,13 +143,12 @@ caldata_save(int id)
p += FLASH_PAGESIZE; p += FLASH_PAGESIZE;
} }
/* write to flash */ /* write settings to flash */
while (count-- > 0) { while (count-- > 0) {
flash_program_half_word((uint32_t)dst, *src++); flash_program_half_word((uint32_t)dst, *src++);
dst++; dst++;
} }
// Flash stored trace to flash
// Flash stored trace
count = sizeof(stored_t) / sizeof(uint16_t); count = sizeof(stored_t) / sizeof(uint16_t);
src = (uint16_t*)&stored_t[0]; src = (uint16_t*)&stored_t[0];
while (count-- > 0) { while (count-- > 0) {
@ -176,22 +158,22 @@ caldata_save(int id)
/* after saving data, make active configuration points to flash */ /* after saving data, make active configuration points to flash */
// active_props = (setting_t*)saveareas[id]; // active_props = (setting_t*)saveareas[id];
lastsaveid = id; // lastsaveid = id;
return 0; return 0;
} }
int int
caldata_recall(int id) caldata_recall(uint16_t id)
{ {
setting_t *src; setting_t *src;
void *dst = &setting; void *dst = &setting;
if (id < 0 || id >= SAVEAREA_MAX) if (id >= SAVEAREA_MAX)
return -1; return -1;
// point to saved area on the flash memory // point to saved area on the flash memory
src = (setting_t*)saveareas[id]; src = (setting_t*)(SAVE_PROP_CONFIG_ADDR + id * SAVE_PROP_CONFIG_SIZE);
if (src->magic != CONFIG_MAGIC) if (src->magic != CONFIG_MAGIC)
return -1; return -1;
@ -200,7 +182,7 @@ caldata_recall(int id)
/* active configuration points to save data on flash memory */ /* active configuration points to save data on flash memory */
// active_props = src; // active_props = src;
lastsaveid = id; // lastsaveid = id;
/* duplicated saved data onto sram to be able to modify marker/trace */ /* duplicated saved data onto sram to be able to modify marker/trace */
memcpy(dst, src, sizeof(setting_t)); memcpy(dst, src, sizeof(setting_t));
@ -229,16 +211,14 @@ caldata_ref(int id)
} }
#endif #endif
const uint32_t save_config_prop_area_size = SAVE_CONFIG_AREA_SIZE;
void void
clear_all_config_prop_data(void) clear_all_config_prop_data(void)
{ {
flash_unlock(); flash_unlock();
/* erase flash pages */ /* erase flash pages */
void *p = (void*)save_config_area; void *p = (void*)SAVE_CONFIG_ADDR;
void *tail = p + save_config_prop_area_size; void *tail = p + SAVE_CONFIG_AREA_SIZE;
while (p < tail) { while (p < tail) {
flash_erase_page((uint32_t)p); flash_erase_page((uint32_t)p);
p += FLASH_PAGESIZE; p += FLASH_PAGESIZE;

@ -705,21 +705,20 @@ extern const float unit_scale_value[];
extern const char * const unit_scale_text[]; extern const char * const unit_scale_text[];
#if 1 #if 1
// Flash save area - flash7 : org = 0x0801B000, len = 20k in *.ld file
// 2k - for config save
// 9 * 2k for setting_t + stored trace
#define SAVEAREA_MAX 9 #define SAVEAREA_MAX 9
// config save area // STM32 minimum page size for write
#define FLASH_PAGESIZE 0x800
// config save area (flash7 addr)
#define SAVE_CONFIG_ADDR 0x0801B000 #define SAVE_CONFIG_ADDR 0x0801B000
// setting_t save area #define SAVE_CONFIG_SIZE 0x00000800
#define SAVE_PROP_CONFIG_0_ADDR 0x0801B800 // setting_t save area (save area + config size)
#define SAVE_PROP_CONFIG_1_ADDR 0x0801C000 #define SAVE_PROP_CONFIG_ADDR (SAVE_CONFIG_ADDR + SAVE_CONFIG_SIZE)
#define SAVE_PROP_CONFIG_2_ADDR 0x0801C800 #define SAVE_PROP_CONFIG_SIZE 0x00000800
#define SAVE_PROP_CONFIG_3_ADDR 0x0801D000 // Should include all save slots
#define SAVE_PROP_CONFIG_4_ADDR 0x0801D800 #define SAVE_CONFIG_AREA_SIZE (SAVE_CONFIG_SIZE + SAVEAREA_MAX * SAVE_PROP_CONFIG_SIZE)
#define SAVE_PROP_CONFIG_5_ADDR 0x0801E000
#define SAVE_PROP_CONFIG_6_ADDR 0x0801E800
#define SAVE_PROP_CONFIG_7_ADDR 0x0801F000
#define SAVE_PROP_CONFIG_8_ADDR 0x0801F800
#define SAVE_CONFIG_AREA_SIZE (0x0801F800 - SAVE_CONFIG_ADDR) // Should include all save slots
#else #else
#define SAVEAREA_MAX 4 #define SAVEAREA_MAX 4
@ -804,8 +803,8 @@ extern int16_t lastsaveid;
#define FREQ_IS_STARTSTOP() (!(setting.freq_mode&FREQ_MODE_CENTER_SPAN)) #define FREQ_IS_STARTSTOP() (!(setting.freq_mode&FREQ_MODE_CENTER_SPAN))
#define FREQ_IS_CENTERSPAN() (setting.freq_mode&FREQ_MODE_CENTER_SPAN) #define FREQ_IS_CENTERSPAN() (setting.freq_mode&FREQ_MODE_CENTER_SPAN)
#define FREQ_IS_CW() (setting.frequency0 == setting.frequency1) #define FREQ_IS_CW() (setting.frequency0 == setting.frequency1)
int caldata_recall(int id); int caldata_recall(uint16_t id);
int caldata_save(int id); int caldata_save(uint16_t id);
//const properties_t *caldata_ref(int id); //const properties_t *caldata_ref(int id);
int config_save(void); int config_save(void);
int config_recall(void); int config_recall(void);

Loading…
Cancel
Save

Powered by TurnKey Linux.