aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-at91
diff options
context:
space:
mode:
authorAlexandre Belloni <alexandre.belloni@free-electrons.com>2015-01-26 13:02:54 -0500
committerNicolas Ferre <nicolas.ferre@atmel.com>2015-02-02 05:01:26 -0500
commit7d7ffd7bae4c15400e0cf8ef61ce4679a4472409 (patch)
tree9ae8e81a3101cb0bacf1a83bd7b5fccafce19a35 /arch/arm/mach-at91
parent980657d8cdff97343619cf2e3332b8307e9d07ea (diff)
ARM: at91: at91rm9200: set idle and restart from rm9200_dt_device_init()
Setup arm_pm_idle and arm_pm_restart function pointers from rm9200_dt_device_init() function to simplify the at91rm9200 initialization process. This same move is already done for the sam9s. Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com> [nicolas.ferre@atmel.com: adapt patch to newer series] Signed-off-by: Nicolas Ferre <nicolas.ferre@atmel.com>
Diffstat (limited to 'arch/arm/mach-at91')
-rw-r--r--arch/arm/mach-at91/at91rm9200.c14
-rw-r--r--arch/arm/mach-at91/board-dt-rm9200.c14
2 files changed, 14 insertions, 14 deletions
diff --git a/arch/arm/mach-at91/at91rm9200.c b/arch/arm/mach-at91/at91rm9200.c
index 3be1963f5c56..ae0d5f0eb108 100644
--- a/arch/arm/mach-at91/at91rm9200.c
+++ b/arch/arm/mach-at91/at91rm9200.c
@@ -22,25 +22,11 @@
22#include "generic.h" 22#include "generic.h"
23 23
24 24
25static void at91rm9200_restart(enum reboot_mode reboot_mode, const char *cmd)
26{
27 /*
28 * Perform a hardware reset with the use of the Watchdog timer.
29 */
30 at91_st_write(AT91_ST_WDMR, AT91_ST_RSTEN | AT91_ST_EXTEN | 1);
31 at91_st_write(AT91_ST_CR, AT91_ST_WDRST);
32}
33 25
34/* -------------------------------------------------------------------- 26/* --------------------------------------------------------------------
35 * AT91RM9200 processor initialization 27 * AT91RM9200 processor initialization
36 * -------------------------------------------------------------------- */ 28 * -------------------------------------------------------------------- */
37 29
38static void __init at91rm9200_initialize(void)
39{
40 arm_pm_idle = at91rm9200_idle;
41 arm_pm_restart = at91rm9200_restart;
42}
43 30
44AT91_SOC_START(at91rm9200) 31AT91_SOC_START(at91rm9200)
45 .init = at91rm9200_initialize,
46AT91_SOC_END 32AT91_SOC_END
diff --git a/arch/arm/mach-at91/board-dt-rm9200.c b/arch/arm/mach-at91/board-dt-rm9200.c
index d47c4433444d..5fcd1c73ece0 100644
--- a/arch/arm/mach-at91/board-dt-rm9200.c
+++ b/arch/arm/mach-at91/board-dt-rm9200.c
@@ -22,9 +22,21 @@
22#include <asm/mach/arch.h> 22#include <asm/mach/arch.h>
23#include <asm/mach/map.h> 23#include <asm/mach/map.h>
24#include <asm/mach/irq.h> 24#include <asm/mach/irq.h>
25#include <asm/system_misc.h>
26
27#include <mach/at91_st.h>
25 28
26#include "generic.h" 29#include "generic.h"
27 30
31static void at91rm9200_restart(enum reboot_mode reboot_mode, const char *cmd)
32{
33 /*
34 * Perform a hardware reset with the use of the Watchdog timer.
35 */
36 at91_st_write(AT91_ST_WDMR, AT91_ST_RSTEN | AT91_ST_EXTEN | 1);
37 at91_st_write(AT91_ST_CR, AT91_ST_WDRST);
38}
39
28static void __init at91rm9200_dt_timer_init(void) 40static void __init at91rm9200_dt_timer_init(void)
29{ 41{
30 of_clk_init(NULL); 42 of_clk_init(NULL);
@@ -35,6 +47,8 @@ static void __init rm9200_dt_device_init(void)
35{ 47{
36 of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL); 48 of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
37 49
50 arm_pm_idle = at91rm9200_idle;
51 arm_pm_restart = at91rm9200_restart;
38 at91_rm9200_pm_init(); 52 at91_rm9200_pm_init();
39} 53}
40 54