aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/sched_rt.c
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/sched_rt.c')
-rw-r--r--kernel/sched_rt.c32
1 files changed, 20 insertions, 12 deletions
diff --git a/kernel/sched_rt.c b/kernel/sched_rt.c
index c79dc7844012..299d012b4394 100644
--- a/kernel/sched_rt.c
+++ b/kernel/sched_rt.c
@@ -1122,12 +1122,13 @@ static struct task_struct *pick_next_highest_task_rt(struct rq *rq, int cpu)
1122 1122
1123static DEFINE_PER_CPU(cpumask_var_t, local_cpu_mask); 1123static DEFINE_PER_CPU(cpumask_var_t, local_cpu_mask);
1124 1124
1125static inline int pick_optimal_cpu(int this_cpu, cpumask_t *mask) 1125static inline int pick_optimal_cpu(int this_cpu,
1126 const struct cpumask *mask)
1126{ 1127{
1127 int first; 1128 int first;
1128 1129
1129 /* "this_cpu" is cheaper to preempt than a remote processor */ 1130 /* "this_cpu" is cheaper to preempt than a remote processor */
1130 if ((this_cpu != -1) && cpu_isset(this_cpu, *mask)) 1131 if ((this_cpu != -1) && cpumask_test_cpu(this_cpu, mask))
1131 return this_cpu; 1132 return this_cpu;
1132 1133
1133 first = cpumask_first(mask); 1134 first = cpumask_first(mask);
@@ -1143,6 +1144,7 @@ static int find_lowest_rq(struct task_struct *task)
1143 struct cpumask *lowest_mask = __get_cpu_var(local_cpu_mask); 1144 struct cpumask *lowest_mask = __get_cpu_var(local_cpu_mask);
1144 int this_cpu = smp_processor_id(); 1145 int this_cpu = smp_processor_id();
1145 int cpu = task_cpu(task); 1146 int cpu = task_cpu(task);
1147 cpumask_var_t domain_mask;
1146 1148
1147 if (task->rt.nr_cpus_allowed == 1) 1149 if (task->rt.nr_cpus_allowed == 1)
1148 return -1; /* No other targets possible */ 1150 return -1; /* No other targets possible */
@@ -1175,19 +1177,25 @@ static int find_lowest_rq(struct task_struct *task)
1175 if (this_cpu == cpu) 1177 if (this_cpu == cpu)
1176 this_cpu = -1; /* Skip this_cpu opt if the same */ 1178 this_cpu = -1; /* Skip this_cpu opt if the same */
1177 1179
1178 for_each_domain(cpu, sd) { 1180 if (alloc_cpumask_var(&domain_mask, GFP_ATOMIC)) {
1179 if (sd->flags & SD_WAKE_AFFINE) { 1181 for_each_domain(cpu, sd) {
1180 cpumask_t domain_mask; 1182 if (sd->flags & SD_WAKE_AFFINE) {
1181 int best_cpu; 1183 int best_cpu;
1182 1184
1183 cpumask_and(&domain_mask, sched_domain_span(sd), 1185 cpumask_and(domain_mask,
1184 lowest_mask); 1186 sched_domain_span(sd),
1187 lowest_mask);
1185 1188
1186 best_cpu = pick_optimal_cpu(this_cpu, 1189 best_cpu = pick_optimal_cpu(this_cpu,
1187 &domain_mask); 1190 domain_mask);
1188 if (best_cpu != -1) 1191
1189 return best_cpu; 1192 if (best_cpu != -1) {
1193 free_cpumask_var(domain_mask);
1194 return best_cpu;
1195 }
1196 }
1190 } 1197 }
1198 free_cpumask_var(domain_mask);
1191 } 1199 }
1192 1200
1193 /* 1201 /*