On Wed, 2011-11-30 at 13:45 +0100, Mike Galbraith wrote: > On Wed, 2011-11-30 at 11:24 +0100, Thomas Gleixner wrote: > > On Wed, 30 Nov 2011, Mike Galbraith wrote: > > > @@ -131,11 +155,18 @@ void softirq_check_pending_idle(void) > > > */ > > > static void wakeup_softirqd(void) > > > { > > > - /* Interrupts are disabled: no need to stop preemption */ > > > - struct task_struct *tsk = __this_cpu_read(ksoftirqd); > > > + struct task_struct *tsk; > > > + u32 pending = local_softirq_pending(), mask, i; > > > > > > - if (tsk && tsk->state != TASK_RUNNING) > > > - wake_up_process(tsk); > > > + /* Interrupts are disabled: no need to stop preemption */ > > > + for (i = 0; pending && i < NR_SOFTIRQ_THREADS; i++) { > > > + mask = __get_cpu_var(ksoftirqd)[i].mask; > > > + if (!(pending & mask)) > > > + continue; > > > + tsk = __get_cpu_var(ksoftirqd)[i].tsk; > > > + if (tsk && tsk->state != TASK_RUNNING) > > > + wake_up_process(tsk); > > > + } > > > } > > > > Dammned serious is seems. :) 'course here I should have just used the busy bits directly. -Mike -- To unsubscribe from this list: send the line "unsubscribe linux-rt-users" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html