From owner-freebsd-questions@FreeBSD.ORG Sat Sep 25 17:06:24 2004 Return-Path: Delivered-To: freebsd-questions@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id B378A16A4CE for ; Sat, 25 Sep 2004 17:06:24 +0000 (GMT) Received: from out001.verizon.net (out001pub.verizon.net [206.46.170.140]) by mx1.FreeBSD.org (Postfix) with ESMTP id 254DD43D54 for ; Sat, 25 Sep 2004 17:06:24 +0000 (GMT) (envelope-from cswiger@mac.com) Received: from [192.168.1.3] ([68.160.246.51]) by out001.verizon.net (InterMail vM.5.01.06.06 201-253-122-130-106-20030910) with ESMTP id <20040925170623.NEZA24594.out001.verizon.net@[192.168.1.3]>; Sat, 25 Sep 2004 12:06:23 -0500 Message-ID: <4155A580.4000501@mac.com> Date: Sat, 25 Sep 2004 13:06:08 -0400 From: Chuck Swiger Organization: The Courts of Chaos User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.7.3) Gecko/20040910 X-Accept-Language: en-us, en MIME-Version: 1.0 To: TM4525@aol.com References: <192.2ebbbb6e.2e86eb67@aol.com> In-Reply-To: <192.2ebbbb6e.2e86eb67@aol.com> X-Enigmail-Version: 0.86.1.0 X-Enigmail-Supports: pgp-inline, pgp-mime Content-Type: text/plain; charset=us-ascii; format=flowed Content-Transfer-Encoding: 7bit X-Authentication-Info: Submitted using SMTP AUTH at out001.verizon.net from [68.160.246.51] at Sat, 25 Sep 2004 12:06:23 -0500 cc: freebsd-questions@freebsd.org cc: mike@sentex.net Subject: Re: Device polling performance X-BeenThere: freebsd-questions@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: User questions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 25 Sep 2004 17:06:24 -0000 TM4525@aol.com wrote: [ ... ] > Ah, so the capacity of a FreeBSD router is > 10 million packets per second, > since 200K pps only uses .1 % of system resources. Kudos to the FreeBSD team > for developing a stack that uses no resources. > > It seems beyond unreasonable that, with interrupts enabled, 55% of the system > is used, and with polling, ~ zero. "Inconceivable!" "Erm...I do not think that word means what you think it means." It's probably easier to claim device polling works by black magic, then to explain just how much useless overhead is added when the CPU has to service tens of thousands of interrupts per second at very high packet rates. If you only need to bridge packets from one NIC to another, modern NICs will do almost all of the work (busmastering DMA, checksum offloading, etc) without needing any CPU time at all. If you've got good hardware, device polling means that the system is usually constrained by PCI bus throughput and the actual network transmission speed of the NICs themselves, not by CPU overhead. If you attempt to use crappy hardware (try digging up some 10Mbs ISA NICs), then the CPU will have to do a lot more work, and device polling will take up more than nearly zero CPU time. If you do routing, have firewall rules (particularly using dynamic stateful rules), or NAT (particularly running userland natd), you'll probably see significant CPU being used there. > Since its clear you have no idea what you're talking about, perhaps if > someone who actually does would like to pipe in it would be useful. > > It seems obvious that the "system" resource is not accurately monitored with > polling enabled, which is what Im trying to get someone to admit, or to tell > me when it was or will be repaired. You've got the source code to look at. If you find a mistake in the way the statistics are monitored, great: feel free to fix it. Not only will you earn more karma by submitting a PR or email containing a diff which solves the problem then you get from whining like a petulant child, you might actually resemble a polite human being long enough to encourage other people to respond to your problems instead of ignoring you. Do you understand this point, or am I being too subtle? -- -Chuck