aboutsummaryrefslogtreecommitdiff
path: root/tools/perf/util/c++/clang.cpp
diff options
context:
space:
mode:
authorVincent Guittot <[email protected]>2020-07-10 17:24:26 +0200
committerPeter Zijlstra <[email protected]>2020-07-16 23:19:48 +0200
commit01cfcde9c26d8555f0e6e9aea9d6049f87683998 (patch)
tree1e14dfeca6f69e6c3ce3b0c3f46f2742c7678432 /tools/perf/util/c++/clang.cpp
parentce3614daabea8a2d01c1dd17ae41d1ec5e5ae7db (diff)
sched/fair: handle case of task_h_load() returning 0
task_h_load() can return 0 in some situations like running stress-ng mmapfork, which forks thousands of threads, in a sched group on a 224 cores system. The load balance doesn't handle this correctly because env->imbalance never decreases and it will stop pulling tasks only after reaching loop_max, which can be equal to the number of running tasks of the cfs. Make sure that imbalance will be decreased by at least 1. misfit task is the other feature that doesn't handle correctly such situation although it's probably more difficult to face the problem because of the smaller number of CPUs and running tasks on heterogenous system. We can't simply ensure that task_h_load() returns at least one because it would imply to handle underflow in other places. Signed-off-by: Vincent Guittot <[email protected]> Signed-off-by: Peter Zijlstra (Intel) <[email protected]> Reviewed-by: Valentin Schneider <[email protected]> Reviewed-by: Dietmar Eggemann <[email protected]> Tested-by: Dietmar Eggemann <[email protected]> Cc: <[email protected]> # v4.4+ Link: https://lkml.kernel.org/r/[email protected]
Diffstat (limited to 'tools/perf/util/c++/clang.cpp')
0 files changed, 0 insertions, 0 deletions