diff options
| author | Hans de Goede <hdegoede@redhat.com> | 2014-12-05 11:11:28 +0100 | 
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2015-01-09 09:58:49 -0800 | 
| commit | 7f5c4d631aed243ca89c6673427954210b1628ec (patch) | |
| tree | 21e3d567d3ba4d1434ed6e653e71da63df9cbe03 /drivers/usb | |
| parent | c401e7b4a808d50ab53ef45cb8d0b99b238bf2c9 (diff) | |
xhci: Add broken-streams quirk for Fresco Logic FL1000G xhci controllers
Streams do not work reliabe on Fresco Logic FL1000G xhci controllers,
trying to use them results in errors like this:
21:37:33 kernel: xhci_hcd 0000:04:00.0: ERROR Transfer event for disabled endpoint or incorrect stream ring
21:37:33 kernel: xhci_hcd 0000:04:00.0: @00000000368b3570 9067b000 00000000 05000000 01078001
21:37:33 kernel: xhci_hcd 0000:04:00.0: ERROR Transfer event for disabled endpoint or incorrect stream ring
21:37:33 kernel: xhci_hcd 0000:04:00.0: @00000000368b3580 9067b400 00000000 05000000 01038001
As always I've ordered a pci-e addon card with a Fresco Logic controller for
myself to see if I can come up with a better fix then the big hammer, in
the mean time this will make uas devices work again (in usb-storage mode)
for FL1000G users.
Reported-by: Marcin ZajÄ…czkowski <mszpak@wp.pl>
Cc: stable@vger.kernel.org # 3.15
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/usb')
| -rw-r--r-- | drivers/usb/host/xhci-pci.c | 2 | 
1 files changed, 2 insertions, 0 deletions
| diff --git a/drivers/usb/host/xhci-pci.c b/drivers/usb/host/xhci-pci.c index 142b601f9563..7f76c8a12f89 100644 --- a/drivers/usb/host/xhci-pci.c +++ b/drivers/usb/host/xhci-pci.c @@ -82,6 +82,8 @@ static void xhci_pci_quirks(struct device *dev, struct xhci_hcd *xhci)  				"must be suspended extra slowly",  				pdev->revision);  		} +		if (pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_PDK) +			xhci->quirks |= XHCI_BROKEN_STREAMS;  		/* Fresco Logic confirms: all revisions of this chip do not  		 * support MSI, even though some of them claim to in their PCI  		 * capabilities. | 
