From owner-freebsd-net@FreeBSD.ORG Fri Apr 18 23:24:01 2008 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 82E4F106566C; Fri, 18 Apr 2008 23:24:01 +0000 (UTC) (envelope-from brde@optusnet.com.au) Received: from mail07.syd.optusnet.com.au (mail07.syd.optusnet.com.au [211.29.132.188]) by mx1.freebsd.org (Postfix) with ESMTP id 1B0FD8FC0A; Fri, 18 Apr 2008 23:24:00 +0000 (UTC) (envelope-from brde@optusnet.com.au) Received: from besplex.bde.org (c220-239-252-11.carlnfd3.nsw.optusnet.com.au [220.239.252.11]) by mail07.syd.optusnet.com.au (8.13.1/8.13.1) with ESMTP id m3INNuxU025237 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Sat, 19 Apr 2008 09:23:57 +1000 Date: Sat, 19 Apr 2008 09:23:56 +1000 (EST) From: Bruce Evans X-X-Sender: bde@besplex.bde.org To: Alexander Sack In-Reply-To: <3c0b01820804181056u389d108ejb8bf81d0941ee66@mail.gmail.com> Message-ID: <20080419090216.M42173@besplex.bde.org> References: <3c0b01820804160929i76cc04fdy975929e2a04c0368@mail.gmail.com> <200804161456.20823.jkim@FreeBSD.org> <3c0b01820804161328m77704ca0g43077a9718d446d4@mail.gmail.com> <200804161654.22452.jkim@FreeBSD.org> <3c0b01820804161402u3aac4425n41172294ad33a667@mail.gmail.com> <20080417112329.G47027@delplex.bde.org> <3c0b01820804170643w6b771ce9jdfc2dc5b240922b@mail.gmail.com> <20080418093328.B50187@delplex.bde.org> <3c0b01820804181056u389d108ejb8bf81d0941ee66@mail.gmail.com> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII; format=flowed Cc: freebsd-net@freebsd.org, Dieter , Jung-uk Kim Subject: Re: bge dropping packets issue 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: Fri, 18 Apr 2008 23:24:01 -0000 On Fri, 18 Apr 2008, Alexander Sack wrote: > Here are my results: > > Good news: > > Well after fiddling around with it, it seems if I bump the number of > rx_bds to 512, disable polling, and use net.isr.direct=1, bge does not > drop packets anymore (as verified by assigning a counter within > bge_ticks() when a packet is dropped as read by the hardware > registers). What's interesting is that there is also an outOfRxBDs > register you can read if you suspect chain starvation which I > discovered after looking at the Linux driver's more complete stat > structure. This register seems to be spelled NoMoreRxBDs in FreeBSD (~7.0 and later): dev.bge.0.stats.NoMoreRxBDs: 0 (This is slightly better spelling. A data book spells it nicNoMoreRxBDs.) > Packets still get dropped but this time by BPF. It seems I pushed the > problem upstream (in terms of the stack). The user land software > listening in this instance is using BPF. I guess my next adventure is > to understand how much can BPF take before dumping packets due to lack > of buffer space - currently net.bpf.bufsize is 1048576 which is the > maxbufsize. Is this common place for BPF to drop packets? (forgive > me I have not searched the mailing list as I just confirmed these > results by instrumenting BPF). Could I raise the maxbufsize and still > operate safely? (I do have 8GB on a 64-bit system). I didn't notice that you needed bpf. I can't offer any hope for avoiding packet loss at rates near the ethernet limit with bpf or any other heavy upstream processing. My main systems (both old ~2GHz A64 or AXP UP) are completely incapable of keeping up with each other when bpf is turned on on the receiver. With bpf, the slowest one with an em receiver drops about 90% of packets at a send rate of about 600 kpps (with the packets being looked at by a simple tcpdump >/dev/null), while the fastest one with a bge receiver drops "only" about 60% of packets at a send rate of about 400 kpps. This is consistent with there being no CPU and/or memory bandwidth to spare without bpf and bpf increasing CPU/memory overheads by more than 50%. Bruce