diff options
author | Alan Stern <stern@rowland.harvard.edu> | 2010-11-15 15:57:58 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2010-11-16 17:04:22 -0500 |
commit | c08512c761e7b9eaaab0e9167a389393f268e93c (patch) | |
tree | 6837bfb8e93915dae46a63a863275f90428f82f0 /drivers/usb/core/driver.c | |
parent | fcc4a01eb8661226e80632327673f67bf6a5840b (diff) |
USB: improve uses of usb_mark_last_busy
This patch (as1434) cleans up the uses of usb_mark_last_busy() in
usbcore. The function will be called when a device is resumed and
whenever a usage count is decremented. A call that was missing from
the hub driver is added: A hub is used whenever one of its ports gets
suspended (this prevents hubs from suspending immediately after their
last child).
In addition, the call to disable autosuspend support for new devices
by default is moved from usb_detect_quirks() (where it doesn't really
belong) into usb_new_device() along with all the other runtime-PM
initializations. Finally, an extra pm_runtime_get_noresume() is added
to prevent new devices from autosuspending while they are being
registered.
Signed-off-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/core/driver.c')
-rw-r--r-- | drivers/usb/core/driver.c | 8 |
1 files changed, 1 insertions, 7 deletions
diff --git a/drivers/usb/core/driver.c b/drivers/usb/core/driver.c index 43c25c29ac1f..b9278a1fb9e5 100644 --- a/drivers/usb/core/driver.c +++ b/drivers/usb/core/driver.c | |||
@@ -1261,6 +1261,7 @@ static int usb_resume_both(struct usb_device *udev, pm_message_t msg) | |||
1261 | udev->reset_resume); | 1261 | udev->reset_resume); |
1262 | } | 1262 | } |
1263 | } | 1263 | } |
1264 | usb_mark_last_busy(udev); | ||
1264 | 1265 | ||
1265 | done: | 1266 | done: |
1266 | dev_vdbg(&udev->dev, "%s: status %d\n", __func__, status); | 1267 | dev_vdbg(&udev->dev, "%s: status %d\n", __func__, status); |
@@ -1328,7 +1329,6 @@ int usb_resume(struct device *dev, pm_message_t msg) | |||
1328 | pm_runtime_disable(dev); | 1329 | pm_runtime_disable(dev); |
1329 | pm_runtime_set_active(dev); | 1330 | pm_runtime_set_active(dev); |
1330 | pm_runtime_enable(dev); | 1331 | pm_runtime_enable(dev); |
1331 | usb_mark_last_busy(udev); | ||
1332 | do_unbind_rebind(udev, DO_REBIND); | 1332 | do_unbind_rebind(udev, DO_REBIND); |
1333 | } | 1333 | } |
1334 | } | 1334 | } |
@@ -1660,11 +1660,6 @@ static int usb_runtime_suspend(struct device *dev) | |||
1660 | return -EAGAIN; | 1660 | return -EAGAIN; |
1661 | 1661 | ||
1662 | status = usb_suspend_both(udev, PMSG_AUTO_SUSPEND); | 1662 | status = usb_suspend_both(udev, PMSG_AUTO_SUSPEND); |
1663 | |||
1664 | /* Prevent the parent from suspending immediately after */ | ||
1665 | if (status == 0 && udev->parent) | ||
1666 | usb_mark_last_busy(udev->parent); | ||
1667 | |||
1668 | return status; | 1663 | return status; |
1669 | } | 1664 | } |
1670 | 1665 | ||
@@ -1677,7 +1672,6 @@ static int usb_runtime_resume(struct device *dev) | |||
1677 | * and all its interfaces. | 1672 | * and all its interfaces. |
1678 | */ | 1673 | */ |
1679 | status = usb_resume_both(udev, PMSG_AUTO_RESUME); | 1674 | status = usb_resume_both(udev, PMSG_AUTO_RESUME); |
1680 | usb_mark_last_busy(udev); | ||
1681 | return status; | 1675 | return status; |
1682 | } | 1676 | } |
1683 | 1677 | ||