A patch to fix my previous
leave-runtime-suspended-devices-off-at-system-resume patch; the new
changes save a copy of power.power_state in order to know whether to
resume a device, independently of mods to that field by a driver suspend
routine. This fixes 2.6.7-rc1-mm1 in the same fashion as the updated
2.6.6 patch sent previously.
Signed-off-by: Greg Kroah-Hartman <greg@kroah.com>
struct device * dev = to_device(entry);
list_del_init(entry);
- if (!dev->power.power_state)
+ if (!dev->power.prev_state)
resume_device(dev);
list_add_tail(entry,&dpm_active);
dev_dbg(dev, "suspending\n");
+ dev->power.prev_state = dev->power.power_state;
+
if (dev->bus && dev->bus->suspend && !dev->power.power_state)
error = dev->bus->suspend(dev,state);
struct dev_pm_info {
u32 power_state;
#ifdef CONFIG_PM
+ u32 prev_state;
u8 * saved_state;
atomic_t pm_users;
struct device * pm_parent;