2017-12-22 05:49:03 -08:00
|
|
|
/**
|
|
|
|
* @file backup_ram.cpp
|
|
|
|
*
|
|
|
|
* @date Dec 19, 2017
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "backup_ram.h"
|
|
|
|
|
|
|
|
uint32_t backupRamLoad(backup_ram_e idx) {
|
2019-04-12 17:52:51 -07:00
|
|
|
#if HAL_USE_RTC
|
2019-07-28 09:33:47 -07:00
|
|
|
switch (idx) {
|
2017-12-22 05:49:03 -08:00
|
|
|
case BACKUP_STEPPER_POS:
|
|
|
|
return RTCD1.rtc->BKP0R & 0xffff;
|
|
|
|
case BACKUP_IGNITION_SWITCH_COUNTER:
|
|
|
|
return (RTCD1.rtc->BKP0R >> 16) & 0xff;
|
2018-01-22 14:47:10 -08:00
|
|
|
case BACKUP_CJ125_CALIBRATION_LAMBDA:
|
|
|
|
return RTCD1.rtc->BKP1R & 0xffff;
|
|
|
|
case BACKUP_CJ125_CALIBRATION_HEATER:
|
|
|
|
return (RTCD1.rtc->BKP1R >> 16) & 0xffff;
|
2019-07-28 09:33:47 -07:00
|
|
|
// it is assembly code which reads this value
|
|
|
|
// case DFU_JUMP_REQUESTED:
|
|
|
|
// return RTCD1.rtc->BKP4R;
|
2017-12-22 05:49:03 -08:00
|
|
|
default:
|
2019-07-28 09:33:47 -07:00
|
|
|
firmwareError(OBD_PCM_Processor_Fault, "Invalid backup ram idx %d", idx);
|
2017-12-22 05:49:03 -08:00
|
|
|
return 0;
|
|
|
|
}
|
2019-07-28 09:33:47 -07:00
|
|
|
#else
|
|
|
|
return 0;
|
|
|
|
#endif /* HAL_USE_RTC */
|
2017-12-22 05:49:03 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
void backupRamSave(backup_ram_e idx, uint32_t value) {
|
2019-04-12 17:52:51 -07:00
|
|
|
#if HAL_USE_RTC
|
2019-07-28 09:33:47 -07:00
|
|
|
switch (idx) {
|
2017-12-22 05:49:03 -08:00
|
|
|
case BACKUP_STEPPER_POS:
|
|
|
|
RTCD1.rtc->BKP0R = (RTCD1.rtc->BKP0R & ~0x0000ffff) | (value & 0xffff);
|
|
|
|
break;
|
|
|
|
case BACKUP_IGNITION_SWITCH_COUNTER:
|
|
|
|
RTCD1.rtc->BKP0R = (RTCD1.rtc->BKP0R & ~0x00ff0000) | ((value & 0xff) << 16);
|
|
|
|
break;
|
2018-01-22 14:47:10 -08:00
|
|
|
case BACKUP_CJ125_CALIBRATION_LAMBDA:
|
|
|
|
RTCD1.rtc->BKP1R = (RTCD1.rtc->BKP1R & ~0x0000ffff) | (value & 0xffff);
|
|
|
|
break;
|
|
|
|
case BACKUP_CJ125_CALIBRATION_HEATER:
|
|
|
|
RTCD1.rtc->BKP1R = (RTCD1.rtc->BKP1R & ~0xffff0000) | ((value & 0xffff) << 16);
|
|
|
|
break;
|
2019-07-28 09:33:47 -07:00
|
|
|
// todo: start using this code
|
|
|
|
case DFU_JUMP_REQUESTED:
|
|
|
|
RTCD1.rtc->BKP4R = value;
|
|
|
|
break;
|
2017-12-22 05:49:03 -08:00
|
|
|
default:
|
2019-07-28 09:33:47 -07:00
|
|
|
firmwareError(OBD_PCM_Processor_Fault, "Invalid backup ram idx %d, value 0x08x", idx, value);
|
2017-12-22 05:49:03 -08:00
|
|
|
break;
|
|
|
|
}
|
2019-07-28 09:33:47 -07:00
|
|
|
#endif /* HAL_USE_RTC */
|
2017-12-22 05:49:03 -08:00
|
|
|
}
|
2020-09-09 05:53:11 -07:00
|
|
|
|
|
|
|
void backupRamFlush(void) {
|
|
|
|
// nothing to do here, in STM32 all data is saved instantaneously
|
|
|
|
}
|
2022-07-07 12:14:31 -07:00
|
|
|
|
|
|
|
// STM32 only has 4k bytes of backup SRAM
|
|
|
|
static_assert(sizeof(BackupSramData) <= 4096);
|
|
|
|
|
|
|
|
extern BackupSramData __backup_sram_addr__;
|
|
|
|
|
|
|
|
BackupSramData* getBackupSram() {
|
|
|
|
return &__backup_sram_addr__;
|
|
|
|
}
|