diff options
author | Andiry Xu <andiry.xu@gmail.com> | 2012-05-04 12:50:10 -0400 |
---|---|---|
committer | Sarah Sharp <sarah.a.sharp@linux.intel.com> | 2012-05-17 13:36:57 -0400 |
commit | c3e751e4f4754793bb52bd5ae30e9cc027edbb12 (patch) | |
tree | 93fbd40123a934b70371932c2d5e9e3773f42eef /drivers/usb | |
parent | 1530bbc6272d9da1e39ef8e06190d42c13a02733 (diff) |
usbcore: enable USB2 LPM if port suspend fails
USB2 LPM is disabled when device begin to suspend and enabled after device
is resumed. That's because USB spec does not define the transition from
U1/U2 state to U3 state.
If usb_port_suspend() fails, usb_port_resume() is never called, and USB2 LPM
is disabled in this situation. Enable USB2 LPM if port suspend fails.
This patch should be backported to kernels as old as 3.2, that contain
the commit 65580b4321eb36f16ae8b5987bfa1bb948fc5112 "xHCI: set USB2
hardware LPM".
Signed-off-by: Andiry Xu <andiry.xu@gmail.com>
Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com>
Cc: stable@vger.kernel.org
Diffstat (limited to 'drivers/usb')
-rw-r--r-- | drivers/usb/core/hub.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c index ec6c97dadbe4..c8e0704c6e5d 100644 --- a/drivers/usb/core/hub.c +++ b/drivers/usb/core/hub.c | |||
@@ -2499,6 +2499,10 @@ int usb_port_suspend(struct usb_device *udev, pm_message_t msg) | |||
2499 | NULL, 0, | 2499 | NULL, 0, |
2500 | USB_CTRL_SET_TIMEOUT); | 2500 | USB_CTRL_SET_TIMEOUT); |
2501 | 2501 | ||
2502 | /* Try to enable USB2 hardware LPM again */ | ||
2503 | if (udev->usb2_hw_lpm_capable == 1) | ||
2504 | usb_set_usb2_hardware_lpm(udev, 1); | ||
2505 | |||
2502 | /* System sleep transitions should never fail */ | 2506 | /* System sleep transitions should never fail */ |
2503 | if (!PMSG_IS_AUTO(msg)) | 2507 | if (!PMSG_IS_AUTO(msg)) |
2504 | status = 0; | 2508 | status = 0; |