diff options
author | Jean-Sebastien A. Beaudry <jsabeaudry@handyem.com> | 2013-01-23 16:02:40 -0500 |
---|---|---|
committer | Tony Lindgren <tony@atomide.com> | 2013-02-01 17:50:18 -0500 |
commit | 14e067c1a5280fe6fe5d3348a0bae87bc4da16db (patch) | |
tree | 3f612a3c8f9bc0e33c0ab977fa45e9868e933f31 | |
parent | 88b62b915b0b7e25870eb0604ed9a92ba4bfc9f7 (diff) |
ARM: OMAP2+: AM33xx: Add SoC specific restart hook
Add restart hook so that DTS based AM33xx builds can restart
the platform.
Tested-by: Nishanth Menon <nm@ti.com>
Signed-off-by: Jean-Sebastien A. Beaudry <jsabeaudry@handyem.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
-rw-r--r-- | arch/arm/mach-omap2/Makefile | 1 | ||||
-rw-r--r-- | arch/arm/mach-omap2/am33xx-restart.c | 34 | ||||
-rw-r--r-- | arch/arm/mach-omap2/board-generic.c | 1 | ||||
-rw-r--r-- | arch/arm/mach-omap2/common.h | 8 |
4 files changed, 44 insertions, 0 deletions
diff --git a/arch/arm/mach-omap2/Makefile b/arch/arm/mach-omap2/Makefile index 947cafe65aef..d1156cfa9745 100644 --- a/arch/arm/mach-omap2/Makefile +++ b/arch/arm/mach-omap2/Makefile | |||
@@ -53,6 +53,7 @@ AFLAGS_sram34xx.o :=-Wa,-march=armv7-a | |||
53 | # Restart code (OMAP4/5 currently in omap4-common.c) | 53 | # Restart code (OMAP4/5 currently in omap4-common.c) |
54 | obj-$(CONFIG_SOC_OMAP2420) += omap2-restart.o | 54 | obj-$(CONFIG_SOC_OMAP2420) += omap2-restart.o |
55 | obj-$(CONFIG_SOC_OMAP2430) += omap2-restart.o | 55 | obj-$(CONFIG_SOC_OMAP2430) += omap2-restart.o |
56 | obj-$(CONFIG_SOC_AM33XX) += am33xx-restart.o | ||
56 | obj-$(CONFIG_ARCH_OMAP3) += omap3-restart.o | 57 | obj-$(CONFIG_ARCH_OMAP3) += omap3-restart.o |
57 | 58 | ||
58 | # Pin multiplexing | 59 | # Pin multiplexing |
diff --git a/arch/arm/mach-omap2/am33xx-restart.c b/arch/arm/mach-omap2/am33xx-restart.c new file mode 100644 index 000000000000..88e4fa8af031 --- /dev/null +++ b/arch/arm/mach-omap2/am33xx-restart.c | |||
@@ -0,0 +1,34 @@ | |||
1 | /* | ||
2 | * am33xx-restart.c - Code common to all AM33xx machines. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License version 2 as | ||
6 | * published by the Free Software Foundation. | ||
7 | */ | ||
8 | #include <linux/kernel.h> | ||
9 | |||
10 | #include "common.h" | ||
11 | #include "prm-regbits-33xx.h" | ||
12 | #include "prm33xx.h" | ||
13 | |||
14 | /** | ||
15 | * am3xx_restart - trigger a software restart of the SoC | ||
16 | * @mode: the "reboot mode", see arch/arm/kernel/{setup,process}.c | ||
17 | * @cmd: passed from the userspace program rebooting the system (if provided) | ||
18 | * | ||
19 | * Resets the SoC. For @cmd, see the 'reboot' syscall in | ||
20 | * kernel/sys.c. No return value. | ||
21 | */ | ||
22 | void am33xx_restart(char mode, const char *cmd) | ||
23 | { | ||
24 | /* TODO: Handle mode and cmd if necessary */ | ||
25 | |||
26 | am33xx_prm_rmw_reg_bits(AM33XX_GLOBAL_WARM_SW_RST_MASK, | ||
27 | AM33XX_GLOBAL_WARM_SW_RST_MASK, | ||
28 | AM33XX_PRM_DEVICE_MOD, | ||
29 | AM33XX_PRM_RSTCTRL_OFFSET); | ||
30 | |||
31 | /* OCP barrier */ | ||
32 | (void)am33xx_prm_read_reg(AM33XX_PRM_DEVICE_MOD, | ||
33 | AM33XX_PRM_RSTCTRL_OFFSET); | ||
34 | } | ||
diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c index 53cb380b7877..fac00f0960be 100644 --- a/arch/arm/mach-omap2/board-generic.c +++ b/arch/arm/mach-omap2/board-generic.c | |||
@@ -141,6 +141,7 @@ DT_MACHINE_START(AM33XX_DT, "Generic AM33XX (Flattened Device Tree)") | |||
141 | .init_machine = omap_generic_init, | 141 | .init_machine = omap_generic_init, |
142 | .timer = &omap3_am33xx_timer, | 142 | .timer = &omap3_am33xx_timer, |
143 | .dt_compat = am33xx_boards_compat, | 143 | .dt_compat = am33xx_boards_compat, |
144 | .restart = am33xx_restart, | ||
144 | MACHINE_END | 145 | MACHINE_END |
145 | #endif | 146 | #endif |
146 | 147 | ||
diff --git a/arch/arm/mach-omap2/common.h b/arch/arm/mach-omap2/common.h index 948bcaa82eb6..0c3a991a240e 100644 --- a/arch/arm/mach-omap2/common.h +++ b/arch/arm/mach-omap2/common.h | |||
@@ -119,6 +119,14 @@ static inline void omap2xxx_restart(char mode, const char *cmd) | |||
119 | } | 119 | } |
120 | #endif | 120 | #endif |
121 | 121 | ||
122 | #ifdef CONFIG_SOC_AM33XX | ||
123 | void am33xx_restart(char mode, const char *cmd); | ||
124 | #else | ||
125 | static inline void am33xx_restart(char mode, const char *cmd) | ||
126 | { | ||
127 | } | ||
128 | #endif | ||
129 | |||
122 | #ifdef CONFIG_ARCH_OMAP3 | 130 | #ifdef CONFIG_ARCH_OMAP3 |
123 | void omap3xxx_restart(char mode, const char *cmd); | 131 | void omap3xxx_restart(char mode, const char *cmd); |
124 | #else | 132 | #else |