* Matthew Garrett <mjg@xxxxxxxxxx> [100511 09:59]: > On Tue, May 11, 2010 at 09:58:21AM -0700, Tony Lindgren wrote: > > * Matthew Garrett <mjg@xxxxxxxxxx> [100511 09:41]: > > > Yes. You still need suspend blocks. > > > > Maybe not if echo opportunistic > /sys/power/policy gets cleared by > > the kernel if the kernel idle loop can't make it. That means something > > has blocked the suspend attempt in a driver for example. The system > > keeps running, and the userspace can deal with the situation. > > So an event arrives just as userspace does this write. How do you avoid > the race? Plausible answers mostly appear to end up looking like suspend > blockers. Assuming you attempt suspend in a custom pm_idle function, any driver handling the event can fail the suspend attempt. And that would clear the opportunistic suspend flag. And the userspace would be still running and could handle the event. And when the userspace is done, it can again echo opportunistic > /sys/power/policy. For the failed suspend path in the kernel, currently the kernel would unwind back all the drivers because of the failed driver, but that path should be possible to optimize. Regards, Tony _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm