From: Richard Cochran Date: Tue, 17 Jul 2012 17:33:49 +0000 (-0400) Subject: ntp: Correct TAI offset during leap second X-Git-Tag: v2.6.39-400.9.0~325 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=c5f7406e214a073701f9d4aa44d5f920b2622f3b;p=users%2Fjedix%2Flinux-maple.git ntp: Correct TAI offset during leap second This is a backport of dd48d708ff3e917f6d6b6c2b696c3f18c019feed When repeating a UTC time value during a leap second (when the UTC time should be 23:59:60), the TAI timescale should not stop. The kernel NTP code increments the TAI offset one second too late. This patch fixes the issue by incrementing the offset during the leap second itself. Signed-off-by: Richard Cochran Cc: Prarit Bhargava Cc: Thomas Gleixner Signed-off-by: John Stultz Signed-off-by: Greg Kroah-Hartman (cherry picked from commit 96bab736bad82423c2b312d602689a9078481fa9) Signed-off-by: Joe Jin --- diff --git a/kernel/time/ntp.c b/kernel/time/ntp.c index 3d17ebd47fa2..17accdaec061 100644 --- a/kernel/time/ntp.c +++ b/kernel/time/ntp.c @@ -412,6 +412,7 @@ int second_overflow(unsigned long secs) if (secs % 86400 == 0) { leap = -1; time_state = TIME_OOP; + time_tai++; printk(KERN_NOTICE "Clock: inserting leap second 23:59:60 UTC\n"); } @@ -426,7 +427,6 @@ int second_overflow(unsigned long secs) } break; case TIME_OOP: - time_tai++; time_state = TIME_WAIT; break;