diff options
Diffstat (limited to 'arch/s390/kernel/setup.c')
| -rw-r--r-- | arch/s390/kernel/setup.c | 55 |
1 files changed, 52 insertions, 3 deletions
diff --git a/arch/s390/kernel/setup.c b/arch/s390/kernel/setup.c index b282034452a4..2b2551e3510b 100644 --- a/arch/s390/kernel/setup.c +++ b/arch/s390/kernel/setup.c | |||
| @@ -37,6 +37,7 @@ | |||
| 37 | #include <linux/seq_file.h> | 37 | #include <linux/seq_file.h> |
| 38 | #include <linux/kernel_stat.h> | 38 | #include <linux/kernel_stat.h> |
| 39 | #include <linux/device.h> | 39 | #include <linux/device.h> |
| 40 | #include <linux/notifier.h> | ||
| 40 | 41 | ||
| 41 | #include <asm/uaccess.h> | 42 | #include <asm/uaccess.h> |
| 42 | #include <asm/system.h> | 43 | #include <asm/system.h> |
| @@ -115,6 +116,7 @@ void __devinit cpu_init (void) | |||
| 115 | */ | 116 | */ |
| 116 | char vmhalt_cmd[128] = ""; | 117 | char vmhalt_cmd[128] = ""; |
| 117 | char vmpoff_cmd[128] = ""; | 118 | char vmpoff_cmd[128] = ""; |
| 119 | char vmpanic_cmd[128] = ""; | ||
| 118 | 120 | ||
| 119 | static inline void strncpy_skip_quote(char *dst, char *src, int n) | 121 | static inline void strncpy_skip_quote(char *dst, char *src, int n) |
| 120 | { | 122 | { |
| @@ -146,6 +148,38 @@ static int __init vmpoff_setup(char *str) | |||
| 146 | 148 | ||
| 147 | __setup("vmpoff=", vmpoff_setup); | 149 | __setup("vmpoff=", vmpoff_setup); |
| 148 | 150 | ||
| 151 | static int vmpanic_notify(struct notifier_block *self, unsigned long event, | ||
| 152 | void *data) | ||
| 153 | { | ||
| 154 | if (MACHINE_IS_VM && strlen(vmpanic_cmd) > 0) | ||
| 155 | cpcmd(vmpanic_cmd, NULL, 0, NULL); | ||
| 156 | |||
| 157 | return NOTIFY_OK; | ||
| 158 | } | ||
| 159 | |||
| 160 | #define PANIC_PRI_VMPANIC 0 | ||
| 161 | |||
| 162 | static struct notifier_block vmpanic_nb = { | ||
| 163 | .notifier_call = vmpanic_notify, | ||
| 164 | .priority = PANIC_PRI_VMPANIC | ||
| 165 | }; | ||
| 166 | |||
| 167 | static int __init vmpanic_setup(char *str) | ||
| 168 | { | ||
| 169 | static int register_done __initdata = 0; | ||
| 170 | |||
| 171 | strncpy_skip_quote(vmpanic_cmd, str, 127); | ||
| 172 | vmpanic_cmd[127] = 0; | ||
| 173 | if (!register_done) { | ||
| 174 | register_done = 1; | ||
| 175 | atomic_notifier_chain_register(&panic_notifier_list, | ||
| 176 | &vmpanic_nb); | ||
| 177 | } | ||
| 178 | return 1; | ||
| 179 | } | ||
| 180 | |||
| 181 | __setup("vmpanic=", vmpanic_setup); | ||
| 182 | |||
| 149 | /* | 183 | /* |
| 150 | * condev= and conmode= setup parameter. | 184 | * condev= and conmode= setup parameter. |
| 151 | */ | 185 | */ |
| @@ -289,19 +323,34 @@ void (*_machine_power_off)(void) = do_machine_power_off_nonsmp; | |||
| 289 | 323 | ||
| 290 | void machine_restart(char *command) | 324 | void machine_restart(char *command) |
| 291 | { | 325 | { |
| 292 | console_unblank(); | 326 | if (!in_interrupt() || oops_in_progress) |
| 327 | /* | ||
| 328 | * Only unblank the console if we are called in enabled | ||
| 329 | * context or a bust_spinlocks cleared the way for us. | ||
| 330 | */ | ||
| 331 | console_unblank(); | ||
| 293 | _machine_restart(command); | 332 | _machine_restart(command); |
| 294 | } | 333 | } |
| 295 | 334 | ||
| 296 | void machine_halt(void) | 335 | void machine_halt(void) |
| 297 | { | 336 | { |
| 298 | console_unblank(); | 337 | if (!in_interrupt() || oops_in_progress) |
| 338 | /* | ||
| 339 | * Only unblank the console if we are called in enabled | ||
| 340 | * context or a bust_spinlocks cleared the way for us. | ||
| 341 | */ | ||
| 342 | console_unblank(); | ||
| 299 | _machine_halt(); | 343 | _machine_halt(); |
| 300 | } | 344 | } |
| 301 | 345 | ||
| 302 | void machine_power_off(void) | 346 | void machine_power_off(void) |
| 303 | { | 347 | { |
| 304 | console_unblank(); | 348 | if (!in_interrupt() || oops_in_progress) |
| 349 | /* | ||
| 350 | * Only unblank the console if we are called in enabled | ||
| 351 | * context or a bust_spinlocks cleared the way for us. | ||
| 352 | */ | ||
| 353 | console_unblank(); | ||
| 305 | _machine_power_off(); | 354 | _machine_power_off(); |
| 306 | } | 355 | } |
| 307 | 356 | ||
