aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOliver Neukum <oneukum@suse.de>2013-09-30 09:50:54 -0400
committerSarah Sharp <sarah.a.sharp@linux.intel.com>2013-10-09 19:27:04 -0400
commit455f58925247e8a1a1941e159f3636ad6ee4c90b (patch)
treee4a84528c611c4989bc6bfc19ccc601e847e5abd
parentf217c980ca980e3a645b7485ea5eae9a747f4945 (diff)
xhci: quirk for extra long delay for S4
It has been reported that this chipset really cannot sleep without this extraordinary delay. This patch should be backported, in order to ensure this host functions under stable kernels. The last quirk for Fresco Logic hosts (commit bba18e33f25072ebf70fd8f7f0cdbf8cdb59a746 "xhci: Extend Fresco Logic MSI quirk.") was backported to stable kernels as old as 2.6.36. Signed-off-by: Oliver Neukum <oneukum@suse.de> Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com> Cc: stable@vger.kernel.org
-rw-r--r--drivers/usb/host/xhci-pci.c8
-rw-r--r--drivers/usb/host/xhci.c7
-rw-r--r--drivers/usb/host/xhci.h1
3 files changed, 15 insertions, 1 deletions
diff --git a/drivers/usb/host/xhci-pci.c b/drivers/usb/host/xhci-pci.c
index 236c3aabe940..5444ecdbfb92 100644
--- a/drivers/usb/host/xhci-pci.c
+++ b/drivers/usb/host/xhci-pci.c
@@ -69,6 +69,14 @@ static void xhci_pci_quirks(struct device *dev, struct xhci_hcd *xhci)
69 "QUIRK: Fresco Logic xHC needs configure" 69 "QUIRK: Fresco Logic xHC needs configure"
70 " endpoint cmd after reset endpoint"); 70 " endpoint cmd after reset endpoint");
71 } 71 }
72 if (pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_PDK &&
73 pdev->revision == 0x4) {
74 xhci->quirks |= XHCI_SLOW_SUSPEND;
75 xhci_dbg_trace(xhci, trace_xhci_dbg_quirks,
76 "QUIRK: Fresco Logic xHC revision %u"
77 "must be suspended extra slowly",
78 pdev->revision);
79 }
72 /* Fresco Logic confirms: all revisions of this chip do not 80 /* Fresco Logic confirms: all revisions of this chip do not
73 * support MSI, even though some of them claim to in their PCI 81 * support MSI, even though some of them claim to in their PCI
74 * capabilities. 82 * capabilities.
diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c
index 1e36dbb48366..6d3e298a8174 100644
--- a/drivers/usb/host/xhci.c
+++ b/drivers/usb/host/xhci.c
@@ -839,6 +839,7 @@ static void xhci_clear_command_ring(struct xhci_hcd *xhci)
839int xhci_suspend(struct xhci_hcd *xhci) 839int xhci_suspend(struct xhci_hcd *xhci)
840{ 840{
841 int rc = 0; 841 int rc = 0;
842 unsigned int delay = XHCI_MAX_HALT_USEC;
842 struct usb_hcd *hcd = xhci_to_hcd(xhci); 843 struct usb_hcd *hcd = xhci_to_hcd(xhci);
843 u32 command; 844 u32 command;
844 845
@@ -861,8 +862,12 @@ int xhci_suspend(struct xhci_hcd *xhci)
861 command = xhci_readl(xhci, &xhci->op_regs->command); 862 command = xhci_readl(xhci, &xhci->op_regs->command);
862 command &= ~CMD_RUN; 863 command &= ~CMD_RUN;
863 xhci_writel(xhci, command, &xhci->op_regs->command); 864 xhci_writel(xhci, command, &xhci->op_regs->command);
865
866 /* Some chips from Fresco Logic need an extraordinary delay */
867 delay *= (xhci->quirks & XHCI_SLOW_SUSPEND) ? 10 : 1;
868
864 if (xhci_handshake(xhci, &xhci->op_regs->status, 869 if (xhci_handshake(xhci, &xhci->op_regs->status,
865 STS_HALT, STS_HALT, XHCI_MAX_HALT_USEC)) { 870 STS_HALT, STS_HALT, delay)) {
866 xhci_warn(xhci, "WARN: xHC CMD_RUN timeout\n"); 871 xhci_warn(xhci, "WARN: xHC CMD_RUN timeout\n");
867 spin_unlock_irq(&xhci->lock); 872 spin_unlock_irq(&xhci->lock);
868 return -ETIMEDOUT; 873 return -ETIMEDOUT;
diff --git a/drivers/usb/host/xhci.h b/drivers/usb/host/xhci.h
index 289fbfbae746..4f82d2172afa 100644
--- a/drivers/usb/host/xhci.h
+++ b/drivers/usb/host/xhci.h
@@ -1548,6 +1548,7 @@ struct xhci_hcd {
1548#define XHCI_COMP_MODE_QUIRK (1 << 14) 1548#define XHCI_COMP_MODE_QUIRK (1 << 14)
1549#define XHCI_AVOID_BEI (1 << 15) 1549#define XHCI_AVOID_BEI (1 << 15)
1550#define XHCI_PLAT (1 << 16) 1550#define XHCI_PLAT (1 << 16)
1551#define XHCI_SLOW_SUSPEND (1 << 17)
1551 unsigned int num_active_eps; 1552 unsigned int num_active_eps;
1552 unsigned int limit_active_eps; 1553 unsigned int limit_active_eps;
1553 /* There are two roothubs to keep track of bus suspend info for */ 1554 /* There are two roothubs to keep track of bus suspend info for */