On Fri, 25 Jun 2010, Rafael J. Wysocki wrote: > > That's not the point. If a wakeup handler queues a work item (for > > example, by calling pm_request_resume) then it wouldn't need to guess a > > timeout. The work item would be guaranteed to run before the system > > could suspend again. > > You seem to be referring to the PM workqueue specifically. Perhaps it would be > better to special-case it and stop it by adding a barrier work during suspend > instead of just freezing? Then, it wouldn't need to be singlethread any more. The barrier work would have to be queued to each CPU's thread. That would be okay. Hmm, it looks like wait_event_freezable() and wait_event_freezable_timeout() could use similar changes: If the condition is true then they shouldn't try to freeze the caller. > Still, I think the timeout is necessary anyway in case the driver simply > doesn't handle the event and user space needs time to catch up. Unfortunately, > the PCI wakeup code doesn't know what happens next in advance. That could all be handled by the lower driver. Still, a 100-ms timeout isn't going to make a significant difference, since a suspend/resume cycle will take a comparable length of time. Alan Stern _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm