On Wednesday, 4 July 2007 21:25, Miklos Szeredi wrote: > > Remember what I wrote a few minutes ago about khubd and ksuspend_usbd > > wanting to resume devices during a system suspend transition? This is > > exactly what happens when those threads aren't frozen. > > OK, let me summarize the situation as I see it now: there are two > camps, the pro-freezers and the anti-freezers. > > Pro-freezers say: > > - don't remove the freezer, otherwise we'll have to deal with > numerous problems in drivers And these problems will generally be difficult to reproduce reliably and debug. > Anti-freezers say: > > - let's remove the freezer, which causes numerous problems > > Alan summerized the pro-freezer arguments well I think. What are the > anti-freezer arguments then? > > After having looked at the freezer and done some experiments with it, > the most obvious problem looks to be, that it can get stuck on a > process doing uninterruptible sleep. That's correct. > And yes, this can happen if a fuse filesystem daemon is frozen before a > filesystem user is. And this is not something that can be fixed in fuse, > some filesystem calls (rename(2) for example) are simply not restartable. > > This doesn't explain the deadlocks, but it could cause failure to > suspend which would be pretty annoying. I think the only thing that can deadlock in that context is the sync. At least, I don't see anything else. > Does this affect other things than fuse? Not that I know of. It may affect user space drivers, but there's no data on that. > Can this be fixed? > > It seems to be a fundamental problem with the freezer: while it does > make sure that user processes are not calling into drivers during > suspend, it also disallows perfectly harmless non-driver calls as > well. The problem is that when the freezer was designed (I didn't do that, BTW), there was no FUSE and similar things, so it's not prepared to cope with such interdependencies between user space tasks. We had an analogous problem with vfork() and it was solved by using the PF_FREEZER_SKIP flag. Perhaps we can do similar thing with FUSE. Greetings, Rafael -- "Premature optimization is the root of all evil." - Donald Knuth _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm