aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/sched_fair.c
diff options
context:
space:
mode:
authorPeter Zijlstra <a.p.zijlstra@chello.nl>2009-09-15 13:38:52 -0400
committerIngo Molnar <mingo@elte.hu>2009-09-15 13:47:23 -0400
commite69b0f1b41c0e57bb1e29100b5810a5914efcb45 (patch)
treeded9f35988e907c1b9cf45cd2f536b920f5f65b7 /kernel/sched_fair.c
parent63859d4fe4c97b737e7adbfe60acb1c2b2e668cb (diff)
sched: Add a few SYNC hint knobs to play with
Currently we use overlap to weaken the SYNC hint, but allow it to set the hint as well. echo NO_SYNC_WAKEUP > /debug/sched_features echo SYNC_MORE > /debug/sched_features preserves pipe-test behaviour without using the WF_SYNC hint. Worth playing with on more workloads... Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl> LKML-Reference: <new-submission> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/sched_fair.c')
-rw-r--r--kernel/sched_fair.c14
1 files changed, 11 insertions, 3 deletions
diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c
index 6766959c7f44..280892e9d85e 100644
--- a/kernel/sched_fair.c
+++ b/kernel/sched_fair.c
@@ -1165,9 +1165,17 @@ static int wake_affine(struct sched_domain *sd, struct task_struct *p, int sync)
1165 load = source_load(prev_cpu, idx); 1165 load = source_load(prev_cpu, idx);
1166 this_load = target_load(this_cpu, idx); 1166 this_load = target_load(this_cpu, idx);
1167 1167
1168 if (sync && (curr->se.avg_overlap > sysctl_sched_migration_cost || 1168 if (sync) {
1169 p->se.avg_overlap > sysctl_sched_migration_cost)) 1169 if (sched_feat(SYNC_LESS) &&
1170 sync = 0; 1170 (curr->se.avg_overlap > sysctl_sched_migration_cost ||
1171 p->se.avg_overlap > sysctl_sched_migration_cost))
1172 sync = 0;
1173 } else {
1174 if (sched_feat(SYNC_MORE) &&
1175 (curr->se.avg_overlap < sysctl_sched_migration_cost &&
1176 p->se.avg_overlap < sysctl_sched_migration_cost))
1177 sync = 1;
1178 }
1171 1179
1172 /* 1180 /*
1173 * If sync wakeup then subtract the (maximum possible) 1181 * If sync wakeup then subtract the (maximum possible)