From: Rafael J. Wysocki <[EMAIL PROTECTED]>

The suspend routines should be called for every device during a system sleep
transition, regardless of the device's state, so that drivers can regard these
method calls as notifications that the system is about to go to sleep, rather
than as directives to put their devices into the 'off' state.

This is documented in Documentation/power/devices.txt and is already done in
the core resume code, so it seems reasonable to make the core suspend code
behave accordingly.

Signed-off-by: Rafael J. Wysocki <[EMAIL PROTECTED]>
---
 drivers/base/power/suspend.c |    8 +++-----
 1 file changed, 3 insertions(+), 5 deletions(-)

Index: linux-2.6.22-rc4/drivers/base/power/suspend.c
===================================================================
--- linux-2.6.22-rc4.orig/drivers/base/power/suspend.c  2007-06-11 
09:59:54.000000000 +0200
+++ linux-2.6.22-rc4/drivers/base/power/suspend.c       2007-06-11 
10:18:11.000000000 +0200
@@ -71,14 +71,13 @@ int suspend_device(struct device * dev, 
                        dev->parent->power.power_state.event);
        }
 
-       if (dev->class && dev->class->suspend && !dev->power.power_state.event) 
{
+       if (dev->class && dev->class->suspend) {
                suspend_device_dbg(dev, state, "class ");
                error = dev->class->suspend(dev, state);
                suspend_report_result(dev->class->suspend, error);
        }
 
-       if (!error && dev->bus && dev->bus->suspend
-           && !dev->power.power_state.event) {
+       if (!error && dev->bus && dev->bus->suspend) {
                suspend_device_dbg(dev, state, "");
                error = dev->bus->suspend(dev, state);
                suspend_report_result(dev->bus->suspend, error);
@@ -97,8 +96,7 @@ static int suspend_device_late(struct de
 {
        int error = 0;
 
-       if (dev->bus && dev->bus->suspend_late
-           && !dev->power.power_state.event) {
+       if (dev->bus && dev->bus->suspend_late) {
                suspend_device_dbg(dev, state, "LATE ");
                error = dev->bus->suspend_late(dev, state);
                suspend_report_result(dev->bus->suspend_late, error);

-------------------------------------------------------------------------
This SF.net email is sponsored by DB2 Express
Download DB2 Express C - the FREE version of DB2 express and take
control of your XML. No limits. Just data. Click to get it now.
http://sourceforge.net/powerbar/db2/
_______________________________________________
linux-usb-devel@lists.sourceforge.net
To unsubscribe, use the last form field at:
https://lists.sourceforge.net/lists/listinfo/linux-usb-devel

Reply via email to