diff options
| author | Rusty Russell <rusty@rustcorp.com.au> | 2008-12-29 16:32:35 -0500 |
|---|---|---|
| committer | Rusty Russell <rusty@rustcorp.com.au> | 2008-12-29 16:32:35 -0500 |
| commit | 33edcf133ba93ecba2e4b6472e97b689895d805c (patch) | |
| tree | 327d7a20acef64005e7c5ccbfa1265be28aeb6ac /kernel/sched_fair.c | |
| parent | be4d638c1597580ed2294d899d9f1a2cd10e462c (diff) | |
| parent | 3c92ec8ae91ecf59d88c798301833d7cf83f2179 (diff) | |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6
Diffstat (limited to 'kernel/sched_fair.c')
| -rw-r--r-- | kernel/sched_fair.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c index 98345e45b059..5ad4440f0fc4 100644 --- a/kernel/sched_fair.c +++ b/kernel/sched_fair.c | |||
| @@ -492,6 +492,8 @@ static void update_curr(struct cfs_rq *cfs_rq) | |||
| 492 | * overflow on 32 bits): | 492 | * overflow on 32 bits): |
| 493 | */ | 493 | */ |
| 494 | delta_exec = (unsigned long)(now - curr->exec_start); | 494 | delta_exec = (unsigned long)(now - curr->exec_start); |
| 495 | if (!delta_exec) | ||
| 496 | return; | ||
| 495 | 497 | ||
| 496 | __update_curr(cfs_rq, curr, delta_exec); | 498 | __update_curr(cfs_rq, curr, delta_exec); |
| 497 | curr->exec_start = now; | 499 | curr->exec_start = now; |
| @@ -1345,12 +1347,11 @@ static void check_preempt_wakeup(struct rq *rq, struct task_struct *p, int sync) | |||
| 1345 | { | 1347 | { |
| 1346 | struct task_struct *curr = rq->curr; | 1348 | struct task_struct *curr = rq->curr; |
| 1347 | struct sched_entity *se = &curr->se, *pse = &p->se; | 1349 | struct sched_entity *se = &curr->se, *pse = &p->se; |
| 1350 | struct cfs_rq *cfs_rq = task_cfs_rq(curr); | ||
| 1348 | 1351 | ||
| 1349 | if (unlikely(rt_prio(p->prio))) { | 1352 | update_curr(cfs_rq); |
| 1350 | struct cfs_rq *cfs_rq = task_cfs_rq(curr); | ||
| 1351 | 1353 | ||
| 1352 | update_rq_clock(rq); | 1354 | if (unlikely(rt_prio(p->prio))) { |
| 1353 | update_curr(cfs_rq); | ||
| 1354 | resched_task(curr); | 1355 | resched_task(curr); |
| 1355 | return; | 1356 | return; |
| 1356 | } | 1357 | } |
