| From: Alexandre Belloni <alexandre.belloni@free-electrons.com> |
| Date: Wed, 30 Sep 2015 01:58:40 +0200 |
| Subject: [PATCH 08/13] ARM: at91: pm: move idle functions to pm.c |
| |
| Avoid using code from clk/at91 for PM. |
| This also has the bonus effect of setting arm_pm_idle for sama5 platforms. |
| |
| Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com> |
| Acked-by: Boris Brezillon <boris.brezillon@free-electrons.com> |
| Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> |
| --- |
| arch/arm/mach-at91/at91rm9200.c | 2 -- |
| arch/arm/mach-at91/at91sam9.c | 2 -- |
| arch/arm/mach-at91/generic.h | 6 ++---- |
| arch/arm/mach-at91/pm.c | 37 ++++++++++++++++++++++++++++++++----- |
| arch/arm/mach-at91/sama5.c | 2 +- |
| drivers/clk/at91/pmc.c | 15 --------------- |
| 6 files changed, 35 insertions(+), 29 deletions(-) |
| |
| --- a/arch/arm/mach-at91/at91rm9200.c |
| +++ b/arch/arm/mach-at91/at91rm9200.c |
| @@ -12,7 +12,6 @@ |
| #include <linux/of_platform.h> |
| |
| #include <asm/mach/arch.h> |
| -#include <asm/system_misc.h> |
| |
| #include "generic.h" |
| #include "soc.h" |
| @@ -33,7 +32,6 @@ static void __init at91rm9200_dt_device_ |
| |
| of_platform_populate(NULL, of_default_bus_match_table, NULL, soc_dev); |
| |
| - arm_pm_idle = at91rm9200_idle; |
| at91rm9200_pm_init(); |
| } |
| |
| --- a/arch/arm/mach-at91/at91sam9.c |
| +++ b/arch/arm/mach-at91/at91sam9.c |
| @@ -62,8 +62,6 @@ static void __init at91sam9_common_init( |
| soc_dev = soc_device_to_device(soc); |
| |
| of_platform_populate(NULL, of_default_bus_match_table, NULL, soc_dev); |
| - |
| - arm_pm_idle = at91sam9_idle; |
| } |
| |
| static void __init at91sam9_dt_device_init(void) |
| --- a/arch/arm/mach-at91/generic.h |
| +++ b/arch/arm/mach-at91/generic.h |
| @@ -18,20 +18,18 @@ |
| extern void __init at91_map_io(void); |
| extern void __init at91_alt_map_io(void); |
| |
| -/* idle */ |
| -extern void at91rm9200_idle(void); |
| -extern void at91sam9_idle(void); |
| - |
| #ifdef CONFIG_PM |
| extern void __init at91rm9200_pm_init(void); |
| extern void __init at91sam9260_pm_init(void); |
| extern void __init at91sam9g45_pm_init(void); |
| extern void __init at91sam9x5_pm_init(void); |
| +extern void __init sama5_pm_init(void); |
| #else |
| static inline void __init at91rm9200_pm_init(void) { } |
| static inline void __init at91sam9260_pm_init(void) { } |
| static inline void __init at91sam9g45_pm_init(void) { } |
| static inline void __init at91sam9x5_pm_init(void) { } |
| +static inline void __init sama5_pm_init(void) { } |
| #endif |
| |
| #endif /* _AT91_GENERIC_H */ |
| --- a/arch/arm/mach-at91/pm.c |
| +++ b/arch/arm/mach-at91/pm.c |
| @@ -31,6 +31,7 @@ |
| #include <asm/mach/irq.h> |
| #include <asm/fncpy.h> |
| #include <asm/cacheflush.h> |
| +#include <asm/system_misc.h> |
| |
| #include "generic.h" |
| #include "pm.h" |
| @@ -354,6 +355,21 @@ static __init void at91_dt_ramc(void) |
| at91_pm_set_standby(standby); |
| } |
| |
| +void at91rm9200_idle(void) |
| +{ |
| + /* |
| + * Disable the processor clock. The processor will be automatically |
| + * re-enabled by an interrupt or by a reset. |
| + */ |
| + writel(AT91_PMC_PCK, pmc + AT91_PMC_SCDR); |
| +} |
| + |
| +void at91sam9_idle(void) |
| +{ |
| + writel(AT91_PMC_PCK, pmc + AT91_PMC_SCDR); |
| + cpu_do_idle(); |
| +} |
| + |
| static void __init at91_pm_sram_init(void) |
| { |
| struct gen_pool *sram_pool; |
| @@ -411,7 +427,7 @@ static const struct of_device_id atmel_p |
| { /* sentinel */ }, |
| }; |
| |
| -static void __init at91_pm_init(void) |
| +static void __init at91_pm_init(void (*pm_idle)(void)) |
| { |
| struct device_node *pmc_np; |
| |
| @@ -425,6 +441,9 @@ static void __init at91_pm_init(void) |
| return; |
| } |
| |
| + if (pm_idle) |
| + arm_pm_idle = pm_idle; |
| + |
| at91_pm_sram_init(); |
| |
| if (at91_suspend_sram_fn) |
| @@ -445,7 +464,7 @@ void __init at91rm9200_pm_init(void) |
| at91_pm_data.uhp_udp_mask = AT91RM9200_PMC_UHP | AT91RM9200_PMC_UDP; |
| at91_pm_data.memctrl = AT91_MEMCTRL_MC; |
| |
| - at91_pm_init(); |
| + at91_pm_init(at91rm9200_idle); |
| } |
| |
| void __init at91sam9260_pm_init(void) |
| @@ -453,7 +472,7 @@ void __init at91sam9260_pm_init(void) |
| at91_dt_ramc(); |
| at91_pm_data.memctrl = AT91_MEMCTRL_SDRAMC; |
| at91_pm_data.uhp_udp_mask = AT91SAM926x_PMC_UHP | AT91SAM926x_PMC_UDP; |
| - at91_pm_init(); |
| + at91_pm_init(at91sam9_idle); |
| } |
| |
| void __init at91sam9g45_pm_init(void) |
| @@ -461,7 +480,7 @@ void __init at91sam9g45_pm_init(void) |
| at91_dt_ramc(); |
| at91_pm_data.uhp_udp_mask = AT91SAM926x_PMC_UHP; |
| at91_pm_data.memctrl = AT91_MEMCTRL_DDRSDR; |
| - at91_pm_init(); |
| + at91_pm_init(at91sam9_idle); |
| } |
| |
| void __init at91sam9x5_pm_init(void) |
| @@ -469,5 +488,13 @@ void __init at91sam9x5_pm_init(void) |
| at91_dt_ramc(); |
| at91_pm_data.uhp_udp_mask = AT91SAM926x_PMC_UHP | AT91SAM926x_PMC_UDP; |
| at91_pm_data.memctrl = AT91_MEMCTRL_DDRSDR; |
| - at91_pm_init(); |
| + at91_pm_init(at91sam9_idle); |
| +} |
| + |
| +void __init sama5_pm_init(void) |
| +{ |
| + at91_dt_ramc(); |
| + at91_pm_data.uhp_udp_mask = AT91SAM926x_PMC_UHP | AT91SAM926x_PMC_UDP; |
| + at91_pm_data.memctrl = AT91_MEMCTRL_DDRSDR; |
| + at91_pm_init(NULL); |
| } |
| --- a/arch/arm/mach-at91/sama5.c |
| +++ b/arch/arm/mach-at91/sama5.c |
| @@ -51,7 +51,7 @@ static void __init sama5_dt_device_init( |
| soc_dev = soc_device_to_device(soc); |
| |
| of_platform_populate(NULL, of_default_bus_match_table, NULL, soc_dev); |
| - at91sam9x5_pm_init(); |
| + sama5_pm_init(); |
| } |
| |
| static const char *const sama5_dt_board_compat[] __initconst = { |
| --- a/drivers/clk/at91/pmc.c |
| +++ b/drivers/clk/at91/pmc.c |
| @@ -32,21 +32,6 @@ struct at91_pmc { |
| void __iomem *at91_pmc_base; |
| EXPORT_SYMBOL_GPL(at91_pmc_base); |
| |
| -void at91rm9200_idle(void) |
| -{ |
| - /* |
| - * Disable the processor clock. The processor will be automatically |
| - * re-enabled by an interrupt or by a reset. |
| - */ |
| - at91_pmc_write(AT91_PMC_SCDR, AT91_PMC_PCK); |
| -} |
| - |
| -void at91sam9_idle(void) |
| -{ |
| - at91_pmc_write(AT91_PMC_SCDR, AT91_PMC_PCK); |
| - cpu_do_idle(); |
| -} |
| - |
| int of_at91_get_clk_range(struct device_node *np, const char *propname, |
| struct clk_range *range) |
| { |