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 /arch/arm/mach-omap2/am33xx-restart.c | |
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>
Diffstat (limited to 'arch/arm/mach-omap2/am33xx-restart.c')
-rw-r--r-- | arch/arm/mach-omap2/am33xx-restart.c | 34 |
1 files changed, 34 insertions, 0 deletions
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 | } | ||