[ added Thomas Gleixner to Cc] On Tue, 2009-09-08 at 10:01 -0700, Stephen Hemminger wrote: > On Tue, 08 Sep 2009 12:40:23 -0400 > Steven Rostedt <rostedt@xxxxxxxxxxx> wrote: > > > On Tue, 2009-09-08 at 09:11 -0700, Stephen Hemminger wrote: > > > > > > > Process context is too slow. > > > > > > > > Well, I'm hoping to prove the opposite. I'm working on some stuff that I > > > > plan to present at Linux Plumbers. I've been too distracted by other > > > > things, but hopefully I'll have some good numbers to present by then. > > > > > > > > > > > > > That's great, does it keep the good properties of NAPI (irq disabling > > > and throttling?) > > > > Not exactly sure what you mean by throttling, but I'm assuming it will. > > > > As for irqs disabling, I'm trying to avoid doing that. Note, the device > > will have its interrupts disabled, but not all other devices will. > > > > -- Steve > > > > > > The way NAPI works is that in irq routine, the device disables interrupts > then schedules processing packets, when processing is done irq's are re-enabled. > This means that if machine is being flooded, irq's stay off, and the packets > get discarded (because device hardware ring is full), rather than in software > (because software receive queue is full). That sounds exactly like what threaded IRQs will do. When an interrupt comes in, the device driver will disable the device interrupts, and then the device irq thread handler is awoken. The device irq handler will handle all the packets. If new packets come in, and the hardware ring buffer is full, those packets will be dropped. When the irq handler thread is done processing all pending packets, it will re-enable the device's interrupts and go to sleep. Yeah, looking at the NAPI code, it does seem to follow what threaded interrupts do. -- Steve -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html