From mboxrd@z Thu Jan 1 00:00:00 1970 From: Thomas Gleixner Subject: Re: [ANNOUNCE] 2.6.31.2-rt13 Date: Tue, 6 Oct 2009 22:07:53 +0200 (CEST) Message-ID: References: <3efb10970910061123k2b6826bci11f0f42509173b26@mail.gmail.com> Mime-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Cc: LKML , rt-users To: Remy Bohmer Return-path: In-Reply-To: Sender: linux-kernel-owner@vger.kernel.org List-Id: linux-rt-users.vger.kernel.org On Tue, 6 Oct 2009, Thomas Gleixner wrote: > On Tue, 6 Oct 2009, Remy Bohmer wrote: > > But I was wondering if you missed this one: > > http://patchwork.kernel.org/patch/50044/ > > Yup, slipped through. Queued for the next release. Correction. I dropped the patch as it is just a sloppy work around. Why creating the thread in the first place ? Real fix below. Thanks, tglx --- diff --git a/kernel/softirq.c b/kernel/softirq.c index aae8d45..3526976 100644 --- a/kernel/softirq.c +++ b/kernel/softirq.c @@ -1161,6 +1161,8 @@ static int __cpuinit cpu_callback(struct notifier_block *nfb, per_cpu(ksoftirqd, hotcpu)[i].tsk = NULL; } for (i = 0; i < NR_SOFTIRQS; i++) { + if (!softirq_names[i]) + continue; p = kthread_create(ksoftirqd, &per_cpu(ksoftirqd, hotcpu)[i], "sirq-%s/%d", softirq_names[i], @@ -1177,8 +1179,11 @@ static int __cpuinit cpu_callback(struct notifier_block *nfb, break; case CPU_ONLINE: case CPU_ONLINE_FROZEN: - for (i = 0; i < NR_SOFTIRQS; i++) - wake_up_process(per_cpu(ksoftirqd, hotcpu)[i].tsk); + for (i = 0; i < NR_SOFTIRQS; i++) { + p = per_cpu(ksoftirqd, hotcpu)[i].tsk; + if (p) + wake_up_process(p); + } break; #ifdef CONFIG_HOTPLUG_CPU case CPU_UP_CANCELED: @@ -1192,9 +1197,11 @@ static int __cpuinit cpu_callback(struct notifier_block *nfb, for (i = 0; i < NR_SOFTIRQS; i++) { param.sched_priority = MAX_RT_PRIO-1; p = per_cpu(ksoftirqd, hotcpu)[i].tsk; - sched_setscheduler(p, SCHED_FIFO, ¶m); - per_cpu(ksoftirqd, hotcpu)[i].tsk = NULL; - kthread_stop(p); + if (p) { + sched_setscheduler(p, SCHED_FIFO, ¶m); + per_cpu(ksoftirqd, hotcpu)[i].tsk = NULL; + kthread_stop(p); + } } takeover_tasklets(hotcpu); break;