2011-11-06 05:10:37 +08:00
|
|
|
/*
|
|
|
|
* arch/arm/plat-spear/restart.c
|
|
|
|
*
|
|
|
|
* SPEAr platform specific restart functions
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009 ST Microelectronics
|
2012-06-21 03:53:02 +08:00
|
|
|
* Viresh Kumar <viresh.linux@gmail.com>
|
2011-11-06 05:10:37 +08:00
|
|
|
*
|
|
|
|
* This file is licensed under the terms of the GNU General Public
|
|
|
|
* License version 2. This program is licensed "as is" without any
|
|
|
|
* warranty of any kind, whether express or implied.
|
|
|
|
*/
|
|
|
|
#include <linux/io.h>
|
2012-03-29 01:30:01 +08:00
|
|
|
#include <asm/system_misc.h>
|
2011-11-06 05:10:37 +08:00
|
|
|
#include <asm/hardware/sp810.h>
|
2012-04-12 01:30:11 +08:00
|
|
|
#include <mach/spear.h>
|
2011-11-06 05:10:37 +08:00
|
|
|
#include <mach/generic.h>
|
|
|
|
|
2012-04-20 00:53:13 +08:00
|
|
|
#define SPEAR13XX_SYS_SW_RES (VA_MISC_BASE + 0x204)
|
2011-11-06 05:10:37 +08:00
|
|
|
void spear_restart(char mode, const char *cmd)
|
|
|
|
{
|
|
|
|
if (mode == 's') {
|
|
|
|
/* software reset, Jump into ROM at address 0 */
|
|
|
|
soft_restart(0);
|
|
|
|
} else {
|
|
|
|
/* hardware reset, Use on-chip reset capability */
|
2012-04-20 00:53:13 +08:00
|
|
|
#ifdef CONFIG_ARCH_SPEAR13XX
|
|
|
|
writel_relaxed(0x01, SPEAR13XX_SYS_SW_RES);
|
|
|
|
#else
|
2011-11-06 05:10:37 +08:00
|
|
|
sysctl_soft_reset((void __iomem *)VA_SPEAR_SYS_CTRL_BASE);
|
2012-04-20 00:53:13 +08:00
|
|
|
#endif
|
2011-11-06 05:10:37 +08:00
|
|
|
}
|
|
|
|
}
|