Re: Back to the future.
From: Rafael J. Wysocki
Date: Sun Apr 29 2007 - 04:54:15 EST
On Sunday, 29 April 2007 01:45, Linus Torvalds wrote:
>
> On Sun, 29 Apr 2007, Rafael J. Wysocki wrote:
> >
> > OK, more precisely: fs-related threads should not try to process their queues,
> > etc., after the snapshot is done, because that may cause some fs data to be
> > written at that time and then the fs in question may be corrupted after the
> > restore. Not all of the I/O in general, fs data.
>
> But that's not true _either_. That's only true because right now I think
> we cannot even suspend to a swapfile (I might be wrong).
You are.
> If you have a swapfile on a filesystem, you'd need those fs queues
> running!
No, I don't. It's done by bmapping the file and writing directly to the
underlying blockdev. Otherwise we'd have corrupted filesystems after the
restore.
Swapfiles are handled this way anyway, so we just use the same code.
> > Well, I'm not sure whether or not that still would have been the case if we had
> > stopped to freeze kernel threads for the hibernation/suspend.
>
> Did you miss the email where Paul pointed out that Mac/PowerPC didn't use
> to do any of this?
No, I didn't.
> And apparently never had any issues with it?
On one platform with a limited subset of device drivers.
> And probably worked more reliably several years ago than suspend/hibernation
> does _today_?
I have no problems with the hibernation on my test boxes (six of them), except
for one network driver that doesn't bother to define a .suspend() callback.
There are problems with the suspend (s2ram), but they are _not_ related to the
freezing of kernel threads. Some of them are related to the other issue that
you have risen, which is that the same callbacks should not be used for the
suspend and hibernation, and which I think is absolutely valid. The remaining
ones are related to the fact that graphic card vendors don't care for us at
all.
> Ie we do have history of _not_ freezing things. The freezing came later,
> and came with the subsystem that had more problems..
It doesn't have that many problems as you are trying to suggest. At present,
the only problems with it happen if someone tries to "improve" it in the way
I did with the workqueues.
Anyway, the freezing of tasks, including kernel threads, is one of the few
things on which Pavel, Nigel and me completely agree that they should be done,
so perhaps you could accept that?
Greetings,
Rafael
-
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/