aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRobin Holt <holt@sgi.com>2013-07-08 19:01:39 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2013-07-09 13:33:29 -0400
commit16d6d5b00ee75307bab7e4ede9452c97b28f30e2 (patch)
treed38e988a966758be0a3f75f88009de532904c68a
parent58591942789abe1ea18e3fb1e8d8502c70060c29 (diff)
reboot: arm: prepare reboot_mode for moving to generic kernel code
Prepare for the moving the parsing of reboot= to the generic kernel code by making reboot_mode into a more generic form. Signed-off-by: Robin Holt <holt@sgi.com> Cc: Russell King <rmk+kernel@arm.linux.org.uk> Cc: Russ Anderson <rja@sgi.com> Cc: Robin Holt <holt@sgi.com> Cc: H. Peter Anvin <hpa@zytor.com> Cc: Guan Xuetao <gxt@mprc.pku.edu.cn> Acked-by: Russell King <rmk+kernel@arm.linux.org.uk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--arch/arm/include/asm/mach/arch.h3
-rw-r--r--arch/arm/kernel/process.c8
-rw-r--r--arch/arm/kernel/setup.c6
-rw-r--r--arch/arm/mach-footbridge/cats-hw.c2
4 files changed, 10 insertions, 9 deletions
diff --git a/arch/arm/include/asm/mach/arch.h b/arch/arm/include/asm/mach/arch.h
index 75bf07910b81..fdf62b4246b0 100644
--- a/arch/arm/include/asm/mach/arch.h
+++ b/arch/arm/include/asm/mach/arch.h
@@ -11,6 +11,7 @@
11#include <linux/types.h> 11#include <linux/types.h>
12 12
13#ifndef __ASSEMBLY__ 13#ifndef __ASSEMBLY__
14#include <linux/reboot.h>
14 15
15struct tag; 16struct tag;
16struct meminfo; 17struct meminfo;
@@ -43,7 +44,7 @@ struct machine_desc {
43 unsigned char reserve_lp0 :1; /* never has lp0 */ 44 unsigned char reserve_lp0 :1; /* never has lp0 */
44 unsigned char reserve_lp1 :1; /* never has lp1 */ 45 unsigned char reserve_lp1 :1; /* never has lp1 */
45 unsigned char reserve_lp2 :1; /* never has lp2 */ 46 unsigned char reserve_lp2 :1; /* never has lp2 */
46 char restart_mode; /* default restart mode */ 47 enum reboot_mode reboot_mode; /* default restart mode */
47 struct smp_operations *smp; /* SMP operations */ 48 struct smp_operations *smp; /* SMP operations */
48 bool (*smp_init)(void); 49 bool (*smp_init)(void);
49 void (*fixup)(struct tag *, char **, 50 void (*fixup)(struct tag *, char **,
diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c
index 7f1efcd4a6e9..2d544062fd7d 100644
--- a/arch/arm/kernel/process.c
+++ b/arch/arm/kernel/process.c
@@ -175,14 +175,14 @@ void arch_cpu_idle(void)
175 default_idle(); 175 default_idle();
176} 176}
177 177
178static char reboot_mode = 'h'; 178enum reboot_mode reboot_mode = REBOOT_HARD;
179 179
180int __init reboot_setup(char *str) 180static int __init reboot_setup(char *str)
181{ 181{
182 reboot_mode = str[0]; 182 if ('s' == str[0])
183 reboot_mode = REBOOT_SOFT;
183 return 1; 184 return 1;
184} 185}
185
186__setup("reboot=", reboot_setup); 186__setup("reboot=", reboot_setup);
187 187
188/* 188/*
diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c
index 9b653278c9e8..63af9a7ae512 100644
--- a/arch/arm/kernel/setup.c
+++ b/arch/arm/kernel/setup.c
@@ -74,7 +74,7 @@ __setup("fpe=", fpe_setup);
74 74
75extern void paging_init(struct machine_desc *desc); 75extern void paging_init(struct machine_desc *desc);
76extern void sanity_check_meminfo(void); 76extern void sanity_check_meminfo(void);
77extern void reboot_setup(char *str); 77extern enum reboot_mode reboot_mode;
78extern void setup_dma_zone(struct machine_desc *desc); 78extern void setup_dma_zone(struct machine_desc *desc);
79 79
80unsigned int processor_id; 80unsigned int processor_id;
@@ -861,8 +861,8 @@ void __init setup_arch(char **cmdline_p)
861 861
862 setup_dma_zone(mdesc); 862 setup_dma_zone(mdesc);
863 863
864 if (mdesc->restart_mode) 864 if (mdesc->reboot_mode != REBOOT_HARD)
865 reboot_setup(&mdesc->restart_mode); 865 reboot_mode = mdesc->reboot_mode;
866 866
867 init_mm.start_code = (unsigned long) _text; 867 init_mm.start_code = (unsigned long) _text;
868 init_mm.end_code = (unsigned long) _etext; 868 init_mm.end_code = (unsigned long) _etext;
diff --git a/arch/arm/mach-footbridge/cats-hw.c b/arch/arm/mach-footbridge/cats-hw.c
index 6987a09ec219..9669cc0b6318 100644
--- a/arch/arm/mach-footbridge/cats-hw.c
+++ b/arch/arm/mach-footbridge/cats-hw.c
@@ -86,7 +86,7 @@ fixup_cats(struct tag *tags, char **cmdline, struct meminfo *mi)
86MACHINE_START(CATS, "Chalice-CATS") 86MACHINE_START(CATS, "Chalice-CATS")
87 /* Maintainer: Philip Blundell */ 87 /* Maintainer: Philip Blundell */
88 .atag_offset = 0x100, 88 .atag_offset = 0x100,
89 .restart_mode = 's', 89 .reboot_mode = REBOOT_SOFT,
90 .fixup = fixup_cats, 90 .fixup = fixup_cats,
91 .map_io = footbridge_map_io, 91 .map_io = footbridge_map_io,
92 .init_irq = footbridge_init_irq, 92 .init_irq = footbridge_init_irq,