login
Header Space

 
 

[patch 23/26] NTP: remove clock_was_set() call to prevent deadlock

Score:
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: <linux-kernel@...>, <stable@...>, <torvalds@...>
Cc: Justin Forbes <jmforbes@...>, Zwane Mwaikambo <zwane@...>, Theodore Ts'o <tytso@...>, Randy Dunlap <rdunlap@...>, Dave Jones <davej@...>, Chuck Wolber <chuckw@...>, Chris Wedgwood <reviews@...>, Michael Krufky <mkrufky@...>, Chuck Ebbert <cebbert@...>, Domenico Andreoli <cavokz@...>, <torvalds@...>, <akpm@...>, <alan@...>, <johnstul@...>, <mingo@...>, <Vincent.Fortier1@...>, Thomas Gleixner <tglx@...>, Chris Wright <chrisw@...>, Greg Kroah-Hartman <gregkh@...>
Date: Tuesday, July 31, 2007 - 12:33 am

-stable review patch.  If anyone has any objections, please let us know.

------------------

The clock_was_set() call in seconds_overflow() which happens only when
leap seconds are inserted / deleted is wrong in two aspects:

1. it results in a call to on_each_cpu() with interrupts disabled
2. it is potential deadlock source vs. call_lock in smp_call_function()

The only possible side effect of the removal might be, that an absolute
CLOCK_REALTIME timer fires 1 second too late, in the rare case of leap
second deletion and an absolute CLOCK_REALTIME timer which expires in
the affected time frame. It will never fire too early.

This was probably observed by the reporter of a June 30th -> July 1st
hang: http://lkml.org/lkml/2007/7/3/

A similar problem was observed by Dave Jones, who provided a screen shot
with a lockdep back trace, which allowed to analyse the problem.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: john stultz <johnstul@us.ibm.com>
Cc: Dave Jones <davej@redhat.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Vincent Fortier <Vincent.Fortier1@EC.GC.CA>
Signed-off-by: Chris Wright <chrisw@sous-sol.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>

---
 kernel/time/ntp.c |    2 --
 1 file changed, 2 deletions(-)

--- linux-2.6.21.6.orig/kernel/time/ntp.c
+++ linux-2.6.21.6/kernel/time/ntp.c
@@ -120,7 +120,6 @@ void second_overflow(void)
 			 */
 			time_interpolator_update(-NSEC_PER_SEC);
 			time_state = TIME_OOP;
-			clock_was_set();
 			printk(KERN_NOTICE "Clock: inserting leap second "
 					"23:59:60 UTC\n");
 		}
@@ -135,7 +134,6 @@ void second_overflow(void)
 			 */
 			time_interpolator_update(NSEC_PER_SEC);
 			time_state = TIME_WAIT;
-			clock_was_set();
 			printk(KERN_NOTICE "Clock: deleting leap second "
 					"23:59:59 UTC\n");
 		}

-- 
-
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[patch 00/26] 2.6.21.7 -stable review, Greg KH, (Tue Jul 31, 12:30 am)
Re: [patch 00/26] 2.6.21.7 -stable review, Greg KH, (Tue Jul 31, 12:43 am)
Re: [patch 00/26] 2.6.21.7 -stable review, Stefan Richter, (Tue Jul 31, 6:50 am)
Re: [patch 00/26] 2.6.21.7 -stable review, Greg KH, (Tue Jul 31, 3:47 pm)
[patch 24/26] sky2: workaround for lost IRQ, Greg KH, (Tue Jul 31, 12:33 am)
[patch 23/26] NTP: remove clock_was_set() call to prevent de..., Greg KH, (Tue Jul 31, 12:33 am)
Re: [patch 20/26] saa7134: fix thread shutdown handling, Mauro Carvalho Chehab, (Tue Jul 31, 1:05 am)
Re: [patch 14/26] sched: fix next_interval determination in ..., Paul E. McKenney, (Tue Jul 31, 11:02 am)
[patch 12/26] dm crypt: fix remove first_clone, Greg KH, (Tue Jul 31, 12:32 am)
[patch 07/26] md: Fix two raid10 bugs., Greg KH, (Tue Jul 31, 12:31 am)
[patch 10/26] dm crypt: fix call to clone_init, Greg KH, (Tue Jul 31, 12:32 am)
[patch 09/26] dm crypt: disable barriers, Greg KH, (Tue Jul 31, 12:32 am)
[patch 03/26] rt-mutex: Fix stale return value, Greg KH, (Tue Jul 31, 12:31 am)
[patch 01/26] BNX2: Fix netdev watchdog on 5708., Greg KH, (Tue Jul 31, 12:31 am)
speck-geostationary