summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Dobrowolski <robert.dobrowolski@linux.intel.com>2016-03-24 13:30:07 +0300
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2016-04-13 22:06:18 +0300
commite86103a75705c7c530768f4ffaba74cf382910f2 (patch)
tree26917529c340135a4dba1e6deab343d568c86ae8
parent1363074667a6b7d0507527742ccd7bbed5e3ceaa (diff)
downloadlinux-e86103a75705c7c530768f4ffaba74cf382910f2.tar.xz
usb: hcd: out of bounds access in for_each_companion
On BXT platform Host Controller and Device Controller figure as same PCI device but with different device function. HCD should not pass data to Device Controller but only to Host Controllers. Checking if companion device is Host Controller, otherwise skip. Cc: <stable@vger.kernel.org> Signed-off-by: Robert Dobrowolski <robert.dobrowolski@linux.intel.com> Acked-by: Alan Stern <stern@rowland.harvard.edu> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--drivers/usb/core/hcd-pci.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/drivers/usb/core/hcd-pci.c b/drivers/usb/core/hcd-pci.c
index f9d42cf23e55..7859d738df41 100644
--- a/drivers/usb/core/hcd-pci.c
+++ b/drivers/usb/core/hcd-pci.c
@@ -73,6 +73,15 @@ static void for_each_companion(struct pci_dev *pdev, struct usb_hcd *hcd,
if (companion->bus != pdev->bus ||
PCI_SLOT(companion->devfn) != slot)
continue;
+
+ /*
+ * Companion device should be either UHCI,OHCI or EHCI host
+ * controller, otherwise skip.
+ */
+ if (companion->class != CL_UHCI && companion->class != CL_OHCI &&
+ companion->class != CL_EHCI)
+ continue;
+
companion_hcd = pci_get_drvdata(companion);
if (!companion_hcd || !companion_hcd->self.root_hub)
continue;