Move source tree closer to the 2.6.32.17 mainline
/drivers/usb/core/driver.c
blob:4f864472c5c4db4eea4004cd49e902cb4acd75c9 -> blob:d784a8b3a6bdb9d869ff2f20d63555bbfcb4f106
--- drivers/usb/core/driver.c
+++ drivers/usb/core/driver.c
@@ -625,9 +625,6 @@ static int usb_uevent(struct device *dev
{
struct usb_device *usb_dev;
- /* driver is often null here; dev_dbg() would oops */
- pr_debug("usb %s: uevent\n", dev_name(dev));
-
if (is_usb_device(dev)) {
usb_dev = to_usb_device(dev);
} else if (is_usb_interface(dev)) {
@@ -639,6 +636,7 @@ static int usb_uevent(struct device *dev
}
if (usb_dev->devnum < 0) {
+ /* driver is often null here; dev_dbg() would oops */
pr_debug("usb %s: already deleted?\n", dev_name(dev));
return -ENODEV;
}
@@ -1177,9 +1175,8 @@ static int usb_suspend_both(struct usb_d
udev->state == USB_STATE_SUSPENDED)
goto done;
- udev->do_remote_wakeup = device_may_wakeup(&udev->dev);
-
if (msg.event & PM_EVENT_AUTO) {
+ udev->do_remote_wakeup = device_may_wakeup(&udev->dev);
status = autosuspend_check(udev, 0);
if (status < 0)
goto done;
@@ -1744,6 +1741,23 @@ int usb_external_resume_device(struct us
return status;
}
+static void choose_wakeup(struct usb_device *udev, pm_message_t msg)
+{
+ /* Remote wakeup is needed only when we actually go to sleep.
+ * For things like FREEZE and QUIESCE, if the device is already
+ * autosuspended then its current wakeup setting is okay.
+ */
+ if (msg.event == PM_EVENT_FREEZE || msg.event == PM_EVENT_QUIESCE) {
+ udev->do_remote_wakeup = 0;
+ return;
+ }
+
+ /* Allow remote wakeup if it is enabled, even if no interface drivers
+ * actually want it.
+ */
+ udev->do_remote_wakeup = device_may_wakeup(&udev->dev);
+}
+
int usb_suspend(struct device *dev, pm_message_t msg)
{
struct usb_device *udev;
@@ -1763,6 +1777,7 @@ int usb_suspend(struct device *dev, pm_m
}
udev->skip_sys_resume = 0;
+ choose_wakeup(udev, msg);
return usb_external_suspend_device(udev, msg);
}