Re: [patch] properly stop devices before poweroff

From: Andrew Morton
Date: Fri Apr 29 2005 - 08:22:28 EST


Pavel Machek <pavel@xxxxxx> wrote:
>
>
> Without this patch, Linux provokes emergency disk shutdowns and
> similar nastiness. It was in SuSE kernels for some time, IIRC.
>

With this patch when running `halt -p' my ia64 Tiger (using
tiger_defconfig) gets a stream of badnesses in iosapic_unregister_intr()
and then hangs up.

Unfortunately it all seems to happen after the serial port has been
disabled because nothing comes out. I set the console to a squitty font
and took a piccy. See
http://www.zip.com.au/~akpm/linux/patches/stuff/dsc02505.jpg

I guess it's an ia64 problem. I'll leave the patch in -mm for now.

>
> --- clean/kernel/sys.c 2005-03-19 00:32:32.000000000 +0100
> +++ linux/kernel/sys.c 2005-03-22 12:20:53.000000000 +0100
> @@ -404,6 +404,7 @@
> case LINUX_REBOOT_CMD_HALT:
> notifier_call_chain(&reboot_notifier_list, SYS_HALT, NULL);
> system_state = SYSTEM_HALT;
> + device_suspend(PMSG_SUSPEND);
> device_shutdown();
> printk(KERN_EMERG "System halted.\n");
> machine_halt();
> @@ -414,6 +415,7 @@
> case LINUX_REBOOT_CMD_POWER_OFF:
> notifier_call_chain(&reboot_notifier_list, SYS_POWER_OFF, NULL);
> system_state = SYSTEM_POWER_OFF;
> + device_suspend(PMSG_SUSPEND);
> device_shutdown();
> printk(KERN_EMERG "Power down.\n");
> machine_power_off();
> @@ -430,6 +432,7 @@
>
> notifier_call_chain(&reboot_notifier_list, SYS_RESTART, buffer);
> system_state = SYSTEM_RESTART;
> + device_suspend(PMSG_FREEZE);
> device_shutdown();
> printk(KERN_EMERG "Restarting system with command '%s'.\n", buffer);
> machine_restart(buffer);
>
> --
> Boycott Kodak -- for their patent abuse against Java.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/