X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=kernel%2Fsoftlockup.c;h=b5c3b94e01ce7408a9f3d0dae310cff0a6939a36;hb=5d22a312b7afddaed3cbb2fffb3cceb0c22a6cf5;hp=14c7faf02909e8e4879a057406416a43a34b3fdf;hpb=63518472c05a351d779f35803e6ccfb361ae630a;p=linux-2.6 diff --git a/kernel/softlockup.c b/kernel/softlockup.c index 14c7faf029..b5c3b94e01 100644 --- a/kernel/softlockup.c +++ b/kernel/softlockup.c @@ -36,7 +36,7 @@ static struct notifier_block panic_block = { void touch_softlockup_watchdog(void) { - per_cpu(touch_timestamp, raw_smp_processor_id()) = jiffies; + __raw_get_cpu_var(touch_timestamp) = jiffies; } EXPORT_SYMBOL(touch_softlockup_watchdog); @@ -127,6 +127,8 @@ cpu_callback(struct notifier_block *nfb, unsigned long action, void *hcpu) break; #ifdef CONFIG_HOTPLUG_CPU case CPU_UP_CANCELED: + if (!per_cpu(watchdog_task, hotcpu)) + break; /* Unbind so it can run. Fall thru. */ kthread_bind(per_cpu(watchdog_task, hotcpu), any_online_cpu(cpu_online_map));