User manual

Table Of Contents
Zynq-7000 AP SoC Technical Reference Manual www.xilinx.com 469
UG585 (v1.11) September 27, 2016
Chapter 15: USB Host, Device, and OTG Controller
15.13 Programming Guide for Host Controller
The host controller driver software (HCD) provides a layered software architecture to control all
aspects of a USB bus system. The HCD controls the functions of an embedded EHCI host controller.
The USB driver layer provides all the USB driver functions to enumerate, manage and schedule a USB
bus system, while the upper layers of the stack support standard USB device class interfaces to the
device drives running on the embedded system.
15.13.1 Controller Reset
The controller has multiple types of resets, as described in section 15.15.2 Reset Types.
15.13.2 Run/Stop
When the HCD sets the usb.USBCMD [RS] bit = 1, the controller proceeds to the execute the periodic
and asynchronous schedules. The controller continues execution as long as this bit is set to a 1. When
this bit is set to 0, the host controller completes the current transaction on the USB and then halts.
When the controller is finished with the transaction and has entered the stopped state, it writes a 1
to the usb.USBSTS [HCH] bit. Software should not write a 1 to the [RS] bit to enable the controller
unless the controller is in the Halted state, usb.USBSTS [HCH] bit = 1.
15.14 OTG Description and Reference
The register bits that are used for OTG operations are not reset when software writes a 1 to the
usb.USBCMD [RST] reset bit. These bits are identified in Table 15-1, page 407.
Table 15-47: USB Host FSTN DWord 1: Back Path Link Pointer
Bits Description
31:5 Back Path Link Pointer. This field contains the address of a Queue Head. This field corresponds to
memory address signals [31:5], respectively.
4:3 Reserved. Field reserved and should be set to 0.
2:1 Transaction Descriptor Type, TYP. Set to 11 (FSTN type). Refer to section 15.12.2 Transfer Descriptor
Type (TYP) Field for general information.
0 Terminate bit, T.
1: Link Pointer field is invalid and the FSTN is a Restore indicator.
0: Link Pointer field points to a valid system memory offset from CTRLDSSEGMENT
and the FSTN is a Save-Place indicator.