User manual
Table Of Contents
- Zynq-7000 All Programmable SoC
- Table of Contents
- Ch. 1: Introduction
- Ch. 2: Signals, Interfaces, and Pins
- Ch. 3: Application Processing Unit
- Ch. 4: System Addresses
- Ch. 5: Interconnect
- Ch. 6: Boot and Configuration
- Ch. 7: Interrupts
- Ch. 8: Timers
- Ch. 9: DMA Controller
- Introduction
- Functional Description
- DMA Transfers on the AXI Interconnect
- AXI Transaction Considerations
- DMA Manager
- Multi-channel Data FIFO (MFIFO)
- Memory-to-Memory Transfers
- PL Peripheral AXI Transactions
- PL Peripheral Request Interface
- PL Peripheral - Length Managed by PL Peripheral
- PL Peripheral - Length Managed by DMAC
- Events and Interrupts
- Aborts
- Security
- IP Configuration Options
- Programming Guide for DMA Controller
- Programming Guide for DMA Engine
- Programming Restrictions
- System Functions
- I/O Interface
- Ch. 10: DDR Memory Controller
- Introduction
- AXI Memory Port Interface (DDRI)
- DDR Core and Transaction Scheduler (DDRC)
- DDRC Arbitration
- Controller PHY (DDRP)
- Initialization and Calibration
- DDR Clock Initialization
- DDR IOB Impedance Calibration
- DDR IOB Configuration
- DDR Controller Register Programming
- DRAM Reset and Initialization
- DRAM Input Impedance (ODT) Calibration
- DRAM Output Impedance (RON) Calibration
- DRAM Training
- Write Data Eye Adjustment
- Alternatives to Automatic DRAM Training
- DRAM Write Latency Restriction
- Register Overview
- Error Correction Code (ECC)
- Programming Model
- Ch. 11: Static Memory Controller
- Ch. 12: Quad-SPI Flash Controller
- Ch. 13: SD/SDIO Controller
- Ch. 14: General Purpose I/O (GPIO)
- Ch. 15: USB Host, Device, and OTG Controller
- Introduction
- Functional Description
- Programming Overview and Reference
- Device Mode Control
- Device Endpoint Data Structures
- Device Endpoint Packet Operational Model
- Device Endpoint Descriptor Reference
- Programming Guide for Device Controller
- Programming Guide for Device Endpoint Data Structures
- Host Mode Data Structures
- EHCI Implementation
- Host Data Structures Reference
- Programming Guide for Host Controller
- OTG Description and Reference
- System Functions
- I/O Interfaces
- Ch. 16: Gigabit Ethernet Controller
- Ch. 17: SPI Controller
- Ch. 18: CAN Controller
- Ch. 19: UART Controller
- Ch. 20: I2C Controller
- Ch. 21: Programmable Logic Description
- Ch. 22: Programmable Logic Design Guide
- Ch. 23: Programmable Logic Test and Debug
- Ch. 24: Power Management
- Ch. 25: Clocks
- Ch. 26: Reset System
- Ch. 27: JTAG and DAP Subsystem
- Ch. 28: System Test and Debug
- Ch. 29: On-Chip Memory (OCM)
- Ch. 30: XADC Interface
- Ch. 31: PCI Express
- Ch. 32: Device Secure Boot
- Appx. A: Additional Resources
- Appx. B: Register Details
- Overview
- Acronyms
- Module Summary
- AXI_HP Interface (AFI) (axi_hp)
- CAN Controller (can)
- DDR Memory Controller (ddrc)
- CoreSight Cross Trigger Interface (cti)
- Performance Monitor Unit (cortexa9_pmu)
- CoreSight Program Trace Macrocell (ptm)
- Debug Access Port (dap)
- CoreSight Embedded Trace Buffer (etb)
- PL Fabric Trace Monitor (ftm)
- CoreSight Trace Funnel (funnel)
- CoreSight Intstrumentation Trace Macrocell (itm)
- CoreSight Trace Packet Output (tpiu)
- Device Configuration Interface (devcfg)
- DMA Controller (dmac)
- Gigabit Ethernet Controller (GEM)
- General Purpose I/O (gpio)
- Interconnect QoS (qos301)
- NIC301 Address Region Control (nic301_addr_region_ctrl_registers)
- I2C Controller (IIC)
- L2 Cache (L2Cpl310)
- Application Processing Unit (mpcore)
- On-Chip Memory (ocm)
- Quad-SPI Flash Controller (qspi)
- SD Controller (sdio)
- System Level Control Registers (slcr)
- Static Memory Controller (pl353)
- SPI Controller (SPI)
- System Watchdog Timer (swdt)
- Triple Timer Counter (ttc)
- UART Controller (UART)
- USB Controller (usb)

Zynq-7000 AP SoC Technical Reference Manual www.xilinx.com 461
UG585 (v1.11) September 27, 2016
Chapter 15: USB Host, Device, and OTG Controller
11:10 Error Counter, Cerr. This field is a 2-bit down counter that keeps track of the number of consecutive
Errors detected while executing this qTD.
HCD write:
• 00: the controller will not count errors for this qTD and there will be no limit on the retries of this
qTD.
• 01 to 11: the controller decrements this field for each consecutive USB transaction error [UEI] that
occurs while processing this qTD. If the counter counts from 01 to 00, the controller marks the
qTD inactive, sets the Halted bit = 1, and sets the usb.USBINTR [CERR] error status bit.
Transaction Error Yes
Stall No, see note 1 below.
Babble Detected No, see note 1 below.
No Error No, see note 2 below.
Data Buffer Error No, see note 3 below.
Notes:
1. Detection of Babble or Stall automatically halts the queue head. Thus, count is not decremented
2. If the QH.EPS field indicates a HS device or the queue head is in the Asynchronous Schedule (and PID
code indicates an IN or OUT) and a bus transaction completes and the host controller does not detect
a transaction error, then the host controller should reset Cerr to extend the total number of errors for
this transaction. For example, Cerr should be reset with maximum value (3) on each successful
completion of a transaction. The host controller must never reset this field if the value at the start of
the transaction is 00b.
3. Data buffer errors are host problems. They don't count against the device's retries.
Note: The HCD must not program Cerr to a value of 0 when the QH.EPS field is programmed with
a value indicating a FS or LS device. This combination could result in undefined behavior.
9:8 PID Code, PID. This field is an encoding of the token, which should be used for transactions
associated with this transfer descriptor. Encodings are:
• 00: DUT. Token generates token (E1h)
• 01: IN. Token generates token (69h)
• 10: Setup. Token generates token (2Dh) (undefined if end-point is an Interrupt transfer type,
e.g. microFrame S-mask field in the queue head is non-zero.)
• 11: Reserved.
7 Active Status. Set to 1 by the HCD to enable the execution of transactions by the host controller.
6
Halted Status. Set to a 1 by the host controller during status updates to indicate that a serious error
has occurred at the device/endpoint addressed by this qTD. This can be caused by babble, the error
counter counting down to 0, or reception of the STALL handshake from the device during a
transaction. Any time that a transaction results in the Halted bit being set to a 1, the Active bit is
also set to 0.
5 Data Buffer Error Status. Set to a 1 by the Host Controller during status update to indicate that
the Host Controller is unable to keep up with the reception of incoming data (overrun) or is unable
to supply data fast enough during transmission (under run). If an overrun condition occurs, the Host
Controller will force a timeout condition on the USB, invalidating the transaction at the source. If
the host controller sets this bit to a 1, then it remains a 1 for the duration of the transfer.
4 Babble Detected Status. Set to a 1 by the host controller during status update when “babble” is
detected during the transaction. In addition to setting this bit, the host controller also sets the
Halted bit to a 1. Since “babble” is considered a fatal error for the transfer, setting the Halted bit to
a 1 insures that no more transactions occur because of this descriptor.
Table 15-38: USB Host qTD DWord 2: DT, Total Bytes (Cont’d)
Bits Description










