On Sat, 2007-05-12 at 03:07 -0700, Andrew Morton wrote: > On Sat, 12 May 2007 11:18:09 +0200 Thomas Gleixner <tglx@xxxxxxxxxxxxx> wrote: > > > > It's peculiar that the hang happens when acpi_evaluate_object() hits its > > > return statement. Any theories there? > > > > Only stack or memory corruption come into mind, but I have no clue how > > this is related to the resume logic changes. > > So I had the brilliant idea of turning on some kernel debugging. It's > a shame that CONFIG_SOFTWARE_SUSPEND disables CONFIG_DEBUG_PAGEALLOC. Really brilliant. I tried to reproduce your problem and stumbled across something else. tglx -------------------------------> Subject: clocksource fix lock order in the resume path lockdep complains about the lock nesting of clocksource and watchdog lock in the resume path. Move watchdog resume out of the clocksource lock. Signed-off-by: Thomas Gleixner <tglx@xxxxxxxxxxxxx> Index: linux-2.6.21/kernel/time/clocksource.c =================================================================== --- linux-2.6.21.orig/kernel/time/clocksource.c +++ linux-2.6.21/kernel/time/clocksource.c @@ -151,9 +151,11 @@ static void clocksource_watchdog(unsigne } static void clocksource_resume_watchdog(void) { - spin_lock(&watchdog_lock); + unsigned long flags; + + spin_lock_irqsave(&watchdog_lock, flags); watchdog_resumed = 1; - spin_unlock(&watchdog_lock); + spin_unlock_irqrestore(&watchdog_lock, flags); } static void clocksource_check_watchdog(struct clocksource *cs) @@ -224,9 +226,9 @@ void clocksource_resume(void) cs->resume(); } - clocksource_resume_watchdog(); - spin_unlock_irqrestore(&clocksource_lock, flags); + + clocksource_resume_watchdog(); } /** - To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html