diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2007-05-29 23:47:39 +0200 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-05-29 18:11:10 -0700 |
commit | eaad084bb0f3a6259e56400cd45d061dbf040600 (patch) | |
tree | 34a5f5c3e1a849b035510ee28d5aaffd42a36dcc /kernel/sched.c | |
parent | 6e98ee75c3ab99db48ecc0615c2246dc193111a9 (diff) | |
download | op-kernel-dev-eaad084bb0f3a6259e56400cd45d061dbf040600.zip op-kernel-dev-eaad084bb0f3a6259e56400cd45d061dbf040600.tar.gz |
NOHZ: prevent multiplication overflow - stop timer for huge timeouts
get_next_timer_interrupt() returns a delta of (LONG_MAX > 1) in case
there is no timer pending. On 64 bit machines this results in a
multiplication overflow in tick_nohz_stop_sched_tick().
Reported by: Dave Miller <davem@davemloft.net>
Make the return value a constant and limit the return value to a 32 bit
value.
When the max timeout value is returned, we can safely stop the tick
timer device. The max jiffies delta results in a 12 days timeout for
HZ=1000.
In the long term the get_next_timer_interrupt() code needs to be
reworked to return ktime instead of jiffies, but we have to wait until
the last users of the original NO_IDLE_HZ code are converted.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Acked-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'kernel/sched.c')
0 files changed, 0 insertions, 0 deletions