Re: [lm-sensors] broken suspend [Was: 2.6.24-rc2-mm1]

From: Alan Stern
Date: Wed Nov 21 2007 - 10:54:52 EST


On Wed, 21 Nov 2007, Rafael J. Wysocki wrote:

> > Is it possible to unregister a driver on CPU_DOWN_PREPARE_FROZEN?
>
> No. In that case the suspend core is holding the device's mutex and your
> attempt to unregister it will deadlock with it.
>
> Do you _have_ _to_ unregister the device at all? Why don't you just leave
> it registered on CPU_DOWN_PREPARE_FROZEN? The CPU is not going away
> physically in this case and it's _guaranteed_ that _cpu_up() will be called on
> it as soon as the hibernation image is ready or we are back from suspend.

This leaves the device registered if for some reason the number of CPUs
after resuming from hibernation is smaller than the number of CPUs
before hibernation. Of course, in theory that's never supposed to
happen...

Alan Stern

-
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/