Date: Mon, 07 Jul 2008 18:20:08 +0200 From: Andre Oppermann <andre@freebsd.org> To: Bruce Evans <brde@optusnet.com.au> Cc: FreeBSD Net <freebsd-net@freebsd.org>, Bart Van Kerckhove <bart@it-ss.be>, Ingo Flaschberger <if@xip.at>, Paul <paul@gtcomm.net> Subject: Re: Freebsd IP Forwarding performance (question, and some info) [7-stable, current, em, smp] Message-ID: <48724238.2020103@freebsd.org> In-Reply-To: <20080708002228.G680@besplex.bde.org> References: <4867420D.7090406@gtcomm.net> <ea7b9c170806302050p2a3a5480t29923a4ac2d7c852@mail.gmail.com><4869ACFC.5020205@gtcomm.net> <4869B025.9080006@gtcomm.net><486A7E45.3030902@gtcomm.net> <486A8F24.5010000@gtcomm.net><486A9A0E.6060308@elischer.org> <486B41D5.3060609@gtcomm.net><alpine.LFD.1.10.0807021052041.557@filebunker.xip.at><486B4F11.6040906@gtcomm.net><alpine.LFD.1.10.0807021155280.557@filebunker.xip.at><486BC7F5.5070604@gtcomm.net><20080703160540.W6369@delplex.bde.org><486C7F93.7010308@gtcomm.net><20080703195521.O6973@delplex.bde.org><486D35A0.4000302@gtcomm.net><alpine.LFD.1.10.0807041106591.19613@filebunker.xip.at><486DF1A3.9000409@gtcomm.net><alpine.LFD.1.10.0807041303490.20760@filebunker.xip.at><486E65E6.3060301@gtcomm.net> <alpine.LFD.1.10.0807052356130.2145@filebunker.xip.at> <2d3001c8def1$f4309b90$020b000a@bartwrkstxp> <486FFF70.3090402@gtcomm.net> <48701921.7090107@gtcomm.net> <4871E618.1080500@freebsd.org> <20080708002228.G680@besplex.bde.org>
next in thread | previous in thread | raw e-mail | index | archive | help
Bruce Evans wrote: > On Mon, 7 Jul 2008, Andre Oppermann wrote: > >> Paul, >> >> to get a systematic analysis of the performance please do the following >> tests and put them into a table for easy comparison: >> >> 1. inbound pps w/o loss with interface in monitor mode (ifconfig em0 >> monitor) >> ... > > I won't be running many of these tests, but found this one interesting -- > I didn't know about monitor mode. It gives the following behaviour: > > -monitor ttcp receiving on bge0 at 397 kpps: 35% idle (8.0-CURRENT) 13.6 > cm/p > monitor ttcp receiving on bge0 at 397 kpps: 83% idle (8.0-CURRENT) 5.8 > cm/p > -monitor ttcp receiving on em0 at 580 kpps: 5% idle (~5.2) 12.5 > cm/p > monitor ttcp receiving on em0 at 580 kpps: 65% idle (~5.2) 4.8 > cm/p > > cm/p = k8-dc-misses (bge0 system) > cm/p = k7-dc-misses (em0 system) > > So it seems that the major overheads are not near the driver (as I already > knew), and upper layers are responsible for most of the cache misses. > The packet header is accessed even in monitor mode, so I think most of > the cache misses in upper layers are not related to the packet header. > Maybe they are due mainly to perfect non-locality for mbufs. Monitor mode doesn't access the payload packet header. It only looks at the mbuf (which has a structure called mbuf packet header). The mbuf header it hot in the cache because the driver just touched it and filled in the information. The packet content (the payload) is cold and just arrived via DMA in DRAM. -- Andre
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?48724238.2020103>