ARM: restart: spear: use new restart hook
Hook these platforms restart code into the new restart hook rather than using arch_reset(). Acked-by: Viresh Kumar <viresh.kumar@st.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:
parent
b95ff9fe24
commit
dd1661e27a
9 changed files with 36 additions and 12 deletions
|
@ -42,6 +42,8 @@ void __init spear3xx_map_io(void);
|
||||||
void __init spear3xx_init_irq(void);
|
void __init spear3xx_init_irq(void);
|
||||||
void __init spear3xx_init(void);
|
void __init spear3xx_init(void);
|
||||||
|
|
||||||
|
void spear_restart(char, const char *);
|
||||||
|
|
||||||
/* pad mux declarations */
|
/* pad mux declarations */
|
||||||
#define PMX_FIRDA_MASK (1 << 14)
|
#define PMX_FIRDA_MASK (1 << 14)
|
||||||
#define PMX_I2C_MASK (1 << 13)
|
#define PMX_I2C_MASK (1 << 13)
|
||||||
|
|
|
@ -69,4 +69,5 @@ MACHINE_START(SPEAR300, "ST-SPEAR300-EVB")
|
||||||
.init_irq = spear3xx_init_irq,
|
.init_irq = spear3xx_init_irq,
|
||||||
.timer = &spear3xx_timer,
|
.timer = &spear3xx_timer,
|
||||||
.init_machine = spear300_evb_init,
|
.init_machine = spear300_evb_init,
|
||||||
|
.restart = spear_restart,
|
||||||
MACHINE_END
|
MACHINE_END
|
||||||
|
|
|
@ -75,4 +75,5 @@ MACHINE_START(SPEAR310, "ST-SPEAR310-EVB")
|
||||||
.init_irq = spear3xx_init_irq,
|
.init_irq = spear3xx_init_irq,
|
||||||
.timer = &spear3xx_timer,
|
.timer = &spear3xx_timer,
|
||||||
.init_machine = spear310_evb_init,
|
.init_machine = spear310_evb_init,
|
||||||
|
.restart = spear_restart,
|
||||||
MACHINE_END
|
MACHINE_END
|
||||||
|
|
|
@ -73,4 +73,5 @@ MACHINE_START(SPEAR320, "ST-SPEAR320-EVB")
|
||||||
.init_irq = spear3xx_init_irq,
|
.init_irq = spear3xx_init_irq,
|
||||||
.timer = &spear3xx_timer,
|
.timer = &spear3xx_timer,
|
||||||
.init_machine = spear320_evb_init,
|
.init_machine = spear320_evb_init,
|
||||||
|
.restart = spear_restart,
|
||||||
MACHINE_END
|
MACHINE_END
|
||||||
|
|
|
@ -41,6 +41,8 @@ void __init spear6xx_init(void);
|
||||||
void __init spear600_init(void);
|
void __init spear600_init(void);
|
||||||
void __init spear6xx_clk_init(void);
|
void __init spear6xx_clk_init(void);
|
||||||
|
|
||||||
|
void spear_restart(char, const char *);
|
||||||
|
|
||||||
/* Add spear600 machine device structure declarations here */
|
/* Add spear600 machine device structure declarations here */
|
||||||
|
|
||||||
#endif /* __MACH_GENERIC_H */
|
#endif /* __MACH_GENERIC_H */
|
||||||
|
|
|
@ -48,4 +48,5 @@ MACHINE_START(SPEAR600, "ST-SPEAR600-EVB")
|
||||||
.init_irq = spear6xx_init_irq,
|
.init_irq = spear6xx_init_irq,
|
||||||
.timer = &spear6xx_timer,
|
.timer = &spear6xx_timer,
|
||||||
.init_machine = spear600_evb_init,
|
.init_machine = spear600_evb_init,
|
||||||
|
.restart = spear_restart,
|
||||||
MACHINE_END
|
MACHINE_END
|
||||||
|
|
|
@ -3,6 +3,6 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
# Common support
|
# Common support
|
||||||
obj-y := clock.o time.o
|
obj-y := clock.o restart.o time.o
|
||||||
|
|
||||||
obj-$(CONFIG_ARCH_SPEAR3XX) += shirq.o padmux.o
|
obj-$(CONFIG_ARCH_SPEAR3XX) += shirq.o padmux.o
|
||||||
|
|
|
@ -14,10 +14,6 @@
|
||||||
#ifndef __PLAT_SYSTEM_H
|
#ifndef __PLAT_SYSTEM_H
|
||||||
#define __PLAT_SYSTEM_H
|
#define __PLAT_SYSTEM_H
|
||||||
|
|
||||||
#include <linux/io.h>
|
|
||||||
#include <asm/hardware/sp810.h>
|
|
||||||
#include <mach/hardware.h>
|
|
||||||
|
|
||||||
static inline void arch_idle(void)
|
static inline void arch_idle(void)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
@ -29,13 +25,6 @@ static inline void arch_idle(void)
|
||||||
|
|
||||||
static inline void arch_reset(char mode, const char *cmd)
|
static inline void arch_reset(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 */
|
|
||||||
sysctl_soft_reset((void __iomem *)VA_SPEAR_SYS_CTRL_BASE);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* __PLAT_SYSTEM_H */
|
#endif /* __PLAT_SYSTEM_H */
|
||||||
|
|
27
arch/arm/plat-spear/restart.c
Normal file
27
arch/arm/plat-spear/restart.c
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
/*
|
||||||
|
* arch/arm/plat-spear/restart.c
|
||||||
|
*
|
||||||
|
* SPEAr platform specific restart functions
|
||||||
|
*
|
||||||
|
* Copyright (C) 2009 ST Microelectronics
|
||||||
|
* Viresh Kumar<viresh.kumar@st.com>
|
||||||
|
*
|
||||||
|
* 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>
|
||||||
|
#include <asm/hardware/sp810.h>
|
||||||
|
#include <mach/hardware.h>
|
||||||
|
#include <mach/generic.h>
|
||||||
|
|
||||||
|
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 */
|
||||||
|
sysctl_soft_reset((void __iomem *)VA_SPEAR_SYS_CTRL_BASE);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue