aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Redpath <chris.redpath@arm.com>2013-08-19 15:06:23 +0100
committerJon Medhurst <tixy@linaro.org>2013-08-19 15:41:37 +0100
commit18e3c3d2cc1346cb7cc2e3fd777b2c6f4fbb6135 (patch)
tree0306d4b5f733c7f53d1d5295f2b5cd36c6f54416
parentde66e01565848d0236ca9e7e9e2f6ecd5c27a021 (diff)
HMP: Update migration timer when we fork-migrate
Prevents fork-migration adversely interacting with normal migration (i.e. runqueues containing forked tasks being selected as migration targets when there is a better choice available) Signed-off-by: Chris Redpath <chris.redpath@arm.com> Signed-off-by: Liviu Dudau <liviu.dudau@arm.com> Signed-off-by: Jon Medhurst <tixy@linaro.org>
-rw-r--r--kernel/sched/fair.c18
1 files changed, 13 insertions, 5 deletions
diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c
index bfd27e89399..754634e774a 100644
--- a/kernel/sched/fair.c
+++ b/kernel/sched/fair.c
@@ -4079,18 +4079,26 @@ select_task_rq_fair(struct task_struct *p, int sd_flag, int wake_flags)
if(hmp_cpu_is_fastest(prev_cpu)) {
struct hmp_domain *hmpdom = list_entry(&hmp_cpu_domain(prev_cpu)->hmp_domains, struct hmp_domain, hmp_domains);
__always_unused int lowest_ratio = hmp_domain_min_load(hmpdom, &new_cpu);
- if(new_cpu != NR_CPUS && cpumask_test_cpu(new_cpu,tsk_cpus_allowed(p)))
+ if (new_cpu != NR_CPUS &&
+ cpumask_test_cpu(new_cpu,
+ tsk_cpus_allowed(p))) {
+ hmp_next_up_delay(&p->se, new_cpu);
return new_cpu;
- else {
- new_cpu = cpumask_any_and(&hmp_faster_domain(cpu)->cpus,
+ } else {
+ new_cpu = cpumask_any_and(
+ &hmp_faster_domain(cpu)->cpus,
tsk_cpus_allowed(p));
- if(new_cpu < nr_cpu_ids)
+ if (new_cpu < nr_cpu_ids) {
+ hmp_next_up_delay(&p->se, new_cpu);
return new_cpu;
+ }
}
} else {
new_cpu = hmp_select_faster_cpu(p, prev_cpu);
- if (new_cpu != NR_CPUS)
+ if (new_cpu != NR_CPUS) {
+ hmp_next_up_delay(&p->se, new_cpu);
return new_cpu;
+ }
}
}
#endif