X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=kernel%2Fsched_clock.c;h=a0b0852414cc599169efd81c5789f03ee50dad8b;hb=f99fb8a2cbf0fd9ce9b2d5d298943d0d4dc479f7;hp=e8ab096ddfe399dc3007e32b169b46d02ed9cb48;hpb=46483d10e5123d78cf9abf37577aa8e75f18b8a4;p=~andy%2Flinux diff --git a/kernel/sched_clock.c b/kernel/sched_clock.c index e8ab096ddfe..a0b0852414c 100644 --- a/kernel/sched_clock.c +++ b/kernel/sched_clock.c @@ -124,7 +124,7 @@ static u64 __update_sched_clock(struct sched_clock_data *scd, u64 now) clock = scd->tick_gtod + delta; min_clock = wrap_max(scd->tick_gtod, scd->clock); - max_clock = scd->tick_gtod + TICK_NSEC; + max_clock = wrap_max(scd->clock, scd->tick_gtod + TICK_NSEC); clock = wrap_max(clock, min_clock); clock = wrap_min(clock, max_clock); @@ -227,6 +227,9 @@ EXPORT_SYMBOL_GPL(sched_clock_idle_sleep_event); */ void sched_clock_idle_wakeup_event(u64 delta_ns) { + if (timekeeping_suspended) + return; + sched_clock_tick(); touch_softlockup_watchdog(); }