Re: [PATCH 7/8] time: Move xtime_nsec adjustment underflow handlingtimekeeping_adjust

From: Ingo Molnar
Date: Fri Jul 13 2012 - 02:04:31 EST



* John Stultz <john.stultz@xxxxxxxxxx> wrote:

> When we make adjustments speeding up the clock, its possible
> for xtime_nsec to underflow. We already handle this properly,
> but we do so from update_wall_time() instead of the more logical
> timekeeping_adjust(), where the possible underflow actually
> occurs.
>
> Thus, move the correction logic to the timekeeping_adjust, which
> is the function that causes the issue. Making update_wall_time()
> more readable.
>
> CC: Ingo Molnar <mingo@xxxxxxxxxx>
> CC: Peter Zijlstra <a.p.zijlstra@xxxxxxxxx>
> CC: Richard Cochran <richardcochran@xxxxxxxxx>
> CC: Prarit Bhargava <prarit@xxxxxxxxxx>
> CC: Thomas Gleixner <tglx@xxxxxxxxxxxxx>
> Signed-off-by: John Stultz <johnstul@xxxxxxxxxx>
> ---
> kernel/time/timekeeping.c | 42 +++++++++++++++++++++---------------------
> 1 file changed, 21 insertions(+), 21 deletions(-)
>
> diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c
> index dd119355..4b76432 100644
> --- a/kernel/time/timekeeping.c
> +++ b/kernel/time/timekeeping.c
> @@ -987,6 +987,27 @@ static void timekeeping_adjust(s64 offset)
> timekeeper.xtime_nsec -= offset;
> timekeeper.ntp_error -= (interval - offset) <<
> timekeeper.ntp_error_shift;
> +
> + /*
> + * It may be possible that when we entered this function, xtime_nsec
> + * was very small. Further, if we're slightly speeding the clocksource
> + * in the code above, its possible the required corrective factor to
> + * xtime_nsec could cause it to underflow.

s/slightly speeding/slightly speeding up ?

> + *
> + * Now, since we already accumulated the second, cannot simply roll
> + * the accumulated second back, since the NTP subsystem has been

s/cannot/we cannot ?

Thanks,

Ingo
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/