On Thu, Dec 14, 2006 at 12:51:14PM -0800, [EMAIL PROTECTED] wrote: > On Thu, 14 Dec 2006, Linas Vepstas wrote: > > >On Wed, Nov 08, 2006 at 07:38:12AM +1100, Benjamin Herrenschmidt wrote: > >> > >>What about Linas patches to do interrupt mitigation with NAPI polling ? > >>That didn't end up working ? > > > >It seems to be "working as designed", which is different than "working > >as naively expected". > > > >For large packets: > >-- a packet comes in > >-- rx interrupt generated > >-- rx interrupts turned off > >-- tcp poll function runs, receives packet > >-- completes all work before next packet has arrived, > > so interupts are turned back on. > >-- go to start > > > >This results in a high number of interrupts, and a high cpu usage. > >We were able to prove that napi works by stalling in the poll function > >just long enough to allow the next packet to arrive. In this case, > >napi works great, and number of irqs is vastly reduced. > >.... > > This sounds awfully familiar. We went through the same > with the tg3 driver on Altix. In that case we succeeded > getting interrupt coalescence added to the driver, which > ended up working pretty well for us. See the thread > beginning with: > > http://oss.sgi.com/archives/netdev/2005-05/msg00497.html > > if you're interested.
I'm interested. The tg3 seems to have "hardware coalescing", which, from what I can tell, is a way of delaying an RX interrupt for some number of microseconds? I assume there's nothing more to it than that? The spider has some suggestively named registers and functions, hinting that it can similarly delay an RX interupt, but the docs are opaque and mysteriously worded, so I cannot really tell. Perhaps Ishizaki Kou can clue us in? > As for the "stalling NAPI" idea, Jamal did a bit of work > with that idea and wrote it up in: > > www.kernel.org/pub/linux/kernel/people/hadi/docs/UKUUG2005.pdf Reading now ... --linas - To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html