Re: [PATCH] Leave runtime suspended devices off at system resume

From: Todd Poynor
Date: Fri May 28 2004 - 12:53:21 EST


On Fri, May 28, 2004 at 10:03:15AM -0700, Greg KH wrote:
> Nice, that looks good.
>
> Applied, thanks.

Sorry, Felipe Solana found that USB drivers tweak the power.power_state
field during suspend, so we can't rely on that field to tell what to
resume. A new patch against 2.6.6 creates a separate field for the
original value, so driver mods to the field won't break resume. I'll
also send a patch against the original patch to fix trees already
updated in a moment. Thanks -- Todd

--- linux-2.6.6-orig/drivers/base/power/suspend.c 2004-05-10 11:22:58.000000000 -0700
+++ linux-2.6.6-prevstate/drivers/base/power/suspend.c 2004-05-27 13:58:01.931014888 -0700
@@ -39,7 +39,9 @@
{
int error = 0;

- if (dev->bus && dev->bus->suspend)
+ dev->power.prev_state = dev->power.power_state;
+
+ if (dev->bus && dev->bus->suspend && ! dev->power.power_state)
error = dev->bus->suspend(dev,state);

if (!error) {
--- linux-2.6.6-orig/drivers/base/power/resume.c 2004-05-10 11:22:58.000000000 -0700
+++ linux-2.6.6-prevstate/drivers/base/power/resume.c 2004-05-27 14:35:03.373304328 -0700
@@ -35,7 +35,10 @@
struct list_head * entry = dpm_off.next;
struct device * dev = to_device(entry);
list_del_init(entry);
- resume_device(dev);
+
+ if (! dev->power.prev_state)
+ resume_device(dev);
+
list_add_tail(entry,&dpm_active);
}
}
--- linux-2.6.6-orig/include/linux/pm.h 2004-05-10 11:23:56.000000000 -0700
+++ linux-2.6.6-prevstate/include/linux/pm.h 2004-05-27 14:35:37.143170528 -0700
@@ -231,6 +231,7 @@
struct dev_pm_info {
#ifdef CONFIG_PM
u32 power_state;
+ u32 prev_state;
u8 * saved_state;
atomic_t pm_users;
struct device * pm_parent;


-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/