On Monday, June 20, 2011, Rafael J. Wysocki wrote: > From: Rafael J. Wysocki <rjw@xxxxxxx> > > Make generic PM domains support system-wide power transitions > (system suspend and hibernation). Add suspend, resume, freeze, thaw, > poweroff and restore callbacks to be associated with struct > generic_pm_domain objects and make pm_genpd_init() use them as > appropriate. > > The new callbacks do nothing for devices belonging to power domains > that were powered down at run time (before the transition). For the > other devices the action carried out depends on the type of the > transition. During system suspend the power domain .suspend() > callback executes pm_generic_suspend() for the device, while the > PM domain .suspend_noirq() callback runs pm_generic_suspend_noirq() > for it, stops it and eventually removes power from the PM domain it > belongs to (after all devices in the domain have been stopped and its > subdomains have been powered off). > > During system resume the PM domain .resume_noirq() callback > restores power to the PM domain (when executed for it first time), > starts the device and executes pm_generic_resume_noirq() for it, > while the .resume() callback executes pm_generic_resume() for the > device. Finally, the .complete() callback executes pm_runtime_idle() > for the device which should put it back into the suspended state if > its runtime PM usage count is equal to zero at that time. > > The actions carried out during hibernation and resume from it are > analogous to the ones described above. > > Signed-off-by: Rafael J. Wysocki <rjw@xxxxxxx> > --- The patch below adds wakeup devices support on top of this one. Thanks, Rafael --- From: Rafael J. Wysocki <rjw@xxxxxxx> Subject: PM / Domains: Don't stop wakeup devices during system sleep transitions Devices that are set up to wake up the system from sleep states should not be stopped and power should not be removed from them when the system goes into a sleep state. Make the generic PM domain code respect that limitation. Signed-off-by: Rafael J. Wysocki <rjw@xxxxxxx> --- drivers/base/power/domain.c | 6 ++++++ 1 file changed, 6 insertions(+) Index: linux-2.6/drivers/base/power/domain.c =================================================================== --- linux-2.6.orig/drivers/base/power/domain.c +++ linux-2.6/drivers/base/power/domain.c @@ -446,6 +446,9 @@ static int pm_genpd_suspend_noirq(struct if (ret) return ret; + if (device_may_wakeup(dev)) + return 0; + if (genpd->stop_device) genpd->stop_device(dev); @@ -666,6 +669,9 @@ static int pm_genpd_dev_poweroff_noirq(s if (ret) return ret; + if (device_may_wakeup(dev)) + return 0; + if (genpd->stop_device) genpd->stop_device(dev); _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm