Commit 2bbe3af3 authored by Tero Kristo's avatar Tero Kristo Committed by Kevin Hilman

OMAP3: PM: Ack pending interrupts before entering suspend

Suspending drivers may still generate interrupts just before their suspend is
completed. Any pending interrupts here will prevent sleep.
Signed-off-by: default avatarTero Kristo <tero.kristo@nokia.com>
Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
parent 7284ce6c
...@@ -274,4 +274,10 @@ void omap_intc_restore_context(void) ...@@ -274,4 +274,10 @@ void omap_intc_restore_context(void)
} }
/* MIRs are saved and restore with other PRCM registers */ /* MIRs are saved and restore with other PRCM registers */
} }
void omap3_intc_suspend(void)
{
/* A pending interrupt would prevent OMAP from entering suspend */
omap_ack_irq(0);
}
#endif /* CONFIG_ARCH_OMAP3 */ #endif /* CONFIG_ARCH_OMAP3 */
...@@ -578,6 +578,8 @@ static int omap3_pm_suspend(void) ...@@ -578,6 +578,8 @@ static int omap3_pm_suspend(void)
} }
omap_uart_prepare_suspend(); omap_uart_prepare_suspend();
omap3_intc_suspend();
omap_sram_idle(); omap_sram_idle();
restore: restore:
......
...@@ -499,6 +499,7 @@ extern void omap_init_irq(void); ...@@ -499,6 +499,7 @@ extern void omap_init_irq(void);
extern int omap_irq_pending(void); extern int omap_irq_pending(void);
void omap_intc_save_context(void); void omap_intc_save_context(void);
void omap_intc_restore_context(void); void omap_intc_restore_context(void);
void omap3_intc_suspend(void);
#endif #endif
#include <mach/hardware.h> #include <mach/hardware.h>
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment