Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- From: Peter Zijlstra <peterz@xxxxxxxxxxxxx>
- Date: Fri, 27 Feb 2009 09:05:10 +0100
On Thu, 2009-02-26 at 23:48 -0800, Andrew Morton wrote:
I was actually kinda surprised by the patch - it needs moderate changes
to each driver. I'd have thought that it would be possible to arrange for
_all_ drivers to have their interrupt handlers automagically called from
process context with no driver changes.
Did anyone ever try that? I think they did...
Yes, current preempt-rt does exactly that, as mentioned in the
changelog. That same changelog also mentions why this isn't such a hot
idea:
"The implementation provides an opt-in mechanism to convert drivers to
the threaded interrupt handler model contrary to the preempt-rt patch
where the threaded handlers are enabled by a brute force switch. The
brute force switch is suboptimal as it does not change the interrupt
handler -> tasklet/softirq interaction problems, but was the only way
which was possible for the limited man power of the preempt-rt
developers."
So the idea is that we want people to re-think and change their
interrupt routines to take advantage of the benefits of threaded
interrupts and avoid the endless context switching between threaded
interrupts handler, softirq/tasklet/workqueue contexts, which preempt-rt
now has.
The only way to avoid that is by pushing all softirq/tasklet/worklet
code into the threaded handler, and the only way to do that is by
reworking the drivers.
Since there are too many drivers to count on our few hands, we need an
opt-in, so that we can gradually migrate towards this scheme.
OK, fair enough, good decision.
What is the plan (if any) for integrating threaded interrupt handlers
with softirqs? I guess things will "just work" at present, and
threaded softirqs happen in a later patch?
Thing is, stuff that now needs softirq could be directly done in the
threaded handler, ergo softirq usage should decline (and hopefully
disappear all together - famous last words).
We only use softirq/workqueues/tasklets because we need a preemptible
environment, which the traditional irq handler didn't provide. With
threaded interrupts we do have that.
I'd have thought that the softirq latency could get quite a bit worse
with this proposed threaded-irq patch?
Due to the propagation of wakeups? irq wakes up thread, thread wakes up
softirq, etc?
Yes it would, another good reason to simply use the threaded handler to
do whatever the softirq used to do, no?
I suppose we could just run the softirq handlers directly after running
the irq handler, from the IRQ thread. Rather than having to poke
softirqd all the time?
One could I suppose, except that softirqs are per-cpu and threaded
interrupts are not, so they don't map that well. We played around with
this on preempt-rt for a while, but it kept on breaking stuff.
Its all a lot more tracktable when you get to change the driver, as you
have more information.
Thwap me if this was all in whatever-changelog-that-was as well ;)
Hehe, no you got some good points this time around ;-)
Also...
Given that this threaded-irq code appears to be new and not very tested
in -rt, I think it would be a good idea to convert some popular drivers
(e1000/e1000e) so that the core code gets a good thrashing before we
merge it.
Right, Thomas did the EHCI usb driver, the network driver you propose is
a tad hard since it relies on the whole network stack softirq stuff.
Re-working the whole net-stack to make use of threaded handlers is a
massive undertaking -- although I seem to remember someone doing it a
few years back and seeing a general performance improvement, Thomas
still got a link to that work?
But yes, it would be prudent to convert a few frequently used driver to
this model before merging I suppose.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
- Follow-Ups:
- Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- From: Arjan van de Ven
- Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- From: Andrew Morton
- Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- References:
- [patch 0/4] genirq: add infrastructure for threaded interrupt handlers V2
- From: Thomas Gleixner
- [patch 4/4] genirq: add support for threaded interrupt handlers
- From: Thomas Gleixner
- Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- From: Andrew Morton
- Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- From: Arjan van de Ven
- Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- From: Andrew Morton
- Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- From: Peter Zijlstra
- Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- From: Andrew Morton
- [patch 0/4] genirq: add infrastructure for threaded interrupt handlers V2
- Prev by Date: Re: [PATCH] change cpuacct usage percpu format v2
- Next by Date: Re: [PATCH] new irq tracer
- Previous by thread: Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- Next by thread: Re: [patch 4/4] genirq: add support for threaded interrupt handlers
- Index(es):
Relevant Pages
|