On Mon, 2008-02-25 at 10:39 -0500, Alan Stern wrote: > Ongoing efforts to remove the freezer from the system suspend and > hibernation code ("system sleep" is the proper catch-all term) have > turned up a fundamental flaw in the Power Management subsystem's > design. In brief, we cannot handle the race between hotplug addition > of new devices and suspending all existing devices. .../... Yup, old problem, I think I've said a long time ago that it's the reponsibility of bus drivers (such as USB khub) to stop issuing device additions when suspend is in progress. It might be possible to still do removal tho. > The only possible solution is to have the drivers themselves be > responsible for preventing calls to device_add() or device_register() > during a system sleep. (It's also necessary to prevent driver binding, > but this isn't a major issue.) Agreed. > The most straightforward approach is to > add a new pair of driver methods: one to disable adding children and > one to re-enable it. Of course this would represent a significant > addition to the Power Management driver interface. No, I think the global notifier is plenty for now. Later on, we can re-add early-suspend, late-resume, or we can finally turn the whole thing into a recursive call tree where the parents are the ones calling the children suspend :-) But for now, I think the global notifier is enough. Cheers, Ben. _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm