From owner-freebsd-net@FreeBSD.ORG Tue Apr 28 15:02:29 2009 Return-Path: Delivered-To: freebsd-net@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 2DA4D106566B for ; Tue, 28 Apr 2009 15:02:29 +0000 (UTC) (envelope-from luigi@onelab2.iet.unipi.it) Received: from onelab2.iet.unipi.it (onelab2.iet.unipi.it [131.114.9.129]) by mx1.freebsd.org (Postfix) with ESMTP id E421E8FC0A for ; Tue, 28 Apr 2009 15:02:28 +0000 (UTC) (envelope-from luigi@onelab2.iet.unipi.it) Received: by onelab2.iet.unipi.it (Postfix, from userid 275) id 346D273098; Tue, 28 Apr 2009 17:07:39 +0200 (CEST) Date: Tue, 28 Apr 2009 17:07:39 +0200 From: Luigi Rizzo To: Barney Cordoba Message-ID: <20090428150739.GC8430@onelab2.iet.unipi.it> References: <36906055-E1AE-486B-BA77-D260E0609BBB@netasq.com> <50451.74235.qm@web63901.mail.re1.yahoo.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <50451.74235.qm@web63901.mail.re1.yahoo.com> User-Agent: Mutt/1.4.2.3i Cc: FreeBSD Net , fabient@freebsd.org Subject: Re: Interrupts + Polling mode (similar to Linux's NAPI) X-BeenThere: freebsd-net@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Networking and TCP/IP with FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 28 Apr 2009 15:02:29 -0000 On Tue, Apr 28, 2009 at 07:26:40AM -0700, Barney Cordoba wrote: ... > The problem with all of this "analysis" is that it assumes that SMP > coding scales intuitively; when the opposite is actually true. > > What you fail to address is the basic fact that moderated interrupts > (ie holding off interrupts to a set number of ints/second) is exactly > the same as polling, as on an active system you'll get exactly X > interrupts per second at equal intervals. So all of this chatter about > polling being more efficient is simply bunk. > > The truth is that polling requires additional overhead to the system while > interrupts do not. So if polling did better for you, its simply because > either > > 1) The polling code in the driver is better > > or > > 2) You tuned polling better than you tuned interrupt moderation. > If i am not mistaken we don't have generic support for interrupt moderation in the kernel but that's a specific NIC feature: it works if the hardware supports it, and it doesn't otherwise. Of course it would be possible to modify polling to implement generic interrupt mitigation even without hardware support, so you get the best of the two worlds. cheers luigi