提交 16985408 编写于 作者: D Dan Streetman 提交者: Greg Kroah-Hartman

USB: retain USB device power/wakeup setting across reconfiguration

Currently a non-root-hub USB device's wakeup settings are initialized when the
device is set to a configured state using device_init_wakeup(), but this is not
correct as wakeup is split into "capable" (can_wakeup) and "enabled"
(should_wakeup).  The settings should be initialized instead in the device
initialization (usb_new_device) with the "capable" setting disabled and the
"enabled" setting enabled.  The "capable" setting should be set based on the
device being configured or unconfigured, and "enabled" setting set based on
the sysfs power/wakeup control.

This patch retains the sysfs power/wakeup setting of a non-root-hub USB device
over a USB device re-configuration, which can happen (for example) after a
suspend/resume cycle.
Signed-off-by: NDan Streetman <ddstreet@ieee.org>
Cc: David Brownell <dbrownell@users.sourceforge.net>
Cc: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 ce126644
...@@ -1448,11 +1448,11 @@ void usb_set_device_state(struct usb_device *udev, ...@@ -1448,11 +1448,11 @@ void usb_set_device_state(struct usb_device *udev,
|| new_state == USB_STATE_SUSPENDED) || new_state == USB_STATE_SUSPENDED)
; /* No change to wakeup settings */ ; /* No change to wakeup settings */
else if (new_state == USB_STATE_CONFIGURED) else if (new_state == USB_STATE_CONFIGURED)
device_init_wakeup(&udev->dev, device_set_wakeup_capable(&udev->dev,
(udev->actconfig->desc.bmAttributes (udev->actconfig->desc.bmAttributes
& USB_CONFIG_ATT_WAKEUP)); & USB_CONFIG_ATT_WAKEUP));
else else
device_init_wakeup(&udev->dev, 0); device_set_wakeup_capable(&udev->dev, 0);
} }
if (udev->state == USB_STATE_SUSPENDED && if (udev->state == USB_STATE_SUSPENDED &&
new_state != USB_STATE_SUSPENDED) new_state != USB_STATE_SUSPENDED)
...@@ -1799,10 +1799,18 @@ int usb_new_device(struct usb_device *udev) ...@@ -1799,10 +1799,18 @@ int usb_new_device(struct usb_device *udev)
{ {
int err; int err;
if (udev->parent) {
/* Increment the parent's count of unsuspended children */ /* Increment the parent's count of unsuspended children */
if (udev->parent)
usb_autoresume_device(udev->parent); usb_autoresume_device(udev->parent);
/* Initialize non-root-hub device wakeup to disabled;
* device (un)configuration controls wakeup capable
* sysfs power/wakeup controls wakeup enabled/disabled
*/
device_init_wakeup(&udev->dev, 0);
device_set_wakeup_enable(&udev->dev, 1);
}
usb_detect_quirks(udev); usb_detect_quirks(udev);
err = usb_enumerate_device(udev); /* Read descriptors */ err = usb_enumerate_device(udev); /* Read descriptors */
if (err < 0) if (err < 0)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册