2021-10-26 15:24:14 +03:00
|
|
|
#include <furi-hal-bootloader.h>
|
2021-05-18 12:23:14 +03:00
|
|
|
#include <stm32wbxx_ll_rtc.h>
|
2021-07-28 11:45:42 +03:00
|
|
|
#include <furi.h>
|
2021-05-18 12:23:14 +03:00
|
|
|
|
2021-07-02 16:02:36 +03:00
|
|
|
// Boot request enum
|
|
|
|
#define BOOT_REQUEST_TAINTED 0x00000000
|
|
|
|
#define BOOT_REQUEST_CLEAN 0xDADEDADE
|
2021-05-18 12:23:14 +03:00
|
|
|
#define BOOT_REQUEST_DFU 0xDF00B000
|
|
|
|
|
2021-10-26 15:24:14 +03:00
|
|
|
void furi_hal_bootloader_init() {
|
2021-07-07 00:23:59 +03:00
|
|
|
#ifndef DEBUG
|
2021-07-02 16:02:36 +03:00
|
|
|
LL_RTC_BAK_SetRegister(RTC, LL_RTC_BKP_DR0, BOOT_REQUEST_TAINTED);
|
2021-07-07 00:23:59 +03:00
|
|
|
#endif
|
2021-07-28 11:45:42 +03:00
|
|
|
FURI_LOG_I("FuriHalBoot", "Init OK");
|
2021-07-02 16:02:36 +03:00
|
|
|
}
|
|
|
|
|
2021-10-26 15:24:14 +03:00
|
|
|
void furi_hal_bootloader_set_mode(FuriHalBootloaderMode mode) {
|
|
|
|
if (mode == FuriHalBootloaderModeNormal) {
|
2021-07-02 16:02:36 +03:00
|
|
|
LL_RTC_BAK_SetRegister(RTC, LL_RTC_BKP_DR0, BOOT_REQUEST_CLEAN);
|
2021-10-26 15:24:14 +03:00
|
|
|
} else if (mode == FuriHalBootloaderModeDFU) {
|
2021-05-18 12:23:14 +03:00
|
|
|
LL_RTC_BAK_SetRegister(RTC, LL_RTC_BKP_DR0, BOOT_REQUEST_DFU);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-26 15:24:14 +03:00
|
|
|
void furi_hal_bootloader_set_flags(FuriHalBootloaderFlag flags) {
|
2021-05-18 16:57:39 +03:00
|
|
|
LL_RTC_BAK_SetRegister(RTC, LL_RTC_BKP_DR2, flags);
|
|
|
|
}
|
|
|
|
|
2021-10-26 15:24:14 +03:00
|
|
|
FuriHalBootloaderFlag furi_hal_bootloader_get_flags() {
|
2021-05-18 16:57:39 +03:00
|
|
|
return LL_RTC_BAK_GetRegister(RTC, LL_RTC_BKP_DR2);
|
|
|
|
}
|