diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2007-02-16 10:27:46 +0100 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-02-16 17:13:58 +0100 |
commit | 1cfd68496e53f7be09a3c1358d1d389004217541 (patch) | |
tree | d854323b9b7821ab45ddea10d97766edce91be99 /kernel/signal.c | |
parent | [PATCH] uninline irq_enter() (diff) | |
download | linux-1cfd68496e53f7be09a3c1358d1d389004217541.tar.xz linux-1cfd68496e53f7be09a3c1358d1d389004217541.zip |
[PATCH] Fix cascade lookup of next_timer_interrupt
When searching for the next pending timer in the timer wheel we need to take
the cascade into account. The current code has several problems:
1. it looks into the previous cascade
2. it ignores a pending cascade
3. it ignores multiple cascades
Change the cascade lookup, so it calculates the array index from the point of
the next cascade and always look at the cascade buckets, when the cascade is
pending, i.e. gets executed in the next timer softirq. When multiple
cascades are pending, then lookup the next buckets too.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Cc: john stultz <johnstul@us.ibm.com>
Cc: Roman Zippel <zippel@linux-m68k.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'kernel/signal.c')
0 files changed, 0 insertions, 0 deletions