per-board pre-low-power handlers (#3752)
* per-board pre-low-power handlers * per-chip standby options * default implementation
This commit is contained in:
parent
c8f87a88c5
commit
4ee76aadc2
|
@ -216,3 +216,26 @@ void setBoardDefaultConfiguration(void) {
|
||||||
engineConfiguration->triggerSimulatorPins[1] = GPIOG_2;
|
engineConfiguration->triggerSimulatorPins[1] = GPIOG_2;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void boardPrepareForStop() {
|
||||||
|
// enable EXTI on PD0 - CAN RX pin
|
||||||
|
palSetPadMode(GPIOD, 0, PAL_MODE_INPUT);
|
||||||
|
palEnableLineEvent(PAL_LINE(GPIOD, 0), PAL_EVENT_MODE_RISING_EDGE);
|
||||||
|
}
|
||||||
|
|
||||||
|
void boardPrepareForStandby() {
|
||||||
|
// We're out of luck trying to wake from standby on an F4, since it can only wake from PA0
|
||||||
|
|
||||||
|
#ifdef STM32F7XX
|
||||||
|
PWR->CSR2 |= PWR_CSR2_EWUP1; //EWUP1: Enable Wakeup pin for PA0
|
||||||
|
PWR->CR2 |= PWR_CR2_CWUPF1; //Clear Wakeup Pin flag for PA0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef STM32H7XX
|
||||||
|
// Wake on wakeup pin 0 - PA0
|
||||||
|
PWR->WKUPEPR = PWR_WKUPEPR_WKUPEN1;
|
||||||
|
|
||||||
|
// clear all possible wakeup bits
|
||||||
|
PWR->WKUPCR = 0xFFFFFFFF;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
|
@ -67,4 +67,10 @@ typedef enum {
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
void stm32_stop();
|
void stm32_stop();
|
||||||
void stm32_standby();
|
void stm32_standby();
|
||||||
|
|
||||||
|
// Called just before the MCU is put in stop mode
|
||||||
|
void boardPrepareForStop();
|
||||||
|
|
||||||
|
// Called just before the MCU is put in standby mode
|
||||||
|
void boardPrepareForStandby();
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -796,4 +796,12 @@ CANDriver* detectCanDevice(brain_pin_e pinRx, brain_pin_e pinTx) {
|
||||||
|
|
||||||
#endif /* EFI_CAN_SUPPORT */
|
#endif /* EFI_CAN_SUPPORT */
|
||||||
|
|
||||||
|
// Stubs for per-board low power helpers
|
||||||
|
__attribute__((weak)) void boardPrepareForStop() {
|
||||||
|
// Default implementation - wake up on PA0 - boards should override this
|
||||||
|
palEnableLineEvent(PAL_LINE(GPIOA, 0), PAL_EVENT_MODE_RISING_EDGE);
|
||||||
|
}
|
||||||
|
|
||||||
|
__attribute__((weak)) void boardPrepareForStandby() { }
|
||||||
|
|
||||||
#endif // EFI_PROD_CODE
|
#endif // EFI_PROD_CODE
|
||||||
|
|
|
@ -178,13 +178,15 @@ void sys_dual_bank(void) {
|
||||||
void stm32_stop() {
|
void stm32_stop() {
|
||||||
SysTick->CTRL = 0;
|
SysTick->CTRL = 0;
|
||||||
SCB->SCR |= SCB_SCR_SLEEPDEEP_Msk;
|
SCB->SCR |= SCB_SCR_SLEEPDEEP_Msk;
|
||||||
|
|
||||||
|
// Turn off the LEDs, those use some power
|
||||||
enginePins.errorLedPin.setValue(0);
|
enginePins.errorLedPin.setValue(0);
|
||||||
enginePins.runningLedPin.setValue(0);
|
enginePins.runningLedPin.setValue(0);
|
||||||
enginePins.communicationLedPin.setValue(0);
|
enginePins.communicationLedPin.setValue(0);
|
||||||
enginePins.warningLedPin.setValue(0);
|
enginePins.warningLedPin.setValue(0);
|
||||||
|
|
||||||
|
// Do anything the board wants to prepare for stop mode - enabling wakeup sources!
|
||||||
palEnableLineEvent(PAL_LINE(GPIOA, 0), PAL_EVENT_MODE_RISING_EDGE);
|
boardPrepareForStop();
|
||||||
|
|
||||||
PWR->CSR1 |= PWR_CSR1_WUIF;
|
PWR->CSR1 |= PWR_CSR1_WUIF;
|
||||||
PWR->CR1 &= ~PWR_CR1_PDDS; // cleared PDDS means stop mode (not standby)
|
PWR->CR1 &= ~PWR_CR1_PDDS; // cleared PDDS means stop mode (not standby)
|
||||||
|
@ -205,9 +207,11 @@ void stm32_standby() {
|
||||||
SysTick->CTRL = 0;
|
SysTick->CTRL = 0;
|
||||||
SCB->SCR |= SCB_SCR_SLEEPDEEP_Msk;
|
SCB->SCR |= SCB_SCR_SLEEPDEEP_Msk;
|
||||||
PWR->CR1 |= PWR_CR1_PDDS; // PDDS = use standby mode (not stop mode)
|
PWR->CR1 |= PWR_CR1_PDDS; // PDDS = use standby mode (not stop mode)
|
||||||
PWR->CSR2 |= PWR_CSR2_EWUP1; //EWUP1: Enable Wakeup pin for PA0
|
PWR->CR1 |= PWR_CR1_CSBF; // Clear standby flag
|
||||||
PWR->CR2 |= PWR_CR2_CWUPF1; //Clear Wakeup Pin flag for PA0
|
|
||||||
PWR->CR1 |= PWR_CR1_CSBF; //Clear standby flag
|
// Do anything the board wants to prepare for standby mode - enabling wakeup sources!
|
||||||
|
boardPrepareForStandby();
|
||||||
|
|
||||||
__disable_irq();
|
__disable_irq();
|
||||||
__WFI();
|
__WFI();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue