Date: Fri, 04 Jul 2008 05:47:15 -0400 From: Paul <paul@gtcomm.net> To: Ingo Flaschberger <if@xip.at> Cc: FreeBSD Net <freebsd-net@freebsd.org> Subject: Re: Freebsd IP Forwarding performance (question, and some info) [7-stable, current, em, smp] Message-ID: <486DF1A3.9000409@gtcomm.net> In-Reply-To: <alpine.LFD.1.10.0807041106591.19613@filebunker.xip.at> References: <4867420D.7090406@gtcomm.net> <alpine.LFD.1.10.0807010257570.19444@filebunker.xip.at> <20080701010716.GF3898@stlux503.dsto.defence.gov.au> <alpine.LFD.1.10.0807010308320.19444@filebunker.xip.at> <486986D9.3000607@monkeybrains.net> <48699960.9070100@gtcomm.net> <ea7b9c170806302005n2a66f592h2127f87a0ba2c6d2@mail.gmail.com> <20080701033117.GH83626@cdnetworks.co.kr> <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>
next in thread | previous in thread | raw e-mail | index | archive | help
ngo Flaschberger wrote: > Dear Paul, > >> Opteron 2222 UP mode, no polling >> >> input (em0) output >> packets errs bytes packets errs bytes colls >> 1071020 0 66403248 2 0 404 0 > > that looks good. (but seems to be near the limit). > Yes it is , any more and errors start. >> Polling turned on provided better performance on 32 bit, but it gets >> strange errors on 64 bit.. >> Even at low pps I get small amounts of errors, and high pps same >> thing.. you would think that if >> it got errors at low pps it would get more errors at high pps but >> that isn't the case.. >> Polling on: >> packets errs bytes packets errs bytes colls >> 979736 963 60743636 1 0 226 0 >> 991838 496 61493960 1 0 178 0 >> 996125 460 61759754 1 0 178 0 >> >> >> what could cause this? > > *) kern.polling.idle_poll enabled? > *) kern.polling.user_frac ? > *) kern.polling.reg_frac ? > *) kern.polling.burst_max ? > *) kern.polling.each_burst ? I tried tons of different values for these and nothing made any significant difference. Idle polling makes a difference, allows more pps, but still errors. Without idle polling it seems PPS is limited to HZ * descriptors, or 1000 * 256 or 512 but 1000 * 1024 is the same as 512.. 4000 * 256 or 2000 * 512 works but starts erroring 600kpps (SMP right now but it happens in UP too) If anyone wants to log into the box and play with settings, recompile the kernel, etc. Let me know. Paul
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?486DF1A3.9000409>