aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Spang <spang@chromium.org>2012-09-14 13:05:49 -0400
committerSarah Sharp <sarah.a.sharp@linux.intel.com>2012-09-24 15:09:39 -0400
commita6e097dfdfd189b6929af6efa1d289af61858386 (patch)
tree7c0539db2668c08cadf7e3b07d02fdc5ee1de635
parentf3f4bf5cf0896e58e9831ea53bcb8c7d88127d20 (diff)
Increase XHCI suspend timeout to 16ms
The Intel XHCI specification says that after clearing the run/stop bit the controller may take up to 16ms to halt. We've seen a device take 14ms, which with the current timeout of 10ms causes the kernel to abort the suspend. Increasing the timeout to the recommended value fixes the problem. This patch should be backported to kernels as old as 2.6.37, that contain the commit 5535b1d5f8885695c6ded783c692e3c0d0eda8ca "USB: xHCI: PCI power management implementation". Signed-off-by: Michael Spang <spang@chromium.org> Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com> Cc: stable@vger.kernel.org
-rw-r--r--drivers/usb/host/xhci.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c
index a4b0ce13fa0c..52b04b0880c3 100644
--- a/drivers/usb/host/xhci.c
+++ b/drivers/usb/host/xhci.c
@@ -888,7 +888,7 @@ int xhci_suspend(struct xhci_hcd *xhci)
888 command &= ~CMD_RUN; 888 command &= ~CMD_RUN;
889 xhci_writel(xhci, command, &xhci->op_regs->command); 889 xhci_writel(xhci, command, &xhci->op_regs->command);
890 if (handshake(xhci, &xhci->op_regs->status, 890 if (handshake(xhci, &xhci->op_regs->status,
891 STS_HALT, STS_HALT, 100*100)) { 891 STS_HALT, STS_HALT, XHCI_MAX_HALT_USEC)) {
892 xhci_warn(xhci, "WARN: xHC CMD_RUN timeout\n"); 892 xhci_warn(xhci, "WARN: xHC CMD_RUN timeout\n");
893 spin_unlock_irq(&xhci->lock); 893 spin_unlock_irq(&xhci->lock);
894 return -ETIMEDOUT; 894 return -ETIMEDOUT;