[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <Pine.LNX.4.61.0612141244160.30447@localhost.localdomain>
Date: Thu, 14 Dec 2006 12:51:14 -0800 (PST)
From: akepner@....com
To: Linas Vepstas <linas@...tin.ibm.com>
cc: Benjamin Herrenschmidt <benh@...nel.crashing.org>,
James K Lewis <jklewis@...ibm.com>,
Arnd Bergmann <arnd@...db.de>,
"cbe-oss-dev@...abs.org" <cbe-oss-dev@...abs.org>,
cbe-oss-dev-bounces+jklewis=us.ibm.com@...abs.org,
Christoph Hellwig <hch@....de>, netdev@...r.kernel.org
Subject: Re: NAPI wait before enabling irq's [was Re: [Cbe-oss-dev] Spider
DMA wrongness]
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.
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
--
Arthur
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists