Prev: virtio-balloon: allow hypervisor refuse locking some pages
Next: [PATCH 16/24] power: fix dangling pointers
From: Rafael J. Wysocki on 20 Mar 2010 10:10 Hi Peter, Your commit 3f6da3905398826d85731247e7fbcf53400c18bd (perf: Rework and fix the arch CPU-hotplug hooks) unfortunately broke suspend to RAM (probably hibernation too, but I haven't checked) on my HP nx6325. I also expect more (if not all) AMD-based boxes to be broken by it. The machine simply hangs solid while trying to disable CPU1 during suspend. The patch below fixes it, although I'm not exactly sure why calling amd_pmu_cpu_offline() during suspend causes the hang to happen. If there's a better way to fix this, please let me know. Rafael --- From: Rafael J. Wysocki <rjw(a)sisk.pl> Subject: x86 / perf: Fix suspend to RAM on HP nx6325 Commit 3f6da3905398826d85731247e7fbcf53400c18bd (perf: Rework and fix the arch CPU-hotplug hooks) broke suspend to RAM on my HP nx6325 (and most likely on other AMD-based boxes too) by allowing amd_pmu_cpu_offline() to be executed for CPUs that are going offline as part of the suspend process. Fix this by modifying x86_pmu_notifier() so that x86_pmu.cpu_dead(cpu) is only called if the CPU_TASK_FROZEN bit is unset. Signed-off-by: Rafael J. Wysocki <rjw(a)sisk.pl> --- arch/x86/kernel/cpu/perf_event.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) Index: linux-2.6/arch/x86/kernel/cpu/perf_event.c =================================================================== --- linux-2.6.orig/arch/x86/kernel/cpu/perf_event.c +++ linux-2.6/arch/x86/kernel/cpu/perf_event.c @@ -1334,18 +1334,21 @@ x86_pmu_notifier(struct notifier_block * { unsigned int cpu = (long)hcpu; - switch (action & ~CPU_TASKS_FROZEN) { + switch (action) { case CPU_UP_PREPARE: + case CPU_UP_PREPARE_FROZEN: if (x86_pmu.cpu_prepare) x86_pmu.cpu_prepare(cpu); break; case CPU_STARTING: + case CPU_STARTING_FROZEN: if (x86_pmu.cpu_starting) x86_pmu.cpu_starting(cpu); break; case CPU_DYING: + case CPU_DYING_FROZEN: if (x86_pmu.cpu_dying) x86_pmu.cpu_dying(cpu); break; -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |