|
@@ -69,7 +69,16 @@ static void restore_cpu_arch_register(void)
|
|
|
|
|
|
static int idle_finisher(unsigned long flags)
|
|
|
{
|
|
|
+ exynos_set_wakeupmask();
|
|
|
+
|
|
|
+ __raw_writel(virt_to_phys(s3c_cpu_resume), REG_DIRECTGO_ADDR);
|
|
|
+ __raw_writel(S5P_CHECK_AFTR, REG_DIRECTGO_FLAG);
|
|
|
+
|
|
|
+ /* Set value of power down register for aftr mode */
|
|
|
+ exynos_sys_powerdown_conf(SYS_AFTR);
|
|
|
+
|
|
|
cpu_do_idle();
|
|
|
+
|
|
|
return 1;
|
|
|
}
|
|
|
|
|
@@ -79,14 +88,6 @@ static int exynos_enter_core0_aftr(struct cpuidle_device *dev,
|
|
|
{
|
|
|
unsigned long tmp;
|
|
|
|
|
|
- exynos_set_wakeupmask();
|
|
|
-
|
|
|
- /* Set value of power down register for aftr mode */
|
|
|
- exynos_sys_powerdown_conf(SYS_AFTR);
|
|
|
-
|
|
|
- __raw_writel(virt_to_phys(exynos_cpu_resume), REG_DIRECTGO_ADDR);
|
|
|
- __raw_writel(S5P_CHECK_AFTR, REG_DIRECTGO_FLAG);
|
|
|
-
|
|
|
save_cpu_arch_register();
|
|
|
|
|
|
/* Setting Central Sequence Register for power down mode */
|