aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/time/timekeeping.c
diff options
context:
space:
mode:
authorJohn Stultz <john.stultz@linaro.org>2011-06-01 18:18:09 -0700
committerDan Murphy <dmurphy@ti.com>2011-11-29 07:44:19 -0600
commitd70dfcc1e3438135c11e753cab32db464b1672fb (patch)
treee649947499d8d24aa4e5c1d79420cca8833de700 /kernel/time/timekeeping.c
parent698b76a12840933592ff2b66f1edd97c62a54f10 (diff)
downloadkernel_samsung_espresso10-d70dfcc1e3438135c11e753cab32db464b1672fb.zip
kernel_samsung_espresso10-d70dfcc1e3438135c11e753cab32db464b1672fb.tar.gz
kernel_samsung_espresso10-d70dfcc1e3438135c11e753cab32db464b1672fb.tar.bz2
time: Catch invalid timespec sleep values in __timekeeping_inject_sleeptime
Arve suggested making sure we catch possible negative sleep time intervals that could be passed into timekeeping_inject_sleeptime. CC: Arve Hjønnevåg <arve@android.com> CC: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: John Stultz <john.stultz@linaro.org>
Diffstat (limited to 'kernel/time/timekeeping.c')
-rw-r--r--kernel/time/timekeeping.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c
index 342408c..9d09777 100644
--- a/kernel/time/timekeeping.c
+++ b/kernel/time/timekeeping.c
@@ -604,6 +604,12 @@ static struct timespec timekeeping_suspend_time;
*/
static void __timekeeping_inject_sleeptime(struct timespec *delta)
{
+ if (!timespec_valid(delta)) {
+ printk(KERN_WARN "__timekeeping_inject_sleeptime: Invalid "
+ "sleep delta value!\n");
+ return;
+ }
+
xtime = timespec_add(xtime, *delta);
wall_to_monotonic = timespec_sub(wall_to_monotonic, *delta);
total_sleep_time = timespec_add(total_sleep_time, *delta);