Skip site navigation (1)Skip section navigation (2)
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>