rusefi/firmware/hw_layer/backup_ram.h

75 lines
1.9 KiB
C
Raw Normal View History

/**
2022-09-07 17:31:04 -07:00
* @file backup_ram.h
* @brief Non-volatile backup-RAM registers support
*
* @date Dec 19, 2017
*/
2020-02-18 05:16:19 -08:00
#pragma once
2019-03-29 06:11:13 -07:00
#include "efi_gpio.h"
#include "error_handling.h"
2024-02-06 11:04:34 -08:00
enum class backup_ram_e {
/**
* IAC Stepper motor position, 16-bit (stored in BKP0R 0..15)
* Used in stepper.cpp
*/
2024-02-06 11:04:34 -08:00
StepperPosition,
/**
* Ignition switch counter, 8-bit (stored in BKP0R 16..23)
* The counter stores the number of times the ignition switch is turned on. Used for prime injection pulse.
* We need a protection against 'fake' ignition switch on and off (i.e. no engine started), to avoid repeated prime pulses.
* So we check and update the ignition switch counter in non-volatile backup-RAM.
* See startPrimeInjectionPulse() in controllers/trigger/main_trigger_callback.cpp
*/
2024-02-06 11:04:34 -08:00
IgnCounter,
2019-07-28 09:33:47 -07:00
2020-09-09 07:20:21 -07:00
/* The number of stored backup variables */
BACKUP_RAM_NUM,
2024-02-06 11:04:34 -08:00
};
2024-02-08 07:14:28 -08:00
#define LAST_BACKUP_RAM_ENUM backup_ram_e::BACKUP_RAM_NUM
// load data from backup-power RTC registers (non-volatile memory)
uint32_t backupRamLoad(backup_ram_e idx);
// use backup-power RTC registers (non-volatile memory) to store the data
void backupRamSave(backup_ram_e idx, uint32_t value);
2020-09-09 07:20:21 -07:00
// make sure that all changes are saved before we shutdown the MCU
void backupRamFlush(void);
// These use very specific values to avoid interpreting random garbage memory as a real value
enum class ErrorCookie : uint32_t {
None = 0,
FirmwareError = 0xcafebabe,
HardFault = 0xdeadbeef,
};
#if EFI_PROD_CODE
struct BackupSramData {
// Error handling/recovery/reporting information
struct {
ErrorCookie Cookie;
critical_msg_t ErrorString;
critical_msg_t hardFile;
int hardLine;
int check;
critical_msg_t rawMsg;
port_extctx FaultCtx;
uint32_t FaultType;
uint32_t FaultAddress;
uint32_t Csfr;
uint32_t BootCount;
uint32_t BootCountCookie;
} Err;
};
BackupSramData* getBackupSram();
#endif // EFI_PROD_CODE