summaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-omap2/ti81xx-restart.c
diff options
context:
space:
mode:
authorTony Lindgren <tony@atomide.com>2015-01-15 02:37:16 +0100
committerTony Lindgren <tony@atomide.com>2015-01-15 02:37:16 +0100
commitbc7235c97f90c9def22ebda620d7eae2b49a7642 (patch)
treec5a4b904acc3f26aee7a39d2340a3e76d57b4583 /arch/arm/mach-omap2/ti81xx-restart.c
parentARM: OMAP2+: Fix dm814 and dm816 for clocks and timer init (diff)
downloadlinux-bc7235c97f90c9def22ebda620d7eae2b49a7642.tar.xz
linux-bc7235c97f90c9def22ebda620d7eae2b49a7642.zip
ARM: OMAP2+: Fix reboot for 81xx
We are missing proper hooks for 81xx for reboot to work. Cc: Brian Hutchinson <b.hutchman@gmail.com> Reviewed-by: Felipe Balbi <balbi@ti.com> Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch/arm/mach-omap2/ti81xx-restart.c')
-rw-r--r--arch/arm/mach-omap2/ti81xx-restart.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/arch/arm/mach-omap2/ti81xx-restart.c b/arch/arm/mach-omap2/ti81xx-restart.c
new file mode 100644
index 000000000000..6c3ce7c46ddd
--- /dev/null
+++ b/arch/arm/mach-omap2/ti81xx-restart.c
@@ -0,0 +1,34 @@
+/*
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+#include <linux/kernel.h>
+#include <linux/init.h>
+#include <linux/reboot.h>
+
+#include "iomap.h"
+#include "common.h"
+#include "control.h"
+#include "prm3xxx.h"
+
+#define TI81XX_PRM_DEVICE_RSTCTRL 0x00a0
+#define TI81XX_GLOBAL_RST_COLD BIT(1)
+
+/**
+ * ti81xx_restart - trigger a software restart of the SoC
+ * @mode: the "reboot mode", see arch/arm/kernel/{setup,process}.c
+ * @cmd: passed from the userspace program rebooting the system (if provided)
+ *
+ * Resets the SoC. For @cmd, see the 'reboot' syscall in
+ * kernel/sys.c. No return value.
+ *
+ * NOTE: Warm reset does not seem to work, may require resetting
+ * clocks to bypass mode.
+ */
+void ti81xx_restart(enum reboot_mode mode, const char *cmd)
+{
+ omap2_prm_set_mod_reg_bits(TI81XX_GLOBAL_RST_COLD, 0,
+ TI81XX_PRM_DEVICE_RSTCTRL);
+ while (1);
+}