[SeaBIOS] [PATCH 0/7] Rework USB device detect timing
Matt DeVillier
matt.devillier at gmail.com
Thu Sep 11 18:52:33 CEST 2014
no regressions using your testing branch on panther, with a variety of USB2/USB3 flash devices connected to an xHCI controller.
On 9/10/2014 1:45 PM, Kevin O'Connor wrote:
> This series reworks the timing of USB detection. Previously, the USB
> controllers would wait for the port power to stabilize and then
> immiediately check for device presence. Unfortunately, the USB
> specification (USB2 spec) allows for devices to wait up to 100ms from
> the time that power is stable to the time they assert their presence.
> This series changes the controllers to behave more like the existing
> usb-hub code - each port will repeatedly re-check for device presence
> for 100ms after power is stable.
>
> This may also help with USB3 device detection. In particular there
> were reports of devices that start off identifying as USB2 and then
> later change to a USB3 type device. The additional polling may catch
> these cases.
>
> This series could cause a slight increase in overall boot time (due to
> the additional 100ms polling). However, when SeaBIOS' threads are
> enabled, I think only a few unusual corner cases would cause higher
> boot times.
>
> The series is a fairly significant change to the initial USB timing
> behaviour. I ran tests on a bunch of USB devices and did not see any
> regressions. More testing would be appreciated.
>
> The series is also at:
> https://github.com/KevinOConnor/seabios/tree/testing
>
> -Kevin
>
>
> Kevin O'Connor (7):
> ehci: Move port power up from ehci_hub_detect() to check_ehci_ports().
> usb-hub: Enable power to all ports prior to calling usb_enumerate().
> xhci: Change xhci_hub_detect() to use connect status instead of link
> state.
> uhci: Repeatedly poll for device detect for 100ms.
> ohci: Repeatedly poll for device detect for 100ms.
> ehci: Stall uhci/ohci init only until default port routing is done.
> usb: Perform device detect polling on all usb controllers.
>
> src/hw/usb-ehci.c | 58 +++++++++++++++++++++++++------------------------------
> src/hw/usb-hub.c | 46 +++++++++++++++----------------------------
> src/hw/usb-ohci.c | 8 +-------
> src/hw/usb-uhci.c | 7 +++----
> src/hw/usb-xhci.c | 16 +++++----------
> src/hw/usb.c | 21 ++++++++++++++------
> src/hw/usb.h | 2 +-
> 7 files changed, 67 insertions(+), 91 deletions(-)
>
More information about the SeaBIOS
mailing list