diff options
Diffstat (limited to 'kernel/sched_fair.c')
-rw-r--r-- | kernel/sched_fair.c | 10 |
1 files changed, 2 insertions, 8 deletions
diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c index 7264814ba62a..fbcb426029d0 100644 --- a/kernel/sched_fair.c +++ b/kernel/sched_fair.c | |||
@@ -546,7 +546,6 @@ dequeue_entity(struct cfs_rq *cfs_rq, struct sched_entity *se, int sleep) | |||
546 | 546 | ||
547 | update_stats_dequeue(cfs_rq, se); | 547 | update_stats_dequeue(cfs_rq, se); |
548 | if (sleep) { | 548 | if (sleep) { |
549 | se->peer_preempt = 0; | ||
550 | #ifdef CONFIG_SCHEDSTATS | 549 | #ifdef CONFIG_SCHEDSTATS |
551 | if (entity_is_task(se)) { | 550 | if (entity_is_task(se)) { |
552 | struct task_struct *tsk = task_of(se); | 551 | struct task_struct *tsk = task_of(se); |
@@ -574,10 +573,8 @@ check_preempt_tick(struct cfs_rq *cfs_rq, struct sched_entity *curr) | |||
574 | 573 | ||
575 | ideal_runtime = sched_slice(cfs_rq, curr); | 574 | ideal_runtime = sched_slice(cfs_rq, curr); |
576 | delta_exec = curr->sum_exec_runtime - curr->prev_sum_exec_runtime; | 575 | delta_exec = curr->sum_exec_runtime - curr->prev_sum_exec_runtime; |
577 | if (delta_exec > ideal_runtime || | 576 | if (delta_exec > ideal_runtime) |
578 | (sched_feat(PREEMPT_RESTRICT) && curr->peer_preempt)) | ||
579 | resched_task(rq_of(cfs_rq)->curr); | 577 | resched_task(rq_of(cfs_rq)->curr); |
580 | curr->peer_preempt = 0; | ||
581 | } | 578 | } |
582 | 579 | ||
583 | static void | 580 | static void |
@@ -867,9 +864,7 @@ static void check_preempt_wakeup(struct rq *rq, struct task_struct *p) | |||
867 | gran = calc_delta_fair(gran, &se->load); | 864 | gran = calc_delta_fair(gran, &se->load); |
868 | 865 | ||
869 | if (delta > gran) { | 866 | if (delta > gran) { |
870 | int now = !sched_feat(PREEMPT_RESTRICT); | 867 | if (p->prio < curr->prio) |
871 | |||
872 | if (now || p->prio < curr->prio || !se->peer_preempt++) | ||
873 | resched_task(curr); | 868 | resched_task(curr); |
874 | } | 869 | } |
875 | } | 870 | } |
@@ -1083,7 +1078,6 @@ static void task_new_fair(struct rq *rq, struct task_struct *p) | |||
1083 | swap(curr->vruntime, se->vruntime); | 1078 | swap(curr->vruntime, se->vruntime); |
1084 | } | 1079 | } |
1085 | 1080 | ||
1086 | se->peer_preempt = 0; | ||
1087 | enqueue_task_fair(rq, p, 0); | 1081 | enqueue_task_fair(rq, p, 0); |
1088 | resched_task(rq->curr); | 1082 | resched_task(rq->curr); |
1089 | } | 1083 | } |