Commit dd1661e2 authored by Russell King's avatar Russell King

ARM: restart: spear: use new restart hook

Hook these platforms restart code into the new restart hook rather
than using arch_reset().
Acked-by: default avatarViresh Kumar <viresh.kumar@st.com>
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent b95ff9fe
...@@ -42,6 +42,8 @@ void __init spear3xx_map_io(void); ...@@ -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") ...@@ -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") ...@@ -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") ...@@ -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); ...@@ -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") ...@@ -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 @@ ...@@ -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 @@ ...@@ -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) ...@@ -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 */
/*
* 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);
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment