Yes but both of these are independent of the scheduler discipline in force.
Load balancing needs to be based on the static priorities (i.e. nice or
real time priority) of the runnable tasks not the dynamic priorities.
If the load balancer manages to keep the weighted (according to static
priority) load and distribution of priorities within the loads on the
CPUs roughly equal and the scheduler does a good job of ensuring
fairness, interactive responsiveness etc. for the tasks within a CPU
then the result will be good system performance within the constraints
set by the sys admins use of real time priorities and nice.
The smpnice modifications to the load balancer were meant to give it the
appropriate behaviour and what we need to fix now is the intra CPU
scheduling.
Even if the load balancer isn't yet perfect perfecting it can be done
separately to fixing the scheduler preferably with as little
interdependency as possible. Probably the only contribution to load
balancing that the scheduler really needs to make is the calculating of
the average weighted load on each of the CPUs (or run queues if there's
more than one CPU per runqueue).
Peter
--
Peter Williams pwil3058@bigpond.net.au
"Learning, n. The kind of ignorance distinguishing the studious."
-- Ambrose Bierce
-