User manual

Table Of Contents
Zynq-7000 AP SoC Technical Reference Manual www.xilinx.com 437
UG585 (v1.11) September 27, 2016
Chapter 15: USB Host, Device, and OTG Controller
flush failed: in very rare cases, a packet is in progress to the particular endpoint when
commanded flush using usb.ENDPTFLUSH. A safeguard is in place to refuse the flush to ensure
that the packet in progress completes successfully. The DCD might need to repeatedly flush any
endpoints that fail to flush be repeating steps 1–3 until each endpoint is successfully flushed.
Note: A time out counter can be programmed to recover from when an endpoint flush fails.
Device Errors
Table 15-16 summarizes packet errors that are not automatically handled by the device controller.
Notice that the device controller handles all errors on Bulk/Control/Interrupt Endpoints except for a
data buffer overflow. However, for IsoUSB endpoints, errors packets are not retried and errors are
tagged as indicated.
15.9.4 Service Device Mode Interrupts
Note: The interrupt service routine must consider that there are high-frequency, low-frequency
operations, and error interrupts. It is likely that multiple interrupts will stack up on a call to the
Interrupt Service Routine (ISR) and then during the execution of the interrupt service routine.
The interrupt handling strategy is up to the user. The ISR can poll the high-frequency and then
low-frequency interrupts before exiting. If another interrupt is detected and processed, then the ISR
would perform another ‘last scan’ of the interrupts before exiting.
High-Frequency Interrupts
High frequency interrupts, in particular, should be handed in the order shown in Table 15-17. The
most important of these are the first two, 1a and 1b. They have equal priority because the software
Table 15-16: USB Device Errors
Error Direction
Packet
Type
Data Buffer
Error Bit
(dTD.Status
bit 5)
Transaction
Error Bit
(dTD.Status
bit 3)
Description
Overflow Rx Any 10
Number of bytes received exceeded max. packet size or
total buffer length. This error will also set the Halt bit in
the dQH and if there are dTDs remaining in the linked
list for the endpoint, then those will not be executed.
Isochronous
Packet
Rx Iso 01
CRC Error on received isochronous packet. Contents not
guaranteed to be correct.
Isochronous
Fulfillment
Both Iso 01
Host failed to complete the number of packets defined
in the dQH.Mult field within the given (micro)frame. For
scheduled data delivery the DCD might need to readjust
the data queue because a fulfillment error will cause
Device Controller to cease data transfers on the pipe for
one (micro)frame. During the “dead” (micro)frame, the
Device Controller reports error on the pipe and primes
for the following frame.