]> git.baikalelectronics.ru Git - kernel.git/commit
clocksource: Prevent potential kgdb dead lock
authorThomas Gleixner <tglx@linutronix.de>
Tue, 26 Jan 2010 11:51:10 +0000 (12:51 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Tue, 26 Jan 2010 13:53:16 +0000 (14:53 +0100)
commit8d09d2a5aa68d6748b4198da3bdc4078bed0c3c8
tree29cb2554e08df65a82afd46f2e034ee0e015ac80
parente518d127e0cd0e9010ee24f56085582987781680
clocksource: Prevent potential kgdb dead lock

commit 91bf3124 (clocksource: Simplify clocksource watchdog resume
logic) introduced a potential kgdb dead lock. When the kernel is
stopped by kgdb inside code which holds watchdog_lock then kgdb dead
locks in clocksource_resume_watchdog().

clocksource_resume_watchdog() is called from kbdg via
clocksource_touch_watchdog() to avoid that the clock source watchdog
marks TSC unstable after the kernel has been stopped.

Solve this by replacing spin_lock with a spin_trylock and just return
in case the lock is held. Not resetting the watchdog might result in
TSC becoming marked unstable, but that's an acceptable penalty for
using kgdb.

The timekeeping is anyway easily screwed up by kgdb when the system
uses either jiffies or a clock source which wraps in short intervals
(e.g. pm_timer wraps about every 4.6s), so we really do not have to
worry about that occasional TSC marked unstable side effect.

The second caller of clocksource_resume_watchdog() is
clocksource_resume(). The trylock is safe here as well because the
system is UP at this point, interrupts are disabled and nothing else
can hold watchdog_lock().

Reported-by: Jason Wessel <jason.wessel@windriver.com>
LKML-Reference: <1264480000-6997-4-git-send-email-jason.wessel@windriver.com>
Cc: kgdb-bugreport@lists.sourceforge.net
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: John Stultz <johnstul@us.ibm.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
kernel/time/clocksource.c