On Sat, Apr 20, 2024 at 12:03 AM Marek Vasut <[email protected]> wrote: > > Make sure the OS would not get any spurious IWDG pretimeout IRQ > right after the system wakes up. This may happen in case the SoC > got woken up by another source than the IWDG pretimeout and the > pretimeout IRQ arrived immediately afterward, but too late to be > handled by the suspend main loop. In case either of the IWDG is > enabled, ping it first and then return to the OS. > > Signed-off-by: Marek Vasut <[email protected]> > --- > Cc: Igor Opaniuk <[email protected]> > Cc: Patrice Chotard <[email protected]> > Cc: Patrick Delaunay <[email protected]> > Cc: Simon Glass <[email protected]> > Cc: Tom Rini <[email protected]> > Cc: [email protected] > Cc: [email protected] > --- > arch/arm/mach-stm32mp/stm32mp1/psci.c | 21 +++++++++++++++++++++ > 1 file changed, 21 insertions(+) > > diff --git a/arch/arm/mach-stm32mp/stm32mp1/psci.c > b/arch/arm/mach-stm32mp/stm32mp1/psci.c > index 4f2379df45f..e99103910d9 100644 > --- a/arch/arm/mach-stm32mp/stm32mp1/psci.c > +++ b/arch/arm/mach-stm32mp/stm32mp1/psci.c > @@ -808,6 +808,27 @@ void __secure psci_system_suspend(u32 __always_unused > function_id, > writel(SYSCFG_CMPENR_MPUEN, STM32_SYSCFG_BASE + SYSCFG_CMPENSETR); > clrbits_le32(STM32_SYSCFG_BASE + SYSCFG_CMPCR, SYSCFG_CMPCR_SW_CTRL); > > + /* > + * Make sure the OS would not get any spurious IWDG pretimeout IRQ > + * right after the system wakes up. This may happen in case the SoC > + * got woken up by another source than the IWDG pretimeout and the > + * pretimeout IRQ arrived immediately afterward, but too late to be > + * handled by the main loop above. In case either of the IWDG is > + * enabled, ping it first and then return to the OS. > + */ > + > + /* Ping IWDG1 and ACK pretimer IRQ */ > + if (gic_enabled[4] & BIT(22)) { > + writel(IWDG_KR_RELOAD_KEY, STM32_IWDG1_BASE + IWDG_KR); > + writel(IWDG_EWCR_EWIC, STM32_IWDG1_BASE + IWDG_EWCR); > + } > + > + /* Ping IWDG2 and ACK pretimer IRQ */ > + if (gic_enabled[4] & BIT(23)) { > + writel(IWDG_KR_RELOAD_KEY, STM32_IWDG2_BASE + IWDG_KR); > + writel(IWDG_EWCR_EWIC, STM32_IWDG2_BASE + IWDG_EWCR); > + } > + > /* > * The system has resumed successfully. Rewrite LR register stored > * on stack with 'ep' value, so that on return from this PSCI call, > -- > 2.43.0 >
Reviewed-by: Igor Opaniuk <[email protected]> -- Best regards - Freundliche Grüsse - Meilleures salutations Igor Opaniuk Senior Software Engineer, Embedded & Security E: [email protected] W: www.foundries.io

