diff options
-rw-r--r-- | kernel/sched/fair.c | 15 | ||||
-rw-r--r-- | kernel/sched/idle_task.c | 1 |
2 files changed, 10 insertions, 6 deletions
diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index d8482e1c575e..b956e70fc503 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c | |||
@@ -4787,17 +4787,16 @@ simple: | |||
4787 | return p; | 4787 | return p; |
4788 | 4788 | ||
4789 | idle: | 4789 | idle: |
4790 | new_tasks = idle_balance(rq); | ||
4790 | /* | 4791 | /* |
4791 | * Because idle_balance() releases (and re-acquires) rq->lock, it is | 4792 | * Because idle_balance() releases (and re-acquires) rq->lock, it is |
4792 | * possible for any higher priority task to appear. In that case we | 4793 | * possible for any higher priority task to appear. In that case we |
4793 | * must re-start the pick_next_entity() loop. | 4794 | * must re-start the pick_next_entity() loop. |
4794 | */ | 4795 | */ |
4795 | new_tasks = idle_balance(rq); | 4796 | if (new_tasks < 0) |
4796 | |||
4797 | if (rq->nr_running != rq->cfs.h_nr_running) | ||
4798 | return RETRY_TASK; | 4797 | return RETRY_TASK; |
4799 | 4798 | ||
4800 | if (new_tasks) | 4799 | if (new_tasks > 0) |
4801 | goto again; | 4800 | goto again; |
4802 | 4801 | ||
4803 | return NULL; | 4802 | return NULL; |
@@ -6728,8 +6727,14 @@ static int idle_balance(struct rq *this_rq) | |||
6728 | this_rq->max_idle_balance_cost = curr_cost; | 6727 | this_rq->max_idle_balance_cost = curr_cost; |
6729 | 6728 | ||
6730 | out: | 6729 | out: |
6731 | if (pulled_task) | 6730 | /* Is there a task of a high priority class? */ |
6731 | if (this_rq->nr_running != this_rq->cfs.h_nr_running) | ||
6732 | pulled_task = -1; | ||
6733 | |||
6734 | if (pulled_task) { | ||
6735 | idle_exit_fair(this_rq); | ||
6732 | this_rq->idle_stamp = 0; | 6736 | this_rq->idle_stamp = 0; |
6737 | } | ||
6733 | 6738 | ||
6734 | return pulled_task; | 6739 | return pulled_task; |
6735 | } | 6740 | } |
diff --git a/kernel/sched/idle_task.c b/kernel/sched/idle_task.c index 1f3725882838..879f2b75266a 100644 --- a/kernel/sched/idle_task.c +++ b/kernel/sched/idle_task.c | |||
@@ -29,7 +29,6 @@ pick_next_task_idle(struct rq *rq, struct task_struct *prev) | |||
29 | put_prev_task(rq, prev); | 29 | put_prev_task(rq, prev); |
30 | 30 | ||
31 | schedstat_inc(rq, sched_goidle); | 31 | schedstat_inc(rq, sched_goidle); |
32 | idle_enter_fair(rq); | ||
33 | return rq->idle; | 32 | return rq->idle; |
34 | } | 33 | } |
35 | 34 | ||