# **Universal Serial Bus Specification** Compaq Hewlett-Packard Intel Lucent Microsoft NEC **Philips** Revision 2.0 April 27, 2000 #### Scope of this Revision The 2.0 revision of the specification is intended for product design. Every attempt has been made to ensure a consistent and implementable specification. Implementations should ensure compliance with this revision. #### **Revision History** | Revision | Issue Date | Comments | |------------------|--------------------|--------------------------------------------------------------| | 0.7 | November 11, 1994 | Supersedes 0.6e. | | 0.8 | December 30, 1994 | Revisions to Chapters 3-8, 10, and 11. Added appendixes. | | 0.9 | April 13, 1995 | Revisions to all the chapters. | | 0.99 | August 25, 1995 | Revisions to all the chapters. | | 1.0 FDR | November 13, 1995 | Revisions to Chapters 1, 2, 5-11. | | 1.0 | January 15, 1996 | Edits to Chapters 5, 6, 7, 8, 9, 10, and 11 for consistency. | | 1.1 | September 23, 1998 | Updates to all chapters to fix problems identified. | | 2.0 (draft 0.79) | October 5, 1999 | Revisions to chapters 5, 7, 8, 9, 11 to add high speed. | | 2.0 (draft 0.9) | December 21, 1999 | Revisions to all chapters to add high speed. | | 2.0 | April 27, 2000 | Revisions for high-speed mode. | Universal Serial Bus Specification Copyright © 2000, Compaq Computer Corporation, Hewlett-Packard Company, Intel Corporation, Lucent Technologies Inc, Microsoft Corporation, NEC Corporation, Koninklijke Philips Electronics N.V. All rights reserved. INTELLECTUAL PROPERTY DISCLAIMER THIS SPECIFICATION IS PROVIDED TO YOU "AS IS" WITH NO WARRANTIES WHATSOEVER, INCLUDING ANY WARRANTY OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE. THE AUTHORS OF THIS SPECIFICATION DISCLAIM ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PROPRIETARY RIGHTS, RELATING TO USE OR IMPLEMENTATION OF INFORMATION IN THIS SPECIFICATION. THE PROVISION OF THIS SPECIFICATION TO YOU DOES NOT PROVIDE YOU WITH ANY LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE, TO ANY INTELLECTUAL PROPERTY RIGHTS. All product names are trademarks, registered trademarks, or servicemarks of their respective owners. Please send comments via electronic mail to techsup@usb.org For industry information, refer to the USB Implementers Forum web page at http://www.usb.org #### Acknowledgement of USB 2.0 Technical Contribution The authors of this specification would like to recognize the following people who participated in the USB 2.0 Promoter Group technical working groups. We would also like to thank others in the USB 2.0 Promoter companies and throughout the industry who contributed to the development of this specification. #### **Hub Working Group** John Garney Intel Corporation (Chair/Editor) Ken Stufflebeam Compaq Computer Corporation David Wooten Compaq Computer Corporation Matt Nieberger Hewlett-Packard Company John Howard Intel Corporation Venkat Iyer Intel Corporation Steve McGowan Intel Corporation Geert Knapen Royal Philips Electronics Zong Liang Wu Royal Philips Electronics Jim Clee Lucent Technologies Inc Jim Guziak Lucent Technologies Inc Dave Thompson Lucent Technologies Inc John Fuller Microsoft Corporation Nathan Sherman Microsoft Corporation Mark Williams Microsoft Corporation Nobuo Furuya **NEC Corporation** Toshimi Sakurai **NEC Corporation** Moto Sato **NEC Corporation** Katsuya Suzuki **NEC Corporation** #### **Electrical Working Group** Jon Lueker Intel Corporation (Chair/Editor) David Wooten Compaq Computer Corporation Matt Nieberger Hewlett-Packard Company Larry Taugher Hewlett-Packard Company Venkat Iyer Intel Corporation Steve McGowan Intel Corporation Mike Pennell Intel Corporation Todd West Intel Corporation Gerrit den Besten Royal Philips Electronics Marq Kole Royal Philips Electronics Zong Liang Wu Royal Philips Electronics Jim Clee Lucent Technologies Inc Jim Guziak Lucent Technologies Inc Par Parikh Lucent Technologies Inc Dave Thompson Lucent Technologies Inc Ed Giaimo Microsoft Corporation Mark Williams Microsoft Corporation Toshihiko Ohtani **NEC Corporation** Kugao Ouchi **NEC Corporation** Katsuya Suzuki **NEC Corporation** Toshio Tasaki **NEC Corporation** ### Contents | CHA | PTER 1 INTRODUCTION | | |----------------|------------------------------------|----| | 1.1 | Motivation | 1 | | 1.2 | Objective of the Specification | 1 | | 1.3 | Scope of the Document | 2 | | 1.4 | USB Product Compliance | 2 | | 1.5 | Document Organization | 2 | | CHAF | PTER 2 TERMS AND ABBREVIATIONS | | | CHAF | PTER 3 BACKGROUND | | | 3.1 | Goals for the Universal Serial Bus | 11 | | 3.2 | Taxonomy of Application Space | 12 | | 3.3 | Feature List | 13 | | CHAF | PTER 4 ARCHITECTURAL OVERVIEW | | | <b>4.1</b> 4.1 | USB System Description | | | 4.2 | Physical Interface | 17 | | 200 | 2.1 Electrical | 17 | | 4.2 | 2.2 Mechanical | 18 | | 4.3 | Power | 18 | | 4.3 | | | | 4.3 | 3.2 Power Management | 18 | | 4.4 | Bus Protocol | 18 | | 4.5 | Robustness | 19 | | 4.5 | | | | 4.5 | 5.2 Error Handling | 19 | | 4.6 | System Configuration | 19 | | 4.6 | | | | 4.6 | 6.2 Removal of USB Devices | | | 4.6 | 6.3 Bus Enumeration | 20 | | 4.7 D | Oata Flow Types | 20 | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----| | 4.7.1 | Control Transfers. | | | 4.7.2 | | | | 4.7.3 | | | | 4.7.4 | | | | 4.7.5 | | | | | | | | 4.8 U | USB Devices | | | 4.8.1 | Device Characterizations | 22 | | 4.8.2 | Device Descriptions | 22 | | 4.9 U | SB Host: Hardware and Software | 24 | | 4.10 A | Architectural Extensions | 24 | | CHADT | ER 5 USB DATA FLOW MODEL | | | | | | | 5.1 In | mplementer Viewpoints | 25 | | 5.2 B | Bus Topology | 27 | | 5.2.1 | USB Host | | | 5.2.2 | USB Devices | 28 | | 5.2.3 | Physical Bus Topology | 29 | | 5.2.4 | | | | 5.2.5 | | | | ~ a * | IOD C | | | | JSB Communication Flow | | | 5.3.1 | Device Endpoints | | | 5.3.2 | | | | 5.3.3 | Frames and Microframes | 30 | | 5.4 T | ransfer Types | 36 | | 5.4.1 | Table Calculation Examples | 37 | | 5.5 C | Control Transfers | 20 | | 5.5.1 | Control Transfer Data Format | | | 5.5.2 | | | | 5.5.3 | | | | 5.5.4 | | | | 5.5.5 | | | | 5.6 Is | sochronous Transfers | 44 | | 5.6.1 | Isochronous Transfer Data Format | | | 5.6.2 | | | | 5.6.3 | | | | 5.6.4 | | | | 5.6.5 | | | | | alter 2000 military et 10 data in | | | | nterrupt Transfers | | | 5.7.1 | Interrupt Transfer Data Format | | | 5.7.2 | • | | | 5.7.3 | | | | 5.7.4 | | | | 5.7.5 | Interrupt Transfer Data Sequences | 52 | | 5.8 Bu | ılk Transfers | . 52 | |---------|-------------------------------------------------------------|------| | 5.8.1 | Bulk Transfer Data Format. | . 52 | | 5.8.2 | Bulk Transfer Direction. | . 52 | | 5.8.3 | Bulk Transfer Packet Size Constraints | . 53 | | 5.8.4 | Bulk Transfer Bus Access Constraints | . 53 | | 5.8.5 | Bulk Transfer Data Sequences | . 55 | | 5.9 Hi | gh-Speed, High Bandwidth Endpoints | . 56 | | 5.9.1 | High Bandwidth Interrupt Endpoints | . 56 | | 5.9.2 | High Bandwidth Isochronous Endpoints | . 57 | | 5.10 Sp | lit Transactions | . 58 | | | s Access for Transfers | | | | Transfer Management | | | | Transaction Tracking | | | | Calculating Bus Transaction Times | | | | Calculating Buffer Sizes in Functions and Software | | | 5.11.5 | Bus Bandwidth Reclamation | . 65 | | 5.12 Sp | ecial Considerations for Isochronous Transfers | . 65 | | 5.12.1 | | | | | USB Clock Model | | | | Clock Synchronization | | | | Isochronous Devices | | | | | | | 5.12.6 | | | | | Error Handling | | | 5.12.8 | Buffering for Rate Matching | . 82 | | CHAPTE | R 6 MECHANICAL | | | 6.1 Ar | chitectural Overview | . 85 | | | | | | 6.2 Ke | eyed Connector Protocol | . 85 | | 6.3 Ca | ble | . 86 | | 6.4 Ca | ble Assembly | . 86 | | 6.4.1 | Standard Detachable Cable Assemblies | | | 6.4.2 | High-/full-speed Captive Cable Assemblies | | | 6.4.3 | Low-speed Captive Cable Assemblies | . 90 | | 6.4.4 | Prohibited Cable Assemblies | . 92 | | 6.5 Co | onnector Mechanical Configuration and Material Requirements | | | 6.5.1 | USB Icon Location | | | 6.5.2 | USB Connector Termination Data | | | 6.5.3 | Series "A" and Series "B" Receptacles | | | 6.5.4 | Series "A" and Series "B" Plugs | . 98 | | 6.6 | Cable Mechanical Configuration and Material Requirements | 102 | |----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | 6.6.1 | Description | 102 | | 6.6.2 | 2 Construction | 103 | | 6.6.3 | B Electrical Characteristics | 105 | | 6.1.4 | Cable Environmental Characteristics | 106 | | 6.1.5 | | | | 6.7 E | Electrical, Mechanical, and Environmental Compliance Standards | 106 | | 6.7.1 | | | | 6.8 L | USB Grounding | 114 | | 6.9 F | PCB Reference Drawings | 114 | | CHAPT | ER 7 ELECTRICAL | | | | Signaling | | | 7.1.1 | | | | 7.1.2 | | | | 7.1.3 | | | | 7.1.4 | | | | 7.1.5 | | | | 7.1.6 | | | | 7.1.7 | | | | 7.1.8 | | | | 7.1.9 | 가 있는 사람들이 가게 되었습니다. 이 🚅 에 기업으로 모든 물로 물리에 그리다면 그리다면 그리다면 가게 되었습니다. 그리고 말이 | | | 7.1.1 | | | | 7.1.1 | . [1] - [1] 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | 7.1.1 | | | | 7.1.1 | | | | 7.1.1<br>7.1.1 | 8 8 | | | 7.1.1 | | | | 7.1.1 | - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 | | | 7.1.1 | | | | 7.1.1 | 3.10 | | | 7.1.2 | | | | 7.2 P | Power Distribution | 171 | | | Classes of Devices | | | 7.2.2 | | | | 7.2.3 | | | | 7.2.4 | • 1 | | | 7.3 P | Physical Layer | | | 7.3.1 | g - graph of the state s | | | 7.3.2 | | | | 7.3.3 | Timing Waveforms | 191 | #### **CHAPTER 8 PROTOCOL LAYER** | 8.1 B | Syte/Bit Ordering | 195 | |--------|-----------------------------------------|-----| | 8.2 S | YNC Field | 195 | | 8.3 P | acket Field Formats | | | 8.3.1 | Packet Identifier Field | | | 8.3.2 | | | | 8.3.3 | | | | 8.3.4 | | | | 8.3.5 | | | | 8.4 Pa | acket Formats | 199 | | 8.4.1 | Token Packets | | | 8.4.2 | Split Transaction Special Token Packets | 199 | | 8.4.3 | Start-of-Frame Packets | | | 8.4.4 | Data Packets | 206 | | 8.4.5 | Handshake Packets | 206 | | 8.4.6 | Handshake Responses | | | 8.5 T | ransaction Packet Sequences | 209 | | 8.5.1 | | | | 8.5.2 | | | | 8.5.3 | Control Transfers | 225 | | 8.5.4 | | | | 8.5.5 | Isochronous Transactions | | | | Oata Toggle Synchronization and Retry | | | 8.6.1 | Initialization via SETUP Token | | | 8.6.2 | Successful Data Transactions | | | 8.6.3 | Data Corrupted or Not Accepted | | | 8.6.4 | Corrupted ACK Handshake | | | 8.6.5 | Low-speed Transactions | | | 8.7 E | error Detection and Recovery | | | 8.7.1 | Packet Error Categories | | | 8.7.2 | Bus Turn-around Timing | 237 | | 8.7.3 | False EOPs | 237 | | 8.7.4 | Babble and Loss of Activity Recovery | | #### CHAPTER 9 USB DEVICE FRAMEWORK | 9.1 US | BB Device States | | |-----------------------------------------|-----------------------------------|-----| | 9.1.1 | Visible Device States | 239 | | 9.1.2 | Bus Enumeration | 243 | | | | | | 9.2 Ge | eneric USB Device Operations | 244 | | 9.2.1 | Dynamic Attachment and Removal | | | 9.2.2 | Address Assignment | 244 | | 9.2.3 | Configuration | 244 | | 9.2.4 | Data Transfer | 245 | | 9.2.5 | Power Management | 245 | | 9.2.6 | Request Processing | 245 | | 9.2.7 | Request Error | 247 | | 9.3 115 | B Device Requests | 248 | | 9.3.1 | bmRequestType | | | 9.3.2 | bRequest | | | 9.3.3 | wValue | | | 9.3.4 | wIndex | | | 9.3.5 | wLength | | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 5 | | | 9.4 Sta | andard Device Requests | 250 | | 9.4.1 | Clear Feature | 252 | | 9.4.2 | Get Configuration | 253 | | 9.4.3 | Get Descriptor | 253 | | 9.4.4 | Get Interface | 254 | | 9.4.5 | Get Status | | | 9.4.6 | Set Address | | | 9.4.7 | Set Configuration | | | 9.4.8 | Set Descriptor | | | 9.4.9 | Set Feature | 258 | | 9.4.10 | Set Interface | | | 9.4.11 | Synch Frame | | | | | | | 9.5 De | scriptors | 260 | | 9.6 Sta | andard USB Descriptor Definitions | 261 | | 9.6.1 | Device | | | 9.6.2 | Device_Qualifier | 264 | | 9.6.3 | Configuration | | | 9.6.4 | Other Speed Configuration. | | | | Interface | | | 9.6.6 | Endpoint | | | 9.6.7 | String | | | | Θ | | | 9.7 De | vice Class Definitions | | | 9.7.1 | Descriptors | | | 9.7.2 | Interface(s) and Endpoint Usage | 274 | | 072 | Pequests | 274 | #### CHAPTER 10 USB HOST: HARDWARE AND SOFTWARE | 10.1 Ov | verview of the USB Host | 275 | |---------|-----------------------------------------------------|-----| | 10.1.1 | Overview | 275 | | 10.1.2 | Control Mechanisms | 278 | | 10.1.3 | Data Flow | 278 | | 10.1.4 | Collecting Status and Activity Statistics | 279 | | 10.1.5 | Electrical Interface Considerations | 279 | | 10.2 Ho | ost Controller Requirements | 279 | | 10.2.1 | State Handling | 280 | | 10.2.2 | Serializer/Deserializer | 280 | | 10.2.3 | Frame and Microframe Generation | 280 | | 10.2.4 | | | | 10.2.5 | Protocol Engine | 28 | | 10.2.6 | Transmission Error Handling | 282 | | 10.2.7 | Remote Wakeup | 282 | | 10.2.8 | Root Hub | 282 | | 10.2.9 | Host System Interface | 283 | | 10.3 Ov | verview of Software Mechanisms | 283 | | 10.3.1 | Device Configuration | 283 | | 10.3.2 | Resource Management | | | 10.3.3 | Data Transfers | 286 | | 10.3.4 | Common Data Definitions | 280 | | 10.4 Ho | ost Controller Driver | 283 | | 10.5 Un | niversal Serial Bus Driver | 28′ | | | USBD Overview. | | | | USBD Command Mechanism Requirements | | | | USBD Pipe Mechanisms | | | | Managing the USB via the USBD Mechanisms | | | | Passing USB Preboot Control to the Operating System | | | 10.6 Or | perating System Environment Guides | 290 | | | | | | CHAPTE | R 11 HUB SPECIFICATION | | | 11.1 Ov | /erview | 29 | | | Hub Architecture | | | | Hub Connectivity | | | 11.2 Hu | ıb Frame/Microframe Timer | 300 | | 11.2.1 | High-speed Microframe Timer Range | | | 11.2.2 | Full-speed Frame Timer Range | | | | Frame/Microframe Timer Synchronization | | | | Microframe Jitter Related to Frame Jitter | | | | EOF1 and EOF2 Timing Points | | | 11.3 H | ost Behavior at End-of-Frame | 306 | |---------|-------------------------------------------------------|-----| | 11.3.1 | Full-/low-speed Latest Host Packet | 306 | | 11.3.2 | Full-/low-speed Packet Nullification | 306 | | | Full-/low-speed Transaction Completion Prediction | | | 11.4 In | ternal Port | 307 | | 11.4.1 | | | | 11.4.2 | | | | 11.4.3 | | | | 11.4.4 | Generate Resume (GResume) | | | 11.5 D | ownstream Facing Ports | 309 | | 11.5.1 | | | | 11.5.2 | Disconnect Detect Timer | 315 | | 11.5.3 | Port Indicator | 316 | | 11.6 U | pstream Facing Port | 318 | | | Full-speed | | | 11.6.2 | High-speed | 318 | | 11.6.3 | Receiver | 318 | | 11.6.4 | Transmitter | 322 | | 11.7 H | ub Repeater | | | 11.7.1 | | | | | Hub Repeater State Machine | | | | Wait for Start of Packet from Upstream Port (WFSOPFU) | | | 11.7.4 | Wait for End of Packet from Upstream Port (WFEOPFU) | | | 11.7.5 | | | | 11.7.6 | Wait for End of Packet (WFEOP) | 330 | | | us State Evaluation | | | | Port Error | | | | Speed Detection | | | | Collision | | | 11.8.4 | Low-speed Port Behavior | 331 | | 11.9 St | spend and Resume | 332 | | 11.10 H | ub Reset Behavior | 334 | | 11 11 W | ub Port Power Control | 335 | | | 1 Multiple Gangs | | | | , , , | | | | ub Controller | | | | 1 Endpoint Organization | | | | 2 Hub Information Architecture and Operation | | | | 3 Port Change Information Processing | | | | 4 Hub and Port Status Change Bitmap | | | | 5 Over-current Reporting and Recovery | | | 11.12. | 6 Enumeration Handling | 340 | | 11.13 H | ub Configuration | 340 | | 11.17 II ansaction a lanslator | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------| | 11.14.1 Overview | | | 11.14.2 Transaction Translator Scheduling | | | | | | 11.15 Split Transaction Notation Information | | | 11.16 Common Split Transaction State Machines | 349 | | 11.16.1 Host Controller State Machine | | | 11.16.2 Transaction Translator State Machine | | | | | | 11.17 Bulk/Control Transaction Translation Overview | | | 11.17.1 Bulk/Control Split Transaction Sequences | | | 11.17.2 Bulk/Control Split Transaction State Machines | | | 11.17.3 Bulk/Control Sequencing | | | 11.17.4 Bulk/Control Buffering Requirements | | | 11.17.5 Other Bulk/Control Details | 372 | | 11.18 Periodic Split Transaction Pipelining and Buffer Management | 372 | | 11.18.1 Best Case Full-Speed Budget | | | 11.18.2 TT Microframe Pipeline | | | 11.18.3 Generation of Full-speed Frames | | | 11.18.4 Host Split Transaction Scheduling Requirements | | | | | | 11.18.5 TT Response Generation | 370 | | | | | 11.18.7 TT Transaction Tracking | | | 11.18.8 TT Complete-split Transaction State Searching | | | 11.19 Approximate TT Buffer Space Required | | | 11.20 Interrupt Transaction Translation Overview | 382 | | 11.20.1 Interrupt Split Transaction Sequences | | | | | | 11.20.2 Interrupt Split Transaction State Machines | | | 11.20.2 Interrupt Split Transaction State Machines | | | 11.20.2 Interrupt Split Transaction State Machines | 392 | | 11.20.3 Interrupt OUT Sequencing | | | 11.20.3 Interrupt OUT Sequencing | | | 11.20.3 Interrupt OUT Sequencing | | | 11.20.3 Interrupt OUT Sequencing | | | 11.20.3 Interrupt OUT Sequencing | 392<br>393<br>394<br>395<br>398<br>403 | | 11.20.3 Interrupt OUT Sequencing | 392<br>393<br>394<br>395<br>398<br>403 | | 11.20.3 Interrupt OUT Sequencing | 392<br>393<br>394<br>395<br>398<br>403<br>404 | | 11.20.3 Interrupt OUT Sequencing | 392<br>393<br>394<br>395<br>398<br>403<br>404 | | 11.20.3 Interrupt OUT Sequencing | 392<br>393<br>394<br>395<br>398<br>403<br>404<br>404 | | 11.20.3 Interrupt OUT Sequencing | 392<br>393<br>394<br>395<br>398<br>403<br>404<br>404<br>404 | | 11.20.3 Interrupt OUT Sequencing | 392<br>393<br>393<br>394<br>395<br>398<br>403<br>404<br>404<br>404<br>405 | | 11.20.3 Interrupt OUT Sequencing | 392 393 394 395 398 403 404 404 405 | | 11.20.3 Interrupt OUT Sequencing | 392<br>393<br>394<br>395<br>398<br>403<br>404<br>404<br>404<br>405 | | 11.20.3 Interrupt OUT Sequencing 11.20.4 Interrupt IN Sequencing 11.21 Isochronous Transaction Translation Overview 11.21.1 Isochronous Split Transaction Sequences 11.21.2 Isochronous Split Transaction State Machines 11.21.3 Isochronous OUT Sequencing 11.21.4 Isochronous IN Sequencing 11.22 TT Error Handling 11.22.1 Loss of TT Synchronization With HS SOFs 11.22.2 TT Frame and Microframe Timer Synchronization Requirements 11.23 Descriptors 11.23.1 Standard Descriptors for Hub Class 11.23.2 Class-specific Descriptors | 392 393 394 395 398 403 404 404 405 407 417 | | 11.20.3 Interrupt OUT Sequencing | 392 393 393 394 395 398 403 404 404 405 407 417 | | APPE | NDIX A TRANSACTION EXAMPLES | |------|---------------------------------------------------| | A.1 | Bulk/Control OUT and SETUP Transaction Examples | | A.2 | Bulk/Control IN Transaction Examples | | A.3 | Interrupt OUT Transaction Examples | | A.4 | Interrupt IN Transaction Examples | | A.5 | Isochronous OUT SpAppendix A Transaction Examples | | APPE | NDIX B EXAMPLE DECLARATIONS FOR STATE MACHINES | | B.1 | Global Declarations | | B.2 | Host Controller Declarations | | В.3 | Transaction Translator Declarations | | APPE | NDIX C RESET PROTOCOL STATE DIAGRAMS | | C.1 | Downstream Facing Port State Diagram | | C.: | 2.1 Reset From Suspended State | | 933 | 2.3 Reset From High-speed Non-suspended State | #### INDEX ## **Figures** | Figure 3-1. Application Space Taxonomy | 12 | |-------------------------------------------------------------------------------------|----| | Figure 4-1. Bus Topology | 16 | | Figure 4-2. USB Cable | 17 | | Figure 4-3. A Typical Hub | 23 | | Figure 4-4. Hubs in a Desktop Computer Environment | 23 | | Figure 5-1. Simple USB Host/Device View | 25 | | Figure 5-2. USB Implementation Areas | 26 | | Figure 5-3. Host Composition | 27 | | Figure 5-4. Physical Device Composition | 28 | | Figure 5-5. USB Physical Bus Topology | 29 | | Figure 5-6. Multiple Full-speed Buses in a High-speed System | 30 | | Figure 5-7. USB Logical Bus Topology | 30 | | Figure 5-8. Client Software-to-function Relationships | 31 | | Figure 5-9. USB Host/Device Detailed View | 32 | | Figure 5-10. USB Communication Flow | 33 | | Figure 5-11. Data Phase PID Sequence for Isochronous IN High Bandwidth Endpoints | 57 | | Figure 5-12. Data Phase PID Sequence for Isochronous OUT High Bandwidth Endpoints | 58 | | Figure 5-13. USB Information Conversion From Client Software to Bus | 59 | | Figure 5-14. Transfers for Communication Flows | 62 | | Figure 5-15. Arrangement of IRPs to Transactions/(Micro)frames | 63 | | Figure 5-16. Non-USB Isochronous Example | 67 | | Figure 5-17. USB Full-speed Isochronous Application | 70 | | Figure 5-18. Example Source/Sink Connectivity | 77 | | Figure 5-19. Data Prebuffering | 81 | | Figure 5-20. Packet and Buffer Size Formulas for Rate-matched Isochronous Transfers | 83 | | Figure 6-1. Keyed Connector Protocol | 85 | | Figure 6-2. USB Standard Detachable Cable Assembly | 87 | | Figure 6-3. USB High-/full-speed Hardwired Cable Assembly | 89 | | Figure 6-4. USB Low-speed Hardwired Cable Assembly | 91 | | Figure 6-5. USB Icon | 93 | | Figure 6-6. Typical USB Plug Orientation | 93 | | Figure 6-7. USB Series "A" Receptacle Interface and Mating Drawing | 95 | | Figure 6-8. USB Series "B" Receptacle Interface and Mating Drawing | 96 | | Figure 6-9. USB Series "A" Plug Interface Drawing | 99 | |--------------------------------------------------------------------------------------|-----| | Figure 6-10. USB Series "B" Plug Interface Drawing. | 100 | | Figure 6-11. Typical High-/full-speed Cable Construction | 102 | | Figure 6-12. Single Pin-type Series "A" Receptacle | 115 | | Figure 6-13. Dual Pin-type Series "A" Receptacle | 116 | | Figure 6-14. Single Pin-type Series "B" Receptacle | 117 | | Figure 7-1. Example High-speed Capable Transceiver Circuit | 120 | | Figure 7-2. Maximum Input Waveforms for USB Signaling | 124 | | Figure 7-3. Example Full-speed CMOS Driver Circuit (non High-speed capable) | 125 | | Figure 7-4. Full-speed Buffer V/I Characteristics | 126 | | Figure 7-5. Full-speed Buffer V/I Characteristics for High-speed Capable Transceiver | 127 | | Figure 7-6. Full-speed Signal Waveforms | 128 | | Figure 7-7. Low-speed Driver Signal Waveforms | 128 | | Figure 7-8. Data Signal Rise and Fall Time | 130 | | Figure 7-9. Full-speed Load | 130 | | Figure 7-10. Low-speed Port Loads | 131 | | Figure 7-11. Measurement Planes | 131 | | Figure 7-12. Transmitter/Receiver Test Fixture | 132 | | Figure 7-13. Template 1 | 133 | | Figure 7-14. Template 2 | 134 | | Figure 7-15. Template 3 | 135 | | Figure 7-16. Template 4 | 136 | | Figure 7-17. Template 5 | 137 | | Figure 7-18. Template 6 | 138 | | Figure 7-19. Differential Input Sensitivity Range for Low-/full-speed | 140 | | Figure 7-20. Full-speed Device Cable and Resistor Connections | 141 | | Figure 7-21. Low-speed Device Cable and Resistor Connections | 141 | | Figure 7-22. Placement of Optional Edge Rate Control Capacitors for Low-/full-speed | 143 | | Figure 7-23. Diagram for High-speed Loading Equivalent Circuit | 143 | | Figure 7-24. Upstream Facing Full-speed Port Transceiver | 146 | | Figure 7-25. Downstream Facing Low-/full-speed Port Transceiver | 146 | | Figure 7-26. Low-/full-speed Disconnect Detection | 149 | | Figure 7-27. Full-/high-speed Device Connect Detection | 149 | | Figure 7-28. Low-speed Device Connect Detection | 150 | | Figure 7-29. Power-on and Connection Events Timing. | 150 | | Figure 7-30. Low-/full-speed Packet Voltage Levels | 152 | | Figure 7-31. NRZI Data Encoding | 157 | | Figure 7-32. Bit Stuffing | 157 | |-----------------------------------------------------------------|--------------------------------------| | Figure 7-33. Illustration of Extra Bit Preceding EOP (Full-/lo | w-speed)158 | | Figure 7-34. Flow Diagram for Bit Stuffing | 158 | | Figure 7-35. Sync Pattern (Low-/full-speed) | 159 | | Figure 7-36. Data Jitter Taxonomy | 160 | | Figure 7-37. SE0 for EOP Width Timing | 161 | | Figure 7-38. Hub Propagation Delay of Full-speed Differentia | al Signals162 | | Figure 7-39. Full-speed Cable Delay | 166 | | Figure 7-40. Low-speed Cable Delay | 166 | | Figure 7-41. Worst-case End-to-end Signal Delay Model for | Low-/full-speed169 | | Figure 7-42. Compound Bus-powered Hub | 172 | | Figure 7-43. Compound Self-powered Hub | 173 | | Figure 7-44. Low-power Bus-powered Function | 174 | | Figure 7-45. High-power Bus-powered Function | 174 | | Figure 7-46. Self-powered Function | 175 | | Figure 7-47. Worst-case Voltage Drop Topology (Steady State | te)175 | | Figure 7-48. Typical Suspend Current Averaging Profile | 176 | | Figure 7-49. Differential Data Jitter for Low-/full-speed | 191 | | Figure 7-50. Differential-to-EOP Transition Skew and EOP V | Vidth for Low-/full-speed191 | | Figure 7-51. Receiver Jitter Tolerance for Low-/full-speed | 191 | | Figure 7-52. Hub Differential Delay, Differential Jitter, and S | OP Distortion for Low-/full-speed192 | | Figure 7-53. Hub EOP Delay and EOP Skew for Low-/full-sp | peed193 | | Figure 8-1. PID Format | 195 | | Figure 8-2. ADDR Field | 197 | | Figure 8-3. Endpoint Field | 197 | | Figure 8-4. Data Field Format | 198 | | Figure 8-5. Token Format | 199 | | Figure 8-6. Packets in a Start-split Transaction | 200 | | Figure 8-7. Packets in a Complete-split Transaction | 200 | | Figure 8-8. Relationship of Interrupt IN Transaction to High- | speed Split Transaction201 | | Figure 8-9. Relationship of Interrupt OUT Transaction to Hig | h-speed Split OUT Transaction202 | | Figure 8-10. Start-split (SSPLIT) Token | 202 | | Figure 8-11. Port Field | 203 | | Figure 8-12. Complete-split (CSPLIT) Transaction Token | 204 | | Figure 8-13. SOF Packet | 204 | | Figure 8-14. Relationship between Frames and Microframes . | 205 | | Figure 8-15. Data Packet Format | 206 | | Figure 8-16. | Handshake Packet | 206 | |--------------|------------------------------------------------------------------------|-----| | Figure 8-17. | Legend for State Machines | 210 | | Figure 8-18. | State Machine Context Overview | 211 | | Figure 8-19. | Host Controller Top Level Transaction State Machine Hierarchy Overview | 211 | | Figure 8-20. | Host Controller Non-split Transaction State Machine Hierarchy Overview | 212 | | Figure 8-21. | Device Transaction State Machine Hierarchy Overview | 212 | | Figure 8-22. | Device Top Level State Machine | 213 | | Figure 8-23. | Device_process_Trans State Machine | 213 | | Figure 8-24. | Dev_do_OUT State Machine | 214 | | Figure 8-25. | Dev_do_IN State Machine | 215 | | Figure 8-26. | HC_Do_nonsplit State Machine | 216 | | Figure 8-27. | Host High-speed Bulk OUT/Control Ping State Machine. | 218 | | Figure 8-28. | Dev_HS_ping State Machine | 219 | | Figure 8-29. | Device High-speed Bulk OUT /Control State Machine | 220 | | Figure 8-30. | Bulk Transaction Format | 221 | | Figure 8-31. | Bulk/Control/Interrupt OUT Transaction Host State Machine | 222 | | Figure 8-32. | Bulk/Control/Interrupt OUT Transaction Device State Machine | 223 | | Figure 8-33. | Bulk/Control/Interrupt IN Transaction Host State Machine | 224 | | Figure 8-34. | Bulk/Control/Interrupt IN Transaction Device State Machine | 225 | | Figure 8-35. | Bulk Reads and Writes | 225 | | Figure 8-36. | Control SETUP Transaction | 226 | | Figure 8-37. | Control Read and Write Sequences | 226 | | Figure 8-38. | Interrupt Transaction Format | 229 | | Figure 8-39. | Isochronous Transaction Format | 229 | | Figure 8-40. | Isochronous OUT Transaction Host State Machine | 230 | | Figure 8-41. | Isochronous OUT Transaction Device State Machine | 231 | | Figure 8-42. | Isochronous IN Transaction Host State Machine | 231 | | Figure 8-43. | Isochronous IN Transaction Device State Machine | 232 | | Figure 8-44. | SETUP Initialization | 233 | | Figure 8-45. | Consecutive Transactions | 233 | | Figure 8-46. | NAKed Transaction with Retry | 234 | | Figure 8-47. | Corrupted ACK Handshake with Retry | 234 | | Figure 8-48. | Low-speed Transaction | 235 | | Figure 8-49. | Bus Turn-around Timer Usage | 237 | | Figure 9-1. | Device State Diagram | 240 | | Figure 9-2. | wIndex Format when Specifying an Endpoint | 249 | | Figure 9-3. | wIndex Format when Specifying an Interface | 249 | | Figure 9-4. Information Returned by a GetStatus() Request to a Device | 255 | |-----------------------------------------------------------------------------------------------|-----| | Figure 9-5. Information Returned by a GetStatus() Request to an Interface | 255 | | Figure 9-6. Information Returned by a GetStatus() Request to an Endpoint | 256 | | Figure 9-7. Example of Feedback Endpoint Numbers | 272 | | Figure 9-8. Example of Feedback Endpoint Relationships | 272 | | Figure 10-1. Interlayer Communications Model | 275 | | Figure 10-2. Host Communications | 276 | | Figure 10-3. Frame and Microframe Creation | 281 | | Figure 10-4. Configuration Interactions | 284 | | Figure 10-5. Universal Serial Bus Driver Structure | 288 | | Figure 11-1. Hub Architecture | 298 | | Figure 11-2. Hub Signaling Connectivity | 299 | | Figure 11-3. Resume Connectivity | 299 | | Figure 11-4. Example High-speed EOF Offsets Due to Propagation Delay Without EOF Advancement | 302 | | Figure 11-5. Example High-speed EOF Offsets Due to Propagation Delay With EOF Advancement | 302 | | Figure 11-6. High-speed EOF2 Timing Point | 304 | | Figure 11-7. High-speed EOF1 Timing Point | 304 | | Figure 11-8. Full-speed EOF Timing Points | 304 | | Figure 11-9. Internal Port State Machine | 308 | | Figure 11-10. Downstream Facing Hub Port State Machine | 310 | | Figure 11-11. Port Indicator State Diagram | 317 | | Figure 11-12. Upstream Facing Port Receiver State Machine | 319 | | Figure 11-13. Upstream Facing Port Transmitter State Machine | 322 | | Figure 11-14. Example Hub Repeater Organization | 324 | | Figure 11-15. High-speed Port Selector State Machine | 326 | | Figure 11-16. Hub Repeater State Machine | 328 | | Figure 11-17. Example Remote-wakeup Resume Signaling With Full-/low-speed Device | 333 | | Figure 11-18. Example Remote-wakeup Resume Signaling With High-speed Device | 334 | | Figure 11-19. Example Hub Controller Organization | 336 | | Figure 11-20. Relationship of Status, Status Change, and Control Information to Device States | 337 | | Figure 11-21. Port Status Handling Method | 338 | | Figure 11-22. Hub and Port Status Change Bitmap | 339 | | Figure 11-23. Example Hub and Port Change Bit Sampling | 339 | | Figure 11-24. Transaction Translator Overview | 342 | | Figure 11-25. Periodic and Non-periodic Buffer Sections of TT | 343 | | Figure 11-26. TT Microframe Pipeline for Periodic Split Transactions | 344 | | Figure 11-27. TT Nonperiodic Buffering | 345 | | Figure 11-28. Example Full-/low-speed Handler Scheduling for Start-splits | 346 | |------------------------------------------------------------------------------------|-----| | Figure 11-29. Flow Sequence Legend | 346 | | Figure 11-30. Legend for State Machines | 347 | | Figure 11-31. State Machine Context Overview | 348 | | Figure 11-32. Host Controller Split Transaction State Machine Hierarchy Overview | 349 | | Figure 11-33. Transaction Translator State Machine Hierarchy Overview | | | Figure 11-34. Host Controller | 350 | | Figure 11-35. HC_Process_Command | 351 | | Figure 11-36. HC_Do_Start | 352 | | Figure 11-37. HC_Do_Complete | 353 | | Figure 11-38. Transaction Translator | 354 | | Figure 11-39. TT_Process_Packet | 355 | | Figure 11-40. TT_Do_Start | 356 | | Figure 11-41. TT_Do_Complete | 357 | | Figure 11-42. TT_BulkSS | 357 | | Figure 11-43. TT_BulkCS | 358 | | Figure 11-44. TT_IntSS | 358 | | Figure 11-45. TT_IntCS | 359 | | Figure 11-46. TT_IsochSS | 359 | | Figure 11-47. Sample Algorithm for Compare_buffs | 361 | | Figure 11-48. Bulk/Control OUT Start-split Transaction Sequence | 362 | | Figure 11-49. Bulk/Control OUT Complete-split Transaction Sequence | 363 | | Figure 11-50. Bulk/Control IN Start-split Transaction Sequence | 364 | | Figure 11-51. Bulk/Control IN Complete-split Transaction Sequence | 365 | | Figure 11-52. Bulk/Control OUT Start-split Transaction Host State Machine | 366 | | Figure 11-53. Bulk/Control OUT Complete-split Transaction Host State Machine | 367 | | Figure 11-54. Bulk/Control OUT Start-split Transaction TT State Machine | 368 | | Figure 11-55. Bulk/Control OUT Complete-split Transaction TT State Machine | 368 | | Figure 11-56. Bulk/Control IN Start-split Transaction Host State Machine | 369 | | Figure 11-57. Bulk/Control IN Complete-split Transaction Host State Machine | 370 | | Figure 11-58. Bulk/Control IN Start-split Transaction TT State Machine | 371 | | Figure 11-59. Bulk/Control IN Complete-split Transaction TT State Machine | 371 | | Figure 11-60. Best Case Budgeted Full-speed Wire Time With No Bit Stuffing | 373 | | Figure 11-61. Scheduling of TT Microframe Pipeline | 374 | | Figure 11-62. Isochronous OUT Example That Avoids a Start-split-end With Zero Data | 375 | | Figure 11-63. End of Frame TT Pipeline Scheduling Example | 376 | | Figure 11-64. Isochronous IN Complete-split Schedule Example at L=Y <sub>6</sub> | 377 | | Figure 11-65. Isochronous IN Complete-split Schedule Example at L=Y <sub>7</sub> | 377 | |----------------------------------------------------------------------------------|-----| | Figure 11-66. Microframe Pipeline | 380 | | Figure 11-67. Advance_Pipeline Pseudocode | 381 | | Figure 11-68. Interrupt OUT Start-split Transaction Sequence | 383 | | Figure 11-69. Interrupt OUT Complete-split Transaction Sequence | 384 | | Figure 11-70. Interrupt IN Start-split Transaction Sequence | 385 | | Figure 11-71. Interrupt IN Complete-split Transaction Sequence | 385 | | Figure 11-72. Interrupt OUT Start-split Transaction Host State Machine | 386 | | Figure 11-73. Interrupt OUT Complete-split Transaction Host State Machine | 387 | | Figure 11-74. Interrupt OUT Start-split Transaction TT State Machine | 388 | | Figure 11-75. Interrupt OUT Complete-split Transaction TT State Machine | 389 | | Figure 11-76. Interrupt IN Start-split Transaction Host State Machine | 389 | | Figure 11-77. Interrupt IN Complete-split Transaction Host State Machine | 390 | | Figure 11-78. HC_Data_or_Error State Machine | 391 | | Figure 11-79. Interrupt IN Start-split Transaction TT State Machine | 391 | | Figure 11-80. Interrupt IN Complete-split Transaction TT State Machine | 392 | | Figure 11-81. Example of CRC16 Handling for Interrupt OUT | 393 | | Figure 11-82. Example of CRC16 Handling for Interrupt IN | 394 | | Figure 11-83. Isochronous OUT Start-split Transaction Sequence | 395 | | Figure 11-84. Isochronous IN Start-split Transaction Sequence | 396 | | Figure 11-85. Isochronous IN Complete-split Transaction Sequence | 397 | | Figure 11-86. Isochronous OUT Start-split Transaction Host State Machine | 398 | | Figure 11-87. Isochronous OUT Start-split Transaction TT State Machine | 399 | | Figure 11-88. Isochronous IN Start-split Transaction Host State Machine | 400 | | Figure 11-89. Isochronous IN Complete-split Transaction Host State Machine | 401 | | Figure 11-90. Isochronous IN Start-split Transaction TT State Machine | 402 | | Figure 11-91. Isochronous IN Complete-split Transaction TT State Machine | 402 | | Figure 11-92. Example of CRC16 Isochronous OUT Data Packet Handling | 403 | | Figure 11-93. Example of CRC16 Isochronous IN Data Packet Handling | 404 | | Figure 11-94. Example Frame/Microframe Synchronization Events | 406 | | Figure A-1. Normal No Smash | 441 | | Figure A-2. Normal HS DATA0/1 Smash | 442 | | Figure A-3. Normal HS DATA0/1 3 Strikes Smash | 443 | | Figure A-4. Normal HS ACK(S) Smash(case 1) | 444 | | Figure A-5. Normal HS ACK(S) Smash(case 2) | 445 | | Figure A-6. Normal HS ACK(S) 3 Strikes Smash | 446 | | Figure A-7. Normal HS CSPLIT Smash | 447 | | Figure A-8. Normal HS CSPLIT 3 Strikes Smash | 448 | |------------------------------------------------------------|-----| | Figure A-9. Normal HS ACK(C) Smash | 449 | | Figure A-10. Normal S ACK(C) 3 Strikes Smash | 450 | | Figure A-11. Normal FS/LS DATA0/1 Smash | 451 | | Figure A-12. Normal FS/LS DATA0/1 3 Strikes Smash | 452 | | Figure A-13. Normal FS/LS ACK Smash | 453 | | Figure A-14. Normal FS/LS ACK 3 Strikes Smash | 454 | | Figure A-15. No buffer Available No Smash (HS NAK(S)) | 455 | | Figure A-16. No Buffer Available HS NAK(S) Smash | 456 | | Figure A-17. No Buffer Available HS NAK(S) 3 Strikes Smash | 457 | | Figure A-18. CS Earlier No Smash (HS NYET) | 458 | | Figure A-19. CS Earlier HS NYET Smash(case 1) | 459 | | Figure A-20. CS Earlier HS NYET Smash(case 2) | 460 | | Figure A-21. CS Earlier HS NYET 3 Strikes Smash | 461 | | Figure A-22. Device Busy No Smash(FS/LS NAK) | 462 | | Figure A-23. Device Stall No Smash(FS/LS STALL) | 463 | | Figure A-24. Normal No Smash | 466 | | Figure A-25. Normal HS SSPLIT Smash | 467 | | Figure A-26. Normal SSPLIT 3 Strikes Smash | 468 | | Figure A-27. Normal HS ACK(S) Smash(case 1) | 469 | | Figure A-28. Normal HS ACK(S) Smash(case 2) | 470 | | Figure A-29. Normal HS ACK(S) 3 Strikes Smash | 471 | | Figure A-30. Normal HS CSPLIT Smash | 472 | | Figure A-31. Normal HS CSPLIT 3 Strikes Smash | 473 | | Figure A-32. Normal HS DATA0/1 Smash | 474 | | Figure A-33. Normal HS DATA0/1 3 Strikes Smash | 475 | | Figure A-34. Normal FS/LS IN Smash | 476 | | Figure A-35. Normal FS/LS IN 3 Strikes Smash | 477 | | Figure A-36. Normal FS/LS DATA0/1 Smash | 478 | | Figure A-37. Normal FS/LS DATA0/1 3 Strikes Smash | 479 | | Figure A-38. Normal FS/LS ACK Smash | 480 | | Figure A-39. No Buffer Available No Smash(HS NAK(S)) | 481 | | Figure A-40. No Buffer Available HS NAK(S) Smash | 482 | | Figure A-41. No Buffer Available HS NAK(S) 3 Strikes Smash | 483 | | Figure A-42. CS Earlier No Smash(HS NYET) | 484 | | Figure A-43. CS Earlier HS NYET Smash(case 1) | 485 | | Figure A-44. CS Earlier HS NYET Smash(case 2) | 486 | | Figure A-45. | Device Busy No Smash(FS/LS NAK) | 487 | |--------------|----------------------------------------------------------------------------------|-----| | Figure A-46. | Device Stall No Smash(FS/LS STALL) | 488 | | Figure A-47. | Normal No Smash(FS/LS Handshake Packet is Done by M+1) | 492 | | Figure A-48. | Normal HS DATA0/1 Smash | 493 | | Figure A-49. | Normal HS CSPLIT Smash | 494 | | Figure A-50. | Normal HS CSPLIT 3 Strikes Smash | 495 | | Figure A-51. | Normal HS ACK(C) Smash | 496 | | Figure A-52. | Normal HS ACK(C) 3 Strikes Smash | 497 | | Figure A-53. | Normal FS/LS DATA0/1 Smash | 498 | | Figure A-54. | Normal FS/LS ACK Smash | 499 | | Figure A-55. | Searching No Smash | 500 | | Figure A-56. | CS Earlier No Smash(HS NYET and FS/LS Handshake Packet is Done by M+2) | 501 | | Figure A-57. | CS Earlier No Smash(HS NYET and FS/LS Handshake Packet is Done by M+3) | 502 | | Figure A-58. | CS Earlier HS NYET Smash | 503 | | Figure A-59. | CS Earlier HS NYET 3 Strikes Smash | 504 | | Figure A-60. | Abort and Free Abort(FS/LS Transaction is Continued at End of M+3) | 505 | | Figure A-61. | Abort and Free Free(FS/LS Transaction is not Started at End of M+3) | 506 | | Figure A-62. | Device Busy No Smash(FS/LS NAK) | 507 | | Figure A-63. | Device Stall No Smash(FS/LS STALL) | 508 | | Figure A-64. | Normal No Smash(FS/LS Data Packet is on M+1) | 512 | | Figure A-65. | Normal HS SSPLIT Smash | 513 | | Figure A-66. | Normal HS CSPLIT Smash | 514 | | Figure A-67. | Normal HS CSPLIT 3 Strikes Smash | 515 | | Figure A-68. | Normal HS DATA0/1 Smash | 516 | | Figure A-69. | Normal HS DATA0/1 3 Strikes Smash | 517 | | Figure A-70. | Normal FS/LS IN Smash | 518 | | Figure A-71. | Normal FS/LS DATA0/1 Smash | 519 | | Figure A-72. | Normal FS/LS ACK Smash | 520 | | Figure A-73. | Searching No Smash | 521 | | Figure A-74. | CS Earlier No Smash(HS MDATA and FS/LS Data Packet is on M+1 and M+2) | 522 | | Figure A-75. | CS Earlier No Smash(HS NYET and FS/LS Data Packet is on M+2) | 523 | | Figure A-76. | CS Earlier No Smash(HS NYET and MDATA and FS/LS Data Packet is on M+2 and M+3) . | 524 | | Figure A-77. | CS Earlier No Smash(HS NYET and FS/LS Data Packet is on M+3) | 525 | | Figure A-78. | CS Earlier HS NYET Smash | 526 | | Figure A-79. | CS Earlier HS NYET 3 Strikes Smash | 527 | | Figure A-80. | Abort and Free Abort(HS NYET and FS/LS Transaction is Continued at End of M+3) | 528 | | Figure A-81. | Abort and Free Free(HS NYET and FS/LS Transaction is not Started at End of M+3) | 529 | | Figure A-82. Device Busy No Smash(FS/LS NAK) | 530 | |-----------------------------------------------------------------|-----| | Figure A-83. Device Stall No Smash(FS/LS STALL) | 531 | | Figure C-1. Downstream Facing Port Reset Protocol State Diagram | 566 | | Figure C-2. Upstream Facing Port Reset Detection State Diagram | 568 | | Figure C-3. Upstream Facing Port Reset Handshake State Diagram | 569 | ### **Tables** | Table 5-1. Low-speed Control Transfer Limits | 41 | |----------------------------------------------------------------------------------|-----| | Table 5-2. Full-speed Control Transfer Limits | 42 | | Table 5-3. High-speed Control Transfer Limits | 43 | | Table 5-4. Full-speed Isochronous Transaction Limits | 45 | | Table 5-5. High-speed Isochronous Transaction Limits | 46 | | Table 5-6. Low-speed Interrupt Transaction Limits | 49 | | Table 5-7. Full-speed Interrupt Transaction Limits | 50 | | Table 5-8. High-speed Interrupt Transaction Limits | 51 | | Table 5-9. Full-speed Bulk Transaction Limits | 54 | | Table 5-10. High-speed Bulk Transaction Limits | 55 | | Table 5-11. wMaxPacketSize Field of Endpoint Descriptor | 56 | | Table 5-12. Synchronization Characteristics | 72 | | Table 5-13. Connection Requirements | 79 | | Table 6-1. USB Connector Termination Assignment | 94 | | Table 6-2. Power Pair | 103 | | Table 6-3. Signal Pair | 104 | | Table 6-4. Drain Wire Signal Pair | 104 | | Table 6-5. Nominal Cable Diameter | 105 | | Table 6-6. Conductor Resistance | 105 | | Table 6-7. USB Electrical, Mechanical, and Environmental Compliance Standards | 106 | | Table 7-1. Description of Functional Elements in the Example Shown in Figure 7-1 | 122 | | Table 7-2. Low-/full-speed Signaling Levels | 145 | | Table 7-3. High-speed Signaling Levels | 147 | | Table 7-4. Full-speed Jitter Budget | 164 | | Table 7-5. Low-speed Jitter Budget | 165 | | Table 7-6. Maximum Allowable Cable Loss | 167 | | Table 7-7. DC Electrical Characteristics | 178 | | Table 7-8. High-speed Source Electrical Characteristics | 180 | | Table 7-9. Full-speed Source Electrical Characteristics | 181 | | Table 7-10. Low-speed Source Electrical Characteristics | 182 | | Table 7-11. Hub/Repeater Electrical Characteristics | 183 | | Table 7-12. Cable Characteristics (Note 14) | 185 | | Table 7-13. Hub Event Timings | 186 | | Table 7-14 Device Event Timings | 188 | | Table 8-1. PID Types | 196 | |------------------------------------------------------------------------------------------------|-----| | Table 8-2. Isochronous OUT Payload Continuation Encoding | 203 | | Table 8-3. Endpoint Type Values in Split Special Token | 204 | | Table 8-4. Function Responses to IN Transactions | 208 | | Table 8-5. Host Responses to IN Transactions | 208 | | Table 8-6. Function Responses to OUT Transactions in Order of Precedence | 209 | | Table 8-7. Status Stage Responses | 227 | | Table 8-8. Packet Error Types | 236 | | Table 9-1. Visible Device States | 241 | | Table 9-2. Format of Setup Data | 248 | | Table 9-3. Standard Device Requests | 250 | | Table 9-4. Standard Request Codes | 251 | | Table 9-5. Descriptor Types | 251 | | Table 9-6. Standard Feature Selectors | 252 | | Table 9-7. Test Mode Selectors | 259 | | Table 9-8. Standard Device Descriptor | 262 | | Table 9-9. Device_Qualifier Descriptor | 264 | | Table 9-10. Standard Configuration Descriptor | 265 | | Table 9-11. Other_Speed_Configuration Descriptor | 267 | | Table 9-12. Standard Interface Descriptor | 268 | | Table 9-13. Standard Endpoint Descriptor | 269 | | Table 9-14. Allowed wMaxPacketSize Values for Different Numbers of Transactions per Microframe | 273 | | Table 9-15. String Descriptor Zero, Specifying Languages Supported by the Device | 273 | | Table 9-16. UNICODE String Descriptor | 274 | | Table 11-1. High-speed Microframe Timer Range Contributions | 300 | | Table 11-2. Full-speed Frame Timer Range Contributions | 301 | | Table 11-3. Hub and Host EOF1/EOF2 Timing Points | 303 | | Table 11-4. Internal Port Signal/Event Definitions | 308 | | Table 11-5. Downstream Facing Port Signal/Event Definitions | 311 | | Table 11-6. Automatic Port State to Port Indicator Color Mapping | 316 | | Table 11-7. Port Indicator Color Definitions | 317 | | Table 11-8. Upstream Facing Port Receiver Signal/Event Definitions | 320 | | Table 11-9. Upstream Facing Port Transmit Signal/Event Definitions | 323 | | Table 11-10. High-speed Port Selector Signal/Event Definitions | 326 | | Table 11-11. Hub Repeater Signal/Event Definitions | 329 | | Table 11-12. Hub Power Operating Mode Summary | 341 | | Table 11-13. Hub Descriptor | 417 | | Table 11-14. | Hub Responses to Standard Device Requests | .419 | |--------------|-------------------------------------------|------| | Table 11-15. | Hub Class Requests | .420 | | Table 11-16. | Hub Class Request Codes | .421 | | Table 11-17. | Hub Class Feature Selectors | .421 | | Table 11-18. | wValue Field for Clear_TT_Buffer | .424 | | Table 11-19. | Hub Status Field, wHubStatus | .425 | | Table 11-20. | Hub Change Field, wHubChange | .426 | | Table 11-21. | Port Status Field, wPortStatus | .427 | | Table 11-22. | Port Change Field, wPortChange | .431 | | Table 11-23. | Format of Returned TT State | .432 | | Table 11-24. | Test Mode Selector Codes | .436 | | Table 11-25. | Port Indicator Selector Codes | .437 | xxviii # Chapter 1 Introduction #### 1.1 Motivation The original motivation for the Universal Serial Bus (USB) came from three interrelated considerations: #### · Connection of the PC to the telephone It is well understood that the merge of computing and communication will be the basis for the next generation of productivity applications. The movement of machine-oriented and human-oriented data types from one location or environment to another depends on ubiquitous and cheap connectivity. Unfortunately, the computing and communication industries have evolved independently. The USB provides a ubiquitous link that can be used across a wide range of PC-to-telephone interconnects. #### Ease-of-use The lack of flexibility in reconfiguring the PC has been acknowledged as the Achilles' heel to its further deployment. The combination of user-friendly graphical interfaces and the hardware and software mechanisms associated with new-generation bus architectures have made computers less confrontational and easier to reconfigure. However, from the end user's point of view, the PC's I/O interfaces, such as serial/parallel ports, keyboard/mouse/joystick interfaces, etc., do not have the attributes of plug-and-play. #### Port expansion The addition of external peripherals continues to be constrained by port availability. The lack of a bi-directional, low-cost, low-to-mid speed peripheral bus has held back the creative proliferation of peripherals such as telephone/fax/modem adapters, answering machines, scanners, PDA's, keyboards, mice, etc. Existing interconnects are optimized for one or two point products. As each new function or capability is added to the PC, a new interface has been defined to address this need. The more recent motivation for USB 2.0 stems from the fact that PCs have increasingly higher performance and are capable of processing vast amounts of data. At the same time, PC peripherals have added more performance and functionality. User applications such as digital imaging demand a high performance connection between the PC and these increasingly sophisticated peripherals. USB 2.0 addresses this need by adding a third transfer rate of 480 Mb/s to the 12 Mb/s and 1.5 Mb/s originally defined for USB. USB 2.0 is a natural evolution of USB, delivering the desired bandwidth increase while preserving the original motivations for USB and maintaining full compatibility with existing peripherals. Thus, USB continues to be the answer to connectivity for the PC architecture. It is a fast, bi-directional, isochronous, low-cost, dynamically attachable serial interface that is consistent with the requirements of the PC platform of today and tomorrow. #### 1.2 Objective of the Specification This document defines an industry-standard USB. The specification describes the bus attributes, the protocol definition, types of transactions, bus management, and the programming interface required to design and build systems and peripherals that are compliant with this standard. The goal is to enable such devices from different vendors to interoperate in an open architecture. The specification is intended as an enhancement to the PC architecture, spanning portable, business desktop, and home environments. It is intended that the specification allow system OEMs and peripheral developers adequate room for product versatility and market differentiation without the burden of carrying obsolete interfaces or losing compatibility. #### 1.3 Scope of the Document The specification is primarily targeted to peripheral developers and system OEMs, but provides valuable information for platform operating system/ BIOS/ device driver, adapter IHVs/ISVs, and platform/adapter controller vendors. This specification can be used for developing new products and associated software. #### 1.4 USB Product Compliance Adopters of the USB 2.0 specification have signed the USB 2.0 Adopters Agreement, which provides them access to a reciprocal royalty-free license from the Promoters and other Adopters to certain intellectual property contained in products that are compliant with the USB 2.0 specification. Adopters can demonstrate compliance with the specification through the testing program as defined by the USB Implementers Forum. Products that demonstrate compliance with the specification will be granted certain rights to use the USB Implementers Forum logo as defined in the logo license. #### 1.5 Document Organization Chapters 1 through 5 provide an overview for all readers, while Chapters 6 through 11 contain detailed technical information defining the USB. - Peripheral implementers should particularly read Chapters 5 through 11. - USB Host Controller implementers should particularly read Chapters 5 through 8, 10, and 11. - USB device driver implementers should particularly read Chapters 5, 9, and 10. This document is complemented and referenced by the *Universal Serial Bus Device Class Specifications*. Device class specifications exist for a wide variety of devices. Please contact the USB Implementers Forum for further details. Readers are also requested to contact operating system vendors for operating system bindings specific to the USB. # Chapter 2 Terms and Abbreviations This chapter lists and defines terms and abbreviations used throughout this specification. ACK Handshake packet indicating a positive acknowledgment. Active Device A device that is powered and is not in the Suspend state. Asynchronous Data Data transferred at irregular intervals with relaxed latency requirements. Asynchronous RA The incoming data rate, Fs<sub>i</sub>, and the outgoing data rate, Fs<sub>o</sub>, of the RA process are independent (i.e., there is no shared master clock). See also rate adaptation. Asynchronous SRC The incoming sample rate, $F_{s_i}$ , and outgoing sample rate, $F_{s_o}$ , of the SRC process are independent (i.e., there is no shared master clock). See also sample rate conversion. Audio Device A device that sources or sinks sampled analog data. AWG# The measurement of a wire's cross section, as defined by the American Wire Gauge standard. Babble Unexpected bus activity that persists beyond a specified point in a (micro)frame. Bandwidth The amount of data transmitted per unit of time, typically bits per second (b/s) or bytes per second (B/s). Big Endian A method of storing data that places the most significant byte of multiple-byte values at a lower storage address. For example, a 16-bit integer stored in big endian format places the least significant byte at the higher address and the most significant byte at the lower address. See also little endian. Bit A unit of information used by digital computers. Represents the smallest piece of addressable memory within a computer. A bit expresses the choice between two possibilities and is typically represented by a logical one (1) or zero (0). Bit Stuffing Insertion of a "0" bit into a data stream to cause an electrical transition on the data wires, allowing a PLL to remain locked. b/s Transmission rate expressed in bits per second. B/s Transmission rate expressed in bytes per second. Buffer Storage used to compensate for a difference in data rates or time of occurrence of events, when transmitting data from one device to another. Bulk Transfer One of the four USB transfer types. Bulk transfers are non-periodic, large bursty communication typically used for a transfer that can use any available bandwidth and can also be delayed until bandwidth is available. See also transfer type. Bus Enumeration Detecting and identifying USB devices. Byte A data element that is eight bits in size. Capabilities Those attributes of a USB device that are administrated by the host. Characteristics Those qualities of a USB device that are unchangeable; for example, the device class is a device characteristic. Client Software resident on the host that interacts with the USB System Software to arrange data transfer between a function and the host. The client is often the data provider and consumer for transferred data. Configuring Software Software resident on the host software that is responsible for configuring a USB device. This may be a system configurator or software specific to the device. **Control Endpoint** A pair of device endpoints with the same endpoint number that are used by a > control pipe. Control endpoints transfer data in both directions and, therefore, use both endpoint directions of a device address and endpoint number combination. Thus, each control endpoint consumes two endpoint addresses. Control Pipe Same as a message pipe. Control Transfer One of the four USB transfer types. Control transfers support configuration/command/status type communications between client and function. See also transfer type. CRC See Cyclic Redundancy Check. CTI Computer Telephony Integration. Cyclic Redundancy A check performed on data to see if an error has occurred in transmitting, Check (CRC) reading, or writing the data. The result of a CRC is typically stored or transmitted with the checked data. The stored or transmitted result is compared to a CRC calculated for the data to determine if an error has occurred. Default Address An address defined by the USB Specification and used by a USB device when it is first powered or reset. The default address is 00H. **Default Pipe** The message pipe created by the USB System Software to pass control and status information between the host and a USB device's endpoint zero. Device A logical or physical entity that performs a function. The actual entity > described depends on the context of the reference. At the lowest level, device may refer to a single hardware component, as in a memory device. At a higher level, it may refer to a collection of hardware components that perform a particular function, such as a USB interface device. At an even higher level, device may refer to the function performed by an entity attached to the USB; for example, a data/FAX modem device. Devices may be physical, electrical, addressable, and logical. When used as a non-specific reference, a USB device is either a hub or a function. **Device Address** A seven-bit value representing the address of a device on the USB. The device > address is the default address (00H) when the USB device is first powered or the device is reset. Devices are assigned a unique device address by the USB System Software. Device Endpoint A uniquely addressable portion of a USB device that is the source or sink of information in a communication flow between the host and device. See also endpoint address. Device Resources Resources provided by USB devices, such as buffer space and endpoints. See also Host Resources and Universal Serial Bus Resources. **Device Software** Software that is responsible for using a USB device. This software may or may not also be responsible for configuring the device for use. **Downstream** The direction of data flow from the host or away from the host. A downstream port is the port on a hub electrically farthest from the host that generates downstream data traffic from the hub. Downstream ports receive upstream data traffic. **Driver** When referring to hardware, an I/O pad that drives an external load. When referring to software, a program responsible for interfacing to a hardware device, that is, a device driver. **DWORD** Double word. A data element that is two words (i.e., four bytes or 32 bits) in Non-volatile rewritable memory storage technology. size. **Dynamic Insertion** and Removal The ability to attach and remove devices while the host is in operation. **E**<sup>2</sup>**PROM** See Electrically Erasable Programmable Read Only Memory. **EEPROM** See Electrically Erasable Programmable Read Only Memory. Electrically Erasable Programmable Read Only Memory (EEPROM) **End User** The user of a host. Endpoint See device endpoint. Endpoint Address The combination of an endpoint number and an endpoint direction on a USB device. Each endpoint address supports data transfer in one direction. **Endpoint Direction** The direction of data transfer on the USB. The direction can be either IN or OUT. IN refers to transfers to the host; OUT refers to transfers from the host. Endpoint Number A four-bit value between 0H and FH, inclusive, associated with an endpoint on a USB device. Envelope detector An electronic circuit inside a USB device that monitors the USB data lines and detects certain voltage related signal characteristics. **EOF** End-of-(micro)Frame. EOP End-of-Packet. External Port See port. Eye pattern A representation of USB signaling that provides minimum and maximum voltage levels as well as signal jitter. False EOP A spurious, usually noise-induced event that is interpreted by a packet receiver as an EOP. Frame A 1 millisecond time base established on full-/low-speed buses. **Frame Pattern** A sequence of frames that exhibit a repeating pattern in the number of samples transmitted per frame. For a 44.1 kHz audio transfer, the frame pattern could be nine frames containing 44 samples followed by one frame containing 45 samples. Fs See sample rate. Full-duplex Computer data transmission occurring in both directions simultaneously. Full-speed USB operation at 12 Mb/s. See also low-speed and high-speed. Function A USB device that provides a capability to the host, such as an ISDN connection, a digital microphone, or speakers. Handshake Packet A packet that acknowledges or rejects a specific condition. For examples, see ACK and NAK. High-bandwidth endpoint A high-speed device endpoint that transfers more than 1024 bytes and less than 3073 bytes per microframe. High-speed USB operation at 480 Mb/s. See also low-speed and full-speed. Host The host computer system where the USB Host Controller is installed. This includes the host hardware platform (CPU, bus, etc.) and the operating system in use. Host Controller The host's USB interface. Host Controller Driver (HCD) The USB software layer that abstracts the Host Controller hardware. The Host Controller Driver provides an SPI for interaction with a Host Controller. The Host Controller Driver hides the specifics of the Host Controller hardware implementation. Host Resources Resources provided by the host, such as buffer space and interrupts. See also Device Resources and Universal Serial Bus Resources. Hub A USB device that provides additional connections to the USB. **Hub Tier** One plus the number of USB links in a communication path between the host and a function. See Figure 4-1. Interrupt Request (IRQ) A hardware signal that allows a device to request attention from a host. The host typically invokes an interrupt service routine to handle the condition that caused the request. Interrupt Transfer One of the four USB transfer types. Interrupt transfer characteristics are small data, non-periodic, low-frequency, and bounded-latency. Interrupt transfers are typically used to handle service needs. See also transfer type. I/O Request Packet An identifiable request by a software client to move data between itself (on the host) and an endpoint of a device in an appropriate direction. IRP See I/O Request Packet. IRQ See Interrupt Request. **Isochronous Data** A stream of data whose timing is implied by its delivery rate. Isochronous Device An entity with isochronous endpoints, as defined in the USB Specification, that sources or sinks sampled analog streams or synchronous data streams. Isochronous Sink Endpoint An endpoint that is capable of consuming an isochronous data stream that is sent by the host. Isochronous Source Endpoint An endpoint that is capable of producing an isochronous data stream and sending it to the host. Isochronous Transfer One of the four USB transfer types. Isochronous transfers are used when working with isochronous data. Isochronous transfers provide periodic, continuous communication between host and device. See also transfer type. Jitter A tendency toward lack of synchronization caused by mechanical or electrical changes. More specifically, the phase shift of digital pulses over a transmission medium. kb/s Transmission rate expressed in kilobits per second. kB/s Transmission rate expressed in kilobytes per second. Little Endian Method of storing data that places the least significant byte of multiple-byte values at lower storage addresses. For example, a 16-bit integer stored in little endian format places the least significant byte at the lower address and the most significant byte at the next address. See also big endian. LOA Loss of bus activity characterized by an SOP without a corresponding EOP. Low-speed USB operation at 1.5 Mb/s. See also full-speed and high-speed. LSb Least significant bit. LSB Least significant byte. Mb/s Least significant byte. Transmission rate expressed in megabits per second. MB/s Message Pipe Transmission rate expressed in megabytes per second. A bi-directional pipe that transfers data using a request/data/status paradigm. The data has an imposed structure that allows requests to be reliably identified and communicated. Microframe A 125 microsecond time base established on high-speed buses. MSb Most significant bit. MSB Most significant byte. NAK Handshake packet indicating a negative acknowledgment. Non Return to Zero Invert (NRZI) A method of encoding serial data in which ones and zeroes are represented by opposite and alternating high and low voltages where there is no return to zero (reference) voltage between encoded bits. Eliminates the need for clock pulses. NRZI See Non Return to Zero Invert. Object Host software or data structure representing a USB entity. Packet A bundle of data organized in a group for transmission. Packets typically contain three elements: control information (e.g., source, destination, and length), the data to be transferred, and error detection and correction bits. **Packet Buffer** The logical buffer used by a USB device for sending or receiving a single packet. This determines the maximum packet size the device can send or receive. Packet ID (PID) A field in a USB packet that indicates the type of packet, and by inference, the format of the packet and the type of error detection applied to the packet. Phase A token, data, or handshake packet. A transaction has three phases. Phase Locked Loop (PLL) A circuit that acts as a phase detector to keep an oscillator in phase with an incoming frequency. Physical Device A device that has a physical implementation; e.g., speakers, microphones, and CD players. PID See Packet ID. Pipe A logical abstraction representing the association between an endpoint on a device and software on the host. A pipe has several attributes; for example, a pipe may transfer data as streams (stream pipe) or messages (message pipe). See also stream pipe and message pipe. PLL See Phase Locked Loop. Polling Asking multiple devices, one at a time, if they have any data to transmit. POR See Power On Reset. Port Point of access to or from a system or circuit. For the USB, the point where a USB device is attached. Power On Reset (POR) Restoring a storage device, register, or memory to a predetermined state when power is applied. Programmable Data Rate Either a fixed data rate (single-frequency endpoints), a limited number of data rates (32 kHz, 44.1 kHz, 48 kHz, ...), or a continuously programmable data rate. The exact programming capabilities of an endpoint must be reported in the appropriate class-specific endpoint descriptors. Protocol A specific set of rules, procedures, or conventions relating to format and timing of data transmission between two devices. RA See rate adaptation. Rate Adaptation The process by which an incoming data stream, sampled at Fs<sub>i</sub>, is converted to an outgoing data stream, sampled at $F_{S_0}$ ,with a certain loss of quality, determined by the rate adaptation algorithm. Error control mechanisms are required for the process. $F_{S_i}$ and $F_{S_0}$ can be different and asynchronous. $F_{S_i}$ is the input data rate of the RA; Fso is the output data rate of the RA. Request A request made to a USB device contained within the data portion of a SETUP packet. Retire The action of completing service for a transfer and notifying the appropriate software client of the completion. Root Hub A USB hub directly attached to the Host Controller. This hub (tier 1) is attached to the host. Root Port The downstream port on a Root Hub. Sample The smallest unit of data on which an endpoint operates; a property of an endpoint. Sample Rate (Fs) The number of samples per second, expressed in Hertz (Hz). Sample Rate Conversion (SRC) A dedicated implementation of the RA process for use on sampled analog data streams. The error control mechanism is replaced by interpolating techniques. Service A procedure provided by a System Programming Interface (SPI). Service Interval The period between consecutive requests to a USB endpoint to send or receive data Service Jitter The deviation of service delivery from its scheduled delivery time. Service Rate The number of services to a given endpoint per unit time. SOF See Start-of-Frame. Start-of-Packet. SOP SPI See System Programming Interface. Split transaction A transaction type supported by host controllers and hubs. This transaction type allows full- and low-speed devices to be attached to hubs operating at high-speed. SRC See Sample Rate Conversion. Stage One part of the sequence composing a control transfer; stages include the Setup stage, the Data stage, and the Status stage. Start-of-Frame (SOF) The first transaction in each (micro)frame. An SOF allows endpoints to identify the start of the (micro)frame and synchronize internal endpoint clocks to the host. Stream Pipe A pipe that transfers data as a stream of samples with no defined USB structure. Synchronization Type A classification that characterizes an isochronous endpoint's capability to connect to other isochronous endpoints. Synchronous RA The incoming data rate, F<sub>si</sub>, and the outgoing data rate, F<sub>so</sub>, of the RA process are derived from the same master clock. There is a fixed relation between F<sub>si</sub> and Fso. Synchronous SRC The incoming sample rate, Fs<sub>i</sub>, and outgoing sample rate, Fs<sub>o</sub>, of the SRC process are derived from the same master clock. There is a fixed relation between Fs; and Fso. System A defined interface to services provided by system software. Programming Interface (SPI) TDM See Time Division Multiplexing. TDR See Time Domain Reflectometer. Termination Passive components attached at the end of cables to prevent signals from being reflected or echoed. Time Division Multiplexing (TDM) A method of transmitting multiple signals (data, voice, and/or video) simultaneously over one communications medium by interleaving a piece of each signal one after another. Time Domain Reflectometer An instrument capable of measuring impedance characteristics of the USB signal lines. (TDR) Timeout The detection of a lack of bus activity for some predetermined interval. Token Packet A type of packet that identifies what transaction is to be performed on the bus. The delivery of service to an endpoint; consists of a token packet, optional data Transaction packet, and optional handshake packet. Specific packets are allowed/required based on the transaction type. Transaction A functional component of a USB hub. The Transaction Translator responds to translator special high-speed transactions and translates them to full/low-speed transactions with full/low-speed devices attached on downstream facing ports. Transfer One or more bus transactions to move information between a software client and its function. Determines the characteristics of the data flow between a software client and Transfer Type its function. Four standard transfer types are defined: control, interrupt, bulk, and isochronous. Turn-around Time The time a device needs to wait to begin transmitting a packet after a packet > has been received to prevent collisions on the USB. This time is based on the length and propagation delay characteristics of the cable and the location of the transmitting device in relation to other devices on the USB. Universal Serial The host resident software entity responsible for providing common services to Bus Driver (USBD) clients that are manipulating one or more functions on one or more Host Controllers. Universal Serial **Bus Resources** Resources provided by the USB, such as bandwidth and power. See also Device Resources and Host Resources. The direction of data flow towards the host. An upstream port is the port on a Upstream device electrically closest to the host that generates upstream data traffic from the hub. Upstream ports receive downstream data traffic. USBD See Universal Serial Bus Driver. **USB-IF** USB Implementers Forum, Inc. is a nonprofit corporation formed to facilitate the development of USB compliant products and promote the technology. Virtual Device A device that is represented by a software interface layer. An example of a virtual device is a hard disk with its associated device driver and client software that makes it able to reproduce an audio .WAV file. Word A data element that is two bytes (16 bits) in size. # Chapter 3 Background This chapter presents a brief description of the background of the Universal Serial Bus (USB), including design goals, features of the bus, and existing technologies. ## 3.1 Goals for the Universal Serial Bus The USB is specified to be an industry-standard extension to the PC architecture with a focus on PC peripherals that enable consumer and business applications. The following criteria were applied in defining the architecture for the USB: - Ease-of-use for PC peripheral expansion - Low-cost solution that supports transfer rates up to 480 Mb/s - · Full support for real-time data for voice, audio, and video - · Protocol flexibility for mixed-mode isochronous data transfers and asynchronous messaging - Integration in commodity device technology - Comprehension of various PC configurations and form factors - · Provision of a standard interface capable of quick diffusion into product - Enabling new classes of devices that augment the PC's capability - · Full backward compatibility of USB 2.0 for devices built to previous versions of the specification # 3.2 Taxonomy of Application Space Figure 3-1 describes a taxonomy for the range of data traffic workloads that can be serviced over a USB. As can be seen, a 480 Mb/s bus comprehends the high-speed, full-speed, and low-speed data ranges. Typically, high-speed and full-speed data types may be isochronous, while low-speed data comes from interactive devices. The USB is primarily a PC bus but can be readily applied to other host-centric computing devices. The software architecture allows for future extension of the USB by providing support for multiple USB Host Controllers. | PERFORMANCE | APPLICATIONS | ATTRIBUTES | |--------------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | LOW-SPEED • Interactive Devices • 10 – 100 kb/s | Keyboard, Mouse<br>Stylus<br>Game Peripherals<br>Virtual Reality Peripherals | Lowest Cost<br>Ease-of-Use<br>Dynamic Attach-Detach<br>Multiple Peripherals | | FULL-SPEED • Phone, Audio, Compressed Video • 500 kb/s – 10 Mb/s | POTS<br>Broadband<br>Audio<br>Microphone | Lower Cost Ease-of-Use Dynamic Attach-Detach Multiple Peripherals Guaranteed Bandwidth Guaranteed Latency | | HIGH-SPEED • Video, Storage • 25 – 400 Mb/s | Video<br>Storage<br>Imaging<br>Broadband | Low Cost Ease-of-Use Dynamic Attach-Detach Multiple Peripherals Guaranteed Bandwidth Guaranteed Latency High Bandwidth | Figure 3-1. Application Space Taxonomy #### 3.3 Feature List The USB Specification provides a selection of attributes that can achieve multiple price/performance integration points and can enable functions that allow differentiation at the system and component level. Features are categorized by the following benefits: #### Easy to use for end user - Single model for cabling and connectors - Electrical details isolated from end user (e.g., bus terminations) - Self-identifying peripherals, automatic mapping of function to driver and configuration - Dynamically attachable and reconfigurable peripherals #### Wide range of workloads and applications - · Suitable for device bandwidths ranging from a few kb/s to several hundred Mb/s - · Supports isochronous as well as asynchronous transfer types over the same set of wires - Supports concurrent operation of many devices (multiple connections) - Supports up to 127 physical devices - Supports transfer of multiple data and message streams between the host and devices - Allows compound devices (i.e., peripherals composed of many functions) - · Lower protocol overhead, resulting in high bus utilization #### Isochronous bandwidth · Guaranteed bandwidth and low latencies appropriate for telephony, audio, video, etc. #### Flexibility - Supports a wide range of packet sizes, which allows a range of device buffering options - Allows a wide range of device data rates by accommodating packet buffer size and latencies - · Flow control for buffer handling is built into the protocol #### Robustness - · Error handling/fault recovery mechanism is built into the protocol - · Dynamic insertion and removal of devices is identified in user-perceived real-time - Supports identification of faulty devices #### Synergy with PC industry - Protocol is simple to implement and integrate - Consistent with the PC plug-and-play architecture - Leverages existing operating system interfaces # Low-cost implementation - · Low-cost subchannel at 1.5 Mb/s - Optimized for integration in peripheral and host hardware - Suitable for development of low-cost peripherals - Low-cost cables and connectors - · Uses commodity technologies # Upgrade path Architecture upgradeable to support multiple USB Host Controllers in a system # Chapter 4 Architectural Overview This chapter presents an overview of the Universal Serial Bus (USB) architecture and key concepts. The USB is a cable bus that supports data exchange between a host computer and a wide range of simultaneously accessible peripherals. The attached peripherals share USB bandwidth through a host-scheduled, token-based protocol. The bus allows peripherals to be attached, configured, used, and detached while the host and other peripherals are in operation. Later chapters describe the various components of the USB in greater detail. # 4.1 USB System Description A USB system is described by three definitional areas: - USB interconnect - USB devices - USB host The USB interconnect is the manner in which USB devices are connected to and communicate with the host. This includes the following: - · Bus Topology: Connection model between USB devices and the host. - Inter-layer Relationships: In terms of a capability stack, the USB tasks that are performed at each layer in the system. - Data Flow Models: The manner in which data moves in the system over the USB between producers and consumers. - USB Schedule: The USB provides a shared interconnect. Access to the interconnect is scheduled in order to support isochronous data transfers and to eliminate arbitration overhead. USB devices and the USB host are described in detail in subsequent sections. # 4.1.1 Bus Topology The USB connects USB devices with the USB host. The USB physical interconnect is a tiered star topology. A hub is at the center of each star. Each wire segment is a point-to-point connection between the host and a hub or function, or a hub connected to another hub or function. Figure 4-1 illustrates the topology of the USB. Due to timing constraints allowed for hub and cable propagation times, the maximum number of tiers allowed is seven (including the root tier). Note that in seven tiers, five non-root hubs maximum can be supported in a communication path between the host and any device. A compound device (see Figure 4-1) occupies two tiers; therefore, it cannot be enabled if attached at tier level seven. Only functions can be enabled in tier seven. Figure 4-1. Bus Topology ## 4.1.1.1 USB Host There is only one host in any USB system. The USB interface to the host computer system is referred to as the Host Controller. The Host Controller may be implemented in a combination of hardware, firmware, or software. A root hub is integrated within the host system to provide one or more attachment points. Additional information concerning the host may be found in Section 4.9 and in Chapter 10. #### 4.1.1.2 USB Devices USB devices are one of the following: - · Hubs, which provide additional attachment points to the USB - Functions, which provide capabilities to the system, such as an ISDN connection, a digital joystick, or speakers USB devices present a standard USB interface in terms of the following: - Their comprehension of the USB protocol - Their response to standard USB operations, such as configuration and reset - Their standard capability descriptive information Additional information concerning USB devices may be found in Section 4.8 and in Chapter 9. ## 4.2 Physical Interface The physical interface of the USB is described in the electrical (Chapter 7) and mechanical (Chapter 6) specifications for the bus. #### 4.2.1 Electrical The USB transfers signal and power over a four-wire cable, shown in Figure 4-2. The signaling occurs over two wires on each point-to-point segment. There are three data rates: - The USB high-speed signaling bit rate is 480 Mb/s. - The USB full-speed signaling bit rate is 12 Mb/s. - A limited capability low-speed signaling mode is also defined at 1.5 Mb/s. USB 2.0 host controllers and hubs provide capabilities so that full-speed and low-speed data can be transmitted at high-speed between the host controller and the hub, but transmitted between the hub and the device at full-speed or low-speed. This capability minimizes the impact that full-speed and low-speed devices have upon the bandwidth available for high-speed devices. The low-speed mode is defined to support a limited number of low-bandwidth devices, such as mice, because more general use would degrade bus utilization. The clock is transmitted, encoded along with the differential data. The clock encoding scheme is NRZI with bit stuffing to ensure adequate transitions. A SYNC field precedes each packet to allow the receiver(s) to synchronize their bit recovery clocks. Figure 4-2. USB Cable The cable also carries VBUS and GND wires on each segment to deliver power to devices. VBUS is nominally +5 V at the source. The USB allows cable segments of variable lengths, up to several meters, by choosing the appropriate conductor gauge to match the specified IR drop and other attributes such as device power budget and cable flexibility. In order to provide guaranteed input voltage levels and proper termination impedance, biased terminations are used at each end of the cable. The terminations also permit the detection of attach and detach at each port and differentiate between high/full-speed and low-speed devices. #### 4.2.2 Mechanical The mechanical specifications for cables and connectors are provided in Chapter 6. All devices have an upstream connection. Upstream and downstream connectors are not mechanically interchangeable, thus eliminating illegal loopback connections at hubs. The cable has four conductors: a twisted signal pair of standard gauge and a power pair in a range of permitted gauges. The connector is four-position, with shielded housing, specified robustness, and ease of attach-detach characteristics. #### 4.3 Power The specification covers two aspects of power: - Power distribution over the USB deals with the issues of how USB devices consume power provided by the host over the USB. - Power management deals with how the USB System Software and devices fit into the host-based power management system. #### 4.3.1 Power Distribution Each USB segment provides a limited amount of power over the cable. The host supplies power for use by USB devices that are directly connected. In addition, any USB device may have its own power supply. USB devices that rely totally on power from the cable are called bus-powered devices. In contrast, those that have an alternate source of power are called self-powered devices. A hub also supplies power for its connected USB devices. The architecture permits bus-powered hubs within certain constraints of topology that are discussed later in Chapter 11. ## 4.3.2 Power Management A USB host may have a power management system that is independent of the USB. The USB System Software interacts with the host's power management system to handle system power events such as suspend or resume. Additionally, USB devices typically implement additional power management features that allow them to be power managed by system software. The power distribution and power management features of the USB allow it to be designed into powersensitive systems such as battery-based notebook computers. ## 4.4 Bus Protocol The USB is a polled bus. The Host Controller initiates all data transfers. Most bus transactions involve the transmission of up to three packets. Each transaction begins when the Host Controller, on a scheduled basis, sends a USB packet describing the type and direction of transaction, the USB device address, and endpoint number. This packet is referred to as the "token packet." The USB device that is addressed selects itself by decoding the appropriate address fields. In a given transaction, data is transferred either from the host to a device or from a device to the host. The direction of data transfer is specified in the token packet. The source of the transaction then sends a data packet or indicates it has no data to transfer. The destination, in general, responds with a handshake packet indicating whether the transfer was successful. Some bus transactions between host controllers and hubs involve the transmission of four packets. These types of transactions are used to manage the data transfers between the host and full-/low- speed devices. The USB data transfer model between a source or destination on the host and an endpoint on a device is referred to as a pipe. There are two types of pipes: stream and message. Stream data has no USB-defined structure, while message data does. Additionally, pipes have associations of data bandwidth, transfer service type, and endpoint characteristics like directionality and buffer sizes. Most pipes come into existence when a USB device is configured. One message pipe, the Default Control Pipe, always exists once a device is powered, in order to provide access to the device's configuration, status, and control information. The transaction schedule allows flow control for some stream pipes. At the hardware level, this prevents buffers from underrun or overrun situations by using a NAK handshake to throttle the data rate. When NAKed, a transaction is retried when bus time is available. The flow control mechanism permits the construction of flexible schedules that accommodate concurrent servicing of a heterogeneous mix of stream pipes. Thus, multiple stream pipes can be serviced at different intervals and with packets of different sizes. #### 4.5 Robustness There are several attributes of the USB that contribute to its robustness: - · Signal integrity using differential drivers, receivers, and shielding - · CRC protection over control and data fields - Detection of attach and detach and system-level configuration of resources - Self-recovery in protocol, using timeouts for lost or corrupted packets - Flow control for streaming data to ensure isochrony and hardware buffer management - Data and control pipe constructs for ensuring independence from adverse interactions between functions #### 4.5.1 Error Detection The core bit error rate of the USB medium is expected to be close to that of a backplane and any glitches will very likely be transient in nature. To provide protection against such transients, each packet includes error protection fields. When data integrity is required, such as with lossless data devices, an error recovery procedure may be invoked in hardware or software. The protocol includes separate CRCs for control and data fields of each packet. A failed CRC is considered to indicate a corrupted packet. The CRC gives 100% coverage on single- and double-bit errors. ### 4.5.2 Error Handling The protocol allows for error handling in hardware or software. Hardware error handling includes reporting and retry of failed transfers. A USB Host Controller will try a transmission that encounters errors up to three times before informing the client software of the failure. The client software can recover in an implementation-specific way. #### 4.6 System Configuration The USB supports USB devices attaching to and detaching from the USB at any time. Consequently, system software must accommodate dynamic changes in the physical bus topology. #### 4.6.1 Attachment of USB Devices All USB devices attach to the USB through ports on specialized USB devices known as hubs. Hubs have status bits that are used to report the attachment or removal of a USB device on one of its ports. The host queries the hub to retrieve these bits. In the case of an attachment, the host enables the port and addresses the USB device through the device's control pipe at the default address. The host assigns a unique USB address to the device and then determines if the newly attached USB device is a hub or a function. The host establishes its end of the control pipe for the USB device using the assigned USB address and endpoint number zero. If the attached USB device is a hub and USB devices are attached to its ports, then the above procedure is followed for each of the attached USB devices. If the attached USB device is a function, then attachment notifications will be handled by host software that is appropriate for the function. #### 4.6.2 Removal of USB Devices When a USB device has been removed from one of a hub's ports, the hub disables the port and provides an indication of device removal to the host. The removal indication is then handled by appropriate USB System Software. If the removed USB device is a hub, the USB System Software must handle the removal of both the hub and of all of the USB devices that were previously attached to the system through the hub. #### 4.6.3 Bus Enumeration Bus enumeration is the activity that identifies and assigns unique addresses to devices attached to a bus. Because the USB allows USB devices to attach to or detach from the USB at any time, bus enumeration is an on-going activity for the USB System Software. Additionally, bus enumeration for the USB also includes the detection and processing of removals. ## 4.7 Data Flow Types The USB supports functional data and control exchange between the USB host and a USB device as a set of either uni-directional or bi-directional pipes. USB data transfers take place between host software and a particular endpoint on a USB device. Such associations between the host software and a USB device endpoint are called pipes. In general, data movement though one pipe is independent from the data flow in any other pipe. A given USB device may have many pipes. As an example, a given USB device could have an endpoint that supports a pipe for transporting data to the USB device and another endpoint that supports a pipe for transporting data from the USB device. The USB architecture comprehends four basic types of data transfers: - Control Transfers: Used to configure a device at attach time and can be used for other device-specific purposes, including control of other pipes on the device. - Bulk Data Transfers: Generated or consumed in relatively large and bursty quantities and have wide dynamic latitude in transmission constraints. - Interrupt Data Transfers: Used for timely but reliable delivery of data, for example, characters or coordinates with human-perceptible echo or feedback response characteristics. - Isochronous Data Transfers: Occupy a prenegotiated amount of USB bandwidth with a prenegotiated delivery latency. (Also called streaming real time transfers). A pipe supports only one of the types of transfers described above for any given device configuration. The USB data flow model is described in more detail in Chapter 5. #### 4.7.1 Control Transfers Control data is used by the USB System Software to configure devices when they are first attached. Other driver software can choose to use control transfers in implementation-specific ways. Data delivery is lossless. #### 4.7.2 Bulk Transfers Bulk data typically consists of larger amounts of data, such as that used for printers or scanners. Bulk data is sequential. Reliable exchange of data is ensured at the hardware level by using error detection in hardware and invoking a limited number of retries in hardware. Also, the bandwidth taken up by bulk data can vary, depending on other bus activities. # 4.7.3 Interrupt Transfers A limited-latency transfer to or from a device is referred to as interrupt data. Such data may be presented for transfer by a device at any time and is delivered by the USB at a rate no slower than is specified by the device. Interrupt data typically consists of event notification, characters, or coordinates that are organized as one or more bytes. An example of interrupt data is the coordinates from a pointing device. Although an explicit timing rate is not required, interactive data may have response time bounds that the USB must support. #### 4.7.4 Isochronous Transfers Isochronous data is continuous and real-time in creation, delivery, and consumption. Timing-related information is implied by the steady rate at which isochronous data is received and transferred. Isochronous data must be delivered at the rate received to maintain its timing. In addition to delivery rate, isochronous data may also be sensitive to delivery delays. For isochronous pipes, the bandwidth required is typically based upon the sampling characteristics of the associated function. The latency required is related to the buffering available at each endpoint. A typical example of isochronous data is voice. If the delivery rate of these data streams is not maintained, drop-outs in the data stream will occur due to buffer or frame underruns or overruns. Even if data is delivered at the appropriate rate by USB hardware, delivery delays introduced by software may degrade applications requiring real-time turn-around, such as telephony-based audio conferencing. The timely delivery of isochronous data is ensured at the expense of potential transient losses in the data stream. In other words, any error in electrical transmission is not corrected by hardware mechanisms such as retries. In practice, the core bit error rate of the USB is expected to be small enough not to be an issue. USB isochronous data streams are allocated a dedicated portion of USB bandwidth to ensure that data can be delivered at the desired rate. The USB is also designed for minimal delay of isochronous data transfers. #### 4.7.5 Allocating USB Bandwidth USB bandwidth is allocated among pipes. The USB allocates bandwidth for some pipes when a pipe is established. USB devices are required to provide some buffering of data. It is assumed that USB devices requiring more bandwidth are capable of providing larger buffers. The goal for the USB architecture is to ensure that buffering-induced hardware delay is bounded to within a few milliseconds. The USB's bandwidth capacity can be allocated among many different data streams. This allows a wide range of devices to be attached to the USB. Further, different device bit rates, with a wide dynamic range, can be concurrently supported. The USB Specification defines the rules for how each transfer type is allowed access to the bus. #### 4.8 USB Devices USB devices are divided into device classes such as hub, human interface, printer, imaging, or mass storage device. The hub device class indicates a specially designated USB device that provides additional USB attachment points (refer to Chapter 11). USB devices are required to carry information for self-identification and generic configuration. They are also required at all times to display behavior consistent with defined USB device states. #### 4.8.1 Device Characterizations All USB devices are accessed by a USB address that is assigned when the device is attached and enumerated. Each USB device additionally supports one or more pipes through which the host may communicate with the device. All USB devices must support a specially designated pipe at endpoint zero to which the USB device's USB control pipe will be attached. All USB devices support a common access mechanism for accessing information through this control pipe. Associated with the control pipe at endpoint zero is the information required to completely describe the USB device. This information falls into the following categories: - Standard: This is information whose definition is common to all USB devices and includes items such as vendor identification, device class, and power management capability. Device, configuration, interface, and endpoint descriptions carry configuration-related information about the device. Detailed information about these descriptors can be found in Chapter 9. - Class: The definition of this information varies, depending on the device class of the USB device. - USB Vendor: The vendor of the USB device is free to put any information desired here. The format, however, is not determined by this specification. Additionally, each USB device carries USB control and status information. #### 4.8.2 Device Descriptions Two major divisions of device classes exist: hubs and functions. Only hubs have the ability to provide additional USB attachment points. Functions provide additional capabilities to the host. #### 4.8.2.1 Hubs Hubs are a key element in the plug-and-play architecture of the USB. Figure 4-3 shows a typical hub. Hubs serve to simplify USB connectivity from the user's perspective and provide robustness at relatively low cost and complexity. Hubs are wiring concentrators and enable the multiple attachment characteristics of the USB. Attachment points are referred to as ports. Each hub converts a single attachment point into multiple attachment points. The architecture supports concatenation of multiple hubs. The upstream port of a hub connects the hub towards the host. Each of the downstream ports of a hub allows connection to another hub or function. Hubs can detect attach and detach at each downstream port and enable the distribution of power to downstream devices. Each downstream port can be individually enabled and attached to either high-, full- or low-speed devices. A USB 2.0 hub consists of three portions: the Hub Controller, the Hub Repeater, and the Transaction Translator. The Hub Repeater is a protocol-controlled switch between the upstream port and downstream ports. It also has hardware support for reset and suspend/resume signaling. The Host Controller provides the communication to/from the host. Hub-specific status and control commands permit the host to configure a hub and to monitor and control its ports. The Transaction Translator provides the mechanisms that support full-/low-speed devices behind the hub, while transmitting all device data between the host and the hub at high-speed. Figure 4-3. A Typical Hub Figure 4-4 illustrates how hubs provide connectivity in a typical desktop computer environment. Figure 4-4. Hubs in a Desktop Computer Environment #### 4.8.2.2 Functions A function is a USB device that is able to transmit or receive data or control information over the bus. A function is typically implemented as a separate peripheral device with a cable that plugs into a port on a hub. However, a physical package may implement multiple functions and an embedded hub with a single USB cable. This is known as a compound device. A compound device appears to the host as a hub with one or more non-removable USB devices. Each function contains configuration information that describes its capabilities and resource requirements. Before a function can be used, it must be configured by the host. This configuration includes allocating USB bandwidth and selecting function-specific configuration options. Examples of functions include the following: - · A human interface device such as a mouse, keyboard, tablet, or game controller - An imaging device such as a scanner, printer, or camera - · A mass storage device such as a CD-ROM drive, floppy drive, or DVD drive ### 4.9 USB Host: Hardware and Software The USB host interacts with USB devices through the Host Controller. The host is responsible for the following: - Detecting the attachment and removal of USB devices - Managing control flow between the host and USB devices - Managing data flow between the host and USB devices - Collecting status and activity statistics - Providing power to attached USB devices The USB System Software on the host manages interactions between USB devices and host-based device software. There are five areas of interactions between the USB System Software and device software: - Device enumeration and configuration - · Isochronous data transfers - Asynchronous data transfers - Power management - Device and bus management information #### 4.10 Architectural Extensions The USB architecture comprehends extensibility at the interface between the Host Controller Driver and USB Driver. Implementations with multiple Host Controllers, and associated Host Controller Drivers, are possible. # Chapter 5 USB Data Flow Model This chapter presents information about how data is moved across the USB. The information in this chapter affects all implementers. The information presented is at a level above the signaling and protocol definitions of the system. Consult Chapter 7 and Chapter 8 for more details about their respective parts of the USB system. This chapter provides framework information that is further expanded in Chapters 9 through 11. All implementers should read this chapter so they understand the key concepts of the USB. ## 5.1 Implementer Viewpoints The USB provides communication services between a host and attached USB devices. However, the simple view an end user sees of attaching one or more USB devices to a host, as in Figure 5-1, is in fact a little more complicated to implement than is indicated by the figure. Different views of the system are required to explain specific USB requirements from the perspective of different implementers. Several important concepts and features must be supported to provide the end user with the reliable operation demanded from today's personal computers. The USB is presented in a layered fashion to ease explanation and allow implementers of particular USB products to focus on the details related to their product. Figure 5-1. Simple USB Host/Device View Figure 5-2 shows a deeper overview of the USB, identifying the different layers of the system that will be described in more detail in the remainder of the specification. In particular, there are four focus implementation areas: - USB Physical Device: A piece of hardware on the end of a USB cable that performs some useful end user function. - Client Software: Software that executes on the host, corresponding to a USB device. This client software is typically supplied with the operating system or provided along with the USB device. - USB System Software: Software that supports the USB in a particular operating system. The USB System Software is typically supplied with the operating system, independently of particular USB devices or client software. - USB Host Controller (Host Side Bus Interface): The hardware and software that allows USB devices to be attached to a host. There are shared rights and responsibilities between the four USB system components. The remainder of this specification describes the details required to support robust, reliable communication flows between a function and its client. Figure 5-2. USB Implementation Areas As shown in Figure 5-2, the simple connection of a host to a device requires interaction between a number of layers and entities. The USB Bus Interface layer provides physical/signaling/packet connectivity between the host and a device. The USB Device layer is the view the USB System Software has for performing generic USB operations with a device. The Function layer provides additional capabilities to the host via an appropriate matched client software layer. The USB Device and Function layers each have a view of logical communication within their layer that actually uses the USB Bus Interface layer to accomplish data transfer. The physical view of USB communication as described in Chapters 6, 7, and 8 is related to the logical communication view presented in Chapters 9 and 10. This chapter describes those key concepts that affect USB implementers and should be read by all before proceeding to the remainder of the specification to find those details most relevant to their product. To describe and manage USB communication, the following concepts are important: - Bus Topology: Section 5.2 presents the primary physical and logical components of the USB and how they interrelate. - Communication Flow Models: Sections 5.3 through 5.8 describe how communication flows between the host and devices through the USB and defines the four USB transfer types. - Bus Access Management: Section 5.11 describes how bus access is managed within the host to support a broad range of communication flows by USB devices. - Special Consideration for Isochronous Transfers: Section 5.12 presents features of the USB specific to devices requiring isochronous data transfers. Device implementers for non-isochronous devices do not need to read Section 5.12. # 5.2 Bus Topology There are four main parts to USB topology: - · Host and Devices: The primary components of a USB system - · Physical Topology: How USB elements are connected - Logical Topology: The roles and responsibilities of the various USB elements and how the USB appears from the perspective of the host and a device - Client Software-to-function Relationships: How client software and its related function interfaces on a USB device view each other ## 5.2.1 USB Host The host's logical composition is shown in Figure 5-3 and includes the following: - USB Host Controller - Aggregate USB System Software (USB Driver, Host Controller Driver, and host software) - Client Figure 5-3. Host Composition The USB host occupies a unique position as the coordinating entity for the USB. In addition to its special physical position, the host has specific responsibilities with regard to the USB and its attached devices. The host controls all access to the USB. A USB device gains access to the bus only by being granted access by the host. The host is also responsible for monitoring the topology of the USB. For a complete discussion of the host and its duties, refer to Chapter 10. # 5.2.2 USB Devices A USB physical device's logical composition is shown in Figure 5-4 and includes the following: - USB bus interface - USB logical device - Function USB physical devices provide additional functionality to the host. The types of functionality provided by USB devices vary widely. However, all USB logical devices present the same basic interface to the host. This allows the host to manage the USB-relevant aspects of different USB devices in the same manner. To assist the host in identifying and configuring USB devices, each device carries and reports configurationrelated information. Some of the information reported is common among all logical devices. Other information is specific to the functionality provided by the device. The detailed format of this information varies, depending on the device class of the device. For a complete discussion of USB devices, refer to Chapter 9. Figure 5-4. Physical Device Composition # 5.2.3 Physical Bus Topology Devices on the USB are physically connected to the host via a tiered star topology, as illustrated in Figure 5-5. USB attachment points are provided by a special class of USB device known as a hub. The additional attachment points provided by a hub are called ports. A host includes an embedded hub called the root hub. The host provides one or more attachment points via the root hub. USB devices that provide additional functionality to the host are known as functions. To prevent circular attachments, a tiered ordering is imposed on the star topology of the USB. This results in the tree-like configuration illustrated in Figure 5-5. Figure 5-5. USB Physical Bus Topology Multiple functions may be packaged together in what appears to be a single physical device. For example, a keyboard and a trackball might be combined in a single package. Inside the package, the individual functions are permanently attached to a hub and it is the internal hub that is connected to the USB. When multiple functions are combined with a hub in a single package, they are referred to as a compound device. The hub and each function attached to the hub within the compound device is assigned its own device address. A device that has multiple interfaces controlled independently of each other is referred to as a composite device. A composite device has only a single device address. From the host's perspective, a compound device is the same as a separate hub with multiple functions attached. Figure 5-5 also illustrates a compound device. Figure 5-6. Multiple Full-speed Buses in a High-speed System The hub plays a special role in a high-speed system. The hub isolates the full-/low-speed signaling environment from the high-speed signaling environment. Figure 5-6 shows a hub operating in high speed supporting a high-speed attached device. The hub also allows USB1.1 hubs to attach and operate at full-/low-speed along with other full-/low-speed only devices. The host controller also directly supports attaching full-/low-speed only devices. Chapter 11 describes the details of how the hub accomplishes the isolation of the two signaling environments. Each high-speed operating hub essentially adds one (or more) additional full-/low-speed buses; i.e., each hub supports additional (optionally multiple) 12 Mb/s of USB full-/low-speed bandwidth. This allows more full-/low-speed buses to be attached without requiring additional host controllers in a system. Even though there can be several 12 Mb/s full-/low-speed buses, there are only at most 127 USB devices attached to any single host controller. ## 5.2.4 Logical Bus Topology While devices physically attach to the USB in a tiered, star topology, the host communicates with each logical device as if it were directly connected to the root port. This creates the logical view illustrated in Figure 5-7 that corresponds to the physical topology shown in Figure 5-5. Hubs are logical devices also but are not shown in Figure 5-7 to simplify the picture. Even though most host/logical device activities use this logical perspective, the host maintains an awareness of the physical topology to support processing the removal of hubs. When a hub is removed, all of the devices attached to the hub must be removed from the host's view of the logical topology. A more complete discussion of hubs can be found in Chapter 11. Figure 5-7. USB Logical Bus Topology # 5.2.5 Client Software-to-function Relationship Even though the physical and logical topology of the USB reflects the shared nature of the bus, client software (CSw) manipulating a USB function interface is presented with the view that it deals only with its interface(s) of interest. Client software for USB functions must use USB software programming interfaces to manipulate their functions as opposed to directly manipulating their functions via memory or I/O accesses as with other buses (e.g., PCI, EISA, PCMCIA, etc.). During operation, client software should be independent of other devices that may be connected to the USB. This allows the designer of the device and client software to focus on the hardware/software interaction design details. Figure 5-8 illustrates a device designer's perspective of the relationships of client software and USB functions with respect to the USB logical topology of Figure 5-7. Figure 5-8. Client Software-to-function Relationships #### 5.3 USB Communication Flow The USB provides a communication service between software on the host and its USB function. Functions can have different communication flow requirements for different client-to-function interactions. The USB provides better overall bus utilization by allowing the separation of the different communication flows to a USB function. Each communication flow makes use of some bus access to accomplish communication between client and function. Each communication flow is terminated at an endpoint on a device. Device endpoints are used to identify aspects of each communication flow. Figure 5-9 shows a more detailed view of Figure 5-2. The complete definition of the actual communication flows of Figure 5-2 supports the logical device and function layer communication flows. These actual communication flows cross several interface boundaries. Chapters 6 through 8 describe the mechanical, electrical, and protocol interface definitions of the USB "wire." Chapter 9 describes the USB device programming interface that allows a USB device to be manipulated from the host side of the wire. Chapter 10 describes two host side software interfaces: - Host Controller Driver (HCD): The software interface between the USB Host Controller and USB System Software. This interface allows a range of Host Controller implementations without requiring all host software to be dependent on any particular implementation. One USB Driver can support different Host Controllers without requiring specific knowledge of a Host Controller implementation. A Host Controller implementer provides an HCD implementation that supports the Host Controller. - USB Driver (USBD): The interface between the USB System Software and the client software. This interface provides clients with convenient functions for manipulating USB devices. Figure 5-9. USB Host/Device Detailed View A USB logical device appears to the USB system as a collection of endpoints. Endpoints are grouped into endpoint sets that implement an interface. Interfaces are views to the function. The USB System Software manages the device using the Default Control Pipe. Client software manages an interface using pipe bundles (associated with an endpoint set). Client software requests that data be moved across the USB between a buffer on the host and an endpoint on the USB device. The Host Controller (or USB device, depending on transfer direction) packetizes the data to move it over the USB. The Host Controller also coordinates when bus access is used to move the packet of data over the USB. Figure 5-10 illustrates how communication flows are carried over pipes between endpoints and host side memory buffers. The following sections describe endpoints, pipes, and communication flows in more detail. Figure 5-10. USB Communication Flow Software on the host communicates with a logical device via a set of communication flows. The set of communication flows are selected by the device software/hardware designer(s) to efficiently match the communication requirements of the device to the transfer characteristics provided by the USB. # 5.3.1 Device Endpoints An endpoint is a uniquely identifiable portion of a USB device that is the terminus of a communication flow between the host and device. Each USB logical device is composed of a collection of independent endpoints. Each logical device has a unique address assigned by the system at device attachment time. Each endpoint on a device is given at design time a unique device-determined identifier called the endpoint number. Each endpoint has a device-determined direction of data flow. The combination of the device address, endpoint number, and direction allows each endpoint to be uniquely referenced. Each endpoint is a simplex connection that supports data flow in one direction: either input (from device to host) or output (from host to device). An endpoint has characteristics that determine the type of transfer service required between the endpoint and the client software. An endpoint describes itself by: - · Bus access frequency/latency requirement - Bandwidth requirement - Endpoint number - · Error handling behavior requirements - Maximum packet size that the endpoint is capable of sending or receiving - The transfer type for the endpoint (refer to Section 5.4 for details) - . The direction in which data is transferred between the endpoint and the host Endpoints other than those with endpoint number zero are in an unknown state before being configured and may not be accessed by the host before being configured. # 5.3.1.1 Endpoint Zero Requirements All USB devices are required to implement a default control method that uses both the input and output endpoints with endpoint number zero. The USB System Software uses this default control method to initialize and generically manipulate the logical device (e.g., to configure the logical device) as the Default Control Pipe (see Section 5.3.2). The Default Control Pipe provides access to the device's configuration information and allows generic USB status and control access. The Default Control Pipe supports control transfers as defined in Section 5.5. The endpoints with endpoint number zero are always accessible once a device is attached, powered, and has received a bus reset. A USB device that is capable of operating at high-speed must have a minimum level of support for operating at full-speed. When the device is attached to a hub operating in full-speed, the device must: - Be able to reset successfully at full-speed - Respond successfully to standard requests: set\_address, set\_configuration, get\_descriptor for device and configuration descriptors, and return appropriate information The high-speed device may or may not be able to support its intended functionality when operating at full-speed. # 5.3.1.2 Non-endpoint Zero Requirements Functions can have additional endpoints as required for their implementation. Low-speed functions are limited to two optional endpoints beyond the two required to implement the Default Control Pipe. Full-speed devices can have additional endpoints only limited by the protocol definition (i.e., a maximum of 15 additional input endpoints and 15 additional output endpoints). Endpoints other than those for the Default Control Pipe cannot be used until the device is configured as a normal part of the device configuration process (refer to Chapter 9). # **5.3.2 Pipes** A USB pipe is an association between an endpoint on a device and software on the host. Pipes represent the ability to move data between software on the host via a memory buffer and an endpoint on a device. There are two mutually exclusive pipe communication modes: - Stream: Data moving through a pipe has no USB-defined structure - · Message: Data moving through a pipe has some USB-defined structure The USB does not interpret the content of data it delivers through a pipe. Even though a message pipe requires that data be structured according to USB definitions, the content of the data is not interpreted by the USB. Additionally, pipes have the following associated with them: - A claim on USB bus access and bandwidth usage. - A transfer type. - The associated endpoint's characteristics, such as directionality and maximum data payload sizes. The data payload is the data that is carried in the data field of a data packet within a bus transaction (as defined in Chapter 8). The pipe that consists of the two endpoints with endpoint number zero is called the Default Control Pipe. This pipe is always available once a device is powered and has received a bus reset. Other pipes come into existence when a USB device is configured. The Default Control Pipe is used by the USB System Software to determine device identification and configuration requirements and to configure the device. The Default Control Pipe can also be used by device-specific software after the device is configured. The USB System Software retains "ownership" of the Default Control Pipe and mediates use of the pipe by other client software. A software client normally requests data transfers via I/O Request Packets (IRPs) to a pipe and then either waits or is notified when they are completed. Details about IRPs are defined in an operating system-specific manner. This specification uses the term to simply refer to an identifiable request by a software client to move data between itself (on the host) and an endpoint of a device in an appropriate direction. A software client can cause a pipe to return all outstanding IRPs if it desires. The software client is notified that an IRP has completed when the bus transactions associated with it have completed either successfully or due to errors. If there are no IRPs pending or in progress for a pipe, the pipe is idle and the Host Controller will take no action with regard to the pipe; i.e., the endpoint for such a pipe will not see any bus transactions directed to it. The only time bus activity is present for a pipe is when IRPs are pending for that pipe. If a non-isochronous pipe encounters a condition that causes it to send a STALL to the host (refer to Chapter 8) or three bus errors are encountered on any packet of an IRP, the IRP is aborted/retired, all outstanding IRPs are also retired, and no further IRPs are accepted until the software client recovers from the condition (in an implementation-dependent way) and acknowledges the halt or error condition via a USBD call. An appropriate status informs the software client of the specific IRP result for error versus halt (refer to Chapter 10). Isochronous pipe behavior is described in Section 5.6. An IRP may require multiple data payloads to move the client data over the bus. The data payloads for such a multiple data payload IRP are expected to be of the maximum packet size until the last data payload that contains the remainder of the overall IRP. See the description of each transfer type for more details. For such an IRP, short packets (i.e., less than maximum-sized data payloads) on input that do not completely fill an IRP data buffer can have one of two possible meanings, depending upon the expectations of a client: - A client can expect a variable-sized amount of data in an IRP. In this case, a short packet that does not fill an IRP data buffer can be used simply as an in-band delimiter to indicate "end of unit of data." The IRP should be retired without error and the Host Controller should advance to the next IRP. - A client can expect a specific-sized amount of data. In this case, a short packet that does not fill an IRP data buffer is an indication of an error. The IRP should be retired, the pipe should be stalled, and any pending IRPs associated with the pipe should also be retired. Because the Host Controller must behave differently in the two cases and cannot know on its own which way to behave for a given IRP; it is possible to indicate per IRP which behavior the client desires. An endpoint can inform the host that it is busy by responding with NAK. NAKs are not used as a retire condition for returning an IRP to a software client. Any number of NAKs can be encountered during the processing of a given IRP. A NAK response to a transaction does not constitute an error and is not counted as one of the three errors described above. ## 5.3.2.1 Stream Pipes Stream pipes deliver data in the data packet portion of bus transactions with no USB-required structure on the data content. Data flows in at one end of a stream pipe and out the other end in the same order. Stream pipes are always uni-directional in their communication flow. Data flowing through a stream pipe is expected to interact with what the USB believes is a single client. The USB System Software is not required to provide synchronization between multiple clients that may be using the same stream pipe. Data presented to a stream pipe is moved through the pipe in sequential order: first-in, first-out. A stream pipe to a device is bound to a single device endpoint number in the appropriate direction (i.e., corresponding to an IN or OUT token as defined by the protocol layer). The device endpoint number for the opposite direction can be used for some other stream pipe to the device. Stream pipes support bulk, isochronous, and interrupt transfer types, which are explained in later sections. # 5.3.2.2 Message Pipes Message pipes interact with the endpoint in a different manner than stream pipes. First, a request is sent to the USB device from the host. This request is followed by data transfer(s) in the appropriate direction. Finally, a Status stage follows at some later time. In order to accommodate the request/data/status paradigm, message pipes impose a structure on the communication flow that allows commands to be reliably identified and communicated. Message pipes allow communication flow in both directions, although the communication flow may be predominately one way. The Default Control Pipe is always a message pipe. The USB System Software ensures that multiple requests are not sent to a message pipe concurrently. A device is required to service only a single message request at a time per message pipe. Multiple software clients on the host can make requests via the Default Control Pipe, but they are sent to the device in a first-in, first-out order. A device can control the flow of information during the Data and Status stages based on its ability to respond to the host transactions (refer to Chapter 8 for more details). A message pipe will not normally be sent the next message from the host until the current message's processing at the device has been completed. However, there are error conditions whereby a message transfer can be aborted by the host and the message pipe can be sent a new message transfer prematurely (from the device's perspective). From the perspective of the software manipulating a message pipe, an error on some part of an IRP retires the current IRP and all queued IRPs. The software client that requested the IRP is notified of the IRP completion with an appropriate error indication. A message pipe to a device requires a single device endpoint number in both directions (IN and OUT tokens). The USB does not allow a message pipe to be associated with different endpoint numbers for each direction. Message pipes support the control transfer type, which is explained in Section 5.5. #### 5.3.3 Frames and Microframes USB establishes a 1 millisecond time base called a frame on a full-/low-speed bus and a 125 $\mu$ s time base called a microframe on a high-speed bus. A (micro)frame can contain several transactions. Each transfer type defines what transactions are allowed within a (micro)frame for an endpoint. Isochronous and interrupt endpoints are given opportunities to the bus every N (micro)frames. The values of N and other details about isochronous and interrupt transfers are described in Sections 5.6 and 5.7. ## 5.4 Transfer Types The USB transports data through a pipe between a memory buffer associated with a software client on the host and an endpoint on the USB device. Data transported by message pipes is carried in a USB-defined structure, but the USB allows device-specific structured data to be transported within the USB-defined message data payload. The USB also defines that data moved over the bus is packetized for any pipe (stream or message), but ultimately the formatting and interpretation of the data transported in the data payload of a bus transaction is the responsibility of the client software and function using the pipe. However, the USB provides different transfer types that are optimized to more closely match the service requirements of the client software and function using the pipe. An IRP uses one or more bus transactions to move information between a software client and its function. Each transfer type determines various characteristics of the communication flow including the following: - Data format imposed by the USB - Direction of communication flow - Packet size constraints - Bus access constraints - Latency constraints - Required data sequences - Error handling The designers of a USB device choose the capabilities for the device's endpoints. When a pipe is established for an endpoint, most of the pipe's transfer characteristics are determined and remain fixed for the lifetime of the pipe. Transfer characteristics that can be modified are described for each transfer type. The USB defines four transfer types: - Control Transfers: Bursty, non-periodic, host software-initiated request/response communication, typically used for command/status operations. - Isochronous Transfers: Periodic, continuous communication between host and device, typically used for time-relevant information. This transfer type also preserves the concept of time encapsulated in the data. This does not imply, however, that the delivery needs of such data is always time-critical. - · Interrupt Transfers: Low-frequency, bounded-latency communication. - Bulk Transfers: Non-periodic, large-packet bursty communication, typically used for data that can use any available bandwidth and can also be delayed until bandwidth is available. Each transfer type is described in detail in the following four major sections. The data for any IRP is carried by the data field of the data packet as described in Section 8.3.4. Chapter 8 also describes details of the protocol that are affected by use of each particular transfer type. ## 5.4.1 Table Calculation Examples The following sections describe each of the USB transfer types. In these sections, there are tables that illustrate the maximum number of transactions that can be expected to be contained in a (micro)frame. These tables can be used to determine the maximum performance behavior possible for a specific transfer type. Actual performance may vary with specific system implementation details. #### Each table shows: - The protocol overhead required for the specific transfer type (and speed) - For some sample data payload sizes: - o The maximum sustained bandwidth possible for this case - o The percentage of a (micro)frame that each transaction requires - The maximum number of transactions in a (micro)frame for the specific case - o The remaining bytes in a (micro)frame that would not be required for the specific case - o The total number of data bytes transported in a single (micro)frame for the specific case A transaction of a particular transfer type typically requires multiple packets. The protocol overhead for each transaction includes: - A SYNC field for each packet: either 8 bits (full-/low-speed) or 32 bits (high-speed) - A PID byte for each packet: includes PID and PID invert (check) bits - An EOP for each packet: 3 bits (full-/low-speed) or 8 bits (high-speed) - In a token packet, the endpoint number, device address, and CRC5 fields (16 bits total) - In a data packet, CRC16 fields (16 bits total) - In a data packet, any data field (8 bits per byte) - For transaction with multiple packets, the inter packet gap or bus turnaround time required. For these calculations, there is assumed to be no bit-stuffing required. Using the low speed interrupt OUT as an example, there are 5 packets in the transaction: - A PRE special packet - A token packet - A PRE special packet - A data packet - A handshake packet There is one bus turnaround between the data and handshake packets. The protocol overhead is therefore: 5 SYNC, 5 PID, Endpoint + CRC5, CRC16, 5 EOPs and interpacket delay (one bus turnaround, 1 delay between packets, and 2 hub setup times). #### 5.5 Control Transfers Control transfers allow access to different parts of a device. Control transfers are intended to support configuration/command/status type communication flows between client software and its function. A control transfer is composed of a Setup bus transaction moving request information from host to function, zero or more Data transactions sending data in the direction indicated by the Setup transaction, and a Status transaction returning status information from function to host. The Status transaction returns "success" when the endpoint has successfully completed processing the requested operation. Section 8.5.3 describes the details of what packets, bus transactions, and transaction sequences are used to accomplish a control transfer. Chapter 9 describes the details of the defined USB command codes. Each USB device is required to implement the Default Control Pipe as a message pipe. This pipe is used by the USB System Software. The Default Control Pipe provides access to the USB device's configuration, status, and control information. A function can, but is not required to, provide endpoints for additional control pipes for its own implementation needs. The USB device framework (refer to Chapter 9) defines standard, device class, or vendor-specific requests that can be used to manipulate a device's state. Descriptors are also defined that can be used to contain different information on the device. Control transfers provide the transport mechanism to access device descriptors and make requests of a device to manipulate its behavior. Control transfers are carried only through message pipes. Consequently, data flows using control transfers must adhere to USB data structure definitions as described in Section 5.5.1. The USB system will make a "best effort" to support delivery of control transfers between the host and devices. A function and its client software cannot request specific bus access frequency or bandwidth for control transfers. The USB System Software may restrict the bus access and bandwidth that a device may desire for control transfers. These restrictions are defined in Section 5.5.3 and Section 5.5.4. # 5.5.1 Control Transfer Data Format The Setup packet has a USB-defined structure that accommodates the minimum set of commands required to enable communication between the host and a device. The structure definition allows vendor-specific extensions for device specific commands. The Data transactions following Setup have a USB-defined structure except when carrying vendor-specific information. The Status transaction also has a USB-defined structure. Specific control transfer Setup/Data definitions are described in Section 8.5.3 and Chapter 9. #### 5.5.2 Control Transfer Direction Control transfers are supported via bi-directional communication flow over message pipes. As a consequence, when a control pipe is configured, it uses both the input and output endpoint with the specified endpoint number. #### 5.5.3 Control Transfer Packet Size Constraints An endpoint for control transfers specifies the maximum data payload size that the endpoint can accept from or transmit to the bus. The allowable maximum control transfer data payload sizes for full-speed devices is 8, 16, 32, or 64 bytes; for high-speed devices, it is 64 bytes and for low-speed devices, it is 8 bytes. This maximum applies to the data payloads of the Data packets following a Setup; i.e., the size specified is for the data field of the packet as defined in Chapter 8, not including other information that is required by the protocol. A Setup packet is always eight bytes. A control pipe (including the Default Control Pipe) always uses its wMaxPacketSize value for data payloads. An endpoint reports in its configuration information the value for its maximum data payload size. The USB does not require that data payloads transmitted be exactly the maximum size; i.e., if a data payload is less than the maximum, it does not need to be padded to the maximum size. All Host Controllers are required to have support for 8-, 16-, 32-, and 64-byte maximum data payload sizes for full-speed control endpoints, only 8-byte maximum data payload sizes for low-speed control endpoints, and only 64-byte maximum data payload size for high-speed control endpoints. No Host Controller is required to support larger or smaller maximum data payload sizes. In order to determine the maximum packet size for the Default Control Pipe, the USB System Software reads the device descriptor. The host will read the first eight bytes of the device descriptor. The device always responds with at least these initial bytes in a single packet. After the host reads the initial part of the device descriptor, it is guaranteed to have read this default pipe's wMaxPacketSize field (byte 7 of the device descriptor). It will then allow the correct size for all subsequent transactions. For all other control endpoints, the maximum data payload size is known after configuration so that the USB System Software can ensure that no data payload will be sent to the endpoint that is larger than the supported size. An endpoint must always transmit data payloads with a data field less than or equal to the endpoint's wMaxPacketSize (refer to Chapter 9). When a control transfer involves more data than can fit in one data payload of the currently established maximum size, all data payloads are required to be maximum-sized except for the last data payload, which will contain the remaining data. The Data stage of a control transfer from an endpoint to the host is complete when the endpoint does one of the following: - Has transferred exactly the amount of data specified during the Setup stage - Transfers a packet with a payload size less than wMaxPacketSize or transfers a zero-length packet When a Data stage is complete, the Host Controller advances to the Status stage instead of continuing on with another data transaction. If the Host Controller does not advance to the Status stage when the Data stage is complete, the endpoint halts the pipe as was outlined in Section 5.3.2. If a larger-than-expected data payload is received from the endpoint, the IRP for the control transfer will be aborted/retired. The Data stage of a control transfer from the host to an endpoint is complete when all of the data has been transferred. If the endpoint receives a larger-than-expected data payload from the host, it halts the pipe. ## 5.5.4 Control Transfer Bus Access Constraints Control transfers can be used by high-speed, full-speed, and low-speed USB devices. An endpoint has no way to indicate a desired bus access frequency for a control pipe. The USB balances the bus access requirements of all control pipes and the specific IRPs that are pending to provide "best effort" delivery of data between client software and functions. The USB requires that part of each (micro)frame be reserved to be available for use by control transfers as follows: - If the control transfers that are attempted (in an implementation-dependent fashion) consume less than 10% of the frame time for full-/low-speed endpoints or less than 20% of a microframe for high-speed endpoints, the remaining time can be used to support bulk transfers (refer to Section 5.8). - A control transfer that has been attempted and needs to be retried can be retried in the current or a future (micro)frame; i.e., it is not required to be retried in the same (micro)frame. - If there are more control transfers than reserved time, but there is additional (micro)frame time that is not being used for isochronous or interrupt transfers, a Host Controller may move additional control transfers as they are available. - If there are too many pending control transfers for the available (micro)frame time, control transfers are selected to be moved over the bus as appropriate. - If there are control transfers pending for multiple endpoints, control transfers for the different endpoints are selected according to a fair access policy that is Host Controller implementation-dependent. - A transaction of a control transfer that is frequently being retried should not be expected to consume an unfair share of the bus time. High-speed control endpoints must support the PING flow control protocol for OUT transactions. The details of this protocol are described in Section 8.5.1. These requirements allow control transfers between host and devices to be regularly moved over the bus with "best effort." The USB System Software can, at its discretion, vary the rate of control transfers to a particular endpoint. An endpoint and its client software cannot assume a specific rate of service for control transfers. A control endpoint may see zero or more transfers in a single (micro)frame. Bus time made available to a software client and its endpoint can be changed as other devices are inserted into and removed from the system or also as control transfers are requested for other device endpoints. The bus frequency and (micro)frame timing limit the maximum number of successful control transfers within a (micro)frame for any USB system. For full-/low-speed buses, the number of successful control transfers per frame is limited to less than 29 full-speed eight-byte data payloads or less than four low-speed eight-byte data payloads. For high-speed buses, the number of control transfers is limited to less than 32 high-speed 64-byte data payloads per microframe. Table 5-1 lists information about different-sized low-speed packets and the maximum number of packets possible in a frame. The table does not include the overhead associated with bit stuffing. Table 5-1. Low-speed Control Transfer Limits | | Protocol Overhead (63 bytes) | | (15 SYNC bytes, 15 PID bytes, 6 Endpoint + CRC bytes, 6 CRC bytes, 8 Setup data bytes, and a 13-byte interpacket delay (EOP, etc.)) | | | | | |---|------------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------|----------------------------|--| | | Data<br>Payload | Max Bandwidth<br>(bytes/second) | Frame<br>Bandwidth<br>per<br>Transfer | Max<br>Transfers | Bytes<br>Remaining | Bytes/Frame<br>Useful Data | | | ľ | 1 | 3000 | 26% | 3 | 40 | 3 | | | ľ | 2 | 6000 | 27% | 3 | 37 | 6 | | | ľ | 4 | 12000 | 28% | 3 | 31 | 12 | | | | 8 | 24000 | 30% | 3 | 19 | 24 | | | T | | 187500 | | | | 187 | | For all speeds, because a control transfer is composed of several packets, the packets can be spread over several (micro)frames to spread the bus time required across several (micro)frames. The 10% frame reservation for full-/low-speed non-periodic transfers means that in a system with bus time fully allocated, all full-speed control transfers in the system contend for a nominal three control transfers per frame. Because the USB system uses control transfers for configuration purposes in addition to whatever other control transfers other client software may be requesting, a given software client and its function should not expect to be able to make use of this full bandwidth for its own control purposes. Host Controllers are also free to determine how the individual bus transactions for specific control transfers are moved over the bus within and across frames. An endpoint could see all bus transactions for a control transfer within the same frame or spread across several noncontiguous frames. A Host Controller, for various implementation reasons, may not be able to provide the theoretical maximum number of control transfers per frame. For high-speed endpoints, the 20% microframe reservation for non-periodic transfers means that all high speed control transfers are contending for nominally six control transfers per microframe. High-speed control transfers contend for microframe time along with split-transactions (see Sections 11.15-11.21 for more information about split transactions) for full- and low-speed control transfers. Both full-speed and low-speed control transfers contend for the same available frame time. However, high-speed control transfers for some endpoints can occur simultaneously with full- and low-speed control transfers for other endpoints. Low-speed control transfers simply take longer to transfer. Table 5-2 lists information about different-sized full-speed control transfers and the maximum number of transfers possible in a frame. This table was generated assuming that there is one Data stage transaction and that the Data stage has a zero-length status phase. The table illustrates the possible power of two data payloads less than or equal to the allowable maximum data payload sizes. The table does not include the overhead associated with bit stuffing. Table 5-2. Full-speed Control Transfer Limits | | Protocol Overhead (45 bytes) | | (9 SYNC bytes, 9 PID bytes, 6 Endpoint + CRC bytes, 6 CRC bytes, 8 Setup data bytes, and a 7-byte interpacket delay (EOP, etc.)) | | | | | |---|------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------|----------------------------|--| | | Data<br>Payload | Max Bandwidth (bytes/second) | Frame<br>Bandwidth<br>per<br>Transfer | Max<br>Transfers | Bytes<br>Remaining | Bytes/Frame<br>Useful Data | | | | 1 | 32000 | 3% | 32 | 23 | 32 | | | | 2 | 62000 | 3% | 31 | 43 | 62 | | | | 4 | 120000 | 3% | 30 | 30 | 120 | | | ľ | 8 | 224000 | 4% | 28 | 16 | 224 | | | | 16 | 384000 | 4% | 24 | 36 | 384 | | | | 32 | 608000 | 5% | 19 | 37 | 608 | | | | 64 | 832000 | 7% | 13 | 83 | 832 | | | T | | 1500000 | | | | 1500 | | Table 5-3 lists information about different-sized high-speed control transfers and the maximum number of transfers possible in a microframe. This table was generated assuming that there is one Data stage transaction and that the Data stage has a zero-length status stage. The table illustrates the possible power of two data payloads less than or equal to the allowable maximum data payload size. The table does not include the overhead associated with bit stuffing. Table 5-3. High-speed Control Transfer Limits | - 1 | Protocol Overhead<br>(173 bytes) | | (Based on 480Mb/s and 8 bit interpacket gap, 88 bit min bus turnaround, 32 bit sync, 8 bit EOP: (9x4 SYNC bytes, 9 PID bytes, 6 EP/ADDR+CRC,6 CRC16, 8 Setup data, 9x(1+11) byte interpacket delay (EOP, etc.)) | | | | | |-----|----------------------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------|-------------------------------------|--| | | Data<br>Payload | Max Bandwidth<br>(bytes/second) | Microframe<br>Bandwidth<br>per Transfer | Max<br>Transfers | Bytes<br>Remaining | Bytes/<br>Microframe<br>Useful Data | | | | 1 | 344000 | 2% | 43 | 18 | 43 | | | | 2 | 672000 | 2% | 42 | 150 | 84 | | | | 4 | 1344000 | 2% | 42 | 66 | 168 | | | | 8 | 2624000 | 2% | 41 | 79 | 328 | | | | 16 | 4992000 | 3% | 39 | 129 | 624 | | | | 32 | 9216000 | 3% | 36 | 120 | 1152 | | | | 64 | 15872000 | 3% | 31 | 153 | 1984 | | | Τ | | 60000000 | | | | 7500 | | ## 5.5.5 Control Transfer Data Sequences Control transfers require that a Setup bus transaction be sent from the host to a device to describe the type of control access that the device should perform. The Setup transaction is followed by zero or more control Data transactions that carry the specific information for the requested access. Finally, a Status transaction completes the control transfer and allows the endpoint to return the status of the control transfer to the client software. After the Status transaction for a control transfer is completed, the host can advance to the next control transfer for the endpoint. As described in Section 5.5.4, each control transaction and the next control transfer will be moved over the bus at some Host Controller implementation-defined time. The endpoint can be busy for a device-specific time during the Data and Status transactions of the control transfer. During these times when the endpoint indicates it is busy (refer to Chapter 8 and Chapter 9 for details), the host will retry the transaction at a later time. If a Setup transaction is received by an endpoint before a previously initiated control transfer is completed, the device must abort the current transfer/operation and handle the new control Setup transaction. A Setup transaction should not normally be sent before the completion of a previous control transfer. However, if a transfer is aborted, for example, due to errors on the bus, the host can send the next Setup transaction prematurely from the endpoint's perspective. After a halt condition is encountered or an error is detected by the host, a control endpoint is allowed to recover by accepting the next Setup PID; i.e., recovery actions via some other pipe are not required for control endpoints. For the Default Control Pipe, a device reset will ultimately be required to clear the halt or error condition if the next Setup PID is not accepted. The USB provides robust error detection and recovery/retransmission for errors that occur during control transfers. Transmitters and receivers can remain synchronized with regard to where they are in a control transfer and recover with minimum effort. Retransmission of Data and Status packets can be detected by a receiver via data retry indicators in the packet. A transmitter can reliably determine that its corresponding receiver has successfully accepted a transmitted packet by information returned in a handshake to the packet. The protocol allows for distinguishing a retransmitted packet from its original packet except for a control Setup packet. Setup packets may be retransmitted due to a transmission error; however, Setup packets cannot indicate that a packet is an original or a retried transmission. ### 5.6 Isochronous Transfers In non-USB environments, isochronous transfers have the general implication of constant-rate, errortolerant transfers. In the USB environment, requesting an isochronous transfer type provides the requester with the following: - Guaranteed access to USB bandwidth with bounded latency - Guaranteed constant data rate through the pipe as long as data is provided to the pipe - In the case of a delivery failure due to error, no retrying of the attempt to deliver the data While the USB isochronous transfer type is designed to support isochronous sources and destinations, it is not required that software using this transfer type actually be isochronous in order to use the transfer type. Section 5.12 presents more detail on special considerations for handling isochronous data on the USB. #### 5.6.1 Isochronous Transfer Data Format The USB imposes no data content structure on communication flows for isochronous pipes. #### 5.6.2 Isochronous Transfer Direction An isochronous pipe is a stream pipe and is, therefore, always uni-directional. An endpoint description identifies whether a given isochronous pipe's communication flow is into or out of the host. If a device requires bi-directional isochronous communication flow, two isochronous pipes must be used, one in each direction. #### 5.6.3 Isochronous Transfer Packet Size Constraints An endpoint in a given configuration for an isochronous pipe specifies the maximum size data payload that it can transmit or receive. The USB System Software uses this information during configuration to ensure that there is sufficient bus time to accommodate this maximum data payload in each (micro)frame. If there is sufficient bus time for the maximum data payload, the configuration is established; if not, the configuration is not established. The USB limits the maximum data payload size to 1,023 bytes for each full-speed isochronous endpoint. High-speed endpoints are allowed up to 1024-byte data payloads. A high speed, high bandwidth endpoint specifies whether it requires two or three transactions per microframe. Table 5-4 lists information about different-sized full-speed isochronous transactions and the maximum number of transactions possible in a frame. The table is shaded to indicate that a full-speed isochronous endpoint (with a non-zero wMaxpacket size) must not be part of a default interface setting. The table does not include the overhead associated with bit stuffing. Table 5-4. Full-speed Isochronous Transaction Limits | Protocol Overhead (9 bytes) | | (2 SYNC bytes, 2 PID bytes, 2 Endpoint + CRC bytes, 2 CRC bytes, and a 1-byte interpacket delay) | | | | | |-----------------------------|-------------|--------------------------------------------------------------------------------------------------|------------------------------------|------------------|--------------------|----------------------------| | 1000 | ata<br>load | Max<br>Bandwidth(bytes/<br>second) | Frame<br>Bandwidth<br>per Transfer | Max<br>Transfers | Bytes<br>Remaining | Bytes/Frame<br>Useful Data | | | 1 | 150000 | 1% | 150 | 0 | 150 | | | 2 | 272000 | 1% | 136 | 4 | 272 | | | 4 | 460000 | 1% | 115 | 5 | 460 | | | 8 | 704000 | 1% | 88 | 4 | 704 | | | 16 | 960000 | 2% | 60 | 0 | 960 | | | 32 | 1152000 | 3% | 36 | 24 | 1152 | | | 64 | 1280000 | 5% | 20 | 40 | 1280 | | | 128 | 1280000 | 9% | 10 | 130 | 1280 | | | 256 | 1280000 | 18% | 5 | 175 | 1280 | | | 512 | 1024000 | 35% | 2 | 458 | 1024 | | | 1023 | 1023000 | 69% | 1 | 468 | 1023 | | | | 1500000 | | | | 1500 | Table 5-5 lists information about different-sized high-speed isochronous transactions and the maximum number of transactions possible in a microframe. The table is shaded to indicate that a high-speed isochronous endpoint must not be part of a default interface setting. The table does not include the overhead associated with bit stuffing. Any given transaction for an isochronous pipe need not be exactly the maximum size specified for the endpoint. The size of a data payload is determined by the transmitter (client software or function) and can vary as required from transaction to transaction. The USB ensures that whatever size is presented to the Host Controller is delivered on the bus. The actual size of a data payload is determined by the data transmitter and may be less than the prenegotiated maximum size. Bus errors can change the actual packet size seen by the receiver. However, these errors can be detected by either CRC on the data or by knowledge the receiver has about the expected size for any transaction. Table 5-5. High-speed Isochronous Transaction Limits | Protocol Overhead | | (Based on 480Mb/s and 8 bit interpacket gap, 88 bit min bu turnaround, 32 bit sync, 8 bit EOP: (2x4 SYNC bytes, 2 PID bytes, 2 EP/ADDR+addr+CRC5, 2 CRC16, and a 2x(1+11) byte interpacket delay (EOP, etc.)) | | | | | |-------------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------|-------------------------------------|--| | Data<br>Payload | Max<br>Bandwidth<br>(bytes/second) | Microframe<br>Bandwidth<br>per Transfer | Max<br>Transfers | Bytes<br>Remaining | Bytes/<br>MicroFrame<br>Useful Data | | | 1 | 1536000 | 1% | 192 | 12 | 192 | | | 2 | 2992000 | 1% | 187 | 20 | 374 | | | 4 | 5696000 | 1% | 178 | 24 | 712 | | | 8 | 10432000 | 1% | 163 | 2 | 1304 | | | 16 | 17664000 | 1% | 138 | 48 | 2208 | | | 32 | 27392000 | 1% | 107 | 10 | 3424 | | | 64 | 37376000 | 1% | 73 | 54 | 4672 | | | 128 | 46080000 | 2% | 45 | 30 | 5760 | | | 256 | 51200000 | 4% | 25 | 150 | 6400 | | | 512 | 53248000 | 7% | 13 | 350 | 6656 | | | 1024 | 57344000 | 14% | 7 | 66 | 7168 | | | 2048 | 49152000 | 28% | 3 | 1242 | 6144 | | | 3072 | 49152000 | 41% | 2 | 1280 | 6144 | | | | 60000000 | | | | 7500 | | Max All device default interface settings must not include any isochronous endpoints with non-zero data payload sizes (specified via wMaxPacketSize in the endpoint descriptor). Alternate interface settings may specify non-zero data payload sizes for isochronous endpoints. If the isochronous endpoints have a large data payload size, it is recommended that additional alternate configurations or interface settings be used to specify a range of data payload sizes. This increases the chance that the device can be used successfully in combination with other USB devices. #### 5.6.4 Isochronous Transfer Bus Access Constraints Isochronous transfers can only be used by full-speed and high-speed devices. The USB requires that no more than 90% of any frame be allocated for periodic (isochronous and interrupt) transfers for full-speed endpoints. High-speed endpoints can allocate at most 80% of a microframe for periodic transfers. An isochronous endpoint must specify its required bus access period. Full-/high-speed endpoints must specify a desired period as $(2^{\text{binterval-1}}) \times F$ , where bInterval is in the range one to (and including) 16 and F is 125 µs for high-speed and 1ms for full-speed. This allows full-/high-speed isochronous transfers to have rates slower than one transaction per (micro)frame. However, an isochronous endpoint must be prepared to handle poll rates faster than the one specified. A host must not issue more than 1 transaction in a (micro)frame for an isochronous endpoint unless the endpoint is high-speed, high-bandwidth (see below). An isochronous IN endpoint must return a zero-length packet whenever data is requested at a faster interval than the specified interval and data is not available. A high-speed endpoint can move up to 3072 bytes per microframe (or 192 Mb/s). A high-speed isochronous endpoint that requires more than 1024 bytes per period is called a high-bandwidth endpoint. A high-bandwidth endpoint uses multiple transactions per microframe. A high-bandwidth endpoint must specify a period of 1x125 µs (i.e., a bInterval value of 1). See Section 5.9 for more information about the details of multiple transactions per microframe for high-bandwidth high-speed endpoints. Errors on the bus or delays in operating system scheduling of client software can result in no packet being transferred for a (micro)frame. An error indication should be returned as status to the client software in such a case. A device can also detect this situation by tracking SOF tokens and noticing a disturbance in the specified bus access period pattern. The bus frequency and (micro)frame timing limit the maximum number of successful isochronous transactions within a (micro)frame for any USB system to less than 151 full-speed one-byte data payloads and less than 193 high-speed one-byte data payloads. A Host Controller, for various implementation reasons, may not be able to provide the theoretical maximum number of isochronous transactions per (micro)frame. ## 5.6.5 Isochronous Transfer Data Sequences Isochronous transfers do not support data retransmission in response to errors on the bus. A receiver can determine that a transmission error occurred. The low-level USB protocol does not allow handshakes to be returned to the transmitter of an isochronous pipe. Normally, handshakes would be returned to tell the transmitter whether a packet was successfully received or not. For isochronous transfers, timeliness is more important than correctness/retransmission, and, given the low error rates expected on the bus, the protocol is optimized by assuming transfers normally succeed. Isochronous receivers can determine whether they missed data during a (micro)frame. Also, a receiver can determine how much data was lost. Section 5.12 describes these USB mechanisms in more detail. An endpoint for isochronous transfers never halts because there is no handshake to report a halt condition. Errors are reported as status associated with the IRP for an isochronous transfer, but the isochronous pipe is not halted in an error case. If an error is detected, the host continues to process the data associated with the next (micro)frame of the transfer. Only limited error detection is possible because the protocol for isochronous transactions does not allow per-transaction handshakes. ## 5.7 Interrupt Transfers The interrupt transfer type is designed to support those devices that need to send or receive data infrequently but with bounded service periods. Requesting a pipe with an interrupt transfer type provides the requester with the following: - Guaranteed maximum service period for the pipe - Retry of transfer attempts at the next period, in the case of occasional delivery failure due to error on the bus ## 5.7.1 Interrupt Transfer Data Format The USB imposes no data content structure on communication flows for interrupt pipes. ## 5.7.2 Interrupt Transfer Direction An interrupt pipe is a stream pipe and is therefore always uni-directional. An endpoint description identifies whether a given interrupt pipe's communication flow is into or out of the host. ## 5.7.3 Interrupt Transfer Packet Size Constraints An endpoint for an interrupt pipe specifies the maximum size data payload that it will transmit or receive. The maximum allowable interrupt data payload size is 64 bytes or less for full-speed. High-speed endpoints are allowed maximum data payload sizes up to 1024 bytes. A high speed, high bandwidth endpoint specifies whether it requires two or three transactions per microframe. Low-speed devices are limited to eight bytes or less maximum data payload size. This maximum applies to the data payloads of the data packets; i.e., the size specified is for the data field of the packet as defined in Chapter 8, not including other protocol-required information. The USB does not require that data packets be exactly the maximum size; i.e., if a data packet is less than the maximum, it does not need to be padded to the maximum size. All Host Controllers are required to support maximum data payload sizes from 0 to 64 bytes for full-speed interrupt endpoints, from 0 to 8 bytes for low-speed interrupt endpoints, and from 0 to 1024 bytes for high-speed interrupt endpoints. See Section 5.9 for more information about the details of multiple transactions per microframe for high bandwidth high-speed endpoints. No Host Controller is required to support larger maximum data payload sizes. The USB System Software determines the maximum data payload size that will be used for an interrupt pipe during device configuration. This size remains constant for the lifetime of a device's configuration. The USB System Software uses the maximum data payload size determined during configuration to ensure that there is sufficient bus time to accommodate this maximum data payload in its assigned period. If there is sufficient bus time, the pipe is established; if not, the pipe is not established. However, the actual size of a data payload is still determined by the data transmitter and may be less than the maximum size. An endpoint must always transmit data payloads with a data field less than or equal to the endpoint's wMaxPacketSize value. A device can move data via an interrupt pipe that is larger than wMaxPacketSize. A software client can accept this data via an IRP for the interrupt transfer that requires multiple bus transactions without requiring an IRP-complete notification per transaction. This can be achieved by specifying a buffer that can hold the desired data size. The size of the buffer is a multiple of wMaxPacketSize with some remainder. The endpoint must transfer each transaction except the last as wMaxPacketSize and the last transaction is the remainder. The multiple data transactions are moved over the bus at the period established for the pipe. When an interrupt transfer involves more data than can fit in one data payload of the currently established maximum size, all data payloads are required to be maximum-sized except for the last data payload, which will contain the remaining data. An interrupt transfer is complete when the endpoint does one of the following: - Has transferred exactly the amount of data expected - Transfers a packet with a payload size less than wMaxPacketSize or transfers a zero-length packet When an interrupt transfer is complete, the Host Controller retires the current IRP and advances to the next IRP. If a data payload is received that is larger than expected, the interrupt IRP will be aborted/retired and the pipe will stall future IRPs until the condition is corrected and acknowledged. All high-speed device default interface settings must not include any interrupt endpoints with a data payload size (specified via wMaxPacketSize in the endpoint descriptor) greater than 64 bytes. Alternate interface settings may specify larger data payload sizes for interrupt endpoints. If the interrupt endpoints have a large data payload size, it is recommended that additional configurations or alternate interface settings be used to specify a range of data payload sizes. This increases the chances that the device can be used successfully in combination with other USB devices. ## 5.7.4 Interrupt Transfer Bus Access Constraints Interrupt transfers can be used by low-speed, full-speed, and high-speed devices. High-speed endpoints can be allocated at most 80% of a microframe for periodic transfers. The USB requires that no more than 90% of any frame be allocated for periodic (isochronous and interrupt) full-/low-speed transfers. The bus frequency and (micro)frame timing limit the maximum number of successful interrupt transactions within a (micro)frame for any USB system to less than 108 full-speed one-byte data payloads, or less than 10 low-speed one-byte data payloads, or to less than 134 high-speed one-byte data payloads. A Host Controller, for various implementation reasons, may not be able to provide the above maximum number of interrupt transactions per (micro)frame. Table 5-6 lists information about different low-speed interrupt transactions and the maximum number of transactions possible in a frame. Table 5-7 lists similar information for full-speed interrupt transactions. Table 5-8 lists similar information for high-speed interrupt transactions. The shaded portion of Table 5-8 indicates the data payload sizes of a high-speed interrupt endpoint that must not be part of a default interface setting. The tables do not include the overhead associated with bit stuffing. Table 5-6. Low-speed Interrupt Transaction Limits | Protocol<br>(19 bytes | Overhead<br>) | (5 SYNC bytes, 5<br>2 CRC bytes, and | | | bytes, | |-----------------------|---------------------------------|--------------------------------------|------------------|--------------------|----------------------------| | Data<br>Payload | Max Bandwidth<br>(bytes/second) | Frame<br>Bandwidth<br>per Transfer | Max<br>Transfers | Bytes<br>Remaining | Bytes/Frame<br>Useful Data | | 1 | 9000 | 11% | 9 | 7 | 9 | | 2 | 16000 | 11% | 8 | 19 | 16 | | 4 | 32000 | 12% | 8 | 3 | 32 | | 8 | 48000 | 14% | 6 | 25 | 48 | | | 187500 | | | | 187 | Table 5-7. Full-speed Interrupt Transaction Limits | | | (3 SYNC bytes, 3 PID bytes, 2 Endpoint + CRC bytes, 2 CRC bytes, and a 3-byte interpacket delay) | | | | | |---|-----------------|--------------------------------------------------------------------------------------------------|------------------------------------|------------------|--------------------|----------------------------| | | Data<br>Payload | Max<br>Bandwidth<br>(bytes/second) | Frame<br>Bandwidth<br>per Transfer | Max<br>Transfers | Bytes<br>Remaining | Bytes/Frame<br>Useful Data | | | 1 | 107000 | 1% | 107 | 2 | 107 | | ſ | 2 | 200000 | 1% | 100 | 0 | 200 | | ſ | 4 | 352000 | 1% | 88 | 4 | 352 | | | 8 | 568000 | 1% | 71 | 9 | 568 | | | 16 | 816000 | 2% | 51 | 21 | 816 | | | 32 | 1056000 | 3% | 33 | 15 | 1056 | | | 64 | 1216000 | 5% | 19 | 37 | 1216 | | T | | 1500000 | | | | 1500 | Table 5-8. High-speed Interrupt Transaction Limits | | l i | | (Based on 480Mb/s and 8 bit interpacket gap, 88 bit min bus turnaround, 32 bit sync, 8 bit EOP: (3x4 SYNC bytes, 3 PID bytes, 2 EP/ADDR+CRC bytes, 2 CRC16 and a 3x(1+11) byte interpacket delay(EOP, etc.)) | | | | |--------------------------|-----------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------|-------------------------------------| | | Data<br>Payload | Max<br>Bandwidth<br>(bytes/second) | Microframe<br>Bandwidth<br>per Transfer | Max<br>Transfers | Bytes<br>Remaining | Bytes/<br>Microframe<br>Useful Data | | | 1 | 1064000 | 1% | 133 | 52 | 133 | | | 2 | 2096000 | 1% | 131 | 33 | 262 | | | 4 | 4064000 | 1% | 127 | 7 | 508 | | | 8 | 7616000 | 1% | 119 | 3 | 952 | | | 16 | 13440000 | 1% | 105 | 45 | 1680 | | | 32 | 22016000 | 1% | 86 | 18 | 2752 | | | 64 | 32256000 | 2% | 63 | 3 | 4032 | | SECONDARISMON SECONDARIA | 128 | 40960000 | 2% | 40 | 180 | 5120 | | CONTRACTOR | 256 | 49152000 | 4% | 24 | 36 | 6144 | | A SECTION SECTION | 512 | 53248000 | 8% | 13 | 129 | 6656 | | TO CONTRACT | 1024 | 49152000 | 14% | 6 | 1026 | 6144 | | | 2048 | 49152000 | 28% | 3 | 1191 | 6144 | | | 3072 | 49152000 | 42% | 2 | 1246 | 6144 | | Ī | | 60000000 | | | | 7500 | An endpoint for an interrupt pipe specifies its desired bus access period. A full-speed endpoint can specify a desired period from 1 ms to 255 ms. Low-speed endpoints are limited to specifying only 10 ms to 255 ms. High-speed endpoints can specify a desired period (2<sup>bloterval-1</sup>)x125 µs, where *bInterval* is in the range 1 to (including) 16. The USB System Software will use this information during configuration to determine a period that can be sustained. The period provided by the system may be shorter than that desired by the device up to the shortest period defined by the USB (125 µs microframe or 1 ms frame). The client software and device can depend only on the fact that the host will ensure that the time duration between two transaction attempts with the endpoint will be no longer than the desired period. Note that errors on the bus can prevent an interrupt transaction from being successfully delivered over the bus and consequently exceed the desired period. Also, the endpoint is only polled when the software client has an IRP for an interrupt transfer pending. If the bus time for performing an interrupt transfer arrives and there is no IRP pending, the endpoint will not be given an opportunity to transfer data at that time. Once an IRP is available, its data will be transferred at the next allocated period. A high-speed endpoint can move up to 3072 bytes per microframe (or 192 Mb/s). A high-speed interrupt endpoint that requires more than 1024 bytes per period is called a high-bandwidth endpoint. A high-bandwidth endpoint uses multiple transactions per microframe. A high-bandwidth endpoint must specify a period of 1x125 µs (i.e., a bInterval value of 1). See Section 5.9 for more information about the details of multiple transactions per microframe for high-bandwidth high-speed endpoints. Interrupt transfers are moved over the USB by accessing an interrupt endpoint every specified period. For input interrupt endpoints, the host has no way to determine whether an endpoint will source an interrupt without accessing the endpoint and requesting an interrupt transfer. If the endpoint has no interrupt data to transmit when accessed by the host, it responds with NAK. An endpoint should only provide interrupt data when it has an interrupt pending to avoid having a software client erroneously notified of IRP complete. A zero-length data payload is a valid transfer and may be useful for some implementations. ## 5.7.5 Interrupt Transfer Data Sequences Interrupt transactions may use either alternating data toggle bits, such that the bits are toggled only upon successful transfer completion or a continuously toggling of data toggle bits. The host in any case must assume that the device is obeying full handshake/retry rules as defined in Chapter 8. A device may choose to always toggle DATA0/DATA1 PIDs so that it can ignore handshakes from the host. However, in this case, the client software can miss some data packets when an error occurs, because the Host Controller interprets the next packet as a retry of a missed packet. If a halt condition is detected on an interrupt pipe due to transmission errors or a STALL handshake being returned from the endpoint, all pending IRPs are retired. Removal of the halt condition is achieved via software intervention through a separate control pipe. This recovery will reset the data toggle bit to DATA0 for the endpoint on both the host and the device. Interrupt transactions are retried due to errors detected on the bus that affect a given transfer. ### 5.8 Bulk Transfers The bulk transfer type is designed to support devices that need to communicate relatively large amounts of data at highly variable times where the transfer can use any available bandwidth. Requesting a pipe with a bulk transfer type provides the requester with the following: - Access to the USB on a bandwidth-available basis - · Retry of transfers, in the case of occasional delivery failure due to errors on the bus - · Guaranteed delivery of data but no guarantee of bandwidth or latency Bulk transfers occur only on a bandwidth-available basis. For a USB with large amounts of free bandwidth, bulk transfers may happen relatively quickly; for a USB with little bandwidth available, bulk transfers may trickle out over a relatively long period of time. ### 5.8.1 Bulk Transfer Data Format The USB imposes no data content structure on communication flows for bulk pipes. ### 5.8.2 Bulk Transfer Direction A bulk pipe is a stream pipe and, therefore, always has communication flowing either into or out of the host for a given pipe. If a device requires bi-directional bulk communication flow, two bulk pipes must be used, one in each direction. #### 5.8.3 Bulk Transfer Packet Size Constraints An endpoint for bulk transfers specifies the maximum data payload size that the endpoint can accept from or transmit to the bus. The USB defines the allowable maximum bulk data payload sizes to be only 8, 16, 32, or 64 bytes for full-speed endpoints and 512 bytes for high-speed endpoints. A low-speed device must not have bulk endpoints. This maximum applies to the data payloads of the data packets; i.e., the size specified is for the data field of the packet as defined in Chapter 8, not including other protocol-required information. A bulk endpoint is designed to support a maximum data payload size. A bulk endpoint reports in its configuration information the value for its maximum data payload size. The USB does not require that data payloads transmitted be exactly the maximum size; i.e., if a data payload is less than the maximum, it does not need to be padded to the maximum size. All Host Controllers are required to have support for 8-, 16-, 32-, and 64-byte maximum packet sizes for full-speed bulk endpoints and 512 bytes for high-speed bulk endpoints. No Host Controller is required to support larger or smaller maximum packet sizes. During configuration, the USB System Software reads the endpoint's maximum data payload size and ensures that no data payload will be sent to the endpoint that is larger than the supported size. An endpoint must always transmit data payloads with a data field less than or equal to the endpoint's reported wMaxPacketSize value. When a bulk IRP involves more data than can fit in one maximum-sized data payload, all data payloads are required to be maximum size except for the last data payload, which will contain the remaining data. A bulk transfer is complete when the endpoint does one of the following: - Has transferred exactly the amount of data expected - Transfers a packet with a payload size less than wMaxPacketSize or transfers a zero-length packet When a bulk transfer is complete, the Host Controller retires the current IRP and advances to the next IRP. If a data payload is received that is larger than expected, all pending bulk IRPs for that endpoint will be aborted/retired. ### 5.8.4 Bulk Transfer Bus Access Constraints Only full-speed and high-speed devices can use bulk transfers. An endpoint has no way to indicate a desired bus access frequency for a bulk pipe. The USB balances the bus access requirements of all bulk pipes and the specific IRPs that are pending to provide "good effort" delivery of data between client software and functions. Moving control transfers over the bus has priority over moving bulk transfers. There is no time guaranteed to be available for bulk transfers as there is for control transfers. Bulk transfers are moved over the bus only on a bandwidth-available basis. If there is bus time that is not being used for other purposes, bulk transfers will be moved over the bus. If there are bulk transfers pending for multiple endpoints, bulk transfers for the different endpoints are selected according to a fair access policy that is Host Controller implementation-dependent. All bulk transfers pending in a system contend for the same available bus time. Because of this, the USB System Software at its discretion can vary the bus time made available for bulk transfers to a particular endpoint. An endpoint and its client software cannot assume a specific rate of service for bulk transfers. Bus time made available to a software client and its endpoint can be changed as other devices are inserted into and removed from the system or also as bulk transfers are requested for other device endpoints. Client software cannot assume ordering between bulk and control transfers; i.e., in some situations, bulk transfers can be delivered ahead of control transfers. High-speed bulk OUT endpoints must support the PING flow control protocol. The details of this protocol are described in Section 8.5.1. The bus frequency and (micro)frame timing limit the maximum number of successful bulk transactions within a (micro)frame for any USB system to less than 72 full-speed eight-byte data payloads or less than 14 high-speed 512-byte data payloads. Table 5-9 lists information about different-sized full-speed bulk transactions and the maximum number of transactions possible in a frame. The table does not include the overhead associated with bit stuffing. Table 5-10 lists similar information for high-speed bulk transactions. Table 5-9. Full-speed Bulk Transaction Limits | Prot | | | (3 SYNC bytes, 3 PID bytes, 2 Endpoint + CRC bytes, 2 CRC bytes, and a 3-byte interpacket delay) | | | | |------------|----|------------------------------|--------------------------------------------------------------------------------------------------|------------------|--------------------|----------------------------| | Da<br>Payl | | Max Bandwidth (bytes/second) | Frame<br>Bandwidth<br>per Transfer | Max<br>Transfers | Bytes<br>Remaining | Bytes/Frame<br>Useful Data | | | 1 | 107000 | 1% | 107 | 2 | 107 | | | 2 | 200000 | 1% | 100 | 0 | 200 | | | 4 | 352000 | 1% | 88 | 4 | 352 | | | 8 | 568000 | 1% | 71 | 9 | 568 | | | 16 | 816000 | 2% | 51 | 21 | 816 | | | 32 | 1056000 | 3% | 33 | 15 | 1056 | | | 64 | 1216000 | 5% | 19 | 37 | 1216 | | | | 1500000 | | | | 1500 | Table 5-10. High-speed Bulk Transaction Limits | Protocol Overhead (55 bytes) | | | (3x4 SYNC bytes, 3 PID bytes, 2 EP/ADDR+CRC bytes, 2 CRC16, and a 3x(1+11) byte interpacket delay (EOP, etc.)) | | | | |------------------------------|---------------------------------|--------|----------------------------------------------------------------------------------------------------------------|--------------------|-------------------------------------|--| | Data<br>Payload | Max Bandwidth<br>(bytes/second) | | Max<br>Transfers | Bytes<br>Remaining | Bytes/<br>Microframe<br>Useful Data | | | | 10640 | 000 1% | 133 | 52 | 133 | | | 2 | 2 20960 | 000 1% | 131 | 33 | 26 | | | 4 | 40640 | 000 1% | 127 | 7 | 50 | | | 8 | 76160 | 000 1% | 119 | 3 | 95 | | | 16 | 134400 | 000 1% | 105 | 45 | 168 | | | 32 | 2 220160 | 000 1% | 86 | 18 | 275 | | | 64 | 322560 | 000 2% | 63 | 3 | 403 | | | 128 | 409600 | 000 2% | 40 | 180 | 512 | | | 256 | 491520 | 000 4% | 24 | 36 | 614 | | | 512 | 532480 | 000 8% | 13 | 129 | 665 | | | | 600000 | 000 | | | 750 | | Host Controllers are free to determine how the individual bus transactions for specific bulk transfers are moved over the bus within and across (micro)frames. An endpoint could see all bus transactions for a bulk transfer within the same (micro)frame or spread across several (micro)frames. A Host Controller, for various implementation reasons, may not be able to provide the above maximum number of transactions per (micro)frame. #### 5.8.5 Bulk Transfer Data Sequences Bulk transactions use data toggle bits that are toggled only upon successful transaction completion to preserve synchronization between transmitter and receiver when transactions are retried due to errors. Bulk transactions are initialized to DATA0 when the endpoint is configured by an appropriate control transfer. The host will also start the first bulk transaction with DATA0. If a halt condition is detected on a bulk pipe due to transmission errors or a STALL handshake being returned from the endpoint, all pending IRPs are retired. Removal of the halt condition is achieved via software intervention through a separate control pipe. This recovery will reset the data toggle bit to DATA0 for the endpoint on both the host and the device. Bulk transactions are retried due to errors detected on the bus that affect a given transaction. ## 5.9 High-Speed, High Bandwidth Endpoints USB supports individual high-speed interrupt or isochronous endpoints that require data rates up to 192 Mb/s (i.e., 3072 data bytes per microframe). One, two, or three high-speed transactions are allowed in a single microframe to support high-bandwidth endpoints. A high-speed interrupt or isochronous endpoint indicates that it requires more than 1024 bytes per microframe when bits 12..11 of the *wMaxPacketSize* field of the endpoint descriptor (see Table 5-11) are non-zero. The lower 11 bits of *wMaxPacketSize* indicate the size of the data payload for each individual transaction while bits 12..11 indicate the maximum number of required transactions possible. See Section 9.6.6 for restrictions on the allowed combinations of values for bits 12..11 and bits 10..0. Bits 15..13 12..11 10..0 Field Reserved, must be set to zero Number of transactions per microframe payload in bytes Table 5-11. wMaxPacketSize Field of Endpoint Descriptor Note: This representation means that endpoints requesting two transactions per microframe will specify a total data payload size in the microframe that is a multiple of two bytes. Also endpoints requesting three transactions per microframe will specify a total data payload size that is a multiple of three bytes. In any case, any number of bytes can actually be transferred in a microframe. The host controller must issue an appropriate number of high-speed transactions per microframe. Errors in the host or on the bus can result in the host controller issuing fewer transactions than requested for the endpoint. The first transaction(s) must have a data payload(s) as specified by the lower 11 bits of wMaxPacketSize if enough data is available, while the last transaction has any remaining data less than or equal to the maximum size specified. The host controller may issue transactions for the same endpoint one immediately after the other (as required for the actual data provided) or may issue transactions for other endpoints in between the transactions for a high bandwidth endpoint. ## 5.9.1 High Bandwidth Interrupt Endpoints For interrupt transactions, if the endpoint NAKs a transaction during a microframe, the host controller must not issue further transactions for that endpoint until the next period. If the endpoint times-out a transaction, the host controller must retry the transaction. The endpoint specifies the maximum number of desired transactions per microframe. If the maximum number of transactions per microframe has not been reached, the host controller may immediately retry the transaction during the current microframe. Host controllers are recommended to do an immediate retry since this minimizes impact on devices that are bandwidth sensitive. If the maximum number of transactions per microframe has been reached, the host controller must retry the transaction at the next period for the endpoint. A host controller is allowed to issue less than the maximum number of transactions to an endpoint per microframe only if more than a single memory buffer is required for the transactions within the microframe. Normal DATA0/DATA1 data toggle sequencing is used for each interrupt transaction during a microframe. ## 5.9.2 High Bandwidth Isochronous Endpoints For isochronous transactions, if an IN endpoint provides less than a maximum data payload as specified by its endpoint descriptor, the host must not issue further transactions for that endpoint for that microframe. For an isochronous OUT endpoint, the host controller must issue the number of transactions as required for the actual data provided, not exceeding the maximum number specified by the endpoint descriptor. The transactions issued must adhere to the maximum payload sizes as specified in the endpoint descriptor. No retries are ever done for isochronous endpoints. High bandwidth isochronous endpoints (IN and OUT) must support data PID sequencing. Data PID sequencing provides the required support for the data receiver to detect one or more lost/damaged packets per microframe. Data PID sequencing for a high-speed, high bandwidth isochronous IN endpoint uses a repeating sequence of DATA2, DATA1, DATA0 PIDs for the data packet of each transaction in a microframe. If there is only a single transaction in the microframe, only a DATA0 data packet PID is used. If there are two transactions per microframe, DATA1 is used for the first transaction data packet and DATA0 is used for the second transaction data packet. If there are three transactions per microframe, DATA2 is used for the first transaction data packet, DATA1 is used for the second, and DATA0 is used for the third. In all cases, the data PID sequence starts over again the next microframe. Figure 5-11 shows the order of data packet PIDs that are used in subsequent transactions within a microframe for high-bandwidth isochronous IN endpoints. | 1 transaction, <1024 bytes: | DATA0 | | | |-------------------------------------|-------|-------|-------| | 2 transactions, 513-1024 bytes ea.: | DATA1 | DATA0 | | | 3 transactions, 683-1024 bytes ea.: | DATA2 | DATA1 | DATA0 | Figure 5-11. Data Phase PID Sequence for Isochronous IN High Bandwidth Endpoints An endpoint must respond to an IN token for the first transaction with a DATA2 when it requires three transactions of data to be moved. It must respond with a DATA1 for the first transaction when it requires two transactions and with a DATA0 when it requires only a single transaction. After the first transaction, the endpoint follows the data PID sequence as described above. The host knows the maximum number of allowed transactions per microframe for the IN endpoint. The host expects the response to the first transaction to encode (via the data packet PID) how many transactions are required by the endpoint for this microframe. If the host doesn't receive an error-free, appropriate response to any transaction, the host must not issue any further transactions to the endpoint for that microframe. When the host receives a DATA0 data packet from the endpoint, it must not issue any further transactions to the endpoint for that microframe. Data PID sequencing for a high-speed, high bandwidth isochronous OUT endpoint uses a different sequence than that used for an IN endpoint. The host must issue a DATA0 data packet when there is a single transaction. The host must issue an MDATA for the first transaction and a DATA1 for the second transaction when there are two transactions per microframe. The host must issue two MDATA transactions and a DATA2 for the third transaction when there are three transactions per microframe. These sequences allow the endpoint to detect if there was a lost/damaged transaction during a microframe. Figure 5-12 shows the order of data packet PIDs that are used in subsequent transactions within a microframe for high-bandwidth isochronous OUT. 1 transaction, <1024 bytes: DATA0 2 transactions, 513-1024 bytes ea.: MDATA DATA1 3 transactions, 683-1024 bytes ea.: MDATA MDATA DATA2 Figure 5-12. Data Phase PID Sequence for Isochronous OUT High Bandwidth Endpoints If the wrong OUT transactions are detected by the endpoint, all of the data transferred during the microframe must be treated as if it had encountered an error. Note that for the three transactions per microframe case with a missing MDATA transaction, USB provides no way for the endpoint to determine which of the two MDATA transactions was lost. There may be application specific methods to more precisely determine which data was lost, but USB provides no method to do so at the bus level. ## 5.10 Split Transactions Host controllers and hubs support one additional transaction type called split transactions. This transaction type allows full- and low-speed devices to be attached to hubs operating at high-speed. These transactions involve only host controllers and hubs and are not visible to devices. High-speed split transactions for interrupt and isochronous transfers must be allocated by the host from the 80% periodic portion of a microframe. More information on split transactions can be found in Chapter 8 and Chapter 11. #### 5.11 Bus Access for Transfers Accomplishing any data transfer between the host and a USB device requires some use of the USB bandwidth. Supporting a wide variety of isochronous and asynchronous devices requires that each device's transfer requirements are accommodated. The process of assigning bus bandwidth to devices is called transfer management. There are several entities on the host that coordinate the information flowing over the USB: client software, the USB Driver (USBD), and the Host Controller Driver (HCD). Implementers of these entities need to know the key concepts related to bus access: - · Transfer Management: The entities and the objects that support communication flow over the USB - Transaction Tracking: The USB mechanisms that are used to track transactions as they move through the USB system - Bus Time: The time it takes to move a packet of information over the bus - Device/Software Buffer Size: The space required to support a bus transaction - Bus Bandwidth Reclamation: Conditions where bandwidth that was allocated to other transfers but was not used and can now be possibly reused by control and bulk transfers The previous sections focused on how client software relates to a function and what the logical flows are over a pipe between the two entities. This section focuses on the different parts of the host and how they must interact to support moving data over the USB. This information may also be of interest to device implementers so they understand aspects of what the host is doing when a client requests a transfer and how that transfer is presented to the device. ## 5.11.1 Transfer Management Transfer management involves several entities that operate on different objects in order to move transactions over the bus: - Client Software: Consumes/generates function-specific data to/from a function endpoint via calls and callbacks requesting IRPs with the USBD interface. - USB Driver (USBD): Converts data in client IRPs to/from device endpoint via calls/callbacks with the appropriate HCD. A single client IRP may involve one or more transfers. - Host Controller Driver (HCD): Converts IRPs to/from transactions (as required by a Host Controller implementation) and organizes them for manipulation by the Host Controller. Interactions between the HCD and its hardware is implementation-dependent and is outside the scope of the USB Specification. - Host Controller: Takes transactions and generates bus activity via packets to move function-specific data across the bus for each transaction. Figure 5-13 shows how the entities are organized as information flows between client software and the USB. The objects of primary interest to each entity are shown at the interfaces between entities. Figure 5-13. USB Information Conversion From Client Software to Bus #### 5.11.1.1 Client Software Client software determines what transfers need to be made with a function. It uses appropriate operating system-specific interfaces to request IRPs. Client software is aware only of the set of pipes (i.e., the interface) it needs to manipulate its function. The client is aware of and adheres to all bus access and bandwidth constraints as described previously for each transfer type. The requests made by the client software are presented via the USBD interface. Some clients may manipulate USB functions via other device class interfaces defined by the operating system and may themselves not make direct USBD calls. However, there is always some lowest level client that makes USBD calls to pass IRPs to the USBD. All IRPs presented are required to adhere to the prenegotiated bandwidth constraints set when the pipe was established. If a function is moved from a non-USB environment to the USB, the driver that would have directly manipulated the function hardware via memory or I/O accesses is the lowest client software in the USB environment that now interacts with the USBD to manipulate the driver's USB function. After client software has requested a transfer of its function and the request has been serviced, the client software receives notification of the completion status of the IRP. If the transfer involved function-to-host data transfer, the client software can access the data in the data buffer associated with the completed IRP. The USBD interface is defined in Chapter 10. ### 5.11.1.2 USB Driver The Universal Serial Bus Driver (USBD) is involved in mediating bus access at two general times: - While a device is attached to the bus during configuration - During normal transfers When a device is attached and configured, the USBD is involved to ensure that the desired device configuration can be accommodated on the bus. The USBD receives configuration requests from the configuring software that describe the desired device configuration: endpoint(s), transfer type(s), transfer period(s), data size(s), etc. The USBD either accepts or rejects a configuration request based on bandwidth availability and the ability to accommodate that request type on the bus. If it accepts the request, the USBD creates a pipe for the requester of the desired type and with appropriate constraints as defined for the transfer type. Bandwidth allocation for periodic endpoints does not have to be made when the device is configured and, once made, a bandwidth allocation can be released without changing the device configuration. The configuration aspects of the USBD are typically operating system-specific and heavily leverage the configuration features of the operating system to avoid defining additional (redundant) interfaces. Once a device is configured, the software client can request IRPs to move data between it and its function endpoints. ## 5.11.1.3 Host Controller Driver The Host Controller Driver (HCD) is responsible for tracking the IRPs in progress and ensuring that USB bandwidth and (micro)frame time maximums are never exceeded. When IRPs are made for a pipe, the HCD adds them to the transaction list. When an IRP is complete, the HCD notifies the requesting software client of the completion status for the IRP. If the IRP involved data transfer from the function to the software client, the data was placed in the client-indicated data buffer. IRPs are defined in an operating system-dependent manner. #### 5.11.1.4 Transaction List The transaction list is a Host Controller implementation-dependent description of the current outstanding set of bus transactions that need to be run on the bus. Only the HCD and its Host Controller have access to the specific representation. Each description contains transaction descriptions in which parameters, such as data size in bytes, the device address and endpoint number, and the memory area to which data is to be sent or received, are identified. A transaction list and the interface between the HCD and its Host Controller is typically represented in an implementation-dependent fashion and is not defined explicitly as part of the USB Specification. #### 5.11.1.5 Host Controller The Host Controller has access to the transaction list and translates it into bus activity. In addition, the Host Controller provides a reporting mechanism whereby the status of a transaction (done, pending, halted, etc.) can be obtained. The Host Controller converts transactions into appropriate implementation-dependent activities that result in USB packets moving over the bus topology rooted in the root hub. The Host Controller ensures that the bus access rules defined by the protocol are obeyed, such as inter-packet timings, timeouts, babble, etc. The HCD interface provides a way for the Host Controller to participate in deciding whether a new pipe is allowed access to the bus. This is done because Host Controller implementations can have restrictions/constraints on the minimum inter-transaction times they may support for combinations of bus transactions. The interface between the transaction list and the Host Controller is hidden within an HCD and Host Controller implementation. ## 5.11.2 Transaction Tracking A USB function sees data flowing across the bus in packets as described in Chapter 8. The Host Controller uses some implementation-dependent representation to track what packets to transfer to/from what endpoints at what time or in what order. Most client software does not want to deal with packetized communication flows because this involves a degree of complexity and interconnect dependency that limits the implementation. The USB System Software (USBD and HCD) provides support for matching data movement requirements of a client to packets on the bus. The Host Controller hardware and software uses IRPs to track information about one or more transactions that combine to deliver a transfer of information between the client software and the function. Figure 5-14 summarizes how transactions are organized into IRPs for the four transfer types. Detailed protocol information for each transfer type can be found in Chapter 8. More information about client software views of IRPs can be found in Chapter 10 and in the operating system specific-information for a particular operating system. Figure 5-14. Transfers for Communication Flows Even though IRPs track the bus transactions that need to occur to move a specific data flow over the USB, Host Controllers are free to choose how the particular bus transactions are moved over the bus subject to the USB-defined constraints (e.g., exactly one transaction per (micro)frame for isochronous transfers). In any case, an endpoint will see transactions in the order they appear within an IRP unless errors occur. For example, Figure 5-15 shows two IRPs, one each for two pipes where each IRP contains three transactions. For any transfer type, a Host Controller is free to move the first transaction of the first IRP followed by the first transaction of the second IRP somewhere in (micro)Frame 1, while moving the second transaction of each IRP in opposite order somewhere in (micro)Frame 2. If these are isochronous transfer types, that is the only degree of freedom a Host Controller has. If these are control or bulk transfers, a Host Controller could further move more or less transactions from either IRP within either (micro)frame. Functions cannot depend on seeing transactions within an IRP back-to-back within a (micro)frame nor should they depend on not seeing transactions back-to-back within a (micro)frame. Figure 5-15. Arrangement of IRPs to Transactions/(Micro)frames # 5.11.3 Calculating Bus Transaction Times When the USB System Software allows a new pipe to be created for the bus, it must calculate how much bus time is required for a given transaction. That bus time is based on the maximum packet size information reported for an endpoint, the protocol overhead for the specific transaction type request, the overhead due to signaling imposed bit stuffing, inter-packet timings required by the protocol, inter-transaction timings, etc. These calculations are required to ensure that the time available in a (micro)frame is not exceeded. The equations used to determine transaction bus time are: ### KEY: | Data_bc | The byte count of data payload | |--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Host_Delay | The time required for the host or transaction translator to prepare for or recover from the transmission; Host Controller implementation-specific | | Floor() | The integer portion of argument | | Hub_LS_Setup | The time provided by the Host Controller for hubs to enable low-speed ports; measured as the delay from the end of the PRE PID to the start of the low-speed SYNC; minimum of four full-speed bit times | | BitStuffTime | Function that calculates theoretical additional time required due to bit stuffing in signaling; worst case is (1.1667*8*Data bc) | ``` High-speed (Input) Non-Isochronous Transfer (Handshake Included) = (55 * 8 * 2.083) + (2.083 * Floor(3.167 + BitStuffTime(Data bc))) + Host Delay Isochronous Transfer (No Handshake) = (38 * 8 * 2.083) + (2.083 * Floor(3.167 + BitStuffTime(Data_bc))) + Host Delay High-speed (Output) Non-Isochronous Transfer (Handshake Included) = (55 * 8 * 2.083) + (2.083 * Floor(3.167 + BitStuffTime(Data bc))) + Host_Delay Isochronous Transfer (No Handshake) = (38 * 8 * 2.083) + (2.083 * Floor(3.167 + BitStuffTime(Data bc))) + Host Delay Full-speed (Input) Non-Isochronous Transfer (Handshake Included) = 9107 + (83.54 * Floor(3.167 + BitStuffTime(Data_bc))) + Host_Delay Isochronous Transfer (No Handshake) = 7268 + (83.54 * Floor(3.167 + BitStuffTime(Data_bc))) + Host_Delay Full-speed (Output) Non-Isochronous Transfer (Handshake Included) = 9107 + (83.54 * Floor(3.167 + BitStuffTime(Data_bc))) + Host Delay Isochronous Transfer (No Handshake) = 6265 + (83.54 * Floor(3.167 + BitStuffTime(Data_bc))) + Host_Delay Low-speed (Input) = 64060 + (2 * Hub_LS_Setup) + (676.67 * Floor(3.167 + BitStuffTime(Data bc))) + Host Delay Low-speed (Output) = 64107 + (2 * Hub_LS_Setup) + (667.0 * Floor(3.167 + BitStuffTime(Data bc))) + Host Delay ``` The bus times in the above equations are in nanoseconds and take into account propagation delays due to the distance the device is from the host. These are typical equations that can be used to calculate bus time; however, different implementations may choose to use coarser approximations of these times. The actual bus time taken for a given transaction will almost always be less than that calculated because bit stuffing overhead is data-dependent. Worst case bit stuffing is calculated as 1.1667 (7/6) times the raw time (i.e., the BitStuffTime function multiplies the Data\_bc by 8\*1.1667 in the equations). This means that there will almost always be time unused on the bus (subject to data pattern specifics) after all regularly scheduled transactions have completed. The bus time made available due to less bit stuffing can be reused as discussed in Section 5.11.5. The Host\_Delay term in the equations is Host Controller-, Transaction Translator(TT)-, and system-dependent and allows for additional time a Host Controller (or TT) may require due to delays in gaining access to memory or other implementation dependencies. This term is incorporated into an implementation of these equations by using the transfer management functions provided by the HCD interface. These equations are typically implemented by a combination of USBD and HCD software working in cooperation. The results of these calculations are used to determine whether a transfer or pipe creation can be supported in a given USB configuration. ## 5.11.4 Calculating Buffer Sizes in Functions and Software Client software and functions both need to provide buffer space for pending data transactions awaiting their turn on the bus. For non-isochronous pipes, this buffer space needs to be just large enough to hold the next data packet. If more than one transaction request is pending for a given endpoint, the buffering for each transaction must be supplied. Methods to calculate the precise absolute minimum buffering a function may require because of specific interactions defined between its client software and the function are outside the scope of this specification. The Host Controller is expected to be able to support an unlimited number of transactions pending for the bus subject to available system memory for buffer and descriptor space, etc. Host Controllers are allowed to limit how many (micro)frames into the future they allow a transaction to be requested. For isochronous pipes, Section 5.12.4 describes details affecting host side and device side buffering requirements. In general, buffers need to be provided to hold approximately twice the amount of data that can be transferred in 1ms for full-speed endpoints or 125 µs for high-speed endpoints. #### 5.11.5 Bus Bandwidth Reclamation The USB bandwidth and bus access are granted based on a calculation of worst-case bus transmission time and required latencies. However, due to the constraints placed on different transfer types and the fact that the bit stuffing bus time contribution is calculated as a constant but is data-dependent, there will frequently be bus time remaining in each (micro)frame time versus what the (micro)frame transmission time was calculated to be. In order to support the most efficient use of the bus bandwidth, control and bulk transfers are candidates to be moved over the bus as bus time becomes available. Exactly how a Host Controller supports this is implementation-dependent. A Host Controller can take into account the transfer types of pending IRPs and implementation-specific knowledge of remaining (micro)frame time to reuse reclaimed bandwidth. #### 5.12 Special Considerations for Isochronous Transfers Support for isochronous data movement between the host and a device is one of the system capabilities supported by the USB. Delivering isochronous data reliably over the USB requires careful attention to detail. The responsibility for reliable delivery is shared by several USB entities: - The device/function - The bus - The Host Controller - One or more software agents Because time is a key part of an isochronous transfer, it is important for USB designers to understand how time is dealt with within the USB by these different entities. Note: The examples in this section describe USB for an example involving full-speed endpoints. The general example details are also appropriate for high-speed endpoints when corresponding changes are made; for example, frame replaced with microframe, 1 ms replaced with 125 µs, rate adjustments made between full-speed and high-speed, etc. All isochronous devices must report their capabilities in the form of device-specific descriptors. The capabilities should also be provided in a form that the potential customer can use to decide whether the device offers a solution to his problem(s). The specific capabilities of a device can justify price differences. In any communication system, the transmitter and receiver must be synchronized enough to deliver data robustly. In an asynchronous communication system, data can be delivered robustly by allowing the transmitter to detect that the receiver has not received a data item correctly and simply retrying transmission of the data. In an isochronous communication system, the transmitter and receiver must remain time- and data-synchronized to deliver data robustly. The USB does not support transmission retry of isochronous data so that minimal bandwidth can be allocated to isochronous transfers and time synchronization is not lost due to a retry delay. However, it is critical that a USB isochronous transmitter/receiver pair still remain synchronized both in normal data transmission cases and in cases where errors occur on the bus. In many systems that deal with isochronous data, a single global clock is used to which all entities in the system synchronize. An example of such a system is the PSTN (Public Switched Telephone Network). Given that a broad variety of devices with different natural frequencies may be attached to the USB, no single clock can provide all the features required to satisfy the synchronization requirements of all devices and software while still supporting the cost targets of mass-market PC products. The USB defines a clock model that allows a broad range of devices to coexist on the bus and have reasonable cost implementations. This section presents options or features that can be used by isochronous endpoints to minimize behavior differences between a non-USB implemented function and a USB version of the function. An example is included to illustrate the similarities and differences between the non-USB and USB versions of a function. The remainder of the section presents the following key concepts: - USB Clock Model: What clocks are present in a USB system that have impact on isochronous data transfers - USB (micro)frame Clock-to-function Clock Synchronization Options: How the USB (micro)frame clock can relate to a function clock - SOF Tracking: Responsibilities and opportunities of isochronous endpoints with respect to the SOF token and USB (micro)frames - Data Prebuffering: Requirements for accumulating data before generation, transmission, and consumption - · Error Handling: Isochronous-specific details for error handling - Buffering for Rate Matching: Equations that can be used to calculate buffer space required for isochronous endpoints ## 5.12.1 Example Non-USB Isochronous Application The example used is a reasonably generalized example. Other simpler or more complex cases are possible and the relevant USB features identified can be used or not as appropriate. The example consists of an 8 kHz mono microphone connected through a mixer driver that sends the input data stream to 44 kHz stereo speakers. The mixer expects the data to be received and transmitted at some sample rate and encoding. A rate matcher driver on input and output converts the sample rate and encoding from the natural rate and encoding of the device to the rate and encoding expected by the mixer. Figure 5-16 illustrates this example. Figure 5-16. Non-USB Isochronous Example A master clock (which can be provided by software driven from the real time clock) in the PC is used to awaken the mixer to ask the input source for input data and to provide output data to the output sink. In this example, assume it awakens every 20 ms. The microphone and speakers each have their own sample clocks that are unsynchronized with respect to each other or the master mixer clock. The microphone produces data at its natural rate (one-byte samples, 8,000 times a second) and the speakers consume data at their natural rate (four-byte samples, 44,100 times a second). The three clocks in the system can drift and jitter with respect to each other. Each rate matcher may also be running at a different natural rate than either the mixer driver, the input source/driver, or output sink/driver. The rate matchers also monitor the long-term data rate of their device compared to the master mixer clock and interpolate an additional sample or merge two samples to adjust the data rate of their device to the data rate of the mixer. This adjustment may be required every couple of seconds, but typically occurs infrequently. The rate matchers provide some additional buffering to carry through a rate match. Note: Some other application might not be able to tolerate sample adjustment and would need some other means of accommodating master clock-to-device clock drift or else would require some means of synchronizing the clocks to ensure that no drift could occur. The mixer always expects to receive exactly a service period of data (20 ms service period) from its input device and produce exactly a service period of data for its output device. The mixer can be delayed up to less than a service period if data or space is not available from its input/output device. The mixer assumes that such delays do not accumulate. The input and output devices and their drivers expect to be able to put/get data in response to a hardware interrupt from the DMA controller when their transducer has processed one service period of data. They expect to get/put exactly one service period of data. The input device produces 160 bytes (ten samples) every service period of 20 ms. The output device consumes 3,528 bytes (882 samples) every 20 ms service period. The DMA controller can move a single sample between the device and the host buffer at a rate much faster than the sample rate of either device. The input and output device drivers provide two service periods of system buffering. One buffer is always being processed by the DMA controller. The other buffer is guaranteed to be ready before the current buffer is exhausted. When the current buffer is emptied, the hardware interrupt awakens the device driver and it calls the rate matcher to give it the buffer. The device driver requests a new IRP with the buffer before the current buffer is exhausted. The devices can provide two samples of data buffering to ensure that they always have a sample to process for the next sample period while the system is reacting to the previous/next sample. The service periods of the drivers are chosen to survive interrupt latency variabilities that may be present in the operating system environment. Different operating system environments will require different service periods for reliable operation. The service periods are also selected to place a minimum interrupt load on the system, because there may be other software in the system that requires processing time. #### 5.12.2 USB Clock Model Time is present in the USB system via clocks. In fact, there are multiple clocks in a USB system that must be understood: - Sample Clock: This clock determines the natural data rate of samples moving between client software on the host and the function. This clock does not need to be different between non-USB and USB implementations. - Bus Clock: This clock runs at a 1.000 ms period (1 kHz frequency) on full-speed segments and 125.000 μs (8 kHz frequency) on high-speed segments of the bus and is indicated by the rate of SOF packets on the bus. This clock is somewhat equivalent to the 8 MHz clock in the non-USB example. In the USB case, the bus clock is often a lower-frequency clock than the sample clock, whereas the bus clock is almost always a higher-frequency clock than the sample clock in a non-USB case. - Service Clock: This clock is determined by the rate at which client software runs to service IRPs that may have accumulated between executions. This clock also can be the same in the USB and non-USB cases. In most existing operating systems, it is not possible to support a broad range of isochronous communication flows if each device driver must be interrupted for each sample for fast sample rates. Therefore, multiple samples, if not multiple packets, will be processed by client software and then given to the Host Controller to sequence over the bus according to the prenegotiated bus access requirements. Figure 5-17 presents an example for a reasonable USB clock environment equivalent to the non-USB example in Figure 5-16. Figure 5-17. USB Full-speed Isochronous Application Figure 5-17 shows a typical round trip path of information from a microphone as an input device to a speaker as an output device. The clocks, packets, and buffering involved are also shown. Figure 5-17 will be explored in more detail in the following sections. The focus of this example is to identify the differences introduced by the USB compared to the previous non-USB example. The differences are in the areas of buffering, synchronization given the existence of a USB bus clock, and delay. The client software above the device drivers can be unaffected in most cases. ## 5.12.3 Clock Synchronization In order for isochronous data to be manipulated reliably, the three clocks identified above must be synchronized in some fashion. If the clocks are not synchronized, several clock-to-clock attributes can be present that can be undesirable: - Clock Drift: Two clocks that are nominally running at the same rate can, in fact, have implementation differences that result in one clock running faster or slower than the other over long periods of time. If uncorrected, this variation of one clock compared to the other can lead to having too much or too little data when data is expected to always be present at the time required. - Clock Jitter: A clock may vary its frequency over time due to changes in temperature, etc. This may also alter when data is actually delivered compared to when it is expected to be delivered. - Clock-to-clock Phase Differences: If two clocks are not phase locked, different amounts of data may be available at different points in time as the beat frequency of the clocks cycle out over time. This can lead to quantization/sampling related artifacts. The bus clock provides a central clock with which USB hardware devices and software can synchronize to one degree or another. However, the software will, in general, not be able to phase- or frequency-lock precisely to the bus clock given the current support for "real time-like" operating system scheduling support in most PC operating systems. Software running in the host can, however, know that data moved over the USB is packetized. For isochronous transfer types, a unit of data is moved exactly once per (micro)frame and the (micro)frame clock is reasonably precise. Providing the software with this information allows it to adjust the amount of data it processes to the actual (micro)frame time that has passed. Note: For high-speed high-bandwidth endpoints, the data exchanged in the two or three transactions per microframe is still considered to belong to the same "single packet." The large amount of data per packet is split into two or three transactions only for bus efficiency reasons. #### 5.12.4 Isochronous Devices The USB includes a framework for isochronous devices that defines synchronization types, how isochronous endpoints provide data rate feedback, and how they can be connected together. Isochronous devices include sampled analog devices (for example, audio and telephony devices) and synchronous data devices. Synchronization type classifies an endpoint according to its capability to synchronize its data rate to the data rate of the endpoint to which it is connected. Feedback is provided by indicating accurately what the required data rate is, relative to the SOF frequency. The ability to make connections depends on the quality of connection that is required, the endpoint synchronization type, and the capabilities of the host application that is making the connection. Additional device class-specific information may be required, depending on the application. Note: The term "data" is used very generally, and may refer to data that represents sampled analog information (like audio), or it may be more abstract information. "Data rate" refers to the rate at which analog information is sampled, or the rate at which data is clocked. The following information is required in order to determine how to connect isochronous endpoints: - Synchronization type: - Asynchronous: Unsynchronized, although sinks provide data rate feedback - Synchronous: Synchronized to the USB's SOF - Adaptive: Synchronized using feedback or feedforward data rate information - Available data rates - Available data formats Synchronization type and data rate information are needed to determine if an exact data rate match exists between source and sink, or if an acceptable conversion process exists that would allow the source to be connected to the sink. It is the responsibility of the application to determine whether the connection can be supported within available processing resources and other constraints (like delay). Specific USB device classes define how to describe synchronization type and data rate information. Data format matching and conversion is also required for a connection, but it is not a unique requirement for isochronous connections. Details about format conversion can be found in other documents related to specific formats. ## 5.12.4.1 Synchronization Type Three distinct synchronization types are defined. Table 5-12 presents an overview of endpoint synchronization characteristics for both source and sink endpoints. The types are presented in order of increasing capability. | | Source | Sink | |--------------|---------------------------------------------|-----------------------------------------------| | Asynchronous | Free running Fs | Free running Fs | | | Provides implicit feedforward (data stream) | Provides explicit feedback (isochronous pipe) | | Synchronous | Fs locked to SOF | Fs locked to SOF | | | Uses implicit feedback (SOF) | Uses implicit feedback (SOF) | | Adaptive | Fs locked to sink | Fs locked to data flow | | | Uses explicit feedback (isochronous pipe) | Uses implicit feedforward (data stream) | Table 5-12. Synchronization Characteristics ## 5.12.4.1.1 Asynchronous Asynchronous endpoints cannot synchronize to SOF or any other clock in the USB domain. They source or sink an isochronous data stream at either a fixed data rate (single-frequency endpoints), a limited number of data rates (32 kHz, 44.1 kHz, 48 kHz, ...), or a continuously programmable data rate. If the data rate is programmable, it is set during initialization of the isochronous endpoint. Asynchronous devices must report their programming capabilities in the class-specific endpoint descriptor as described in their device class specification. The data rate is locked to a clock external to the USB or to a free-running internal clock. These devices place the burden of data rate matching elsewhere in the USB environment. Asynchronous source endpoints carry their data rate information implicitly in the number of samples they produce per (micro)frame. Asynchronous sink endpoints must provide explicit feedback information to an adaptive driver (refer to Section 5.12.4.2). An example of an asynchronous source is a CD-audio player that provides its data based on an internal clock or resonator. Another example is a Digital Audio Broadcast (DAB) receiver or a Digital Satellite Receiver (DSR). Here, too, the sample rate is fixed at the broadcasting side and is beyond USB control. Asynchronous sink endpoints could be low-cost speakers running off of their internal sample clock. ## 5.12.4.1.2 Synchronous Synchronous endpoints can have their clock system (their notion of time) controlled externally through SOF synchronization. These endpoints must slave their sample clock to the 1 ms SOF tick (by means of a programmable PLL). For high-speed endpoints, the presence of the microframe SOF can be used for tighter frame clock tracking. Synchronous endpoints may source or sink isochronous data streams at either a fixed data rate (single-frequency endpoints), a limited number of data rates (32 kHz, 44.1 kHz, 48 kHz, ...), or a continuously programmable data rate. If programmable, the operating data rate is set during initialization of the isochronous endpoint. The number of samples or data units generated in a series of USB (micro)frames is deterministic and periodic. Synchronous devices must report their programming capabilities in the class-specific endpoint descriptor as described in their device class specification. An example of a synchronous source is a digital microphone that synthesizes its sample clock from SOF and produces a fixed number of audio samples every USB (micro)frame. Likewise, a synchronous sink derives its sample clock from SOF and consumes a fixed number of samples every USB (micro)frame. ## 5.12.4.1.3 Adaptive Adaptive endpoints are the most capable endpoints possible. They are able to source or sink data at any rate within their operating range. Adaptive source endpoints produce data at a rate that is controlled by the data sink. The sink provides feedback (refer to Section 5.12.4.2) to the source, which allows the source to know the desired data rate of the sink. For adaptive sink endpoints, the data rate information is embedded in the data stream. The average number of samples received during a certain averaging time determines the instantaneous data rate. If this number changes during operation, the data rate is adjusted accordingly. The data rate operating range may center around one rate (e.g., 8 kHz), select between several programmable or auto-detecting data rates (32 kHz, 44.1 kHz, 48 kHz, ...), or may be within one or more ranges (e.g., 5 kHz to 12 kHz or 44 kHz to 49 kHz). Adaptive devices must report their programming capabilities in the class-specific endpoint descriptor as described in their device class specification. An example of an adaptive source is a CD player that contains a fully adaptive sample rate converter (SRC) so that the output sample frequency no longer needs to be 44.1 kHz but can be anything within the operating range of the SRC. Adaptive sinks include such endpoints as high-end digital speakers, headsets, etc. ## 5.12.4.2 Feedback An asynchronous sink must provide explicit feedback to the host by indicating accurately what its desired data rate $(F_f)$ is, relative to the USB (micro)frame frequency. This allows the host to continuously adjust the number of samples sent to the sink so that neither underflow or overflow of the data buffer occurs. Likewise, an adaptive source must receive explicit feedback from the host so that it can accurately generate the number of samples required by the host. Feedback endpoints can be specified as described in Section 9.6.6 for the bmAttributes field of the endpoint descriptor. To generate the desired data rate $F_f$ , the device must measure its actual sampling rate $F_s$ , referenced to the USB notion of time, i.e., the USB (micro)frame frequency. This specification requires the data rate $F_f$ to be resolved to better than one sample per second (1Hz) in order to allow a high-quality source rate to be created and to tolerate delays and errors in the feedback loop. To achieve this accuracy, the measurement time $T_{meas}$ must be at least 1 second. Therefore: $$T_{max} = 2^K$$ where $T_{meas}$ is now expressed in USB (micro)frames and K=10 for full-speed devices (1 ms frames) and K=13 for high-speed devices (125 $\mu$ s microframes). However, in most devices, the actual sampling rate $F_s$ is derived from a master clock $F_m$ through a binary divider. Therefore: $$F_m = F_s *2^P$$ where P is a positive integer (including 0 if no higher-frequency master clock is available). The measurement time $T_{meas}$ can now be decreased by measuring $F_m$ instead of $F_s$ and: $$T_{meas} = \frac{2^K}{2^P} = 2^{(K-P)}$$ In this way, a new estimate for $F_f$ becomes available every $2^{(K-P)}$ (micro)frames. P is practically bound to be in the range [0,K] because there is no point in using a clock slower than $F_s$ (P=0), and no point in trying to update $F_f$ more than once per (micro)frame (P=K). A sink can determine $F_f$ by counting cycles of the master clock $F_m$ for a period of $2^{(K-P)}$ (micro)frames. The counter is read into $F_f$ and reset every $2^{(K-P)}$ (micro)frames. As long as no clock cycles are skipped, the count will be accurate over the long term. Each (micro)frame, an adaptive source adds $F_f$ to any remaining fractional sample count from the previous (micro)frame, sources the number of samples in the integer part of the sum, and retains the fractional sample count for the next (micro)frame. The source can look at the behavior of $F_f$ over many (micro)frames to determine an even more accurate rate, if it needs to. $F_f$ is expressed in number of samples per (micro)frame. The $F_f$ value consists of an integer part that represents the (integer) number of samples per (micro)frame and a fractional part that represents the "fraction" of a sample that would be needed to match the sampling frequency $F_s$ to a resolution of 1 Hz or better. The fractional part requires at least K bits to represent the "fraction" of a sample to a resolution of 1 Hz or better. The integer part must have enough bits to represent the maximum number of samples that can ever occur in a single (micro)frame. Assuming that the minimum sample size is one byte, then this number is limited to 1,023 for full-speed endpoints. Ten bits are therefore sufficient to encode this value. For high-speed endpoints, this number is limited to 3\*1,024=3,072 and twelve bits are needed. In summary, for full-speed endpoints, the $F_f$ value shall be encoded in an unsigned 10.10 (K=10) format which fits into three bytes. Because the maximum integer value is fixed to 1,023, the 10.10 number will be left-justified in the 24 bits, so that it has a 10.14 format. Only the first ten bits behind the binary point are required. The lower four bits may be optionally used to extend the precision of $F_f$ otherwise, they shall be reported as zero. For high-speed endpoints, the $F_f$ value shall be encoded in an unsigned 12.13 (K=13) format which fits into four bytes. The value shall be aligned into these four bytes so that the binary point is located between the second and the third byte so that it has a 16.16 format. The most significant four bits shall be reported zero. Only the first 13 bits behind the binary point are required. The lower three bits may be optionally used to extend the precision of $F_f$ otherwise, they shall be reported as zero. An endpoint needs to implement only the number of bits that it effectively requires for its maximum $F_{f}$ The choice of *P* is endpoint-specific. Use the following guidelines when choosing *P*: - P must be in the range [0,K]. - Larger values of P are preferred, because they reduce the size of the frame counter and increase the rate at which F<sub>f</sub> is updated. More frequent updates result in a tighter control of the source data rate, which reduces the buffer space required to handle F<sub>f</sub> changes. - P should be less than K so that F<sub>f</sub> is averaged across at least two frames in order to reduce SOF jitter effects. - P should not be zero in order to keep the deviation in the number of samples sourced to less than 1 in the event of a lost F<sub>f</sub> value. Isochronous transfers are used to read $F_f$ from the feedback register. The desired reporting rate for the feedback should be $2^{(K-P)}$ frames. $F_f$ will be reported at most once per update period. There is nothing to be gained by reporting the same $F_f$ value more than once per update period. The endpoint may choose to report $F_f$ only if the updated value has changed from the previous $F_f$ value. If the value has not changed, the endpoint may report the current $F_f$ value or a zero length data payload. It is strongly recommended that an endpoint always report the current $F_f$ value any time it is polled. It is possible that the source will deliver one too many or one too few samples over a long period due to errors or accumulated inaccuracies in measuring $F_f$ . The sink must have sufficient buffer capability to accommodate this. When the sink recognizes this condition, it should adjust the reported $F_f$ value to correct it. This may also be necessary to compensate for relative clock drifts. The implementation of this correction process is endpoint-specific and is not specified. ## 5.12.4.3 Implicit Feedback In some cases, implementing a separate explicit feedback endpoint can be avoided. If a device implements a group of isochronous data endpoints that are closely related and if: - All the endpoints in the group are synchronized (i.e. use sample clocks that are derived from a common master clock) - The group contains one or more isochronous data endpoints in one direction that normally would need explicit feedback - . The group contains at least one isochronous data endpoint in the opposite direction Under these circumstances, the device may elect not to implement a separate isochronous explicit feedback endpoint. Instead, feedback information can be derived from the data endpoint in the opposite direction by observing its data rate. Two cases can arise: - One or more asynchronous sink endpoints are accompanied by an asynchronous source endpoint. The data rate on the source endpoint can be used as implicit feedback information to adjust the data rate on the sink endpoint(s). - One or more adaptive source endpoints are accompanied by an adaptive sink endpoint. The source endpoint can adjust its data rate based on the data rate received by the sink endpoint. This specification provides the necessary framework to implement synchronization as described above (see Chapter 9). However, exactly how the desired data rate $F_f$ is derived from the data rate of the implied feedback endpoint is implementation-dependent. ## 5.12.4.4 Connectivity In order to fully describe the source-to-sink connectivity process, an interconnect model is presented. The model indicates the different components involved and how they interact to establish the connection. The model provides for multi-source/multi-sink situations. Figure 5-18 illustrates a typical situation (highly condensed and incomplete). A physical device is connected to the host application software through different hardware and software layers as described in this specification. At the client interface level, a virtual device is presented to the application. From the application standpoint, only virtual devices exist. It is up to the device driver and client software to decide what the exact relation is between physical and virtual device. Figure 5-18. Example Source/Sink Connectivity Device manufacturers (or operating system vendors) must provide the necessary device driver software and client interface software to convert their device from the physical implementation to a USB-compliant software implementation (the virtual device). As stated before, depending on the capabilities built into this software, the virtual device can exhibit different synchronization behavior from the physical device. However, the synchronization classification applies equally to both physical and virtual devices. All physical devices belong to one of the three possible synchronization types. Therefore, the capabilities that have to be built into the device driver and/or client software are the same as the capabilities of a physical device. The word "application" must be replaced by "device driver/client software." In the case of a physical source to virtual source connection, "virtual source device" must be replaced by "physical source device" and "virtual sink device" must be replaced by "virtual sink device" and "virtual sink device" and "virtual sink device" must be replaced by "physical sink device" and "virtual sink device" must be replaced by "physical sink device" must be replaced by "physical sink device." Placing the rate adaptation (RA) functionality into the device driver/client software layer has the distinct advantage of isolating all applications, relieving the device from the specifics and problems associated with rate adaptation. Applications that would otherwise be multi-rate degenerate to simpler mono-rate systems. Note: The model is not limited to only USB devices. For example, a CD-ROM drive containing 44.1 kHz audio can appear as either an asynchronous, synchronous, or adaptive source. Asynchronous operation means that the CD-ROM fills its buffer at the rate that it reads data from the disk, and the driver empties the buffer according to its USB service interval. Synchronous operation means that the driver uses the USB service interval (e.g., 10 ms) and nominal sample rate of the data (44.1 kHz) to determine to put out 441 samples every USB service interval. Adaptive operation would build in a sample rate converter to match the CD-ROM output rate to different sink sampling rates. Using this reference model, it is possible to define what operations are necessary to establish connections between various sources and sinks. Furthermore, the model indicates at what level these operations must or can take place. First, there is the stage where physical devices are mapped onto virtual devices and vice versa. This is accomplished by the driver and/or client software. Depending on the capabilities included in this software, a physical device can be transformed into a virtual device of an entirely different synchronization type. The second stage is the application that uses the virtual devices. Placing rate matching capabilities at the driver/client level of the software stack relieves applications communicating with virtual devices from the burden of performing rate matching for every device that is attached to them. Once the virtual device characteristics are decided, the actual device characteristics are not any more interesting than the actual physical device characteristics of another driver. As an example, consider a mixer application that connects at the source side to different sources, each running at their own frequencies and clocks. Before mixing can take place, all streams must be converted to a common frequency and locked to a common clock reference. This action can be performed in the physical-to-virtual mapping layer or it can be handled by the application itself for each source device independently. Similar actions must be performed at the sink side. If the application sends the mixed data stream out to different sink devices, it can either do the rate matching for each device itself or it can rely on the driver/client software to do that, if possible. Table 5-13 indicates at the intersections what actions the application must perform to connect a source endpoint to a sink endpoint. Table 5-13. Connection Requirements | | Source Endpoint | | | | | | |---------------|-------------------------------------|----------------------------------|-----------------------------------------------------------|--|--|--| | Sink Endpoint | Asynchronous | Synchronous | Adaptive | | | | | Asynchronous | Async Source/Sink RA<br>See Note 1. | Async SOF/Sink RA<br>See Note 2. | Data + Feedback<br>Feedthrough<br>See Note 3. | | | | | Synchronous | Async Source/SOF RA<br>See Note 4. | Sync RA<br>See Note 5. | Data Feedthrough +<br>Application Feedback<br>See Note 6. | | | | | Adaptive | Data Feedthrough<br>See Note 7. | Data Feedthrough<br>See Note 8. | Data Feedthrough<br>See Note 9. | | | | #### Notes: - Asynchronous RA in the application. Fs<sub>i</sub> is determined by the source, using the feedforward information embedded in the data stream. Fs<sub>0</sub> is determined by the sink, based on feedback information from the sink. If nominally Fs<sub>i</sub> = Fs<sub>0</sub>, the process degenerates to a feedthrough connection if slips/stuffs due to lack of synchronization are tolerable. Such slips/stuffs will cause audible degradation in audio applications. - Asynchronous RA in the application. Fs<sub>i</sub> is determined by the source but locked to SOF. Fs<sub>0</sub> is determined by the sink, based on feedback information from the sink. If nominally Fs<sub>i</sub> = Fs<sub>0</sub>, the process degenerates to a feedthrough connection if slips/stuffs due to lack of synchronization are tolerable. Such slips/stuffs will cause audible degradation in audio applications. - 3. If Fs<sub>0</sub> falls within the locking range of the adaptive source, a feedthrough connection can be established. Fs<sub>i</sub> = Fs<sub>0</sub> and both are determined by the asynchronous sink, based on feedback information from the sink. If Fs<sub>0</sub> falls outside the locking range of the adaptive source, the adaptive source is switched to synchronous mode and Note 2 applies. - 4. Asynchronous RA in the application. Fs<sub>i</sub> is determined by the source. Fs<sub>0</sub> is determined by the sink and locked to SOF. If nominally Fs<sub>i</sub> = Fs<sub>0</sub>, the process degenerates to a feedthrough connection if slips/stuffs due to lack of synchronization are tolerable. Such slips/stuffs will cause audible degradation in audio applications. - Synchronous RA in the application. Fs<sub>i</sub> is determined by the source and locked to SOF. Fs<sub>0</sub> is determined by the sink and locked to SOF. If Fs<sub>i</sub> = Fs<sub>0</sub>, the process degenerates to a loss-free feedthrough connection. - 6. The application will provide feedback to synchronize the source to SOF. The adaptive source appears to be a synchronous endpoint and Note 5 applies. - 7. If Fs<sub>i</sub> falls within the locking range of the adaptive sink, a feedthrough connection can be established. Fs<sub>i</sub> = Fs<sub>o</sub> and both are determined by and locked to the source. If Fs<sub>i</sub> falls outside the locking range of the adaptive sink, synchronous RA is done in the host to provide an Fs<sub>o</sub> that is within the locking range of the adaptive sink. - 8. If Fs<sub>i</sub> falls within the locking range of the adaptive sink, a feedthrough connection can be established. Fs<sub>0</sub> = Fs<sub>i</sub> and both are determined by the source and locked to SOF. If Fs<sub>i</sub> falls outside the locking range of the adaptive sink, synchronous RA is done in the host to provide an Fs<sub>0</sub> that is within the locking range of the adaptive sink. - The application will use feedback control to set Fs<sub>0</sub> of the adaptive source when the connection is set up. The adaptive source operates as an asynchronous source in the absence of ongoing feedback information and Note 7 applies. In cases where RA is needed but not available, the rate adaptation process could be mimicked by sample dropping/stuffing. The connection could then still be made, possibly with a warning about poor quality, otherwise, the connection cannot be made. ## 5.12.4.4.1 Audio Connectivity When the above is applied to audio data streams, the RA process is replaced by sample rate conversion, which is a specialized form of rate adaptation. Instead of error control, some form of sample interpolation is used to match incoming and outgoing sample rates. Depending on the interpolation techniques used, the audio quality (distortion, signal to noise ratio, etc.) of the conversion can vary significantly. In general, higher quality requires more processing power. ### 5.12.4.4.2 Synchronous Data Connectivity For the synchronous data case, RA is used. Occasional slips/stuffs may be acceptable to many applications that implement some form of error control. Error control includes error detection and discard, error detection and retransmit, or forward error correction. The rate of slips/stuffs will depend on the clock mismatch between the source and sink and may be the dominant error source of the channel. If the error control is sufficient, then the connection can still be made. ## 5.12.5 Data Prebuffering The USB requires that devices prebuffer data before processing/transmission to allow the host more flexibility in managing when each pipe's transaction is moved over the bus from (micro)frame to (micro)frame. For transfers from function to host, the endpoint must accumulate samples during (micro)frame X until it receives the SOF token for (micro)frame X+1. It "latches" the data from (micro)frame X into its packet buffer and is now ready to send the packet containing those samples during (micro)frame X+1. When it will send that data during the (micro)frame is determined solely by the Host Controller and can vary from (micro)frame to (micro)frame. For transfers from host to function, the endpoint will accept a packet from the host sometime during (micro)frame Y. When it receives the SOF for (micro)frame Y+1, it can then start processing the data received in (micro)frame Y. This approach allows an endpoint to use the SOF token as a stable clock with very little jitter and/or drift when the Host Controller moves the packet over the bus. This approach also allows the Host Controller to vary within a (micro)frame precisely when the packet is actually moved over the bus. This prebuffering introduces some additional delay between when a sample is available at an endpoint and when it moves over the bus compared to an environment where the bus access is at exactly the same time offset from SOF from (micro)frame to (micro)frame. Figure 5-19 shows the time sequence for a function-to-host transfer (IN process). Data $D_0$ is accumulated during (micro)frame $F_i$ at time $T_i$ and transmitted to the host during (micro)frame $F_{i+1}$ . Similarly, for a host-to-function transfer (OUT process), data $D_0$ is received by the endpoint during (micro)frame $F_{i+1}$ and processed during (micro)frame $F_{i+2}$ . Figure 5-19. Data Prebuffering ## 5.12.6 SOF Tracking Functions supporting isochronous pipes must receive and comprehend the SOF token to support prebuffering as previously described. Given that SOFs can be corrupted, a device must be prepared to recover from a corrupted SOF. These requirements limit isochronous transfers to full-speed and high-speed devices only, because low-speed devices do not see SOFs on the bus. Also, because SOF packets can be damaged in transmission, devices that support isochronous transfers need to be able to synthesize the existence of an SOF that they may not see due to a bus error. Isochronous transfers require the appropriate data to be transmitted in the corresponding (micro)frame. The USB requires that when an isochronous transfer is presented to the Host Controller, it identifies the (micro)frame number for the first (micro)frame. The Host Controller must not transmit the first transaction before the indicated (micro)frame number. Each subsequent transaction in the IRP must be transmitted in succeeding (micro)frames (except for high-speed high-bandwidth transfers where up to three transactions may occur in the same microframe). If there are no transactions pending for the current (micro)frame, then the Host Controller must not transmit anything for an isochronous pipe. If the indicated (micro)frame number has passed, the Host Controller must skip (i.e., not transmit) all transactions until the one corresponding to the current (micro)frame is reached. ## 5.12.7 Error Handling Isochronous transfers provide no data packet retries (i.e., no handshakes are returned to a transmitter by a receiver) so that timeliness of data delivery is not perturbed. However, it is still important for the agents responsible for data transport to know when an error occurs and how the error affects the communication flow. In particular, for a sequence of data packets (A, B, C, D), the USB allows sufficient information such that a missing packet (A, \_, C, D) can be detected and will not unknowingly be turned into an incorrect data or time sequence (A, C, D or A, \_, B, C, D). The protocol provides four mechanisms that support this: a strictly defined periodicity for the transmission of packets and data PID sequencing mechanisms for high-speed high-bandwidth endpoints, SOF, CRC, and bus transaction timeout. • Isochronous transfers require periodic occurrence of data transactions for normal operation. The period must be an exact power of two (micro)frames. The USB does not dictate what data is transmitted in each frame. The data transmitter/source determines specifically what data to provide. This regular periodic data delivery provides a framework that is fundamental to detecting missing data errors. For high-speed high-bandwidth endpoints, data PID sequencing allows the detection of missing or damaged transactions during a microframe. Any phase of a transaction can be damaged during transmission on the bus. Chapter 8 describes how each error case affects the protocol. - Because every (micro)frame is preceded by an SOF and a receiver can see SOFs on the bus, a receiver can determine that its expected transaction for that (micro)frame did not occur between two SOFs. Additionally, because even an SOF can be damaged, a device must be able to reconstruct the existence of a missed SOF as described in Section 5.12.6. - A data packet may be corrupted on the bus; therefore, CRC protection allows a receiver to determine that the data packet it received was corrupted. - The protocol defines the details that allow a receiver to determine via bus transaction timeout that it is not going to receive its data packet after it has successfully seen its token packet. Once a receiver has determined that a data packet was not received, it may need to know the size of the data that was missed in order to recover from the error with regard to its functional behavior. If the communication flow is always the same data size per (micro)frame, then the size is always a known constant. However, in some cases, the data size can vary from (micro)frame to (micro)frame. In this case, the receiver and transmitter have an implementation-dependent mechanism to determine the size of the lost packet. In summary, whether a transaction is actually moved successfully over the bus or not, the transmitter and receiver always advance their data/buffer streams as indicated by the bus access period to keep data-per-time synchronization. The detailed mechanisms described above allow detection, tracking, and reporting of damaged transactions so that a function or its client software can react to the damage in a function-appropriate fashion. The details of that function- or application-specific reaction are outside the scope of the USB Specification. # 5.12.8 Buffering for Rate Matching Given that there are multiple clocks that affect isochronous communication flows in the USB, buffering is required to rate match the communication flow across the USB. There must be buffer space available both in the device per endpoint and on the host side on behalf of the client software. These buffers provide space for data to accumulate until it is time for a transfer to move over the USB. Given the natural data rates of the device, the maximum size of the data packets that move over the bus can also be calculated. Figure 5-20 shows the equations used to determine buffer size on the device and host and maximum packet size that must be requested to support a desired data rate. These equations are a function of the service clock rate $(F_X)$ , bus clock rate $(F_{SOF})$ , sample clock rate $(F_S)$ , bus access period (I), and sample size (S). These equations should provide design information for selecting the appropriate packet size that an endpoint will report in its characteristic information and the appropriate buffer requirements for the device/endpoint and its client software. Figure 5-17 shows actual buffer, packet, and clock values for a typical full-speed isochronous example. Figure 5-20. Packet and Buffer Size Formulas for Rate-matched Isochronous Transfers The USB data model assumes that devices have some natural sample size and rate. The USB supports the transmission of packets that are multiples of sample size to make error recovery handling easier when isochronous transactions are damaged on the bus. If a device has no natural sample size or if its samples are larger than a packet, it should describe its sample size as being one byte. If a sample is split across a data packet, the error recovery can be harder when an arbitrary transaction is lost. In some cases, data synchronization can be lost unless the receiver knows in what (micro)frame number each partial sample is transmitted. Furthermore, if the number of samples can vary due to clock correction (e.g., for a non-derived device clock), it may be difficult or inefficient to know when a partial sample is transmitted. Therefore, the USB does not split samples across packets. # Chapter 6 Mechanical This chapter provides the mechanical and electrical specifications for the cables, connectors, and cable assemblies used to interconnect USB devices. The specification includes the dimensions, materials, electrical, and reliability requirements. This chapter documents minimum requirements for the external USB interconnect. Substitute material may be used as long as it meets these minimums. #### 6.1 Architectural Overview The USB physical topology consists of connecting the downstream hub port to the upstream port of another hub or to a device. The USB can operate at three speeds. High-speed (480 Mb/s) and full-speed (12 Mb/s) require the use of a shielded cable with two power conductors and twisted pair signal conductors. Low-speed (1.5 Mb/s) recommends, but does not require the use of a cable with twisted pair signal conductors. The connectors are designed to be hot plugged. The USB Icon on the plugs provides tactile feedback making it easy to obtain proper orientation. # 6.2 Keyed Connector Protocol To minimize end user termination problems, USB uses a "keyed connector" protocol. The physical difference in the Series "A" and "B" connectors insures proper end user connectivity. The "A" connector is the principle means of connecting USB devices directly to a host or to the downstream port of a hub. All USB devices must have the standard Series "A" connector specified in this chapter. The "B" connector allows device vendors to provide a standard detachable cable. This facilitates end user cable replacement. Figure 6-1 illustrates the keyed connector protocol. Figure 6-1. Keyed Connector Protocol The following list explains how the plugs and receptacles can be mated: - Series "A" receptacle mates with a Series "A" plug. Electrically, Series "A" receptacles function as outputs from host systems and/or hubs. - Series "A" plug mates with a Series "A" receptacle. The Series "A" plug always is oriented towards the host system. - Series "B" receptacle mates with a Series "B" plug (male). Electrically, Series "B" receptacles function as inputs to hubs or devices. - Series "B" plug mates with a Series "B" receptacle. The Series "B" plug is always oriented towards the USB hub or device. #### 6.3 Cable USB cable consists of four conductors, two power conductors, and two signal conductors. High-/full-speed cable consists of a signaling twisted pair, VBUS, GND, and an overall shield. High-/full-speed cable must be marked to indicate suitability for USB usage (see Section 6.6.2). High-/full-speed cable may be used with either low-speed, full-speed, or high-speed devices. When high-/full-speed cable is used with low-speed devices, the cable must meet all low-speed requirements. Low-speed recommends, but does not require the use of a cable with twisted signaling conductors. ## 6.4 Cable Assembly This specification describes three USB cable assemblies: standard detachable cable, high-/full-speed captive cable, and low-speed captive cable. A standard detachable cable is a high-/full-speed cable that is terminated on one end with a Series "A" plug and terminated on the opposite end with a series "B" plug. A high-/full-speed captive cable is terminated on one end with a Series "A" plug and has a vendor-specific connect means (hardwired or custom detachable) on the opposite end for the high-/full-speed peripheral. The low-speed captive cable is terminated on one end with a Series "A" plug and has a vendor-specific connect means (hardwired or custom detachable) on the opposite end for the low-speed peripheral. Any other cable assemblies are prohibited. The color used for the cable assembly is vendor specific; recommended colors are white, grey, or black. #### 6.4.1 Standard Detachable Cable Assemblies High-speed and full-speed devices can utilize the "B" connector. This allows the device to have a standard detachable USB cable. This eliminates the need to build the device with a hardwired cable and minimizes end user problems if cable replacement is necessary. Devices utilizing the "B" connector must be designed to work with worst case maximum length detachable cable. Standard detachable cable assemblies may be used only on high-speed and full-speed devices. Using a high-/full-speed standard detachable cable on a low-speed device may exceed the maximum low-speed cable length. Figure 6-2 illustrates a standard detachable cable assembly. Figure 6-2. USB Standard Detachable Cable Assembly Standard detachable cable assemblies must meet the following electrical requirements: - The cable must be terminated on one end with an overmolded Series "A" plug and the opposite end is terminated with an overmolded Series "B" plug. - The cable must be rated for high-speed and full-speed. - The cable impedance must match the impedance of the high-speed and full-speed drivers. The drivers are characterized to drive specific cable impedance. Refer to Section 7.1.1 for details. - The maximum allowable cable length is determined by signal pair attenuation and propagation delay. Refer to Sections 7.1.14 and 7.1.17 for details. - Differences in propagation delay between the two signal conductors must be minimized. Refer to Section 7.1.3 for details. - The GND lead provides a common ground reference between the upstream and downstream ports. The maximum cable length is limited by the voltage drop across the GND lead. Refer to Section 7.2.2 for details. The minimum acceptable wire gauge is calculated assuming the attached device is high power. - The VBUS lead provides power to the connected device. For standard detachable cables, the VBUS requirement is the same as the GND lead. # 6.4.2 High-/full-speed Captive Cable Assemblies Assemblies are considered captive if they are provided with a vendor-specific connect means (hardwired or custom detachable) to the peripheral. High-/full-speed hardwired cable assemblies may be used with either high-speed, full-speed, or low-speed devices. When using a high-/full-speed hardwired cable on a low-speed device, the cable must meet all low-speed requirements. Figure 6-3 illustrates a high-/full-speed hardwired cable assembly. Figure 6-3. USB High-/full-speed Hardwired Cable Assembly High-/full-speed captive cable assemblies must meet the following electrical requirements: - The cable must be terminated on one end with an overmolded Series "A" plug and the opposite end is vendor specific. If the vendor specific interconnect is to be hot plugged, it must meet the same performance requirements as the USB "B" connector. - The cable must be rated for high-speed and full-speed. - The cable impedance must match the impedance of the high-speed and full-speed drivers. The drivers are characterized to drive specific cable impedance. Refer to Section 7.1.1 for details. - The maximum allowable cable length is determined by signal pair attenuation and propagation delay. Refer to Sections 7.1.14 and 7.1.17 for details. - Differences in propagation delay between the two signal conductors must be minimized. Refer to Section 7.1.3 for details. - The GND lead provides a common reference between the upstream and downstream ports. The maximum cable length is determined by the voltage drop across the GND lead. Refer to Section 7.2.2 for details. The minimum wire gauge is calculated using the worst case current consumption. - The VBUS lead provides power to the connected device. The minimum wire gauge is vendor specific. ## 6.4.3 Low-speed Captive Cable Assemblies Assemblies are considered captive if they are provided with a vendor-specific connect means (hardwired or custom detachable) to the peripheral. Low-speed cables may only be used on low-speed devices. Figure 6-4 illustrates a low-speed hardwired cable assembly. Figure 6-4. USB Low-speed Hardwired Cable Assembly Low-speed captive cable assemblies must meet the following electrical requirements: - The cable must be terminated on one end with an overmolded Series "A" plug and the opposite end is vendor specific. If the vendor specific interconnect is to be hot plugged, it must meet the same performance requirements as the USB "B" connector. - Low-speed drivers are characterized for operation over a range of capacitive loads. This value includes all sources of capacitance on the D+ and D-lines, not just the cable. Cable selection must insure that total load capacitance falls between specified minimum and maximum values. If the desired implementation does not meet the minimum requirement, additional capacitance needs to be added to the device. Refer to Section 7.1.1.2 for details. - The maximum low-speed cable length is determined by the rise and fall times of low-speed signaling. This forces low-speed cable to be significantly shorter than high-/full-speed. Refer to Section 7.1.1.2 for details. - Differences in propagation delay between the two signal conductors must be minimized. Refer to Section 7.1.3 for details. - The GND lead provides a common reference between the upstream and downstream ports. The maximum cable length is determined by the voltage drop across the GND lead. Refer to Section 7.2.2 for details. The minimum wire gauge is calculated using the worst case current consumption. - The VBUS lead provides power to the connected device. The minimum wire gauge is vendor specific. #### 6.4.4 Prohibited Cable Assemblies USB is optimized for ease of use. The expectation is that if the device can be plugged in, it will work. By specification, the only conditions that prevent a USB device from being successfully utilized are lack of power, lack of bandwidth, and excessive topology depth. These conditions are well understood by the system software. Prohibited cable assemblies may work in some situations, but they cannot be guaranteed to work in all instances. #### Extension cable assembly A cable assembly that provides a Series "A" plug with a series "A" receptacle or a Series "B" plug with a Series "B" receptacle. This allows multiple cable segments to be connected together, possibly exceeding the maximum permissible cable length. #### Cable assembly that violates USB topology rules A cable assembly with both ends terminated in either Series "A" plugs or Series "B" receptacles. This allows two downstream ports to be directly connected. Note: This prohibition does not prevent using a USB device to provide a bridge between two USB buses. #### Standard detachable cables for low-speed devices Low-speed devices are prohibited from using standard detachable cables. A standard detachable cable assembly must be high-/full-speed. Since a standard detachable cable assembly is high-/full-speed rated, using a long high-/full-speed cable exceeds the capacitive load of low-speed. ## 6.5 Connector Mechanical Configuration and Material Requirements The USB Icon is used to identify USB plugs and the receptacles. Figure 6-5 illustrates the USB Icon. Figure 6-5. USB Icon ### 6.5.1 USB Icon Location The USB Icon is embossed, in a recessed area, on the topside of the USB plug. This provides easy user recognition and facilitates alignment during the mating process. The USB Icon and Manufacturer's logo should not project beyond the overmold surface. The USB Icon is required, while the Manufacturer's logo is recommended, for both Series "A" and "B" plug assemblies. The USB Icon is also located adjacent to each receptacle. Receptacles should be oriented to allow the Icon on the plug to be visible during the mating process. Figure 6-6 illustrates the typical plug orientation. Figure 6-6. Typical USB Plug Orientation ## 6.5.2 USB Connector Termination Data Table 6-1 provides the standardized contact terminating assignments by number and electrical value for Series "A" and Series "B" connectors. Table 6-1. USB Connector Termination Assignment | Contact<br>Number | Signal Name | Typical Wiring<br>Assignment | |-------------------|-------------|------------------------------| | 1 | VBUS | Red | | 2 | D- | White | | 3 | D+ | Green | | 4 | GND | Black | | Shell | Shield | Drain Wire | # 6.5.3 Series "A" and Series "B" Receptacles Electrical and mechanical interface configuration data for Series "A" and Series "B" receptacles are shown in Figure 6-7 and Figure 6-8. Also, refer to Figure 6-12, Figure 6-13, and Figure 6-14 at the end of this chapter for typical PCB receptacle layouts. Figure 6-7. USB Series "A" Receptacle Interface and Mating Drawing Figure 6-8. USB Series "B" Receptacle Interface and Mating Drawing ## 6.5.3.1 Receptacle Injection Molded Thermoplastic Insulator Material Minimum UL 94-V0 rated, thirty percent (30%) glass-filled polybutylene terephthalate (PBT) or polyethylene terephthalate (PET) or better. Typical Colors: Black, gray, and natural. Flammability Characteristics: UL 94-V0 rated. Flame Retardant Package must meet or exceed the requirements for UL, CSA, VDE, etc. Oxygen Index (LOI): Greater than 21%. ASTM D 2863. ## 6.5.3.2 Receptacle Shell Materials Substrate Material: 0.30 + 0.05 mm phosphor bronze, nickel silver, or other copper based high strength materials. #### Plating: - Underplate: Optional. Minimum 1.00 micrometers (40 microinches) nickel. In addition, manufacturer may use a copper underplate beneath the nickel. - 2. Outside: Minimum 2.5 micrometers (100 microinches) bright tin or bright tin-lead. ## 6.5.3.3 Receptacle Contact Materials Substrate Material: $0.30 \pm 0.05$ mm minimum half-hard phosphor bronze or other high strength copper based material. Plating: Contacts are to be selectively plated. #### A. Option I - Underplate: Minimum 1.25 micrometers (50 microinches) nickel. Copper over base material is optional. - Mating Area: Minimum 0.05 micrometers (2 microinches) gold over a minimum of 0.70 micrometers (28 microinches) palladium. - 3. Solder Tails: Minimum 3.8 micrometers (150 microinches) bright tin-lead over the underplate. ## B. Option II - Underplate: Minimum 1.25 micrometers (50 microinches) nickel. Copper over base material is optional. - Mating Area: Minimum 0.05 micrometers (2 microinches) gold over a minimum of 0.75 micrometers (30 microinches) palladium-nickel. - Solder Tails: Minimum 3.8 micrometers (150 microinches) bright tin-lead over the underplate. #### C. Option III - Underplate: Minimum 1.25 micrometers (50 microinches) nickel. Copper over base material is optional. - 2. Mating Area: Minimum 0.75 micrometers (30 microinches) gold. - Solder Tails: Minimum 3.8 micrometers (150 microinches) bright tin-lead over the underplate. # 6.5.4 Series "A" and Series "B" Plugs Electrical and mechanical interface configuration data for Series "A" and Series "B" plugs are shown in Figure 6-9 and Figure 6-10. Figure 6-9. USB Series "A" Plug Interface Drawing Figure 6-10. USB Series "B" Plug Interface Drawing # 6.5.4.1 Plug Injection Molded Thermoplastic Insulator Material Minimum UL 94-V0 rated, thirty percent (30%) glass-filled polybutylene terephthalate (PBT) or polyethylene terephthalate (PET) or better. Typical Colors: Black, gray, and natural. Flammability Characteristics: UL 94-V0 rated. Flame Retardant Package must meet or exceed the requirements for UL, CSA, and VDE. Oxygen Index (LOI): 21%. ASTM D 2863. ## 6.5.4.2 Plug Shell Materials Substrate Material: 0.30 ± 0.05 mm phosphor bronze, nickel silver, or other suitable material. #### Plating: - A. Underplate: Optional. Minimum 1.00 micrometers (40 microinches) nickel. In addition, manufacturer may use a copper underplate beneath the nickel. - B. Outside: Minimum 2.5 micrometers (100 microinches) bright tin or bright tin-lead. ## 6.5.4.3 Plug (Male) Contact Materials Substrate Material: $0.30 \pm 0.05$ mm half-hard phosphor bronze. Plating: Contacts are to be selectively plated. #### A. Option I - Underplate: Minimum 1.25 micrometers (50 microinches) nickel. Copper over base material is optional. - 2. Mating Area: Minimum 0.05 micrometers (2 microinches) gold over a minimum of 0.70 micrometers (28 microinches) palladium. - Solder Tails: Minimum 3.8 micrometers (150 microinches) bright tin-lead over the underplate. #### B. Option II - Underplate: Minimum 1.25 micrometers (50 microinches) nickel. Copper over base material is optional. - Mating Area: Minimum 0.05 micrometers (2 microinches) gold over a minimum of 0.75 micrometers (30 microinches) palladium-nickel. - Wire Crimp/Solder Tails: Minimum 3.8 micrometers (150 microinches) bright tin-lead over the underplate. #### C. Option III - Underplate: Minimum 1.25 micrometers (50 microinches) nickel. Copper over base material is optional. - 2. Mating Area: Minimum 0.75 micrometers (30 microinches) gold. - Solder Tails: Minimum 3.8 micrometers (150 microinches) bright tin-lead over the underplate. ## 6.6 Cable Mechanical Configuration and Material Requirements High-/full-speed and low-speed cables differ in data conductor arrangement and shielding. Low-speed recommends, but does not require, use of a cable with twisted data conductors. Low speed recommends, but does not require, use of a cable with a braided outer shield. Figure 6-11 shows the typical high-/full-speed cable construction. Figure 6-11. Typical High-/full-speed Cable Construction ## 6.6.1 Description High-/full-speed cable consists of one 28 to 20 AWG non-twisted power pair and one 28 AWG twisted data pair with an aluminum metallized polyester inner shield, 28 AWG stranded tinned copper drain wire, ≥ 65% tinned copper wire interwoven (braided) outer shield, and PVC outer jacket. Low-speed cable consists of one 28 to 20 AWG non-twisted power pair and one 28 AWG data pair (a twist is recommended) with an aluminum metallized polyester inner shield, 28 AWG stranded tinned copper drain wire and PVC outer jacket. $A \ge 65\%$ tinned copper wire interwoven (braided) outer shield is recommended. #### 6.6.2 Construction Raw materials used in the fabrication of this cable must be of such quality that the fabricated cable is capable of meeting or exceeding the mechanical and electrical performance criteria of the most current USB Specification revision and all applicable domestic and international safety/testing agency requirements; e.g., UL, CSA, BSA, NEC, etc., for electronic signaling and power distribution cables in its category. Table 6-2. Power Pair | American Wire<br>Gauge (AWG) | Nominal Conductor<br>Outer Diameter | Stranded Tinned<br>Conductors | |------------------------------|-------------------------------------|-------------------------------| | 28 | 0.381 mm (0.015") | 7 x 36 | | | 0.406 mm (0.016") | 19 x 40 | | 26 | 0.483 mm (0.019") | 7 x 34 | | | 0.508 mm (0.020") | 19 x 38 | | 24 | 0.610 mm (0.024") | 7 x 32 | | | 0.610 mm (0.024") | 19 x 36 | | 22 | 0.762 mm (0.030") | 7 × 30 | | | 0.787 mm (0.031") | 19 x 34 | | 20 | 0.890 mm (0.035") | 7 x 28 | | | 0.931 mm (0.037") | 19 x 32 | Note: Minimum conductor construction must be stranded tinned copper. ## Non-Twisted Power Pair: - A. Wire Gauge: Minimum 28 AWG or as specified by the user contingent upon the specified cable length. Refer to Table 6-2. - B. Wire Insulation: Semirigid polyvinyl chloride (PVC). - 1. Nominal Insulation Wall Thickness: 0.25 mm (0.010") - 2. Typical Power (VBUS) Conductor: Red Insulation - 3. Typical Ground Conductor: Black Insulation ## Signal Pair: A. Wire Gauge: 28 AWG minimum. Refer to Table 6-3. Table 6-3. Signal Pair | American Wire<br>Gauge (AWG) | Nominal Conductor<br>Outer Diameter | Stranded Tinned<br>Conductors | |------------------------------|-------------------------------------|-------------------------------| | 20 | 0.381 mm (0.015") | 7 x 36 | | 28 | 0.406 mm (0.016") | 19 x 40 | Note: Minimum conductor construction must be stranded tinned copper. - Wire Insulation: High-density polyethylene (HDPE), alternately foamed polyethylene or foamed polypropylene - 1. Nominal Insulation Wall Thickness: 0.31 mm (0.012") - 2. Typical Data Plus (+) Conductor: Green Insulation - 3. Typical Data Minus (-) Conductor: White Insulation - C. Nominal Twist Ratio (not required for low-speed): One full twist every 60 mm (2.36") to 80 mm (3.15") Aluminum Metallized Polyester Inner Shield (required for low-speed): - A. Substrate Material: Polyethylene terephthalate (PET) or equivalent material - B. Metallizing: Vacuum deposited aluminum - C. Assembly: - The aluminum metallized side of the inner shield must be positioned facing out to ensure direct contact with the drain wire. - 2. The aluminum metallized inner shield must overlap by approximately one-quarter turn. Drain Wire (required for low-speed): A. Wire Gauge: Minimum 28 AWG stranded tinned copper (STC) non-insulated. Refer to Table 6-4. Table 6-4. Drain Wire Signal Pair | American Wire<br>Gauge (AWG) | Nominal Conductor<br>Outer Diameter | Stranded Tinned<br>Conductors | |------------------------------|-------------------------------------|-------------------------------| | 28 | 0.381 mm (0.015") | 7 x 36 | | 20 | 0.406 mm (0.016") | 19 x 40 | Interwoven (Braided) Tinned Copper Wire (ITCW) Outer Shield (recommended but not required for low-speed): - A. Coverage Area: Minimum 65%. - B. Assembly: The interwoven (braided) tinned copper wire outer shield must encase the aluminum metallized PET shielded power and signal pairs and must be in direct contact with the drain wire. Outer Polyvinyl Chloride (PVC) Jacket: A. Assembly: The outer PVC jacket must encase the fully shielded power and signal pairs and must be in direct contact with the tinned copper outer shield. B. Nominal Wall Thickness: 0.64 mm (0.025"). Marking: The cable must be legibly marked using contrasting color permanent ink. - A. Minimum marking information for high-/full-speed cable must include: - USB SHIELDED <Gauge/2C + Gauge/2C> UL CM 75 °C UL Vendor ID. - B. Minimum marking information for low-speed cable shall include: USB specific marking is not required for low-speed cable. Nominal Fabricated Cable Outer Diameter: This is a nominal value and may vary slightly from manufacturer to manufacturer as a function of the conductor insulating materials and conductor specified. Refer to Table 6-5. Table 6-5. Nominal Cable Diameter | Shielded USB<br>Cable Configuration | Nominal Outer<br>Cable Diameter | |-------------------------------------|---------------------------------| | 28/28 | 4.06 mm (0.160") | | 28/26 | 4.32 mm (0.170") | | 28/24 | 4.57 mm (0.180") | | 28/22 | 4.83 mm (0.190") | | 28/20 | 5.21 mm (0.205") | #### 6.6.3 Electrical Characteristics All electrical characteristics must be measured at or referenced to +20 °C (68 °F). Voltage Rating: 30 V rms maximum. Conductor Resistance: Conductor resistance must be measured in accordance with ASTM-D-4566 Section 13. Refer to Table 6-6. Conductor Resistance Unbalance (Pairs): Conductor resistance unbalance between two (2) conductors of any pair must not exceed five percent (5%) when measured in accordance with ASTM-D-4566 Section 15. The DC resistance from plug shell to plug shell (or end of integrated cable) must be less than 0.6 ohms. Table 6-6. Conductor Resistance | American<br>Wire Gauge (AWG) | Ohms (Ω) / 100 Meters<br>Maximum | |------------------------------|----------------------------------| | 28 | 23.20 | | 26 | 14.60 | | 24 | 9.09 | | 22 | 5.74 | | 20 | 3.58 | ## 6.6.4 Cable Environmental Characteristics Temperature Range: A. Operating Temperature Range: 0 °C to +50 °C B. Storage Temperature Range: -20 °C to +60 °C C. Nominal Temperature Rating: +20 °C Flammability: All plastic materials used in the fabrication of this product shall meet or exceed the requirements of NEC Article 800 for communications cables Type CM (Commercial). # 6.6.5 Listing The product shall be UL listed per UL Subject 444, Class 2, Type CM for Communications Cable Requirements. # 6.7 Electrical, Mechanical, and Environmental Compliance Standards Table 6-7 lists the minimum test criteria for all USB cable, cable assemblies, and connectors. Table 6-7. USB Electrical, Mechanical, and Environmental Compliance Standards | Test Description | Test Procedure | Performance Requirement | |------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------| | Visual and Dimensional Inspection | EIA 364-18 Visual, dimensional, and functional inspection in accordance with the USB quality inspection plans. | Must meet or exceed the requirements specified by the most current version of Chapter 6 of the USB Specification. | | Insulation Resistance | EIA 364-21 The object of this test procedure is to detail a standard method to assess the insulation resistance of USB connectors. This test procedure is used to determine the resistance offered by the insulation materials and the various seals of a connector to a DC potential tending to produce a leakage of current through or on the surface of these members. | 1,000 MΩ minimum. | | Dielectric<br>Withstanding Voltage | EIA 364-20 The object of this test procedure is to detail a test method to prove that a USB connector can operate safely at its rated voltage and withstand momentary over-potentials due to switching, surges, and/or other similar phenomena. | The dielectric must withstand 500 V AC for one minute at sea level. | Table 6-7. USB Electrical, Mechanical, and Environmental Compliance Standards (Continued) | Test Description | Test Procedure | Performance Requirement | |---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Low Level<br>Contact Resistance | EIA 364-23 The object of this test is to detail a standard method to measure the electrical resistance across a pair of mated contacts such that the insulating films, if present, will not be broken or asperity melting will not occur. | $30~\text{m}\Omega$ maximum when measured at 20 mV maximum open circuit at 100 mA. Mated test contacts must be in a connector housing. | | Contact Current<br>Rating | EIA 364-70 — Method B The object of this test procedure is to detail a standard method to assess the current carrying capacity of mated USB connector contacts. | 1.5 A at 250 V AC minimum when measured at an ambient temperature of 25 °C. With power applied to the contacts, the Δ T must not exceed +30 °C at any point in the USB connector under test. | | Contact Capacitance | EIA 364-30 The object of this test is to detail a standard method to determine the capacitance between conductive elements of a USB connector. | 2 pF maximum unmated per contact. | | Insertion Force | EIA 364-13 The object of this test is to detail a standard method for determining the mechanical forces required for inserting a USB connector. | 35 Newtons maximum at a maximum rate of 12.5 mm (0.492") per minute. | | Extraction Force | EIA 364-13 The object of this test is to detail a standard method for determining the mechanical forces required for extracting a USB connector. | 10 Newtons minimum at a maximum rate of 12.5 mm (0.492") per minute. | Table 6-7. USB Electrical, Mechanical, and Environmental Compliance Standards (Continued) | Test Description | Test Procedure | Performance Requirement | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Durability | EIA 364-09 The object of this test procedure is to detail a uniform test method for determining the effects caused by subjecting a USB connector to the conditioning action of insertion and extraction, simulating the expected life of the connectors. Durability cycling with a gauge is intended only to produce mechanical stress. Durability performed with mating components is intended to produce both mechanical and wear stress. | 1,500 insertion/extraction cycles at a maximum rate of 200 cycles per hour. | | Cable Pull-Out | EIA 364-38 Test Condition A The object of this test procedure is to detail a standard method for determining the holding effect of a USB plug cable clamp without causing any detrimental effects upon the cable or connector components when the cable is subjected to inadvertent axial tensile loads. | After the application of a steady state axial load of 40 Newtons for one minute. | | Physical Shock | EIA 364-27 Test Condition H The object of this test procedure is to detail a standard method to assess the ability of a USB connector to withstand specified severity of mechanical shock. | No discontinuities of 1 μs or longer duration when mated USB connectors are subjected to 11 ms duration 30 Gs half-sine shock pulses. Three shocks in each direction applied along three mutually perpendicular planes for a total of 18 shocks. | Table 6-7. USB Electrical, Mechanical, and Environmental Compliance Standards (Continued) | Test Description | Test Procedure | Performance Requirement | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Random Vibration | EIA 364-28 Test Condition V Test Letter A This test procedure is applicable to USB connectors that may, in service, be subjected to conditions involving vibration. Whether a USB connector has to function during vibration or merely to survive conditions of vibration should be clearly stated by the detailed product specification. In either case, the relevant specification should always prescribe the acceptable performance tolerances. | No discontinuities of 1 μs or longer duration when mated USB connectors are subjected to 5.35 Gs RMS. 15 minutes in each of three mutually perpendicular planes. | | Thermal Shock | Test Condition I The object of this test is to determine the resistance of a USB connector to exposure at extremes of high and low temperatures and to the shock of alternate exposures to these extremes, simulating the worst case conditions for storage, transportation, and application. | 10 cycles –55 °C and +85 °C. The USB connectors under test must be mated. | | Humidity Life | EIA 364-31 Test Condition A Method III The object of this test procedure is to detail a standard test method for the evaluation of the properties of materials used in USB connectors as they are influenced by the effects of high humidity and heat. | 168 hours minimum (seven complete cycles). The USB connectors under test must be tested in accordance with EIA 364-31. | | Solderability | EIA 364-52 The object of this test procedure is to detail a uniform test method for determining USB connector solderability. The test procedure contained herein utilizes the solder dip technique. It is not intended to test or evaluate solder cup, solder eyelet, other hand-soldered type, or SMT type terminations. | USB contact solder tails must pass 95% coverage after one hour steam aging as specified in Category 2. |