Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 19 Jan 2007 23:00:19 -0800 (PST)
From:      Jeff Roberson <jroberson@chesapeake.net>
To:        current@freebsd.org
Subject:   Re: Improved ULE load balancing.
Message-ID:  <20070119225918.P629@10.0.0.1>
In-Reply-To: <20070119135849.D558@10.0.0.1>
References:  <20070119135849.D558@10.0.0.1>

next in thread | previous in thread | raw e-mail | index | archive | help
I have a few reports that pickpri disturbs interactive performance.  If 
you're running ULE on a SMP desktop machine please set kern.sched.pick_pri 
= 0.  I'll look into this asap.  Unfortunately my primary desktop is not 
SMP and I didn't notice this regression.

Thanks,
Jeff

On Fri, 19 Jan 2007, Jeff Roberson wrote:

> I'd like those of you that reported relatively poor SMP performance on ULE to 
> update to revision 1.179.  This improved performance on my dual xeon to about 
> 10% better than 4BSD running supersmack.  It is also highly tunable. Some 
> options of interest:
>
> kern.sched. :
> pick_pri - The default is on.  Turning this off will revert to the older 
> algorithm which is now called pickidle.  pick_pri tries to always run the 
> highest priority threads.  pickidle really just tries to balance cpu load and 
> doesn't take priority into consideration.
>
> pick_pri_affinity - Number of ticks a thread has slept for before we stop 
> considering it as having affinity for a given cpu.
>
> busy_thresh - Length of run queue allowed before idle cpus will try to steal 
> some of our work.  This defaults to 4 but on some workloads I see improvement 
> with values as low as 2.
>
> ipi_thresh - Priorities below this generate IPIs to preempt the target cpu. 
> Can decrease latency for some workloads but at the expense of extra context 
> switches and interrupt overhead.
>
> The default configuration was fastest on the most workloads on my 8way 
> opteron and 2x xeon (+2xHTT).  I tested parallel compiles and super-smack 
> with select-key.smack doing different workloads on both machines and with 
> different numbers of processors enabled on the 8way opteron.  The opteron in 
> 8way mode shows about 300% speedup compared to 4BSD on super-smack. compile 
> times are nearly identical across all schedulers and platforms.  I get a more 
> modest 5-10% faster on super-smack on my xeon running super-smack depending 
> on the configuration.
>
> Please report back your findings.  Hopefully with the tunables present I can 
> experiment and get the settings ride for a wide array of machines.
>
> Thanks,
> Jeff
>
> ---------- Forwarded message ----------
> Date: Fri, 19 Jan 2007 21:56:08 +0000 (UTC)
> From: Jeff Roberson <jeff@FreeBSD.org>
> To: src-committers@FreeBSD.org, cvs-src@FreeBSD.org, cvs-all@FreeBSD.org
> Subject: cvs commit: src/sys/kern sched_ule.c
>
> jeff        2007-01-19 21:56:08 UTC
>
>  FreeBSD src repository
>
>  Modified files:
>    sys/kern             sched_ule.c
>  Log:
>  Major revamp of ULE's cpu load balancing:
>   - Switch back to direct modification of remote CPU run queues.  This added
>     a lot of complexity with questionable gain.  It's easy enough to
>     reimplement if it's shown to help on huge machines.
>   - Re-implement the old tdq_transfer() call as tdq_pickidle().  Change
>     sched_add() so we have selectable cpu choosers and simplify the logic
>     a bit here.
>   - Implement tdq_pickpri() as the new default cpu chooser.  This algorithm
>     is similar to Solaris in that it tries to always run the threads with
>     the best priorities.  It is actually slightly more complex than
>     solaris's algorithm because we also tend to favor the local cpu over
>     other cpus which has a boost in latency but also potentially enables
>     cache sharing between the waking thread and the woken thread.
>   - Add a bunch of tunables that can be used to measure effects of different
>     load balancing strategies.  Most of these will go away once the
>     algorithm is more definite.
>   - Add a new mechanism to steal threads from busy cpus when we idle.  This
>     is enabled with kern.sched.steal_busy and kern.sched.busy_thresh.  The
>     threshold is the required length of a tdq's run queue before another
>     cpu will be able to steal runnable threads.  This prevents most queue
>     imbalances that contribute the long latencies.
>
>  Revision  Changes    Path
>  1.179     +293 -240  src/sys/kern/sched_ule.c
> _______________________________________________
> freebsd-current@freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-current
> To unsubscribe, send any mail to "freebsd-current-unsubscribe@freebsd.org"
>



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20070119225918.P629>