RE: [PATCH v1] usb: hcd: out of bounds access in for_each_companion

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



> -----Original Message-----
> From: Alan Stern [mailto:stern@xxxxxxxxxxxxxxxxxxx]
> Sent: Monday, 29 February, 2016 16:30
> To: Dobrowolski, Robert <robert.dobrowolski@xxxxxxxxx>
> Cc: linux-usb@xxxxxxxxxxxxxxx; Andruszak, Adam <adam.andruszak@xxxxxxxxx>;
> Nyman, Mathias <mathias.nyman@xxxxxxxxx>
> Subject: Re: [PATCH v1] usb: hcd: out of bounds access in for_each_companion
> 
> On Mon, 29 Feb 2016, Robert Dobrowolski wrote:
> 
> > 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. Checking if companion device is Device
> > Controller and omitting it.
> >
> > Signed-off-by: Robert Dobrowolski <robert.dobrowolski@xxxxxxxxx>
> > ---
> >  drivers/usb/core/hcd-pci.c | 10 ++++++++++
> >  1 file changed, 10 insertions(+)
> >
> > diff --git a/drivers/usb/core/hcd-pci.c b/drivers/usb/core/hcd-pci.c
> > index 9eb1cff..ae977d7 100644
> > --- a/drivers/usb/core/hcd-pci.c
> > +++ b/drivers/usb/core/hcd-pci.c
> > @@ -74,6 +74,16 @@ static void for_each_companion(struct pci_dev *pdev,
> struct usb_hcd *hcd,
> >  		if (companion->bus != pdev->bus ||
> >  				PCI_SLOT(companion->devfn) != slot)
> >  			continue;
> > +
> > +		/*
> > +		 * On certain platforms Host Controller and Device Controller
> > +		 * figure as same device with different device function. HCD
> > +		 * should not pass data to Device Controller. Checking if
> > +		 * companion device is Device Controller and omitting it.
> > +		 */
> > +		if (companion->class == ((PCI_CLASS_SERIAL_USB << 8) | 0xfe))
> > +			continue;
> > +
> >  		companion_hcd = pci_get_drvdata(companion);
> >  		if (!companion_hcd || !companion_hcd->self.root_hub)
> >  			continue;
> 
> This cries out for a #define.
> 
> Besides, wouldn't it be safer to check that the class _is_ equal to CL_UHCI,
> CL_OHCI, or CL_EHCI instead of checking what the class _isn't_ equal to?  What
> if somebody puts a non-USB function in the same slot?
> 
> Alan Stern

Hi,
PCI_CLASS_SERIAL_USB_XDCI is not yet defined in PCI IDs. I could define it in this patch
but there is already code using  PCI_CLASS_SERIAL_USB << 8) | 0xfe somewhere else. 
So I was thinking I could use this here, and then do a proper #define in another patch and
change all other instances.

I think you are right with the OHCI and other. All host controllers are defined in pci_id
However, in case some new definition show up in the future, companion device could be
Checked if it is host controller (0x0c03) and then checked if its not device controller (0c03fe)
Something like: 
if (((companion->class >> 8) != PCI_CLASS_SERIAL_USB) ||
		companion->class == ((PCI_CLASS_SERIAL_USB << 8) | 0xfe))
	continue;

Could that do?




--------------------------------------------------------------------

Intel Technology Poland sp. z o.o.
ul. Slowackiego 173 | 80-298 Gdansk | Sad Rejonowy Gdansk Polnoc | VII Wydzial Gospodarczy Krajowego Rejestru Sadowego - KRS 101882 | NIP 957-07-52-316 | Kapital zakladowy 200.000 PLN.

Ta wiadomosc wraz z zalacznikami jest przeznaczona dla okreslonego adresata i moze zawierac informacje poufne. W razie przypadkowego otrzymania tej wiadomosci, prosimy o powiadomienie nadawcy oraz trwale jej usuniecie; jakiekolwiek
przegladanie lub rozpowszechnianie jest zabronione.
This e-mail and any attachments may contain confidential material for the sole use of the intended recipient(s). If you are not the intended recipient, please contact the sender and delete all copies; any review or distribution by
others is strictly prohibited.

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux