]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
hrtimer: prevent overrun DoS in hrtimer_forward()
authorThomas Gleixner <tglx@linutronix.de>
Sun, 8 Apr 2007 23:04:23 +0000 (01:04 +0200)
committerAdrian Bunk <bunk@stusta.de>
Sun, 8 Apr 2007 23:04:23 +0000 (01:04 +0200)
hrtimer_forward() does not check for the possible overflow of
timer->expires. This can happen on 64 bit machines with large interval
values and results currently in an endless loop in the softirq because
the expiry value becomes negative and therefor the timer is expired all
the time.

Check for this condition and set the expiry value to the max. expiry
time in the future.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Adrian Bunk <bunk@stusta.de>
kernel/hrtimer.c

index 14bc9cfa63999eee7fa1b25e4129ee67463e53bc..a29ceb04c257ee9b2e47a038ea553b85f5ef47d2 100644 (file)
@@ -316,6 +316,12 @@ hrtimer_forward(struct hrtimer *timer, ktime_t interval)
                orun++;
        }
        timer->expires = ktime_add(timer->expires, interval);
+       /*
+        * Make sure, that the result did not wrap with a very large
+        * interval.
+        */
+       if (timer->expires.tv64 < 0)
+               timer->expires = ktime_set(KTIME_SEC_MAX, 0);
 
        return orun;
 }