diff options
author | Robin Holt <holt@sgi.com> | 2013-07-08 19:01:39 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-07-09 13:33:29 -0400 |
commit | 16d6d5b00ee75307bab7e4ede9452c97b28f30e2 (patch) | |
tree | d38e988a966758be0a3f75f88009de532904c68a | |
parent | 58591942789abe1ea18e3fb1e8d8502c70060c29 (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.h | 3 | ||||
-rw-r--r-- | arch/arm/kernel/process.c | 8 | ||||
-rw-r--r-- | arch/arm/kernel/setup.c | 6 | ||||
-rw-r--r-- | arch/arm/mach-footbridge/cats-hw.c | 2 |
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 | ||
15 | struct tag; | 16 | struct tag; |
16 | struct meminfo; | 17 | struct 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 | ||
178 | static char reboot_mode = 'h'; | 178 | enum reboot_mode reboot_mode = REBOOT_HARD; |
179 | 179 | ||
180 | int __init reboot_setup(char *str) | 180 | static 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 | ||
75 | extern void paging_init(struct machine_desc *desc); | 75 | extern void paging_init(struct machine_desc *desc); |
76 | extern void sanity_check_meminfo(void); | 76 | extern void sanity_check_meminfo(void); |
77 | extern void reboot_setup(char *str); | 77 | extern enum reboot_mode reboot_mode; |
78 | extern void setup_dma_zone(struct machine_desc *desc); | 78 | extern void setup_dma_zone(struct machine_desc *desc); |
79 | 79 | ||
80 | unsigned int processor_id; | 80 | unsigned 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) | |||
86 | MACHINE_START(CATS, "Chalice-CATS") | 86 | MACHINE_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, |