]> Git Repo - linux.git/commit
sched/numa: Avoid overloading CPUs on a preferred NUMA node
authorMel Gorman <[email protected]>
Mon, 7 Oct 2013 10:29:10 +0000 (11:29 +0100)
committerIngo Molnar <[email protected]>
Wed, 9 Oct 2013 10:40:39 +0000 (12:40 +0200)
commit58d081b5082dd85e02ac9a1fb151d97395340a09
tree5bfc7ac630ba62d898dfb860e63f118079cba57d
parentfc3147245d193bd0f57307859c698fa28a20b0fe
sched/numa: Avoid overloading CPUs on a preferred NUMA node

This patch replaces find_idlest_cpu_node with task_numa_find_cpu.
find_idlest_cpu_node has two critical limitations. It does not take the
scheduling class into account when calculating the load and it is unsuitable
for using when comparing loads between NUMA nodes.

task_numa_find_cpu uses similar load calculations to wake_affine() when
selecting the least loaded CPU within a scheduling domain common to the
source and destimation nodes. It avoids causing CPU load imbalances in
the machine by refusing to migrate if the relative load on the target
CPU is higher than the source CPU.

Signed-off-by: Mel Gorman <[email protected]>
Reviewed-by: Rik van Riel <[email protected]>
Cc: Andrea Arcangeli <[email protected]>
Cc: Johannes Weiner <[email protected]>
Cc: Srikar Dronamraju <[email protected]>
Signed-off-by: Peter Zijlstra <[email protected]>
Link: http://lkml.kernel.org/r/[email protected]
Signed-off-by: Ingo Molnar <[email protected]>
kernel/sched/fair.c
This page took 0.057155 seconds and 4 git commands to generate.