aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCatalin Marinas <catalin.marinas@arm.com>2013-02-28 11:43:19 -0500
committerCatalin Marinas <catalin.marinas@arm.com>2013-03-21 11:17:40 -0400
commit65deb782858128cde598ac4a9150ab7cdd29dafa (patch)
treeb16411cdfe6158f84dc28330d872347f2e5f0afc
parent2655f51d0afd2087fb3e0e6a996610e06032d754 (diff)
arm: vexpress: Decouple vexpress-poweroff implementation from machine_desc
This patch adds the pm_power_off and arm_pm_restart variable settings to the vexpress-poweroff.c driver to decouple it from the machine_desc definition. Signed-off-by: Catalin Marinas <catalin.marinas@arm.com> Acked-by: Pawel Moll <pawel.moll@arm.com>
-rw-r--r--arch/arm/mach-vexpress/v2m.c5
-rw-r--r--drivers/power/reset/vexpress-poweroff.c9
-rw-r--r--include/linux/vexpress.h3
3 files changed, 7 insertions, 10 deletions
diff --git a/arch/arm/mach-vexpress/v2m.c b/arch/arm/mach-vexpress/v2m.c
index 915683cb67d6..c970762e8386 100644
--- a/arch/arm/mach-vexpress/v2m.c
+++ b/arch/arm/mach-vexpress/v2m.c
@@ -361,8 +361,6 @@ static void __init v2m_init(void)
361 for (i = 0; i < ARRAY_SIZE(v2m_amba_devs); i++) 361 for (i = 0; i < ARRAY_SIZE(v2m_amba_devs); i++)
362 amba_device_register(v2m_amba_devs[i], &iomem_resource); 362 amba_device_register(v2m_amba_devs[i], &iomem_resource);
363 363
364 pm_power_off = vexpress_power_off;
365
366 ct_desc->init_tile(); 364 ct_desc->init_tile();
367} 365}
368 366
@@ -374,7 +372,6 @@ MACHINE_START(VEXPRESS, "ARM-Versatile Express")
374 .init_irq = v2m_init_irq, 372 .init_irq = v2m_init_irq,
375 .init_time = v2m_timer_init, 373 .init_time = v2m_timer_init,
376 .init_machine = v2m_init, 374 .init_machine = v2m_init,
377 .restart = vexpress_restart,
378MACHINE_END 375MACHINE_END
379 376
380static struct map_desc v2m_rs1_io_desc __initdata = { 377static struct map_desc v2m_rs1_io_desc __initdata = {
@@ -464,7 +461,6 @@ static void __init v2m_dt_init(void)
464{ 461{
465 l2x0_of_init(0x00400000, 0xfe0fffff); 462 l2x0_of_init(0x00400000, 0xfe0fffff);
466 of_platform_populate(NULL, v2m_dt_bus_match, NULL, NULL); 463 of_platform_populate(NULL, v2m_dt_bus_match, NULL, NULL);
467 pm_power_off = vexpress_power_off;
468} 464}
469 465
470static const char * const v2m_dt_match[] __initconst = { 466static const char * const v2m_dt_match[] __initconst = {
@@ -481,5 +477,4 @@ DT_MACHINE_START(VEXPRESS_DT, "ARM-Versatile Express")
481 .init_irq = irqchip_init, 477 .init_irq = irqchip_init,
482 .init_time = v2m_dt_timer_init, 478 .init_time = v2m_dt_timer_init,
483 .init_machine = v2m_dt_init, 479 .init_machine = v2m_dt_init,
484 .restart = vexpress_restart,
485MACHINE_END 480MACHINE_END
diff --git a/drivers/power/reset/vexpress-poweroff.c b/drivers/power/reset/vexpress-poweroff.c
index 465923aa3819..469e6962b2cf 100644
--- a/drivers/power/reset/vexpress-poweroff.c
+++ b/drivers/power/reset/vexpress-poweroff.c
@@ -18,6 +18,8 @@
18#include <linux/stat.h> 18#include <linux/stat.h>
19#include <linux/vexpress.h> 19#include <linux/vexpress.h>
20 20
21#include <asm/system_misc.h>
22
21static void vexpress_reset_do(struct device *dev, const char *what) 23static void vexpress_reset_do(struct device *dev, const char *what)
22{ 24{
23 int err = -ENOENT; 25 int err = -ENOENT;
@@ -39,14 +41,14 @@ static void vexpress_reset_do(struct device *dev, const char *what)
39 41
40static struct device *vexpress_power_off_device; 42static struct device *vexpress_power_off_device;
41 43
42void vexpress_power_off(void) 44static void vexpress_power_off(void)
43{ 45{
44 vexpress_reset_do(vexpress_power_off_device, "power off"); 46 vexpress_reset_do(vexpress_power_off_device, "power off");
45} 47}
46 48
47static struct device *vexpress_restart_device; 49static struct device *vexpress_restart_device;
48 50
49void vexpress_restart(char str, const char *cmd) 51static void vexpress_restart(char str, const char *cmd)
50{ 52{
51 vexpress_reset_do(vexpress_restart_device, "restart"); 53 vexpress_reset_do(vexpress_restart_device, "restart");
52} 54}
@@ -103,14 +105,17 @@ static int vexpress_reset_probe(struct platform_device *pdev)
103 switch (func) { 105 switch (func) {
104 case FUNC_SHUTDOWN: 106 case FUNC_SHUTDOWN:
105 vexpress_power_off_device = &pdev->dev; 107 vexpress_power_off_device = &pdev->dev;
108 pm_power_off = vexpress_power_off;
106 break; 109 break;
107 case FUNC_RESET: 110 case FUNC_RESET:
108 if (!vexpress_restart_device) 111 if (!vexpress_restart_device)
109 vexpress_restart_device = &pdev->dev; 112 vexpress_restart_device = &pdev->dev;
113 arm_pm_restart = vexpress_restart;
110 device_create_file(&pdev->dev, &dev_attr_active); 114 device_create_file(&pdev->dev, &dev_attr_active);
111 break; 115 break;
112 case FUNC_REBOOT: 116 case FUNC_REBOOT:
113 vexpress_restart_device = &pdev->dev; 117 vexpress_restart_device = &pdev->dev;
118 arm_pm_restart = vexpress_restart;
114 device_create_file(&pdev->dev, &dev_attr_active); 119 device_create_file(&pdev->dev, &dev_attr_active);
115 break; 120 break;
116 }; 121 };
diff --git a/include/linux/vexpress.h b/include/linux/vexpress.h
index 75818744ab59..ea7168a68081 100644
--- a/include/linux/vexpress.h
+++ b/include/linux/vexpress.h
@@ -115,9 +115,6 @@ unsigned __vexpress_get_site(struct device *dev, struct device_node *node);
115void vexpress_sysreg_early_init(void __iomem *base); 115void vexpress_sysreg_early_init(void __iomem *base);
116void vexpress_sysreg_of_early_init(void); 116void vexpress_sysreg_of_early_init(void);
117 117
118void vexpress_power_off(void);
119void vexpress_restart(char str, const char *cmd);
120
121/* Clocks */ 118/* Clocks */
122 119
123struct clk *vexpress_osc_setup(struct device *dev); 120struct clk *vexpress_osc_setup(struct device *dev);