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: Tero Kristo <tero.kristo@nokia.com> Signed-off-by: Kevin Hilman <khilman@deeprootsystems.com>
This commit is contained in:
parent
7284ce6c9f
commit
2bbe3af3f1
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
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);
|
||||||
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>
|
||||||
|
|
Loading…
Reference in New Issue