diff options
author | Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com> | 2015-01-24 00:05:50 -0500 |
---|---|---|
committer | Kukjin Kim <kgene@kernel.org> | 2015-01-29 18:39:15 -0500 |
commit | 712eddf70225ab5ae65e946e22d2dfe6b93e8dd1 (patch) | |
tree | 62477a0a4b364cd2e87786481ee6dfe03e3fd569 /arch/arm/mach-exynos/exynos.c | |
parent | 865e8b76a04d018f23d809ebf735c52105e3adb2 (diff) |
cpuidle: exynos: add coupled cpuidle support for exynos4210
The following patch adds coupled cpuidle support for Exynos4210 to
an existing cpuidle-exynos driver. As a result it enables AFTR mode
to be used by default on Exynos4210 without the need to hot unplug
CPU1 first.
The patch is heavily based on earlier cpuidle-exynos4210 driver from
Daniel Lezcano:
http://www.spinics.net/lists/linux-samsung-soc/msg28134.html
Changes from Daniel's code include:
- porting code to current kernels
- fixing it to work on my setup (by using S5P_INFORM register
instead of S5P_VA_SYSRAM one on Revison 1.1 and retrying poking
CPU1 out of the BOOT ROM if necessary)
- fixing rare lockup caused by waiting for CPU1 to get stuck in
the BOOT ROM (CPU hotplug code in arch/arm/mach-exynos/platsmp.c
doesn't require this and works fine)
- moving Exynos specific code to arch/arm/mach-exynos/pm.c
- using cpu_boot_reg_base() helper instead of BOOT_VECTOR macro
- using exynos_cpu_*() helpers instead of accessing registers
directly
- using arch_send_wakeup_ipi_mask() instead of dsb_sev()
(this matches CPU hotplug code in arch/arm/mach-exynos/platsmp.c)
- integrating separate exynos4210-cpuidle driver into existing
exynos-cpuidle one
Cc: Colin Cross <ccross@google.com>
Cc: Kukjin Kim <kgene.kim@samsung.com>
Cc: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Cc: Tomasz Figa <tomasz.figa@gmail.com>
Signed-off-by: Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>
Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Acked-by: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Kukjin Kim <kgene@kernel.org>
Diffstat (limited to 'arch/arm/mach-exynos/exynos.c')
-rw-r--r-- | arch/arm/mach-exynos/exynos.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/arm/mach-exynos/exynos.c b/arch/arm/mach-exynos/exynos.c index c13d0837fa8c..509f2e5a2d70 100644 --- a/arch/arm/mach-exynos/exynos.c +++ b/arch/arm/mach-exynos/exynos.c | |||
@@ -246,6 +246,10 @@ static void __init exynos_dt_machine_init(void) | |||
246 | if (!IS_ENABLED(CONFIG_SMP)) | 246 | if (!IS_ENABLED(CONFIG_SMP)) |
247 | exynos_sysram_init(); | 247 | exynos_sysram_init(); |
248 | 248 | ||
249 | #ifdef CONFIG_ARM_EXYNOS_CPUIDLE | ||
250 | if (of_machine_is_compatible("samsung,exynos4210")) | ||
251 | exynos_cpuidle.dev.platform_data = &cpuidle_coupled_exynos_data; | ||
252 | #endif | ||
249 | if (of_machine_is_compatible("samsung,exynos4210") || | 253 | if (of_machine_is_compatible("samsung,exynos4210") || |
250 | of_machine_is_compatible("samsung,exynos4212") || | 254 | of_machine_is_compatible("samsung,exynos4212") || |
251 | (of_machine_is_compatible("samsung,exynos4412") && | 255 | (of_machine_is_compatible("samsung,exynos4412") && |