aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/host/xhci.c
diff options
context:
space:
mode:
authorSarah Sharp <sarah.a.sharp@linux.intel.com>2013-10-08 11:28:43 -0400
committerSarah Sharp <sarah.a.sharp@linux.intel.com>2013-10-16 15:24:21 -0400
commitf468f7b9467b285b87ea61e2a3c8c0e641117b0e (patch)
tree5c74b9778be3be051cd865b5e8a4906cc0347ecd /drivers/usb/host/xhci.c
parent890dae88672175f1d39f6105444d9bdc71c89258 (diff)
usb: Push USB2 LPM disable on disconnect into USB core.
The USB core currently handles enabling and disabling optional USB power management features during device transitions (device suspend/resume, driver bind/unbind, device reset, and device disconnect). Those optional power features include Latency Tolerance Messaging (LTM), USB 3.0 Link PM, and USB 2.0 Link PM. The USB core currently enables LPM on device enumeration and disables USB 2.0 Link PM when the device is reset. However, the xHCI driver disables LPM when the device is disconnected and the device context is freed. Push the call up into the USB core, in order to be consistent with the core handling all power management enabling and disabling. Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com>
Diffstat (limited to 'drivers/usb/host/xhci.c')
-rw-r--r--drivers/usb/host/xhci.c5
1 files changed, 0 insertions, 5 deletions
diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c
index 0ea253ec813d..e7571c90c40f 100644
--- a/drivers/usb/host/xhci.c
+++ b/drivers/usb/host/xhci.c
@@ -3571,11 +3571,6 @@ void xhci_free_dev(struct usb_hcd *hcd, struct usb_device *udev)
3571 del_timer_sync(&virt_dev->eps[i].stop_cmd_timer); 3571 del_timer_sync(&virt_dev->eps[i].stop_cmd_timer);
3572 } 3572 }
3573 3573
3574 if (udev->usb2_hw_lpm_enabled) {
3575 xhci_set_usb2_hardware_lpm(hcd, udev, 0);
3576 udev->usb2_hw_lpm_enabled = 0;
3577 }
3578
3579 spin_lock_irqsave(&xhci->lock, flags); 3574 spin_lock_irqsave(&xhci->lock, flags);
3580 /* Don't disable the slot if the host controller is dead. */ 3575 /* Don't disable the slot if the host controller is dead. */
3581 state = xhci_readl(xhci, &xhci->op_regs->status); 3576 state = xhci_readl(xhci, &xhci->op_regs->status);