Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | 23-Aug-2002 |
| 2 | |
| 3 | The "ohci-hcd" driver is a USB Host Controller Driver (HCD) that is derived |
| 4 | from the "usb-ohci" driver from the 2.4 kernel series. The "usb-ohci" code |
| 5 | was written primarily by Roman Weissgaerber <weissg@vienna.at> but with |
| 6 | contributions from many others (read its copyright/licencing header). |
| 7 | |
| 8 | It supports the "Open Host Controller Interface" (OHCI), which standardizes |
| 9 | hardware register protocols used to talk to USB 1.1 host controllers. As |
| 10 | compared to the earlier "Universal Host Controller Interface" (UHCI) from |
| 11 | Intel, it pushes more intelligence into the hardware. USB 1.1 controllers |
| 12 | from vendors other than Intel and VIA generally use OHCI. |
| 13 | |
| 14 | Changes since the 2.4 kernel include |
| 15 | |
| 16 | - improved robustness; bugfixes; and less overhead |
| 17 | - supports the updated and simplified usbcore APIs |
| 18 | - interrupt transfers can be larger, and can be queued |
| 19 | - less code, by using the upper level "hcd" framework |
| 20 | - supports some non-PCI implementations of OHCI |
| 21 | - ... more |
| 22 | |
| 23 | The "ohci-hcd" driver handles all USB 1.1 transfer types. Transfers of all |
| 24 | types can be queued. That was also true in "usb-ohci", except for interrupt |
| 25 | transfers. Previously, using periods of one frame would risk data loss due |
| 26 | to overhead in IRQ processing. When interrupt transfers are queued, those |
| 27 | risks can be minimized by making sure the hardware always has transfers to |
| 28 | work on while the OS is getting around to the relevant IRQ processing. |
| 29 | |
| 30 | - David Brownell |
| 31 | <dbrownell@users.sourceforge.net> |
| 32 | |