mirror of
https://github.com/smaeul/u-boot.git
synced 2025-10-19 07:08:14 +01:00
usb: ehci-pci: Clarify and cleanup the EHCI controller detection
The detection function of the EHCI PCI controller was really cryptic, add a beefy comment and clean the portion of the code up a bit. No change in the logic of the code. Signed-off-by: Marek Vasut <marex@denx.de> Cc: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
3990994c43
commit
8fb83547b9
@ -54,8 +54,30 @@ static pci_dev_t ehci_find_class(int index)
|
|||||||
bdf += PCI_BDF(0, 0, 1)) {
|
bdf += PCI_BDF(0, 0, 1)) {
|
||||||
pci_read_config_dword(bdf, PCI_CLASS_REVISION,
|
pci_read_config_dword(bdf, PCI_CLASS_REVISION,
|
||||||
&class);
|
&class);
|
||||||
if ((class >> 8 == PCI_CLASS_SERIAL_USB_EHCI)
|
class >>= 8;
|
||||||
&& !index--)
|
/*
|
||||||
|
* Here be dragons! In case we have multiple
|
||||||
|
* PCI EHCI controllers, this function will
|
||||||
|
* be called multiple times as well. This
|
||||||
|
* function will scan the PCI busses, always
|
||||||
|
* starting from bus 0, device 0, function 0,
|
||||||
|
* until it finds an USB controller. The USB
|
||||||
|
* stack gives us an 'index' of a controller
|
||||||
|
* that is currently being registered, which
|
||||||
|
* is a number, starting from 0 and growing
|
||||||
|
* in ascending order as controllers are added.
|
||||||
|
* To avoid probing the same controller in tne
|
||||||
|
* subsequent runs of this function, we will
|
||||||
|
* skip 'index - 1' detected controllers and
|
||||||
|
* report the index'th controller.
|
||||||
|
*/
|
||||||
|
if (class != PCI_CLASS_SERIAL_USB_EHCI)
|
||||||
|
continue;
|
||||||
|
if (index) {
|
||||||
|
index--;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
/* Return index'th controller. */
|
||||||
return bdf;
|
return bdf;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user