Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 104540
b: refs/heads/master
c: 9e5eace
h: refs/heads/master
v: v3
  • Loading branch information
Greg Kroah-Hartman committed Jul 21, 2008
1 parent ecdadfc commit 57f4b37
Show file tree
Hide file tree
Showing 2 changed files with 3 additions and 45 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 24618b0cd42f936cda461bdf6144670a5c925178
refs/heads/master: 9e5eace734a7b4e96a4ba4cf1f85622446e95e17
46 changes: 2 additions & 44 deletions trunk/drivers/usb/core/hub.c
Original file line number Diff line number Diff line change
Expand Up @@ -644,48 +644,6 @@ static void hub_stop(struct usb_hub *hub)

#ifdef CONFIG_PM

/* Try to identify which devices need USB-PERSIST handling */
static int persistent_device(struct usb_device *udev)
{
int i;
int retval;
struct usb_host_config *actconfig;

/* Explicitly not marked persistent? */
if (!udev->persist_enabled)
return 0;

/* No active config? */
actconfig = udev->actconfig;
if (!actconfig)
return 0;

/* FIXME! We should check whether it's open here or not! */

/*
* Check that all the interface drivers have a
* 'reset_resume' entrypoint
*/
retval = 0;
for (i = 0; i < actconfig->desc.bNumInterfaces; i++) {
struct usb_interface *intf;
struct usb_driver *driver;

intf = actconfig->interface[i];
if (!intf->dev.driver)
continue;
driver = to_usb_driver(intf->dev.driver);
if (!driver->reset_resume)
return 0;
/*
* We have at least one driver, and that one
* has a reset_resume method.
*/
retval = 1;
}
return retval;
}

static void hub_restart(struct usb_hub *hub, int type)
{
struct usb_device *hdev = hub->hdev;
Expand Down Expand Up @@ -731,8 +689,8 @@ static void hub_restart(struct usb_hub *hub, int type)
* turn off the various status changes to prevent
* khubd from disconnecting it later.
*/
if (status == 0 && !(portstatus & USB_PORT_STAT_ENABLE) &&
persistent_device(udev)) {
if (udev->persist_enabled && status == 0 &&
!(portstatus & USB_PORT_STAT_ENABLE)) {
if (portchange & USB_PORT_STAT_C_ENABLE)
clear_port_feature(hub->hdev, port1,
USB_PORT_FEAT_C_ENABLE);
Expand Down

0 comments on commit 57f4b37

Please sign in to comment.