Re: [patch] big IRQ lock removal, 2.5.27-G0

Oleg Nesterov (oleg@tv-sign.ru)
Wed, 24 Jul 2002 03:40:53 +0400


Hello.

I can't understand the preempt_count() check in irq_exit()
and local_bh_enable(). Did you meant irq_count() instead?
I beleive preempt_disable() should not disable soft interrupts.

In local_bh_enable() it is probably unneeded at all, because
nested local_bh_disable() is rare (i think), and do_softirq()
checks in_interrupt().

Now suppose preempt_count() & PREEMPT_MASK == 0.

Then local_bh_enable() has a small preemptible window between
__local_bh_enable() and do_softirq()->local_irq_save(flags).
It is only latency problem.

But in irq_exit() case interrupt context may be preempted
while doing wakeup_softirqd(cpu) after __local_bh_enable()
in do_softirq().

So i suggest something like this pseudo code:

__preempt_hack(offset)
{
barrier();
preempt_count() -= offset
#ifdef CONFIG_PREEMPT
- 1
#endif
;
}

irq_exit()
{
__preempt_hack(HARDIRQ_OFFSET);
if (unlikely(!irq_count() &&
softirq_pending(smp_processor_id())))
do_softirq();
preempt_enable_no_resched();
}

local_bh_enable()
{
__preempt_hack(SOFTIRQ_OFFSET);
if (unlikely(!irq_count() &&
softirq_pending(smp_processor_id())))
do_softirq();
preempt_enable();
}

Or just add extra preempt_disable() in both functions to kill
terrible __preempt_hack().

Sorry, i have no remove-irqlock patches applied, so can't
suggest diff.

Oleg.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/