|
|
@@ -63,11 +63,13 @@ static void wait_dcdc_good(void) {
|
|
|
static int pre_deepsleep(void){
|
|
|
LED_ALL_ON(0);
|
|
|
systick_close();
|
|
|
+ shark_rtc_set_backup(0xF0);
|
|
|
shark_uart_deinit(SHARK_UART0);
|
|
|
#if (CONFIG_BOARD_TYPE==SHARK_BOARD_SP700)
|
|
|
shark_uart_deinit(SHARK_UART1);
|
|
|
#endif
|
|
|
wdog_reload();
|
|
|
+ shark_rtc_set_backup(0xF1);
|
|
|
ml5238_power_save(1); //call, before spi0_deinit
|
|
|
cs1180_adc_shutdown();
|
|
|
AT24CXX_DeInit();
|
|
|
@@ -76,6 +78,7 @@ static int pre_deepsleep(void){
|
|
|
AUX_VOL_OPEN(0);//we should close small power, before dcdc close
|
|
|
delay_us(1000);
|
|
|
}
|
|
|
+ shark_rtc_set_backup(0xF2);
|
|
|
wdog_reload();
|
|
|
io_state()->aux_lock_detect = 0;
|
|
|
DCDC_VOL_OPEN(0);
|
|
|
@@ -83,39 +86,53 @@ static int pre_deepsleep(void){
|
|
|
AUX_VOL_OPEN(1);
|
|
|
delay_us(5000); //give 5s to detect if the small current is short
|
|
|
if (io_state()->aux_lock_detect){
|
|
|
+ shark_rtc_set_backup(0xF3);
|
|
|
post_deepsleep();
|
|
|
return -1;
|
|
|
}
|
|
|
- wdog_set_timeout(WDOG_TIME_FOR_SLEEP);
|
|
|
+ shark_rtc_set_backup(0xF4);
|
|
|
+ if (wdog_set_timeout(WDOG_TIME_FOR_SLEEP) < 0){
|
|
|
+ post_deepsleep();
|
|
|
+ return -1;
|
|
|
+ }
|
|
|
+ shark_rtc_set_backup(0xF5);
|
|
|
wait_for_enter_dsleep();
|
|
|
+ shark_rtc_set_backup(0xF6);
|
|
|
if (_is_wakeup_source()) {
|
|
|
_wakeup_source = 0;
|
|
|
post_deepsleep();
|
|
|
return -1;
|
|
|
}
|
|
|
+ shark_rtc_set_backup(0xF7);
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
static void post_deepsleep(void){
|
|
|
+ shark_rtc_set_backup(0xF8);
|
|
|
DCDC_VOL_OPEN(1);
|
|
|
AUX_VOL_OPEN(0);//must close small power, cs1180 cali need small power close
|
|
|
wait_dcdc_good();
|
|
|
+ shark_rtc_set_backup(0xF9);
|
|
|
SystemInit();
|
|
|
system_clock_config();
|
|
|
SystemCoreClockUpdate();
|
|
|
ml5238_power_save(0);
|
|
|
gd32_adc_init();
|
|
|
cs1180_adc_init();
|
|
|
+ shark_rtc_set_backup(0xFA);
|
|
|
shark_uart_init(SHARK_UART0);
|
|
|
#if (CONFIG_BOARD_TYPE==SHARK_BOARD_SP700)
|
|
|
shark_uart_init(SHARK_UART1);
|
|
|
#endif
|
|
|
AT24CXX_Init();
|
|
|
+ shark_rtc_set_backup(0xFB);
|
|
|
wdog_set_timeout(4);
|
|
|
+ shark_rtc_set_backup(0xFC);
|
|
|
current_calibrate();
|
|
|
wdog_reload();
|
|
|
systick_open();
|
|
|
AUX_VOL_OPEN(1);
|
|
|
+ shark_rtc_set_backup(0xFD);
|
|
|
}
|
|
|
|
|
|
void mcu_enter_deepsleep(void){
|
|
|
@@ -129,9 +146,11 @@ void mcu_enter_deepsleep(void){
|
|
|
post_deepsleep();
|
|
|
return;
|
|
|
}
|
|
|
+ shark_rtc_set_backup(0xFF0);
|
|
|
do {
|
|
|
u32 start_time = shark_rtc_get_second();
|
|
|
pmu_to_deepsleepmode(PMU_LDO_LOWPOWER, WFI_CMD);
|
|
|
+ shark_rtc_set_backup(0xFF1);
|
|
|
u32 end_time = shark_rtc_get_second();
|
|
|
if (end_time >= start_time) {
|
|
|
_sleep_second_time_now += end_time - start_time;
|
|
|
@@ -140,17 +159,22 @@ void mcu_enter_deepsleep(void){
|
|
|
}
|
|
|
if (_wakeup_source & WAKEUP_SOURCE_RTC) {
|
|
|
wdog_reload();
|
|
|
+ shark_rtc_set_backup(0xFF2);
|
|
|
while (shark_rtc_start_alarm(RTC_ALARM_FOR_SLEEP) < 0){
|
|
|
wdog_reload();
|
|
|
+ shark_rtc_set_backup(0xFF3);
|
|
|
if (_is_wakeup_source() || (_sleep_second_time_now >= (60))){
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
|
+ shark_rtc_set_backup(0xFF4);
|
|
|
wait_for_enter_dsleep();
|
|
|
+ shark_rtc_set_backup(0xFF5);
|
|
|
}
|
|
|
}while(!_is_wakeup_source() && (_sleep_second_time_now < (60)));
|
|
|
_sleep_second_time += _sleep_second_time_now;
|
|
|
disable_wakeup_irq();
|
|
|
+ shark_rtc_set_backup(0xFF6);
|
|
|
post_deepsleep();
|
|
|
}
|
|
|
|