- •TABLE OF CONTENTS
- •1.1 Motivation
- •1.2 Design Goals
- •1.3 Objective of the Specification
- •1.4 Scope of the Document
- •1.5 USB Product Compliance
- •1.6 Document Organization
- •2.1 Terms
- •2.2 Conventions:
- •2.3 References
- •3.1 USB System Description
- •3.1.1 Topology
- •3.1.1.1 USB Host
- •3.1.1.2 Wireless USB Devices
- •3.2 Physical Interface
- •3.3 Power Management
- •3.4 Bus Protocol
- •3.5 Robustness
- •3.5.1 Error Handling
- •3.6 Security
- •3.7 System Configuration
- •3.7.1 Attachment of Wireless USB Devices
- •3.7.2 Removal of Wireless USB Devices
- •3.7.3 Bus Enumeration
- •3.8 Data Flow Types
- •3.9 Wireless USB Devices
- •3.9.1 Device Characterizations
- •3.9.2 Devices and MAC Layer
- •3.10 Wireless USB Host: Hardware and Software
- •4.1 Implementer Viewpoints
- •4.2 Communications Topology
- •4.2.1 Physical Topology
- •4.3 Wireless USB Communication Flows
- •4.3.1 Wireless USB Channel Time
- •4.3.2 MMC Transmission Accuracy
- •4.3.3 USB Time across Device Wire Adapters
- •4.3.5 Device Endpoints
- •4.3.6 Wireless USB Information Exchange Methods
- •4.3.7 Device Perspective
- •4.3.7.1 Self Beaconing Devices
- •4.3.7.2 Directed Beaconing Devices
- •4.3.7.3 Non Beaconing Devices
- •4.3.7.4 Selecting A Wireless USB Host
- •4.3.8 Host Perspective
- •4.3.8.1 MAC Layer Compliant Device
- •4.3.8.2 Wireless USB Host
- •4.3.8.3 Host System Management
- •4.3.8.5 Other Host Considerations
- •4.4 Data Transfers
- •4.4.1 Burst Mode Data Phase
- •4.5 Bulk Transfers
- •4.5.1 Bulk Transfer Packet Size and Signaling Rate Constraints
- •4.5.2 Bulk Transfer Channel Access Constraints
- •4.5.3 Bulk Transfer Data Sequences
- •4.6 Interrupt Transfers
- •4.6.1 Low Power Interrupt IN
- •4.6.2 Interrupt Transfer Packet Size and Signaling Rate Constraints
- •4.6.3 Interrupt Transfer Channel Access Constraints
- •4.6.4 Interrupt Transfer Data Sequences
- •4.7 Isochronous Transfers
- •4.7.1 Isochronous Transfer Packet Size and Signaling Rate Constraints
- •4.7.2 Isochronous Transfer Channel Access Constraints
- •4.7.3 Isochronous Transfer Data Sequences
- •4.7.4 Isochronous Endpoint Host System Admission Decisions
- •4.7.5 Isochronous Data Discards and Use of Isochronous Packet Discard IE
- •4.8 Control Transfers
- •4.8.1 Control Transfer Packet Size and Signaling Rate Constraints
- •4.8.2 Control Transfer Channel Access Constraints
- •4.8.3 Control Transfer Data Sequences
- •4.8.4 Data Loopback Commands
- •4.9 Device Notifications
- •4.10 Media Reliability Considerations
- •4.10.1 Transmit Power Control
- •4.10.2 Adjustments to Data Phase Packet Payload Sizes
- •4.10.3 Adjustments to Transmit Bit Rate
- •4.10.4 Changing PHY Channel
- •4.10.5 Host Schedule Control
- •4.10.6 Dynamic Bandwidth Interface Control
- •4.11 Special Considerations for Isochronous Transfers
- •4.11.1 Summary Of Key Features Of USB Wired Isochrony
- •4.11.1.1 Wireless Service Intervals
- •4.11.2 UWB Media Characteristics
- •4.11.2.1 Superframe Layout
- •4.11.2.2 Worst Case Superframe Layout – Service Interval Bounds.
- •4.11.2.3 Wireless Packet Error Rates
- •4.11.3 Wireless USB Isochronous Transfer Level Protocol
- •4.11.4 Wireless USB Isochronous IN Example
- •4.11.5 Wireless USB Isochronous OUT Example
- •4.11.6 Choosing an Isochronous IN or Isochronous OUT Endpoint Buffer Size
- •4.11.7 Isochronous OUT endpoint receiver implementation options
- •4.11.7.1 Presentation Time aware implementation
- •4.11.7.2 Presentation time aware implementation with “false” acknowledgement
- •4.11.7.3 Presentation time unaware implementations
- •4.11.8 Synchronization
- •4.11.8.1 Synchronizing a Stream Start Time
- •4.11.9 Error Handling Details
- •4.11.9.1 Reporting Data Discarded At the Transmitter
- •4.11.9.2 Discarding Data during A Burst
- •4.11.9.3 Application Handling of Discards
- •4.12 Device Reset
- •4.13 Connection Process
- •4.13.1 Reconnection Process
- •4.14 Disconnect
- •4.15 Security Mechanisms
- •4.15.1 Connection Lifetime
- •4.15.2 Host Security Considerations
- •4.15.2.1 CHID Selection
- •4.15.2.2 CDID Selection
- •4.16 Wireless USB Power Management
- •4.16.1 Device Power Management
- •4.16.1.1 Device Sleep
- •4.16.1.2 Device Wakeup
- •4.16.2 Host Power Management
- •4.16.2.1 Channel Stop
- •4.16.2.2 Remote Wakeup
- •4.16.2.3 Channel Start
- •4.17 Dual Role Devices (DRD)
- •4.17.2 Pairing P2P-DRD to establish reverse link
- •5.1 Packet Formats
- •5.2 Wireless USB Transaction Groups
- •5.2.1 Wireless USB Channel Time Allocation Information Elements
- •5.3 Transaction Group Timing Constraints
- •5.3.1 Streaming-Mode Inter-packet Constraints for the PHY
- •5.3.2 Protocol Synchronization
- •5.4 Data Burst Synchronization and Retry
- •5.5 Wireless USB Transactions
- •5.5.1 Isochronous Transactions
- •5.5.2 Control Transfers
- •5.5.3 Device Notifications
- •5.5.4 Flow Control
- •6.1 Introduction
- •6.1.1 Goal of USB Security
- •6.1.2 Security and USB
- •6.2 Overview
- •6.2.1 Base of Trust
- •6.2.2 Preserve the Nature of the USB Device Model
- •6.2.3 Implementation of Security Extensions
- •6.2.4 Encryption Methods
- •6.2.5 Message Format
- •6.2.6 Encryption Keys
- •6.2.6.1 Master Keys
- •6.2.6.2 Session Keys
- •6.2.7 Correct key determination
- •6.2.8 Replay Prevention
- •6.2.9 Secure Packet Reception
- •6.2.10 General Connection Model
- •6.2.10.1 Connection Context
- •6.2.10.2 Connection Lifetime
- •6.2.10.3 New Connection
- •6.2.10.4 Connection
- •6.2.10.5 Reconnection
- •6.2.10.6 Revocation
- •6.2.10.8 Diagnostic Support
- •6.2.10.9 Mutual Authentication
- •6.2.11 Key Management
- •6.2.11.1 PTK Management
- •6.2.11.2 GTK Management
- •6.3 Association and Authentication
- •6.3.1 Connection and Reconnection Requests
- •6.3.2 Authentication
- •6.3.2.1 Authentication Related Device Capabilities
- •6.3.2.2 Ceremonies
- •6.4.1 CCM nonce Construction
- •6.4.2 l(m) and l(a) Calculation
- •6.4.3 Counter-mode Bx Blocks
- •6.4.4 Encryption Ax Blocks
- •6.5.1 Key Derivation
- •6.5.2 Out-of-band MIC Generation
- •6.5.3 Example Random Number Generation
- •7.1 Wireless USB Device States
- •7.1.1 UnConnected
- •7.1.2 UnAuthenticated
- •7.1.3 Authenticated
- •7.1.4 Reconnecting
- •7.2 Generic Wireless USB Device Operations
- •7.3 Standard Wireless USB Device Requests
- •7.3.1 Wireless USB Extensions to Standard Requests
- •7.3.1.1 Clear Feature
- •7.3.1.2 Get Status
- •7.3.1.3 Set Address
- •7.3.1.4 Set Feature
- •7.3.1.5 Set Interface DS
- •7.3.1.6 Set WUSB Data
- •7.3.1.7 Data Loopback Write
- •7.3.1.8 DATA Loopback Read
- •7.3.2 Security-related Requests
- •7.3.2.1 Get Security Descriptor
- •7.3.2.2 Set Encryption
- •7.3.2.3 Get Encryption
- •7.3.2.4 Key Management
- •7.3.2.6 Set Security Data
- •7.3.2.7 Get Security Data
- •7.4 Standard Wireless USB Descriptors
- •7.4.1 Device Level Descriptors
- •7.4.1.1 Wireless USB Device Capabilities – UWB
- •7.4.2 Configuration
- •7.4.3 Endpoint
- •7.4.4 Wireless USB Endpoint Companion
- •7.4.5 Security-Related Descriptors
- •7.4.5.1 Security Descriptor
- •7.4.5.2 Key Descriptor
- •7.5 Wireless USB Channel Information Elements
- •7.5.1 Wireless USB Connect Acknowledge IE
- •7.5.2 Wireless USB Host Information IE
- •7.5.3 Wireless USB Channel Change Announcement IE
- •7.5.4 Wireless USB Device Disconnect IE
- •7.5.5 Wireless USB Host Disconnect IE
- •7.5.6 Wireless USB Release Channel IE
- •7.5.7 Wireless USB Work IE
- •7.5.8 Wireless USB Channel Stop IE
- •7.5.9 Wireless USB Device Keepalive IE
- •7.5.10 Wireless USB Isochronous Packet Discard IE
- •7.5.11 Wireless USB Reset Device IE
- •7.5.12 Wireless USB Transmit Packet Adjustment IE
- •7.6 Device Notifications
- •7.6.1 Device Connect (DN_Connect)
- •7.6.1.1 Connect Request
- •7.6.1.2 Reconnect Request
- •7.6.2 Device Disconnect (DN_Disconnect)
- •7.6.3 Device Endpoints Ready (DN_EPRdy)
- •7.6.4 Device MAS Availability Changed (DN_MASAvailChanged)
- •7.6.5 Device Sleep (DN_Sleep)
- •7.6.6 Remote Wakeup (DN_RemoteWakeup)
- •7.6.7 Device Alive (DN_Alive)
- •8.1 Operational Model
- •8.1.1 Functional Characteristics
- •8.1.2 Data Transfer Interface
- •8.1.3 Remote Pipe
- •8.1.4 Wire Adapter Functional Blocks
- •8.1.5 Downstream Port(s)
- •8.1.6 Upstream Port
- •8.1.7 Downstream Host Controller
- •8.1.8 Upstream Endpoint Controller
- •8.1.9 Remote Pipe Controller
- •8.1.9.1 RPipe Descriptor
- •8.1.9.2 Bulk OUT Overview
- •8.1.9.3 Bulk IN Overview
- •8.1.9.4 Control Transfer Overview
- •8.1.9.5 Interrupt Transfer Overview
- •8.1.9.6 Isochronous Transfer Overview
- •8.1.10 Suspend and Resume
- •8.1.10.1 DWA Suspend and Resume
- •8.1.10.2 HWA Suspend and Resume
- •8.1.11 Reset Behavior
- •8.1.12 Device Control
- •8.1.13 Buffer Configuration
- •8.2 Descriptors
- •8.3 Requests
- •8.3.1 Wire Adapter Class-Specific Requests
- •8.3.1.1 Abort RPipe
- •8.3.1.2 Clear RPipe Feature
- •8.3.1.3 Clear Wire Adapter Feature
- •8.3.1.4 Get RPipe Descriptor
- •8.3.1.5 Get RPipe Status
- •8.3.1.6 Get Wire Adapter Status
- •8.3.1.7 Set RPipe Descriptor
- •8.3.1.8 Set RPipe Feature
- •8.3.1.9 Set Wire Adapter Feature
- •8.3.1.10 Reset RPipe
- •8.3.2 Notification Information
- •8.3.3 Transfer Requests
- •8.3.3.1 Control Transfers
- •8.3.3.2 Bulk and Interrupt Transfers
- •8.3.3.3 Transfer Completion Notification
- •8.3.3.4 Transfer Result
- •8.3.3.5 Abort Transfer
- •8.4 DWA Interfaces, Descriptors and Control
- •8.4.1 DWA Isochronous Streaming Interface
- •8.4.2 DWA Isochronous Streaming Overview
- •8.4.3 DWA Descriptors
- •8.4.3.1 Device Descriptor
- •8.4.3.2 Binary Device Object (BOS) Descriptor
- •8.4.3.3 Configuration Descriptor
- •8.4.3.4 Security Descriptors
- •8.4.3.5 Interface Association Descriptor
- •8.4.3.6 Data Transfer Interface Descriptor
- •8.4.3.7 Wire Adapter Class Descriptor
- •8.4.3.8 Notification Endpoint Descriptor
- •8.4.3.9 Notification Endpoint Companion Descriptor
- •8.4.3.10 Data Transfer Write Endpoint Descriptor
- •8.4.3.11 Data Transfer Write Endpoint Companion Descriptor
- •8.4.3.12 Data Transfer Read Endpoint Descriptor
- •8.4.3.13 Data Transfer Read Endpoint Companion Descriptor
- •8.4.3.14 Isochronous Streaming Interface Descriptor
- •8.4.3.15 Isochronous Streaming OUT Endpoint Descriptor
- •8.4.3.16 Isochronous Streaming OUT Endpoint Companion Descriptor
- •8.4.3.17 Isochronous Streaming IN Endpoint Descriptor
- •8.4.3.18 Isochronous Streaming IN Endpoint Companion Descriptor
- •8.4.3.19 Wire Adapter RPipe Descriptor
- •8.4.4 DWA Specific Requests
- •8.4.4.1 Clear Port Feature
- •8.4.4.2 Get Port Status
- •8.4.4.3 Set Isochronous Endpoint Attributes
- •8.4.4.4 Set Port Feature
- •8.4.5 DWA Notification Information
- •8.4.5.1 Remote Wake
- •8.4.5.2 Port Status Change
- •8.4.6 DWA Isochronous Transfers
- •8.4.6.1 DWA Isochronous OUT Responsibilities
- •8.4.6.2 DWA Isochronous IN Responsibilities
- •8.5 HWA Interfaces, Descriptors and Control
- •8.5.1 HWA Isochronous Streaming Overview
- •8.5.2 HWA Descriptors
- •8.5.2.1 Device Descriptor
- •8.5.2.2 Device_Qualifier Descriptor
- •8.5.2.3 Configuration Descriptor
- •8.5.2.4 Other_Speed_Configuration Descriptor
- •8.5.2.5 Security Descriptors
- •8.5.2.6 Data Transfer Interface Descriptor
- •8.5.2.7 Wire Adapter Class Descriptor
- •8.5.2.8 Notification Endpoint Descriptor
- •8.5.2.9 Data Transfer Write Endpoint Descriptor
- •8.5.2.10 Data Transfer Read Endpoint Descriptor
- •8.5.2.11 Wire Adapter RPipe Descriptor
- •8.5.3 HWA Specific Requests
- •8.5.3.2 Get BPST Adjustment
- •8.5.3.3 Get BPST Time
- •8.5.3.4 Get WUSB Time
- •8.5.3.5 Remove MMC IE
- •8.5.3.6 Set Device Encryption
- •8.5.3.7 Set Device Info
- •8.5.3.8 Set Device Key
- •8.5.3.9 Set Group Key
- •8.5.3.10 Set Num DNTS Slots
- •8.5.3.11 Set WUSB Cluster ID
- •8.5.3.12 Set WUSB MAS
- •8.5.3.13 Set WUSB Stream Index
- •8.5.3.14 WUSB Channel Stop
- •8.5.4 HWA Notification Information
- •8.5.4.1 BPST Adjustment Change
- •8.5.4.2 DN Received Notification
- •8.5.5 HWA Isochronous Transfers
- •8.5.5.1 HWA Isochronous OUT Responsibilities
- •8.5.5.2 HWA Isochronous IN Responsibilities
- •8.5.5.3 HWA Isochronous Transfer Completion
- •8.6 Radio Control Interface
- •8.6.1 Radio Control Descriptors
- •8.6.1.1 Radio Control Interface Descriptor
- •8.6.1.2 Radio Control Interface Class Descriptor
- •8.6.1.3 Radio Control Interrupt Endpoint Descriptor
- •8.6.2 Radio Control Command
- •8.6.2.1 Channel Change
- •8.6.2.2 Device Address Management
- •8.6.2.4 Reset
- •8.6.2.5 Scan
- •8.6.2.6 Set Beacon Filter
- •8.6.2.9 Set Notification Filter
- •8.6.2.10 Set TX Power
- •8.6.2.11 Sleep
- •8.6.2.12 Start Beaconing
- •8.6.2.13 Stop Beaconing
- •8.6.3 Radio Control Notifications
- •8.6.3.1 Application-specific Probe IE Received Notification
- •8.6.3.2 Beacon Received Notification
- •8.6.3.3 Beacon Size Notification
- •8.6.3.4 BPOIE Change Notification
- •8.6.3.5 BP Slot Change Notification
- •8.6.3.6 BP Switch IE Received Notification
- •8.6.3.7 Device Address Conflict Notification
- •8.6.3.8 DRP Availability Changed Notification
- •8.6.3.9 DRP Notification
- •A.1 Key Derivation
- •A.2 Handshake MIC calculation
- •A.3 Secure MMC (EO = payload length)
- •A.4 Data IN from device (EO = 2)
- •B.1 Descriptors for DWA
- •B.2 Descriptors for HWA
Chapter 8 |
|
Wire Adapter |
Wireless Universal Serial Bus Specification, Revision 1.0 |
Chapter 8
Wire Adapter
The Wire Adapter Class definition provides a generic abstraction that delivers the capabilities of a Wired or Wireless USB Host Controller through a USB device interface. This definition includes devices that are used to connect wired USB devices to a Wireless USB host (Device Wire Adapter) and also to those devices that add Wireless USB capabilities to a USB 2.0 host (Host Wire Adapter).
This chapter contains all necessary information for a designer to build a compliant Wire Adapter device. It specifies the standard and class-specific descriptors that must be present in each Wire Adapter. It further explains the use of class-specific requests that allow for full control of the Wire Adapter. This chapter is intended to be useful for:
•A hardware device vendor or firmware engineer intending to build and program a Wired or Wireless USB connected Wire Adapter which adheres to this specification, and
•A software driver developer.
This chapter first describes the common operation model and control mechanisms for Wire Adapters. This is followed by a Device Wire Adapter-specific section then a Host Wire Adapter specific section. The last section details requirements for a radio management interface, which is a required interface for a Host Wire Adapter.
8.1Operational Model
This chapter defines two forms of Wire Adapters as illustrated in Figure 8-1. A Host Wire Adapter (HWA) is a USB device whose upstream connection is a USB 2.0 wired interface. The HWA operates as a host to a cluster of downstream Wireless USB devices. The Device Wire Adapter (DWA) is a USB device whose upstream connection is a Wireless USB interface. The DWA operates as a USB 2.0 (wired) host to devices connected below its downstream port(s). Figure 8-1 illustrates the USB device connection topology enabled when HWAs and DWAs are ‘connected’ in series. The HWA is the host to the DWA and WUSB Dev devices and the DWA is the host for the Mass Storage and other USB2 device.
Figure 8-1. Wire Adapter Enabled USB Device Topology
8.1.1 Functional Characteristics
The basic functional block models for a HWA and DWA are illustrated in Figure 8-2. The common functional components of a Wire Adapter (WA) include the device control and WA functions. Device control is accessed via the Default Control Pipe using the USB 2.0 or Wireless USB standard device requests. These requests are defined in Chapter 9 of the USB 2.0 specification and Section 7.3 of this specification. Host Wire Adapters provide an interface for controlling the UWB radio (see Section 8.6). Device Wire Adapters provide an Isochronous Streaming interface to support isochronous data streams (see Section 8.4.1).
195
Chapter 8 |
|
Wire Adapter |
Wireless Universal Serial Bus Specification, Revision 1.0 |
Figure 8-2. Wire Adapter Functional Model Block Diagrams
The WA function is operationally common to all WA implementations. The WA function is managed via the WA Data Transfer Interface (see Section 8.1.2). HWA and DWA-specific portions of the Data Transfer interface are described in Sections 8.5 and 8.4, respectively.
8.1.2 Data Transfer Interface
This interface has a minimum of three function endpoints. These endpoints, plus the default Control endpoint are used to accomplish all of the data and control communications between the USB host system and the Wire Adapter. The endpoints and their purposes are enumerated below:
Control Endpoint |
This is the standard Default Control Pipe. It handles all non-transfer |
|
requests including all of the required standard requests which are |
|
defined in chapter 9 of the USB 2.0 specification and the WA class |
|
specific requests defined in Section8.3. |
Notification Endpoint |
This Interrupt IN endpoint provides transfer status notifications to the |
|
host. Transfer status is not returned on this endpoint. Instead, it |
|
provides a notification that transfer status or data is available on the |
|
Data Transfer Read Endpoint. Other asynchronous notifications are |
|
also returned on this endpoint. |
|
A Wire Adapter can send multiple notifications (up to the max packet |
|
size of the interrupt endpoint) when it is polled. See Section 8.3.2 for |
|
the types of notifications that may be sent to a host by a Wire Adapter. |
Data Transfer |
This set of paired (IN/OUT) endpoints is used to move data and data |
Endpoint Pair |
transfer requests through the Wire Adapter to/from the client function |
|
endpoint. Note 1 |
|
The bulk OUT endpoint is used to send transfer requests and transfer |
|
data from the host to the Wire Adapter. |
|
The bulk IN endpoint is used to return transfer status and transfer data |
|
from the Wire Adapter to the host. See below for details. |
A DWA does not use the Data Transfer endpoint pair in the Data Transfer Interface to perform Isochronous transfers. All DWAs that support Isochronous transfers must have an Isochronous Streaming interface (See Section 8.4.1).
196
Chapter 8 |
|
Wire Adapter |
Wireless Universal Serial Bus Specification, Revision 1.0 |
8.1.3 Remote Pipe
A Remote Pipe is a logical abstraction that provides a data flow through the Wire Adapter to a specific endpoint on a specific device. Pipes are described in detail in Chapters 5 and 10 of the USB Specification 2.0.
A Wire Adapter provides a fixed number of Remote Pipes. The number of Remote Pipes supported is up to the implementer. A simple Wire Adapter must provide at least 1 Remote Pipe to provide support for a single attached device that only requires a control endpoint. The maximum number of Remote Pipes that a Wire Adapter would need to support is 3937 (127 devices X 31 endpoints/device); however Wire Adapter implementations are never expected to support 3937 physical Remote Pipes. Host software will multiplex Remote Pipes between Asynchronous endpoints. Periodic endpoints that have active transfers will require dedicated Remote Pipes. The minimum number of Remote Pipes is twice the number of devices (HWA) or ports (DWA) that the Wire Adapter supports at the same time.
The Default Control Pipe is used to initialize and manage individual Remote Pipes and the Data Transfer Pair is used to move data through them. The general operational flow of a Remote Pipe is:
1.Host initializes a Remote Pipe resource on the Wire Adapter via requests on the Default Control Pipe (see Section 8.3.1).
2.To start a control, bulk, or interrupt transfer to a device connected downstream of a Wire Adapter, the host sends a Transfer Request (Section 8.3.3) over the Data Transfer OUT endpoint to the Wire Adapter function. The Transfer Request is addressed to a specific Remote Pipe resource on the Wire Adapter. If the associated client function endpoint is an OUT, the OUT data will immediately follow the Transfer Request. In general the Data Transfer OUT endpoint is used for the following purposes:
•Send Transfer Requests
•Send data destined for a device connected to one of the ports of the Wire Adapter
•Stop a Transfer Request by sending Abort Transfer Request
The Wire Adapter must check the length and transfer request type of the Transfer Request packet received and ensure that they match. It also must check that the target Remote Pipe is configured to the same transfer type.
If the Transfer Request received by the Wire Adapter is an OUT transaction, then the data destined for the downstream device will be sent immediately after the request in the next packet. The amount of data that follows the Transfer Request is described in the Transfer Request.
The Wire Adapter does not STALL the endpoint when the Transfer Request is incorrect. Rather, it continues to accept the Transfer Request and any data that may follow the request. The Wire Adapter must then send a Transfer Completion notification on the notification endpoint. The host will respond by polling the associated Data Transfer IN endpoint to get the Transfer Result, which must state that the Wire Adapter detected an error in the Transfer Request. The error values are defined in Table 8-15 (see Section 8.3.3.4).
3.When the transfer completes, the Wire Adapter sends a Transfer Complete Notification (Section 8.3.3.3) to the host on the notification endpoint.
4.The data and transfer results generated from a bulk, interrupt or control transfer request are transferred to the host from the Wire Adapter through the Data Transfer IN endpoint. The data stream on this endpoint is organized as a Transfer Result (Section 8.3.3.4) followed by an optional stream of transfer data from the associated endpoint. The amount of data to be returned to the host is described in the Transfer Result.
If a transfer does not complete successfully, the Wire Adapter will only return a Transfer Result and will not return any data back to the host.
If the host sends more Transfer Requests than a Remote Pipe in the Wire Adapter can concurrently handle (as reported in its RPipe descriptor) the Wire Adapter will NAK the transaction until it has completed a pending transfer on that Remote Pipe.
Section 8.5.1 describes how isochronous transfers are handled on a HWA and Section 8.4.1 describes how they are handled on a DWA.
197
Chapter 8 |
|
Wire Adapter |
Wireless Universal Serial Bus Specification, Revision 1.0 |
8.1.4 Wire Adapter Functional Blocks
The Wire Adapter consists of five functional blocks as illustrated in Figure 8-3.
Upstream Port
Upstream Endpoint |
|
RPipe Controller |
Controller |
|
|
|
|
|
|
|
|
Downstream Host Controller
Downstream Port(s)
Figure 8-3. General WA Function Blocks
8.1.5 Downstream Port(s)
A Device Wire Adapter has one or more downstream ports. The ports behave like those in the USB 2.0 hubs. The Device Wire Adapter monitors the status of all of the ports and reports them to the host if there is any change.
The number of downstream ports that is implemented on a Device Wire Adapter is indicated in the bNumPorts field of the Wire Adapter Class Descriptor. The maximum number of downstream ports that can be implemented on a Wire Adapter is 127. The functions and behavior of the downstream port on a DWA are the same as the ones of a USB 2.0 Hub which are described in the Section 11.5 of the USB 2.0 Specification.
A Host Wire Adapter does not have downstream ports since all the devices it can communicate with are Wireless. The HWA will forward all asynchronous notifications (connect/reconnect/disconnect/sleep etc) received from a downstream device to Host software. Host software is responsible for handling the various downstream port functions for an HWA. However, an HWA needs to store some information for each device connected downstream of it, See Section 8.5.3.6. An HWA specifies the total number of devices that can be connected to it in the bNumPorts field in its Wire Adapter descriptor.
8.1.6 Upstream Port
A host communicates with a Wire Adapter via its upstream port. The port is used for:
•Control of the Wire Adapter function
•Notification of changes to the host
•Communicating with the devices connected downstream of the Wire Adapter (via Remote Pipes)
A HWA may be a Bus Powered USB 2.0 device. The upstream port of the HWA must operate at Full-speed and High-speed. If the HWA is operating at full speed then Isochronous transfers are not supported. The upstream port of an HWA is the device side interface of a USB 2.0 device which is described in Section 11.6 of the USB 2.0 Specification.
The upstream port of a DWA is the device side interface of a Wireless USB device which is described in Chapter 7 of this specification.
198