[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1183677643.3388.105.camel@localhost.localdomain>
Date: Fri, 06 Jul 2007 09:20:43 +1000
From: Benjamin Herrenschmidt <benh@...nel.crashing.org>
To: Nigel Cunningham <nigel@...el.suspend2.net>
Cc: Pavel Machek <pavel@....cz>, "Rafael J. Wysocki" <rjw@...k.pl>,
Matthew Garrett <mjg59@...f.ucam.org>,
linux-kernel@...r.kernel.org, linux-pm@...ts.linux-foundation.org,
Alan Stern <stern@...land.harvard.edu>
Subject: Re: [PATCH] Remove process freezer from suspend to RAM pathway
> Will you be able to guarantee that every place where a task can/will block
> will be harmless place? If so, how will you guarantee that? How will you
> debug issues where a task occasionally doesn't block in the right place,
> particularly instances where it is some less than obvious interaction with
> other tasks?
Which places aren't harmless if you don't have a freezer ?
> This is the whole point to having the freezer. It makes things more
> predictable and testable. It shows us, clearly, when process X is the one
> that is causing problems.
No, the freezer creates all those places what are harmful for a task to
block because they will break the freezer :-)
> > - Silently add GFP_NOIO to all allocations, to avoid having things
> > blocking in kmalloc() with a mutex held that will deadlock with
> > suspend() in a driver for example. Or set some way to have all GFP
> > waiters wakeup and fail rather than wait for IOs. It's hard/bizarre but
> > necessary, again, with or without a freezer.
>
> GFP_ATOMIC? (In driver suspend, they shouldn't be sleeping either, right?)
NOIO should be enough I think but ATOMIC would do).
That's one of the reason why I used to have the pre-suspend and
post-resume hooks in my original powermac implementation, for those few
drivers complicated enough to require some pre-allocations.
> > - Deal with the firmware problem. The best way is probably to have an
> > async request_firmware interface(). Another thing is, drivers may want
> > to cache their firmware in main memory, that sort of thing...
> >
Note that the above firmware problem could be dealt with also with the
pre-suspend/post-resume. Allowing to pre-request firmware etc... and
keep it around until after resume, because we know we will need it.
Gives a chance to drivers to perform things while the system is still
live, filesystems still working, etc... (big memory allocations for
example).
> > And that's just a small list off the top of my mind, of known problems
> > that will cause deadlocks or misbehaviours today, with or without the
> > freezer, and that need to be addressed.
>
> Userspace device drivers too?
Maybe but they are less of an issue, most of the time, they don't do DMA
or whatever harmful things. If they are USB drivers, for example, they
are an non-issues at that level.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists