aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorIngo Molnar <mingo@elte.hu>2008-03-14 17:16:08 -0400
committerIngo Molnar <mingo@elte.hu>2008-03-14 22:02:50 -0400
commite22ecef1d2658ba54ed7d3fdb5d60829fb434c23 (patch)
tree49069e160107578ec8212d969b599e03d7a62fae /kernel
parentaa2ac25229cd4d0280f6174c42712744ad61b140 (diff)
sched: fix fair sleepers
Fair sleepers need to scale their latency target down by runqueue weight. Otherwise busy systems will gain ever larger sleep bonus. Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/sched_fair.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c
index 31c4a2988b6..31aa1b9fa76 100644
--- a/kernel/sched_fair.c
+++ b/kernel/sched_fair.c
@@ -528,8 +528,10 @@ place_entity(struct cfs_rq *cfs_rq, struct sched_entity *se, int initial)
528 528
529 if (!initial) { 529 if (!initial) {
530 /* sleeps upto a single latency don't count. */ 530 /* sleeps upto a single latency don't count. */
531 if (sched_feat(NEW_FAIR_SLEEPERS)) 531 if (sched_feat(NEW_FAIR_SLEEPERS)) {
532 vruntime -= sysctl_sched_latency; 532 vruntime -= calc_delta_fair(sysctl_sched_latency,
533 &cfs_rq->load);
534 }
533 535
534 /* ensure we never gain time by being placed backwards. */ 536 /* ensure we never gain time by being placed backwards. */
535 vruntime = max_vruntime(se->vruntime, vruntime); 537 vruntime = max_vruntime(se->vruntime, vruntime);