Bad routing performance on 500Mhz Geode LX with CURRENT, ipfw and mpd5

Adrian Chadd adrian at freebsd.org
Wed Sep 5 07:08:01 UTC 2012


I'm so sorry for dropping off the radar here.

Can you please compile your kernel with KTR enabled so we can capture
some schedgraph traces?

I'd like to let the scheduler people see what's going on.

I bet it's something like preemption is allowing the taskqueues to
preempt each other (which they shouldn't, not when they're at the same
level) when an interrupt occurs that calls taskqueue_enqueue().

On a non-preempt kernel it'll just jump back to running the same
thread until yield or tick; on a preempt kernel a driver taskqueue
could be preempted by another driver.

(Holy crap, this is one situation where maybe the linux spinlock_bh()
semantics make sense. If used correctly. Yikes.)



Adrian

On 31 August 2012 09:33, Eugene Grosbein <egrosbein at rdtc.ru> wrote:
> 31.08.2012 22:54, Eugene Grosbein пишет:
>
>> I've rebuilt by kernel with SCHED_ULE and excluded PREEMPTION.
>> Stock driver works without changes in behaviour and driver from HEAD
>> now works very similar to old one: LA is not higher than 2 and
>> userland is pretty responsive. Also, transfer speed with new driver is
>> several percent more. That's good.
>>
>> Care to explain such dramatic difference for new driver
>> with/without PREEMPTION for relatively slow uniprocessor system?
>>
>>> And run 4BSD + no preemption, try again?
>
> I've tried 4BSD without preemption too. Can't see any difference
> from ULE without preemption. Should I stick with 4BSD for UP system?
>
> Eugene Grosbein


More information about the freebsd-net mailing list