Extensible Host Controller Interface: Difference between revisions

Content deleted Content added
Better template
Explain why USB moves the management of polling to the host controller, and add xHCI 1.1.
Line 1:
{{No footnotes|date=April 2014}}
'''eXtensible Host Controller Interface (xHCI)''' is a computer interface specification that defines a register-level description of a Host Controller for Universal Serial bus (USB), which is capable of interfacing with USB 1.x, 2.0, and 3.0x compatible devices. The specification is also referred to as the [[USB 3.0]] Host Controller specification.
 
== Architectural goals ==
Line 24:
When USB was originally developed in 1995, it was targeted at desktop platforms to stem the proliferation of connectors that were appearing on PCs, e.g. [[PS/2 connector|PS/2]], [[serial port]], [[parallel port]], Game Port, etc., and host power consumption was not an important consideration at the time. Since then, mobile platforms have become the platform of choice, and their batteries have made power consumption a key consideration. The architectures of the legacy USB host controllers (OHCI, UHCI, and EHCI) were very similar in that the "schedule" for the transactions to be performed on the USB were built by software in host memory, and the host controller hardware would continuously read the schedules to determine what transactions needed to be driven on the USB, and when, even if no data was moved. Additionally, in the case of reads from the device, the device was polled each schedule interval, even if there was no data to read.
* The xHCI eliminates host memory based USB transaction schedules, enabling zero host memory activity when there is no USB data movement.
* The xHCI reduces the need for periodic device polling by allowing a USB 3.0 or later device to notify the host controller when it has data available to read, and moves the management of polling USB 2.0 and 1.1 devices that use interrupt transactions from the CPU-driven USB driver to the USB host controller. If any USB device using interrupt transactions does have data to send, then the host controller will send an interrupt to notify the CPU that there is a USB interrupt transaction that needs handling. Since the CPU no longer has to handle polling the USB bus, it can spend more time in low power states.
* The xHCI does not require that implementations provide support for all advanced USB 2 and 3 power management features, including USB 2 LPM, USB 3 U1 and U2 states, HERD, LTM, Function Wake, etc.; but these features are required to realize all of the advantages of xHCI.
 
Line 73:
* ''xHCI 1.0, errata files 1-7'': Released in June 13, 2011. <br />Clarifications.
 
==== xHCI 1.1 ====
* ''xHCI 1.1'': Released on December 21, 2013. Specified USB 3.1 data rate of ''10&nbsp;Gbit/s'' (''SuperSpeed+''). This incorporates xHCI 1.0 errata files 1-21.
== External links ==
{{Commons category|USB}}