From 2c92024243e8296c127e38624e086a3fd5d99b1a Mon Sep 17 00:00:00 2001 From: Peter Zijlstra Date: Fri, 25 Jan 2008 21:08:32 +0100 Subject: [PATCH] --- yaml --- r: 76186 b: refs/heads/master c: 1020387f5f3b52929b387103cf976321981f8e26 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/kernel/sched_rt.c | 5 ++++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/[refs] b/[refs] index c228fee69440..8ae9e22eb12c 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 37bb6cb4097e29ffee970065b74499cbf10603a3 +refs/heads/master: 1020387f5f3b52929b387103cf976321981f8e26 diff --git a/trunk/kernel/sched_rt.c b/trunk/kernel/sched_rt.c index 8bfdb3f8a52d..f1f215db3bd0 100644 --- a/trunk/kernel/sched_rt.c +++ b/trunk/kernel/sched_rt.c @@ -94,8 +94,11 @@ static void sched_rt_ratio_enqueue(struct rt_rq *rt_rq) struct sched_rt_entity *rt_se = rt_rq->rt_se; if (rt_se && !on_rt_rq(rt_se) && rt_rq->rt_nr_running) { + struct task_struct *curr = rq_of_rt_rq(rt_rq)->curr; + enqueue_rt_entity(rt_se); - resched_task(rq_of_rt_rq(rt_rq)->curr); + if (rt_rq->highest_prio < curr->prio) + resched_task(curr); } }