diff options
author | Catalin Marinas <catalin.marinas@arm.com> | 2013-02-28 11:43:19 -0500 |
---|---|---|
committer | Catalin Marinas <catalin.marinas@arm.com> | 2013-03-21 11:17:40 -0400 |
commit | 65deb782858128cde598ac4a9150ab7cdd29dafa (patch) | |
tree | b16411cdfe6158f84dc28330d872347f2e5f0afc | |
parent | 2655f51d0afd2087fb3e0e6a996610e06032d754 (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.c | 5 | ||||
-rw-r--r-- | drivers/power/reset/vexpress-poweroff.c | 9 | ||||
-rw-r--r-- | include/linux/vexpress.h | 3 |
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, | ||
378 | MACHINE_END | 375 | MACHINE_END |
379 | 376 | ||
380 | static struct map_desc v2m_rs1_io_desc __initdata = { | 377 | static 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 | ||
470 | static const char * const v2m_dt_match[] __initconst = { | 466 | static 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, | ||
485 | MACHINE_END | 480 | MACHINE_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 | |||
21 | static void vexpress_reset_do(struct device *dev, const char *what) | 23 | static 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 | ||
40 | static struct device *vexpress_power_off_device; | 42 | static struct device *vexpress_power_off_device; |
41 | 43 | ||
42 | void vexpress_power_off(void) | 44 | static 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 | ||
47 | static struct device *vexpress_restart_device; | 49 | static struct device *vexpress_restart_device; |
48 | 50 | ||
49 | void vexpress_restart(char str, const char *cmd) | 51 | static 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); | |||
115 | void vexpress_sysreg_early_init(void __iomem *base); | 115 | void vexpress_sysreg_early_init(void __iomem *base); |
116 | void vexpress_sysreg_of_early_init(void); | 116 | void vexpress_sysreg_of_early_init(void); |
117 | 117 | ||
118 | void vexpress_power_off(void); | ||
119 | void vexpress_restart(char str, const char *cmd); | ||
120 | |||
121 | /* Clocks */ | 118 | /* Clocks */ |
122 | 119 | ||
123 | struct clk *vexpress_osc_setup(struct device *dev); | 120 | struct clk *vexpress_osc_setup(struct device *dev); |