aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-exynos/include
diff options
context:
space:
mode:
authorJonathan Kliegman <kliegs@chromium.org>2013-04-04 02:15:49 -0400
committerKukjin Kim <kgene.kim@samsung.com>2013-04-04 02:15:49 -0400
commit8521420375d0e6824a76fda24677f428c1d3f598 (patch)
tree1ce1255ab11a645c84a3d1e076750c835de6b729 /arch/arm/mach-exynos/include
parent672b6829e7290cb4e51987fdcb1078f4eee6546c (diff)
ARM: EXYNOS: Clear ENABLE_WAKEUP_SW bit when entering suspend
Setting this bit to 0 causes the system to wait until suspended to use the wakeup masks. With it being set high previously, masked interrupts were being received and processed before the EINT_WAKEUP_MASK was configured. Signed-off-by: Jonathan Kliegman <kliegs@chromium.org> Signed-off-by: Doug Anderson <dianders@chromium.org> Reviewed-by: Doug Anderson <dianders@chromium.org> Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
Diffstat (limited to 'arch/arm/mach-exynos/include')
-rw-r--r--arch/arm/mach-exynos/include/mach/pm-core.h7
1 files changed, 1 insertions, 6 deletions
diff --git a/arch/arm/mach-exynos/include/mach/pm-core.h b/arch/arm/mach-exynos/include/mach/pm-core.h
index 9d8da51e35ca..7dbbfec13ea5 100644
--- a/arch/arm/mach-exynos/include/mach/pm-core.h
+++ b/arch/arm/mach-exynos/include/mach/pm-core.h
@@ -27,13 +27,8 @@ static inline void s3c_pm_debug_init_uart(void)
27 27
28static inline void s3c_pm_arch_prepare_irqs(void) 28static inline void s3c_pm_arch_prepare_irqs(void)
29{ 29{
30 unsigned int tmp;
31 tmp = __raw_readl(S5P_WAKEUP_MASK);
32 tmp &= ~(1 << 31);
33 __raw_writel(tmp, S5P_WAKEUP_MASK);
34
35 __raw_writel(s3c_irqwake_intmask, S5P_WAKEUP_MASK);
36 __raw_writel(s3c_irqwake_eintmask, S5P_EINT_WAKEUP_MASK); 30 __raw_writel(s3c_irqwake_eintmask, S5P_EINT_WAKEUP_MASK);
31 __raw_writel(s3c_irqwake_intmask & ~(1 << 31), S5P_WAKEUP_MASK);
37} 32}
38 33
39static inline void s3c_pm_arch_stop_clocks(void) 34static inline void s3c_pm_arch_stop_clocks(void)