> You're missing the effect that irq throttling has: it results in a system
> that is effectively running in "polled" mode. Information does get
> processed, and thruput remains high, it is just that some additional
> latency is found in operations. Which is acceptable by definition as
> the system is under extreme load.
So, when you turn off the IRQs, are the drivers somehow made
aware of this so that they can go into polling mode? That might
fix the 10ms latency/starvation problem that bothers me...
Assuming it is fairly easy to put a driver into polling mode, if
you are explicitly told to do so, maybe this generic IRQ coelescing
could be the thing that generically poked all drivers. Drivers
that are too primitive to understand or deal with polling can just
wait their 10ms, but smarter ones will happily poll away untill told
not to by the IRQ load limiter...
> That information will eventually be picked up. I doubt the extra latency
> will be of significant note. If it is, you've got realtime concerns,
> which is not our goal to address at this time.
I'm more worried about dropped pkts. If you can receive 10k packets per second,
then you can receive (lose) 100 packets in 10ms....
> > and what is this "known safe limit"? ;->
> It's system dependant. It's load dependant. For a short list of the number
> of factors that you have to include to compute this:
> - number of cycles userspace needs to run
> - number of cache misses that userspace is forced to
> incur due to irq handlers running
> - amount of time to dedicate to the irq handler
> - variance due to error path handling
> - increased system cpu usage due to higher memory load
> - front side bus speed of cpu
> - speed of cpu
> - length of cpu pipelines
> - time spent waiting on io cycles
Hopefully, at the very worst, you can have configurables like:
- User-space responsiveness v/s kernel IRQ handling,
range of 1 to 100, where 100 == userRules.
- Latency: 1 who cares, so long as work happens, to 100: Fast and furious, or not at all.
In otherwords, for gods sake don't make me have to understand how my
cache and CPU pipeline works!! :)
- Another Ben
-- Ben Greear <email@example.com> <Ben_Greear@excite.com> President of Candela Technologies Inc http://www.candelatech.com ScryMUD: http://scry.wanfear.com http://scry.wanfear.com/~greear - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to firstname.lastname@example.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/