Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 19 Jan 2007 14:07:21 -0800 (PST)
From:      Jeff Roberson <jroberson@chesapeake.net>
To:        current@freebsd.org
Subject:   Improved ULE load balancing.
Message-ID:  <20070119135849.D558@10.0.0.1>

next in thread | raw e-mail | index | archive | help
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



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