[PATCH] Disable CPU hotplug during suspend
The current suspend code has to be run on one CPU, so we use the CPU hotplug to take the non-boot CPUs offline on SMP machines. However, we should also make sure that these CPUs will not be enabled by someone else after we have disabled them. The functions disable_nonboot_cpus() and enable_nonboot_cpus() are moved to kernel/cpu.c, because they now refer to some stuff in there that should better be static. Also it's better if disable_nonboot_cpus() returns an error instead of panicking if something goes wrong, and enable_nonboot_cpus() has no reason to panic(), because the CPUs may have been enabled by the userland before it tries to take them online. Signed-off-by:Rafael J. Wysocki <rjw@sisk.pl> Acked-by:
Pavel Machek <pavel@ucw.cz> Signed-off-by:
Andrew Morton <akpm@osdl.org> Signed-off-by:
Linus Torvalds <torvalds@osdl.org>
Showing
- include/linux/cpu.h 8 additions, 0 deletionsinclude/linux/cpu.h
- include/linux/suspend.h 0 additions, 8 deletionsinclude/linux/suspend.h
- kernel/cpu.c 118 additions, 20 deletionskernel/cpu.c
- kernel/power/Makefile 0 additions, 2 deletionskernel/power/Makefile
- kernel/power/disk.c 6 additions, 1 deletionkernel/power/disk.c
- kernel/power/main.c 4 additions, 6 deletionskernel/power/main.c
- kernel/power/smp.c 0 additions, 62 deletionskernel/power/smp.c
- kernel/power/user.c 9 additions, 5 deletionskernel/power/user.c
Loading
Please register or sign in to comment