Commit 61b76840 authored by John Stultz's avatar John Stultz Committed by Willy Tarreau

time: Avoid making adjustments if we haven't accumulated anything

This is a -stable backport of bf2ac312

If update_wall_time() is called and the current offset isn't large
enough to accumulate, avoid re-calling timekeeping_adjust which may
change the clock freq and can cause 1ns inconsistencies with
CLOCK_REALTIME_COARSE/CLOCK_MONOTONIC_COARSE.
Signed-off-by: default avatarJohn Stultz <john.stultz@linaro.org>
Cc: Prarit Bhargava <prarit@redhat.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: stable@vger.kernel.org
Link: http://lkml.kernel.org/r/1345595449-34965-5-git-send-email-john.stultz@linaro.orgSigned-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Cc: Linux Kernel <linux-kernel@vger.kernel.org>
Signed-off-by: default avatarJohn Stultz <john.stultz@linaro.org>
Signed-off-by: default avatarWilly Tarreau <w@1wt.eu>
parent 436b6be6
...@@ -807,6 +807,10 @@ void update_wall_time(void) ...@@ -807,6 +807,10 @@ void update_wall_time(void)
#else #else
offset = timekeeper.cycle_interval; offset = timekeeper.cycle_interval;
#endif #endif
/* Check if there's really nothing to do */
if (offset < timekeeper.cycle_interval)
return;
timekeeper.xtime_nsec = (s64)xtime.tv_nsec << timekeeper.shift; timekeeper.xtime_nsec = (s64)xtime.tv_nsec << timekeeper.shift;
/* normally this loop will run just once, however in the /* normally this loop will run just once, however in the
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment