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 446
UG585 (v1.11) September 27, 2016
Chapter 15: USB Host, Device, and OTG Controller
15.11.3 EHCI Functional Changes for the TT
This section includes:
• Port Reset Timer to off-load software
• Port Speed detection
In a standard EHCI controller design, the Host controller driver (HCD) detects a full-speed or
low-speed device by noting if the port enable bit is set after the port reset operation. The port
enable is set after the port reset operation when the host and device negotiate a High-Speed
connection (i.e., chirp completes successfully).
Because the controller emulates a transaction translator (TT), the port enable is always set after the
port reset operation regardless of the result of the host device chirp result. The resulting port speed
is indicated by the usb.PORTSC1 [PSPD] bit field.
Therefore, a standard EHCI HCD requires alteration to handle direct connection to Full and Low
speed devices or hubs. The changes are fundamental and summarized in Table 15-21.
15.11.4 Port Reset Timer Enhancement
The port connect methods specified by EHCI require setting the port reset bit in the PORTSC register
for a duration of 10 ms. The controller has timers that can count the 10 ms reset pulse to alleviate the
requirement of the HCD to control this timing. The basic connection for the HCD software:
Example: Port Reset Timer for Discovery
This example show a simple attach event and the step that is made optional because of the Port
Reset Timer feature.
1. Wait for device to attach. Receive a port connect change [Port Change Interrupt].
Table 15-21: EHCI HCD Alteration
Function Standard EHCI Embedded Transaction Translator
Hub Speed After port enable bit is set following a
connection and reset sequence, the
device/hub is assumed to be HS.
After port enable bit is set following a connection and reset
sequence, the device (hub) speed is noted from PORTSC1.
FS/LS devices FS and LS devices are assumed to be
downstream from a HS hub thus, all
port-level control is performed through
the Hub Class to the nearest Hub.
FS/LS device can be either downstream from an HS hub or
directly attached. When its downstream, then port-level
control is done using the Hub Class through the nearest
Hub. When a FS/LS device is directly attached, then
port-level control is accomplished using PORTSC1.
Split Target FS and LS devices are assumed to be
downstream from a HS hub with
HubAddr=X; where HubAddr > 0 and
HubAddr is the address of the Hub
where the bus transitions from HS to
FS/LS (i.e. Split target hub).
FS/LS device can be either downstream from a HS hub with
HubAddr = X [HubAddr > 0] or directly attached; where
HubAddr = [TTHA]. [TTHA] is programmable and defaults
to 0. HubAddr is the address of the Root Hub where the bus
transitions from HS to FS/LS (i.e. Split target hub is the root
hub).










