blob: c88d8df753c2d49b44db050e450c8dcb8fada2de [file] [log] [blame]
Jean-Sebastien A. Beaudry14e067c2013-01-23 16:02:40 -05001/*
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>
Robin Holt7b6d8642013-07-08 16:01:40 -07009#include <linux/reboot.h>
Jean-Sebastien A. Beaudry14e067c2013-01-23 16:02:40 -050010
11#include "common.h"
12#include "prm-regbits-33xx.h"
13#include "prm33xx.h"
14
15/**
16 * am3xx_restart - trigger a software restart of the SoC
17 * @mode: the "reboot mode", see arch/arm/kernel/{setup,process}.c
18 * @cmd: passed from the userspace program rebooting the system (if provided)
19 *
20 * Resets the SoC. For @cmd, see the 'reboot' syscall in
21 * kernel/sys.c. No return value.
22 */
Robin Holt7b6d8642013-07-08 16:01:40 -070023void am33xx_restart(enum reboot_mode mode, const char *cmd)
Jean-Sebastien A. Beaudry14e067c2013-01-23 16:02:40 -050024{
25 /* TODO: Handle mode and cmd if necessary */
26
Matus Ujhelyi56cab602013-08-05 12:02:24 +020027 am33xx_prm_rmw_reg_bits(AM33XX_RST_GLOBAL_WARM_SW_MASK,
28 AM33XX_RST_GLOBAL_WARM_SW_MASK,
Jean-Sebastien A. Beaudry14e067c2013-01-23 16:02:40 -050029 AM33XX_PRM_DEVICE_MOD,
30 AM33XX_PRM_RSTCTRL_OFFSET);
31
32 /* OCP barrier */
33 (void)am33xx_prm_read_reg(AM33XX_PRM_DEVICE_MOD,
34 AM33XX_PRM_RSTCTRL_OFFSET);
35}