Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 279818
b: refs/heads/master
c: 59136ef
h: refs/heads/master
v: v3
  • Loading branch information
Russell King committed Nov 21, 2011
1 parent 83efa51 commit c48fdff
Show file tree
Hide file tree
Showing 32 changed files with 65 additions and 48 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 3f1517a761905c55d1db71cb0afd359d74a76a6c
refs/heads/master: 59136ef3c596606d3eef920dc3e0fdfa2ce52c6f
9 changes: 5 additions & 4 deletions trunk/arch/arm/include/asm/mach/arch.h
Original file line number Diff line number Diff line change
Expand Up @@ -30,10 +30,10 @@ struct machine_desc {
unsigned int video_start; /* start of video RAM */
unsigned int video_end; /* end of video RAM */

unsigned int reserve_lp0 :1; /* never has lp0 */
unsigned int reserve_lp1 :1; /* never has lp1 */
unsigned int reserve_lp2 :1; /* never has lp2 */
unsigned int soft_reboot :1; /* soft reboot */
unsigned char reserve_lp0 :1; /* never has lp0 */
unsigned char reserve_lp1 :1; /* never has lp1 */
unsigned char reserve_lp2 :1; /* never has lp2 */
char restart_mode; /* default restart mode */
void (*fixup)(struct tag *, char **,
struct meminfo *);
void (*reserve)(void);/* reserve mem blocks */
Expand All @@ -45,6 +45,7 @@ struct machine_desc {
#ifdef CONFIG_MULTI_IRQ_HANDLER
void (*handle_irq)(struct pt_regs *);
#endif
void (*restart)(char, const char *);
};

/*
Expand Down
1 change: 1 addition & 0 deletions trunk/arch/arm/include/asm/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,7 @@ extern int __pure cpu_architecture(void);
extern void cpu_init(void);

void arm_machine_restart(char mode, const char *cmd);
void soft_restart(unsigned long);
extern void (*arm_pm_restart)(char str, const char *cmd);

#define UDBG_UNDEFINED (1 << 0)
Expand Down
4 changes: 2 additions & 2 deletions trunk/arch/arm/kernel/machine_kexec.c
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
extern const unsigned char relocate_new_kernel[];
extern const unsigned int relocate_new_kernel_size;

extern void setup_mm_for_reboot(char mode);
extern void setup_mm_for_reboot(void);

extern unsigned long kexec_start_address;
extern unsigned long kexec_indirection_page;
Expand Down Expand Up @@ -114,7 +114,7 @@ void machine_kexec(struct kimage *image)
kexec_reinit();
local_irq_disable();
local_fiq_disable();
setup_mm_for_reboot(0); /* mode is not used, so just pass 0*/
setup_mm_for_reboot();
flush_cache_all();
outer_flush_all();
outer_disable();
Expand Down
35 changes: 21 additions & 14 deletions trunk/arch/arm/kernel/process.c
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ static const char *isa_modes[] = {
"ARM" , "Thumb" , "Jazelle", "ThumbEE"
};

extern void setup_mm_for_reboot(char mode);
extern void setup_mm_for_reboot(void);

static volatile int hlt_counter;

Expand Down Expand Up @@ -92,7 +92,7 @@ static int __init hlt_setup(char *__unused)
__setup("nohlt", nohlt_setup);
__setup("hlt", hlt_setup);

void arm_machine_restart(char mode, const char *cmd)
void soft_restart(unsigned long addr)
{
/* Disable interrupts first */
local_irq_disable();
Expand All @@ -103,7 +103,7 @@ void arm_machine_restart(char mode, const char *cmd)
* we may need it to insert some 1:1 mappings so that
* soft boot works.
*/
setup_mm_for_reboot(mode);
setup_mm_for_reboot();

/* Clean and invalidate caches */
flush_cache_all();
Expand All @@ -114,18 +114,17 @@ void arm_machine_restart(char mode, const char *cmd)
/* Push out any further dirty data, and ensure cache is empty */
flush_cache_all();

/*
* Now call the architecture specific reboot code.
*/
arch_reset(mode, cmd);
cpu_reset(addr);
}

/*
* Whoops - the architecture was unable to reboot.
* Tell the user!
*/
mdelay(1000);
printk("Reboot failed -- System halted\n");
while (1);
void arm_machine_restart(char mode, const char *cmd)
{
/* Disable interrupts first */
local_irq_disable();
local_fiq_disable();

/* Call the architecture specific reboot code. */
arch_reset(mode, cmd);
}

/*
Expand Down Expand Up @@ -250,7 +249,15 @@ void machine_power_off(void)
void machine_restart(char *cmd)
{
machine_shutdown();

arm_pm_restart(reboot_mode, cmd);

/* Give a grace period for failure to restart of 1s */
mdelay(1000);

/* Whoops - the platform was unable to reboot. Tell the user! */
printk("Reboot failed -- System halted\n");
while (1);
}

void __show_regs(struct pt_regs *regs)
Expand Down
7 changes: 5 additions & 2 deletions trunk/arch/arm/kernel/setup.c
Original file line number Diff line number Diff line change
Expand Up @@ -902,8 +902,8 @@ void __init setup_arch(char **cmdline_p)
machine_desc = mdesc;
machine_name = mdesc->name;

if (mdesc->soft_reboot)
reboot_setup("s");
if (mdesc->restart_mode)
reboot_setup(&mdesc->restart_mode);

init_mm.start_code = (unsigned long) _text;
init_mm.end_code = (unsigned long) _etext;
Expand All @@ -922,6 +922,9 @@ void __init setup_arch(char **cmdline_p)
paging_init(mdesc);
request_standard_resources(mdesc);

if (mdesc->restart)
arm_pm_restart = mdesc->restart;

unflatten_device_tree();

#ifdef CONFIG_SMP
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-clps711x/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ static inline void arch_idle(void)

static inline void arch_reset(char mode, const char *cmd)
{
cpu_reset(0);
soft_restart(0);
}

#endif
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-ebsa110/core.c
Original file line number Diff line number Diff line change
Expand Up @@ -283,7 +283,7 @@ MACHINE_START(EBSA110, "EBSA110")
.atag_offset = 0x400,
.reserve_lp0 = 1,
.reserve_lp2 = 1,
.soft_reboot = 1,
.restart_mode = 's',
.map_io = ebsa110_map_io,
.init_irq = ebsa110_init_irq,
.timer = &ebsa110_timer,
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-ebsa110/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,6 @@ static inline void arch_idle(void)
asm volatile ("mcr p15, 0, ip, c15, c1, 2" : : : "cc");
}

#define arch_reset(mode, cmd) cpu_reset(0x80000000)
#define arch_reset(mode, cmd) soft_restart(0x80000000)

#endif
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-footbridge/cats-hw.c
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ fixup_cats(struct tag *tags, char **cmdline, struct meminfo *mi)
MACHINE_START(CATS, "Chalice-CATS")
/* Maintainer: Philip Blundell */
.atag_offset = 0x100,
.soft_reboot = 1,
.restart_mode = 's',
.fixup = fixup_cats,
.map_io = footbridge_map_io,
.init_irq = footbridge_init_irq,
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-footbridge/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ static inline void arch_reset(char mode, const char *cmd)
/*
* Jump into the ROM
*/
cpu_reset(0x41000000);
soft_restart(0x41000000);
} else {
if (machine_is_netwinder()) {
/* open up the SuperIO chip
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-iop32x/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,5 +28,5 @@ static inline void arch_reset(char mode, const char *cmd)
*IOP3XX_PCSR = 0x30;

/* Jump into ROM at address 0 */
cpu_reset(0);
soft_restart(0);
}
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-iop33x/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -19,5 +19,5 @@ static inline void arch_reset(char mode, const char *cmd)
*IOP3XX_PCSR = 0x30;

/* Jump into ROM at address 0 */
cpu_reset(0);
soft_restart(0);
}
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-ixp4xx/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ static inline void arch_reset(char mode, const char *cmd)
{
if ( 1 && mode == 's') {
/* Jump into ROM at address 0 */
cpu_reset(0);
soft_restart(0);
} else {
/* Use on-chip reset capability */

Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-ks8695/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ static void arch_reset(char mode, const char *cmd)
unsigned int reg;

if (mode == 's')
cpu_reset(0);
soft_restart(0);

/* disable timer0 */
reg = __raw_readl(KS8695_TMR_VA + KS8695_TMCON);
Expand Down
4 changes: 2 additions & 2 deletions trunk/arch/arm/mach-mmp/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@ static inline void arch_idle(void)
static inline void arch_reset(char mode, const char *cmd)
{
if (cpu_is_pxa168())
cpu_reset(0xffff0000);
soft_restart(0xffff0000);
else
cpu_reset(0);
soft_restart(0);
}
#endif /* __ASM_MACH_SYSTEM_H */
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-mxs/system.c
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ void arch_reset(char mode, const char *cmd)
mdelay(50);

/* We'll take a jump through zero as a poor second */
cpu_reset(0);
soft_restart(0);
}

static int __init mxs_arch_reset_init(void)
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-pnx4008/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ static void arch_idle(void)

static inline void arch_reset(char mode, const char *cmd)
{
cpu_reset(0);
soft_restart(0);
}

#endif
1 change: 1 addition & 0 deletions trunk/arch/arm/mach-pxa/mioa701.c
Original file line number Diff line number Diff line change
Expand Up @@ -752,6 +752,7 @@ static void mioa701_machine_exit(void)

MACHINE_START(MIOA701, "MIO A701")
.atag_offset = 0x100,
.restart_mode = 's',
.map_io = &pxa27x_map_io,
.init_irq = &pxa27x_init_irq,
.handle_irq = &pxa27x_handle_irq,
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-pxa/reset.c
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ void arch_reset(char mode, const char *cmd)
switch (mode) {
case 's':
/* Jump into ROM at address 0 */
cpu_reset(0);
soft_restart(0);
break;
case 'g':
do_gpio_reset();
Expand Down
3 changes: 3 additions & 0 deletions trunk/arch/arm/mach-pxa/spitz.c
Original file line number Diff line number Diff line change
Expand Up @@ -982,6 +982,7 @@ static void __init spitz_fixup(struct tag *tags, char **cmdline,

#ifdef CONFIG_MACH_SPITZ
MACHINE_START(SPITZ, "SHARP Spitz")
.restart_mode = 'g',
.fixup = spitz_fixup,
.map_io = pxa27x_map_io,
.init_irq = pxa27x_init_irq,
Expand All @@ -993,6 +994,7 @@ MACHINE_END

#ifdef CONFIG_MACH_BORZOI
MACHINE_START(BORZOI, "SHARP Borzoi")
.restart_mode = 'g',
.fixup = spitz_fixup,
.map_io = pxa27x_map_io,
.init_irq = pxa27x_init_irq,
Expand All @@ -1004,6 +1006,7 @@ MACHINE_END

#ifdef CONFIG_MACH_AKITA
MACHINE_START(AKITA, "SHARP Akita")
.restart_mode = 'g',
.fixup = spitz_fixup,
.map_io = pxa27x_map_io,
.init_irq = pxa27x_init_irq,
Expand Down
1 change: 1 addition & 0 deletions trunk/arch/arm/mach-pxa/tosa.c
Original file line number Diff line number Diff line change
Expand Up @@ -970,6 +970,7 @@ static void __init fixup_tosa(struct tag *tags, char **cmdline,
}

MACHINE_START(TOSA, "SHARP Tosa")
.restart_mode = 'g',
.fixup = fixup_tosa,
.map_io = pxa25x_map_io,
.nr_irqs = TOSA_NR_IRQS,
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-rpc/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -23,5 +23,5 @@ static inline void arch_reset(char mode, const char *cmd)
/*
* Jump into the ROM
*/
cpu_reset(0);
soft_restart(0);
}
4 changes: 2 additions & 2 deletions trunk/arch/arm/mach-s3c2410/include/mach/system-reset.h
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ static void
arch_reset(char mode, const char *cmd)
{
if (mode == 's') {
cpu_reset(0);
soft_restart(0);
}

if (s3c24xx_reset_hook)
Expand All @@ -28,5 +28,5 @@ arch_reset(char mode, const char *cmd)
arch_wdt_reset();

/* we'll take a jump through zero as a poor second */
cpu_reset(0);
soft_restart(0);
}
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-s3c64xx/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ static void arch_reset(char mode, const char *cmd)
arch_wdt_reset();

/* if all else fails, or mode was for soft, jump to 0 */
cpu_reset(0);
soft_restart(0);
}

#endif /* __ASM_ARCH_IRQ_H */
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-sa1100/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ static inline void arch_reset(char mode, const char *cmd)
{
if (mode == 's') {
/* Jump into ROM at address 0 */
cpu_reset(0);
soft_restart(0);
} else {
/* Use on-chip reset capability */
RSRR = RSRR_SWR;
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-shmobile/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ static inline void arch_idle(void)

static inline void arch_reset(char mode, const char *cmd)
{
cpu_reset(0);
soft_restart(0);
}

#endif
2 changes: 1 addition & 1 deletion trunk/arch/arm/mach-w90x900/include/mach/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ static void arch_reset(char mode, const char *cmd)
{
if (mode == 's') {
/* Jump into ROM at address 0 */
cpu_reset(0);
soft_restart(0);
} else {
__raw_writel(WTE | WTRE | WTCLK, WTCR);
}
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mm/idmap.c
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ void identity_mapping_del(pgd_t *pgd, unsigned long addr, unsigned long end)
* the user-mode pages. This will then ensure that we have predictable
* results when turning the mmu off
*/
void setup_mm_for_reboot(char mode)
void setup_mm_for_reboot(void)
{
/*
* We need to access to user-mode page tables here. For kernel threads
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/mm/nommu.c
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ void __init paging_init(struct machine_desc *mdesc)
/*
* We don't need to do anything here for nommu machines.
*/
void setup_mm_for_reboot(char mode)
void setup_mm_for_reboot(void)
{
}

Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/plat-mxc/system.c
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ void arch_reset(char mode, const char *cmd)
mdelay(50);

/* we'll take a jump through zero as a poor second */
cpu_reset(0);
soft_restart(0);
}

void mxc_arch_reset_init(void __iomem *base)
Expand Down
2 changes: 1 addition & 1 deletion trunk/arch/arm/plat-spear/include/plat/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ static inline void arch_reset(char mode, const char *cmd)
{
if (mode == 's') {
/* software reset, Jump into ROM at address 0 */
cpu_reset(0);
soft_restart(0);
} else {
/* hardware reset, Use on-chip reset capability */
sysctl_soft_reset((void __iomem *)VA_SPEAR_SYS_CTRL_BASE);
Expand Down

0 comments on commit c48fdff

Please sign in to comment.