diff options
author | Con Kolivas <kernel@kolivas.org> | 2006-03-31 02:31:29 -0800 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-03-31 12:18:59 -0800 |
commit | 7c4bb1f9b3788309e1159961c606ba0bdf7ed382 (patch) | |
tree | 47051dcde0cc24ec123e9ae3043465cc677a8c06 /kernel | |
parent | 5138930e6a69f1c7851a82d7cedaa01fad029fcf (diff) | |
download | kernel_samsung_crespo-7c4bb1f9b3788309e1159961c606ba0bdf7ed382.zip kernel_samsung_crespo-7c4bb1f9b3788309e1159961c606ba0bdf7ed382.tar.gz kernel_samsung_crespo-7c4bb1f9b3788309e1159961c606ba0bdf7ed382.tar.bz2 |
[PATCH] sched: remove on runqueue requeueing
On runqueue time is used to elevate priority in schedule().
In the code it currently requeues tasks even if their priority is not
elevated, which would end up placing them at the end of their runqueue
array effectively delaying them instead of improving their priority.
Bug spotted by Mike Galbraith <efault@gmx.de>
This patch removes this requeueing.
Signed-off-by: Con Kolivas <kernel@kolivas.org>
Acked-by: Ingo Molnar <mingo@elte.hu>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Nick Piggin <nickpiggin@yahoo.com.au>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/sched.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/kernel/sched.c b/kernel/sched.c index 3055fe8..73bb4d9 100644 --- a/kernel/sched.c +++ b/kernel/sched.c @@ -3023,8 +3023,7 @@ go_idle: dequeue_task(next, array); next->prio = new_prio; enqueue_task(next, array); - } else - requeue_task(next, array); + } } next->sleep_type = SLEEP_NORMAL; switch_tasks: |