

---

| <b>Rev.</b> | <b>Date</b> | <b>Author</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                    |
|-------------|-------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.2         | 30/3/01     | RU            | Rearranged Appendixes.<br>Moved Buffer Memory (SSRAM) outside the core.<br>Added Appendix describing SSRAM timing.<br>Filled in Core Configuration Appendix.<br>Modified DMA Operations section.<br>Added OTS_STOP bit in endpoint CSR register.<br>Added "OUT is smaller than MAX_PL_SZ" interrupt.<br>Fixed addresses of registers. |
| 1.3         | 30/5/01     | RU            | Fixed many syntax and grammar errors.<br>Removed Software model Section.<br>Added Appendix E: Software model, provided by Chris Ziomkowski (chris@asics.ws).                                                                                                                                                                          |
| 1.4         | 10/8/01     | RU            | - Changed IO names to be more clear.<br>- Uniquifyed define names to be core specific.                                                                                                                                                                                                                                                |
| 1.5         | 26/1/02     | RU            | - Added more detailed descriptions and clarifications.                                                                                                                                                                                                                                                                                |
|             |             |               |                                                                                                                                                                                                                                                                                                                                       |

# 1

---

## Introduction

The Universal Serial Bus (USB) has evolved to the standard interconnect between computers and peripherals. Everything from a mouse to a camera can be connected via USB. With the new USB 2.0 specification, data rates of over 480 Mb/s are possible.

The Universal Serial Bus is a point to point interface. Multiple peripherals are attached through a HUB to the host.

This core provides a function (peripheral device) interface. It can be used to interface almost any peripheral to a computer via USB. This core fully complies to the USB 2.0 specification and can operate at USB Full and High Speed rates (12 and 480 Mb/s).

### **Note:**

---

This specification assumes that the core will most likely be used in a high speed environment and includes references to special high speed extensions. However, when operation in full speed mode only, some of those high speed extensions will not be used and the core will properly behave as a full speed function only.

---

(This page intentionally left blank)

# 2

## Architecture

The figure below illustrates the overall architecture of the core. The host interface provides a bridge between the internal data memory and control registers to the function controller. The data memory and control registers interface to the Protocol Layer (PL). The protocol layer interfaces to UTMI interface block. The UTMI block interfaces to the PHY. Each of the blocks is described in detail below.

**Figure 1: Core Architecture Overview**



### 2.1. Clocks

The USB core has two clock domains. The UTMI interface block, runs off the clock provided by the PHY. The maximum clock output from the PHY is 60 MHz. The actual clock frequency depends on the operation mode (High Speed/Full

Speed). The UTMI block includes synchronization logic to the rest of the USB core.

All other blocks run off the clock from the host interface. Because of USB latency requirements, the host interface must run at least at 60 MHz. The goal is that the minimum frequency of the USB core host interface is at least 100Mhz.

## 2.2. Host Interface

The host interface block provides a consistent core interface between the internal functions of the core and the function-specific host or micro controller. The host interface is WISHBONE SoC bus specification Rev. B compliant.



### 2.2.1. Bandwidth Requirement

The USB maximum theoretical throughput is 480Mb/s, which translates to 60 Mbytes/s. On a 32 bit bus, four bytes (one word) are transferred per cycle. The minimum bandwidth requirement for the host is therefore 15 Mwords/s.

## 2.3. Memory Interface and Arbiter

The memory interface and arbiter arbitrates between the USB core and host interface for memory access. This block allows the usage of standard single port Synchronous SRAM. Besides arbitration it performs data steering and flow control.

**Figure 2: Memory Interface & Arbiter**



## 2.4. SSRAM

The SSRAM is a single ported Synchronous SRAM block that is used to buffer the input and output data.

## 2.5. Protocol Layer (PL)

The protocol layer is responsible for all USB data IO and control communications.

**Figure 3: Protocol Layer Block**



### 2.5.1. DMA & Memory Interface

This block interfaces to the data memory. It provides random memory access and also DMA block transfers. This block also performs pre-fetching when byte misaligned data must be written (RMW cycles).

### 2.5.2. Protocol Engine

This block handles all the standard USB protocol handshakes and control correspondence. Those are SOF tokens, acknowledgment of data transfers (ACK, NACK, NYET), replying to PING tokens.

### 2.5.3. Packet Assembly

This block assembles packets and places them in to the output FIFO. It first assembles the header, inserting a proper PID and check sums, then adds a data field if requested.

### 2.5.4. Packet Disassembly

This block decodes all incoming packets and forwards the decoded data to the appropriate blocks. The decoding includes extracting of PID and sequence numbers, as well as header check sum checking.

## 2.6. UTMI I/F

This is the interface block to the UTMI compliant PHY (transceiver).

**Figure 4: UTMI Interface Block**



### 2.6.1. Interface State Engine

This block tracks the interface state. It controls suspend/resume modes and Full Speed/High Speed switching. An internal state machine keeps track of the state and the switching of the operating modes.

### 2.6.2. Speed Negotiation Engine

This block negotiates the speed of the USB interface and handles suspend and reset detection.

### 2.6.3. Rx & Tx FIFOs

The FIFOs hold the temporary receive and transmit data. The receive FIFO temporarily hold received bytes before the DMS writes them to the SSRAM buffer. The transmit FIFO temporarily holds the bytes to be transmitted.

### 2.6.4. Rx & Tx Bus Interface

These blocks ensure proper handshaking with the receive and transmit interfaces of the PHY.

(This page intentionally left blank)

# 3

## Operation

This section describes the operation of the USB function controller. It first discusses the logical interface to the host micro controller (function) and then the logical USB interface.

The USB core uses a local buffer memory which is used as a temporary data storage. The memory size is user definable. Each endpoint has its own dedicated input/output buffer. No software intervention is needed between different endpoint accesses. Double buffers may be set up, reducing the latency requirement on the software, and increasing USB throughput.

**Figure 5: Logical Representation of USB**



### 3.1. Endpoints

This USB core supports up to 16 endpoints. The actual number of endpoints is set before synthesizing the core.

The function controller must set up the endpoints by writing to the endpoint registers: EPn\_CSR, EPn\_INT, EPn\_BUFX.

The function controller must also assign actual endpoint numbers to each endpoint (EP\_NO). The endpoint numbering in this specification refers to the physical endpoints. The actual logical (the one that is matched against the endpoint field in tokens from the host) must be set in the EPn\_CSR register EP\_NO field. The software must make sure that all endpoints for a given transaction type are unique.

#### 3.1.1. Buffer Pointers

The buffer pointers point to the input/output data structure in memory. A value of all ones (7FFFh) indicates that the buffer has not been allocated. If all buffers are not allocated, the core will respond with NAK acknowledgments to the USB host.

This USB core supports a double buffering feature which reduces the latency requirements on the functions micro controller and driver software. Double buffering is enabled when all buffer pointers have been set. Data is being retrieved/filled from/to the buffers in a round robin fashion. When data is sent to/from an endpoint, first buffer 0 is used. When the first buffer is empty/full, the function controller may be notified via an interrupt. The function controller can refill/empty buffer 0 now. The USB core will now use buffer 1 for the next operation. When the second buffer is full/empty, the function controller is interrupted, and the USB core will use buffer 0 again, and so on. Any buffer that is not allocated will be skipped. A buffer that has the used bit set will cause the core to stall, replying with NAK/NYET acknowledgments to the host.

The Buffer Used bits indicate when a buffer has been used (this information is also provided in the Interrupt Source register). The function controller must clear these bits after it has emptied/refilled the buffer.

A buffer may be larger than the maximum payload size. In that case, multiple packets will be sourced/placed from/to a buffer. A buffer for an OUT endpoint must always be in multiples of maximum payload size. When the remaining space in a buffer is less than the maximum payload size (because one or more packets with less than maximum payload were received), the buffer is considered full, and the USB core will switch to the next buffer. For example, if the maximum payload size is 512 bytes, the buffer may be 512, 1024, 1536, 2048, etc. bytes large. The software should always check the buffer size field. It should be zero when the entire buffer has been used. If the buffer size is not zero, then the size field indicates how many bytes of the buffer have not been used. There is no such limitation for IN buffers. The core will always transmit the maximum possible number of bytes. The maximum possible number of bytes is always the smaller one of maximum payload size and remaining buffer size.

**Figure 6: Buffer Operation**

Control endpoints are somewhat special because they can receive and transmit data. Therefore, for control endpoints, Buffer 0 is always an OUT buffer, and Buffer 1 always an IN buffer. Data from SETUP and OUT tokens will therefore always be written to Buffer 0. Data sent in response to an IN token is always retrieved from Buffer 1.

**Figure 7: Control Endpoint Buffer Usage**

### 3.1.2. Buffer Underflow

A buffer underflow condition occurs when either the function controller or external DMA engine did not fill the internal buffer with enough data for one MAX\_PL\_SZ packet. When an IN token is received in this condition, the USB core will reply with a NACK to the host. No special handling is required by the function controller. The UCB core will continue sending a NACK to each IN token, as long as this condition is true.

When both buffers are not allocated or empty (USED bit set), a buffer underflow condition occurs as well.

### 3.1.3. Buffer Overflow

A buffer overflow occurs when a packet has been received that does not fit into the buffer. The packet will be discarded and a NACK will be sent to the host.

Typically the buffer would be set up to hold one or more MAX\_PL\_SZ packets. There is no guarantee that the host will actually send MAX\_PL\_SZ packets, and therefore the buffer will not be completely filled with MAX\_PL\_SZ data on each transfer.

When a buffer overflow occurs, the USB core will discard the received data and reply with a NACK to the host. It will continue discarding received data and replying with NACK to each OUT token which payload size does not fit into the buffer.

When both buffers are not allocated or full, the USB core will immediately reply with a NACK when it receives an OUT token (it will not wait for the actual data packet from the host).

### 3.1.4. Data Organization

Since the buffer memory is 32 bits wide and USB defines all transactions on byte boundaries it is important to understand the relationship of data in the buffer to actual USB byte sequence. This USB core supports Little Endian byte ordering.

**Figure 8: Byte Ordering**



The buffer pointer always points to byte 0. The USB core always fetches four bytes from the buffer memory. The actual final byte that is transmitted in the Nth transaction depends on the Buffer Size. The MaxPacketSize must always be a multiple of 4 bytes.

### 3.2. DMA Operation

DMA operation allows completely transparent data movement between the USB core and the function attached to the WISHBONE bus. Once set up, no function micro controller intervention is needed for normal operations. Each endpoint has an associated pair of DMA\_REQ and DMA\_ACK signals.

When the DMAEN bit in the channel CSR register is set, the USB core will use the DMA\_REQ and DMA\_ACK signals for DMA flow control. The DMA\_REQ signal is asserted when the buffer contains data or when the buffer is empty and needs to be filled. The DMA must reply with a DMA\_ACK for each word (4 bytes) transferred. In DMA mode, the USED bits are not used and always cleared.

In DMA mode, only one buffer (buffer 0) is used. Buffer 1 is never used in DMA mode. Both buffer 0 and the external DMA must be set up to the same starting location in the USB memory buffer (the actual address for the external DMA will vary depending on the external address decoder for the USB core buffer select). They must also be set up to equal buffer size and wrap around when the amount of bytes specified has been transferred.

The buffer must hold at least one MAX\_PL\_SZ packet. Depending on DMA and external bus latency it may be set up to hold more than one packet.

MAX\_PL\_SZ must be set in 4 byte multiples, as the USB core does not support byte transfers. For OUT endpoints it is impossible to guarantee that a received packet will be in multiples of 4 bytes. The USB core provides a mechanism to recover in those cases: Whenever the received packet is smaller than MAX\_PL\_SZ, an interrupt may be generated to notify the function controller of this condition. In addition buffer1 is set to the local buffer address of the packet that was smaller than MAX\_PL\_SZ. The size field in buffer1 indicates the number of actual bytes in that packet. The USB core will always pad the buffer to MAX\_PL\_SZ bytes, so that DMA transfers can continue uninterrupted.

If the OTS\_STOP bit is set in the endpoint CSR register, the endpoint will be disabled to allow the function controller enough time to deal with the short packet. The function controller must re-enable the endpoint by setting the EP\_DIS field in the endpoint CSR register to Normal Operation.

### 3.3. PID Sequencing

USB utilizes PID sequencing to keep data transfers synchronized. It also provides a mechanism to recover data and synchronization when synchronization is lost. Synchronization can be lost due to corrupt packets, resulting in bad CRCs. This USB core fully implements and follows the PID synchronization and recovery as specified in the USB specification.

Isochronous endpoints provide no mechanism to automatically recover lost data due to a loss of synchronization. The USB core will automatically resynchronize with the host, however, since isochronous endpoints have no handshaking stage, have therefore no way to inform the host of such failures. The USB core provides a “PID Sequencing Error” interrupt for this cases in order for the function controller to be notified of such events. This interrupt will only be asserted for iso-

chronous OUT endpoints. For any other endpoints it has no meaning and is automatically disabled.

### 3.4. USB Core Memory Size

This USB core includes a memory block which it uses for storing data and endpoint control information. The memory is 32 bits wide. Depending on the application, the user should choose the appropriate memory size for the buffer memory.

Based on the actual number of endpoints and application, the memory can be as small as 256 bytes. The maximum supported memory size is 128 Kilobytes.

### 3.5. USB Core Behavior

Below table illustrates the behavior of the USB core. It also summarizes all “What if?” conditions. (This information is mostly copied from the USB 2.0 specification. Some items required interpretation of the information provided in the USB 2.0 specification).

**Table 1: Core Specification and Behavior**

| Condition/<br>Operation                                    | Full Speed Mode Behavior              | High Speed Mode Behavior             |
|------------------------------------------------------------|---------------------------------------|--------------------------------------|
| <b>Packet Sizes</b>                                        |                                       |                                      |
| Isochronous Transfer<br>Max. Payload size                  | 1023 bytes                            | 1024 bytes                           |
| Interrupt Transfer<br>Max. Payload size                    | 64 bytes                              | 1024 bytes                           |
| Bulk Transfer<br>Max. Payload size                         | 8, 16, 32, 64 bytes                   | 512 bytes                            |
| <b>Timing</b>                                              |                                       |                                      |
| One Bit Time                                               | 83.33nS                               | 2.0833 nS                            |
| UTMI Clock (UCLK)                                          | 16.67 nS                              | 16.67 nS                             |
| Max. Inter Packet<br>Delay (measured on<br>the USB bus)    | 7.5 Bit Times (~622 nS)               | 192 Bit Times (400 nS)               |
| UTMI Rx worst case<br>delay                                | 17 UCLK (~283 nS)                     | 63 Bit Times or 8 UCLK<br>(~132 nS)  |
| UTMI Tx worst case<br>delay                                | 5 UCLK (~83 nS)                       | 16 Bit Times or 2 UCLK<br>(~33 nS)   |
| Worst Case USB core<br>allowed decision time<br>(Rx to Tx) | ~256 nS (15 UCLK)                     | 96 Bit Times or 12 UCLK<br>(200 nS)  |
| Worst Case USB core<br>allowed decision time<br>(Tx to Tx) | 7.5 Bit Times or 37 UCLK<br>(~622 nS) | 192 Bit Times or 24 UCLK<br>(400 nS) |

**Table 1: Core Specification and Behavior**

| <b>Condition/<br/>Operation</b>                                  | <b>Full Speed Mode Behavior</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>High Speed Mode Behavior</b> |
|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| <b>Data PID sequencing</b>                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                 |
| Isochronous Transfer<br>Data PID sequencing                      | Normal Endpoints use DATA0 only<br>High Speed High Bandwidth Endpoints perform data PID sequencing depending on the number of transaction per microframe and data flow:<br>IN Endpoints:<br>1 transaction (<1024 bytes each): DATA0 only<br>2 transaction (513-1024 bytes each): DATA1, DATA0<br>3 transaction (683-1024 bytes each): DATA2, DATA1, DATA0<br>OUT Endpoints:<br>1 transaction (<1024 bytes each): DATA0 only<br>2 transaction (513-1024 bytes each): MDATA, DATA1<br>3 transaction (683-1024 bytes each): MDATA, MDATA, DATA2 |                                 |
| Interrupt Transfer<br>Data PID sequencing                        | DATA0/DATA1 toggle either continuously or on successful transactions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                 |
| Bulk Transfer<br>Data PID sequencing                             | DATA0/DATA1 toggle ONLY on successful transactions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                 |
| <b>Packet Errors and Mismatches</b>                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                 |
| Packet with Address<br>Mismatch                                  | Ignored, no action is taken.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                 |
| Endpoint Field mis-<br>match                                     | Ignored, no action is taken.<br>(The function controller may be interrupted.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                 |
| Packet with bad PID<br>checksum received                         | Ignored, no action is taken.<br>(The function controller may be interrupted.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                 |
| Token with bad CRC5<br>received                                  | Ignored, no action is taken.<br>(The function controller may be interrupted.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                 |
| Packet with bad<br>CRC16                                         | Ignored, no action is taken.<br>(The function controller may be interrupted.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                 |
| Unsupported token<br>(e.g. OUT endpoint<br>receives an IN token) | Ignored, no action is taken.<br>(The function controller may be interrupted.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                 |
| <b>Tokens</b>                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                 |
| PRE and SPLIT<br>tokens                                          | Ignored, no action is taken.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                 |
| SOF Token                                                        | Frame number is recorded in the FRM_NAT register, if frame number is the same as previous, the same frame number field in the FRM_NAT register is increment. The frame time counter in the FRM_NAT register is reset.                                                                                                                                                                                                                                                                                                                        |                                 |
| PING Token received<br>and have space for<br>MAX_PL_SZ           | N/A<br>(Ignored, no action is taken.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Issue ACK handshake             |

**Table 1: Core Specification and Behavior**

| <b>Condition/<br/>Operation</b>                                                   | <b>Full Speed Mode Behavior</b>                                                                | <b>High Speed Mode Behavior</b> |
|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|---------------------------------|
| PING Token received and no space for MAX_PL_SZ                                    | N/A<br>(Ignored, no action is taken.)                                                          | Issue NAK handshake.            |
| PING Token received and HALT mode set                                             | N/A<br>(Ignored, no action is taken.)                                                          | Issue STALL handshake.          |
| <b>IN Endpoint</b>                                                                |                                                                                                |                                 |
| IN Token received and HALT mode set                                               | Issue STALL handshake.                                                                         |                                 |
| IN Token received both buffers either have the USED bit set are not allocated     | Issue NAK handshake.                                                                           |                                 |
| IN Token received, can transmit data                                              | Send data packet.                                                                              |                                 |
| Host sends ACK after receiving data packet                                        | Transaction successful, go to IDLE state.                                                      |                                 |
| No response from host - time-out (also corrupted response from host)              | Do not advance PID toggle bits and buffer pointers. Go to IDL state. Host will retry IN token. |                                 |
| <b>OUT Endpoint</b>                                                               |                                                                                                |                                 |
| OUT Token received and HALT bit is set                                            | Issue STALL handshake.                                                                         |                                 |
| OUT Token received and PID sequence mismatch                                      | Issue ACK (ignore data packet).                                                                |                                 |
| OUT Token received both buffers have either the USED bit set or are not allocated | Issue NAK handshake (ignore data packet)                                                       |                                 |
| OUT Token received can accept data                                                | Issue ACK handshake.                                                                           |                                 |
| OUT Token received can accept this data and have room for one more MAX_PK_SZ      |                                                                                                | Issue ACK response.             |

**Table 1: Core Specification and Behavior**

| <b>Condition/<br/>Operation</b>                                                                    | <b>Full Speed Mode Behavior</b>              | <b>High Speed Mode Behavior</b> |
|----------------------------------------------------------------------------------------------------|----------------------------------------------|---------------------------------|
| OUT Token received,<br>can accept this data<br>and does not have<br>room for one more<br>MAX_PK_SZ |                                              | Issue NYET response.            |
| Data packet CRC16<br>error or received next<br>token                                               | Ignore, no acknowledgment, handle new token. |                                 |
| <b>Control Endpoint</b>                                                                            |                                              |                                 |
| SETUP Stage                                                                                        | Same as OUT Token Above                      |                                 |
| DATA Stage                                                                                         | Same as IN Token above                       |                                 |
| STATUS Stage                                                                                       | Same as OUT Token Above                      |                                 |

### 3.6. USB Core Flowcharts

Below flowcharts outline the basic operation of the USB core.

#### 3.6.1. Main Loop

This flowchart illustrates the main USB loop. It always wait for an token from the host before performing any operation. Once a token has been received, the USB Function Core will decode it and perform the appropriate action.

**Figure 9: USB Core Main Flowchart**



### 3.6.2. Special Token Processing

The USB Core currently supports only two special tokens in addition to SETUP, IN and OUT tokens. These tokens are SOF and PING. When a SOF token is received, the FRM\_NAT register is updated.

The PING token is a special query token for high speed OUT endpoints. It allows the host to query whether there is space in the output buffer or not.

**Figure 10: Special Token Processing Flowchart**



### 3.6.3. IN Data Cycle

This section illustrates the decision flow for an IN token.

**Figure 11: IN Data Cycle Flowchart**



### 3.6.4. Out Data Cycle

This section illustrates the decision flow for an OUT token.

**Figure 12: Out Data Cycle Flowchart**



### 3.6.5. USB Device Control Processing

The USB provides a special mechanism to control the attached devices beyond data exchange. Those special controls are: Reset, Suspend/Resume and Speed Negotiation. Below flow chart illustrates the support provided by this USB core.

**Figure 13: USB Device Control Processing**



**Figure 14: Suspend Control Processing**

**Figure 15: Reset Control Processing**

### 3.7. Interrupts

The USB core provides two interrupt outputs (INT\_A and INT\_B). Both outputs are fully programmable. The programming for both outputs is identical to provide full flexibility to software. The intention is to have one high priority interrupt and one low priority interrupt. The actual usage of the interrupts is up to the system into which the USB core is incorporated.

The interrupt mechanism in the USB core consists of a two level hierarchy:

- The main interrupt source register (INT\_SRC) indicates interrupts that are endpoint independent. These interrupts indicate overall events that have either global meaning for all endpoints or can not be associated with an endpoint because of an error condition.
- The endpoint interrupt source registers indicate events that are specific to an endpoint.

### 3.7.1. Timing

The interrupt outputs are asserted when the condition that is enabled in the interrupt mask occurs. They remain asserted until the main interrupt register is read.

### 3.7.2. Software Interaction

A interrupt handler should first read the main interrupt source register (INT\_SRC) to determine the source of an interrupt. It must remember the value that was read until it is done, processing each interrupt source. If any of the bits 15 through 0 are set, the interrupt handler should also read the appropriate endpoint interrupt register to determine endpoint specific events. Multiple interrupt sources may be indicated at any given time. Software should be prepared to handle every interrupt source it cares about.

**Note:**

---

When using both interrupt pins to service different events, or prioritizing event handling, care must be taken not to lose interrupt sources, as the main interrupt source register is cleared after a read.

---

## 3.8. Suspend & Resume

USB defines a protocol for suspending devices that are attached to the UCB bus. Devices that are powered by USB bus must enter a low power mode when a suspend signaling has been received. The USB core will assert and hold asserted the SUSP\_O for as long as the device must remain in the suspended state.

A device that has entered suspend mode can be “woken up” in two different ways:

1. Resume Signaling from the USB.
2. Asserting the *resume\_req\_i* line.

(This page intentionally left blank)

# 4

## Core Registers

This section describes all control and status registers inside the USB function. The *Address* field indicates a relative address in hexadecimal. *Width* specifies the number of bits in the register, and *Access* specifies the valid access types to that register. RW stands for read and write access, RO for read only access. A ‘C’ appended to RW or RO indicates that some or all of the bits are cleared after a read.

**Table 2: Control/Status Registers**

| Name                      | Addr. | Width | Access | Description                                     |
|---------------------------|-------|-------|--------|-------------------------------------------------|
| CSR                       | 0     | 32    | RW     | Control/Status Register                         |
| FA                        | 4     | 32    | RW     | Function Address                                |
| INT_MSK                   | 8     | 32    | RW     | Interrupt Mask for endpoint independent sources |
| INT_SRC                   | C     | 32    | ROC    | Interrupt Source register                       |
| FRM_NAT                   | 10    | 32    | RO     | Frame Number and Time                           |
| UTMI_VEND                 | 14    | 32    | RW     | Vendor Specific IO port                         |
| <b>Endpoint Registers</b> |       |       |        |                                                 |
| EP0_CSR                   | 40    | 32    | RW     | Endpoint 0: CSR                                 |
| EP0_INT                   | 44    | 32    | RW     | Endpoint 0: Interrupt Register                  |
| EP0_BUF0                  | 48    | 32    | RW     | Endpoint 0: Buffer Register 0                   |
| EP0_BUF1                  | 4c    | 32    | RW     | Endpoint 0: Buffer Register 1                   |
| EP1_CSR                   | 50    | 32    | RW     | Endpoint 1: CSR                                 |
| EP1_INT                   | 54    | 32    | RW     | Endpoint 1: Interrupt Register                  |
| EP1_BUF0                  | 58    | 32    | RW     | Endpoint 1: Buffer Register 0                   |
| EP1_BUF1                  | 5c    | 32    | RW     | Endpoint 1: Buffer Register 1                   |
| EP2_CSR                   | 60    | 32    | RW     | Endpoint 2: CSR                                 |
| EP2_INT                   | 64    | 32    | RW     | Endpoint 2: Interrupt Register                  |

**Table 2: Control/Status Registers**

| Name     | Addr. | Width | Access | Description                     |
|----------|-------|-------|--------|---------------------------------|
| EP2_BUF0 | 68    | 32    | RW     | Endpoint 2: Buffer Register 0   |
| EP2_BUF1 | 6c    | 32    | RW     | Endpoint 2: Buffer Register 1   |
| EP3_CSR  | 70    | 32    | RW     | Endpoint 3: CSR                 |
| EP3_INT  | 74    | 32    | RW     | Endpoint 3: Interrupt Register  |
| EP3_BUF0 | 78    | 32    | RW     | Endpoint 3: Buffer Register 0   |
| EP3_BUF1 | 7c    | 32    | RW     | Endpoint 3: Buffer Register 1   |
| EP4_CSR  | 80    | 32    | RW     | Endpoint 4: CSR                 |
| EP4_INT  | 84    | 32    | RW     | Endpoint 4: Interrupt Register  |
| EP4_BUF0 | 88    | 32    | RW     | Endpoint 4: Buffer Register 0   |
| EP4_BUF1 | 8c    | 32    | RW     | Endpoint 4: Buffer Register 1   |
| EP5_CSR  | 90    | 32    | RW     | Endpoint 5: CSR                 |
| EP5_INT  | 94    | 32    | RW     | Endpoint 5: Interrupt Register  |
| EP5_BUF0 | 98    | 32    | RW     | Endpoint 5: Buffer Register 0   |
| EP5_BUF1 | 9c    | 32    | RW     | Endpoint 5: Buffer Register 1   |
| EP6_CSR  | a0    | 32    | RW     | Endpoint 6: CSR                 |
| EP6_INT  | a4    | 32    | RW     | Endpoint 6: Interrupt Register  |
| EP6_BUF0 | a8    | 32    | RW     | Endpoint 6: Buffer Register 0   |
| EP6_BUF1 | ac    | 32    | RW     | Endpoint 6: Buffer Register 1   |
| EP7_CSR  | b0    | 32    | RW     | Endpoint 7: CSR                 |
| EP7_INT  | b4    | 32    | RW     | Endpoint 7: Interrupt Register  |
| EP7_BUF0 | b8    | 32    | RW     | Endpoint 7: Buffer Register 0   |
| EP7_BUF1 | bc    | 32    | RW     | Endpoint 7: Buffer Register 1   |
| EP8_CSR  | c0    | 32    | RW     | Endpoint 8: CSR                 |
| EP8_INT  | c4    | 32    | RW     | Endpoint 8: Interrupt Register  |
| EP8_BUF0 | c8    | 32    | RW     | Endpoint 8: Buffer Register 0   |
| EP8_BUF1 | cc    | 32    | RW     | Endpoint 8: Buffer Register 1   |
| EP9_CSR  | d0    | 32    | RW     | Endpoint 9: CSR                 |
| EP9_INT  | d4    | 32    | RW     | Endpoint 9: Interrupt Register  |
| EP9_BUF0 | d8    | 32    | RW     | Endpoint 9: Buffer Register 0   |
| EP9_BUF1 | dc    | 32    | RW     | Endpoint 9: Buffer Register 1   |
| EP10_CSR | e0    | 32    | RW     | Endpoint 10: CSR                |
| EP10_INT | e4    | 32    | RW     | Endpoint 10: Interrupt Register |

**Table 2: Control/Status Registers**

| Name      | Addr. | Width | Access | Description                     |
|-----------|-------|-------|--------|---------------------------------|
| EP10_BUF0 | e8    | 32    | RW     | Endpoint 10: Buffer Register 0  |
| EP10_BUF1 | ec    | 32    | RW     | Endpoint 10: Buffer Register 1  |
| EP11_CSR  | f0    | 32    | RW     | Endpoint 11: CSR                |
| EP11_INT  | f4    | 32    | RW     | Endpoint 11: Interrupt Register |
| EP11_BUF0 | f8    | 32    | RW     | Endpoint 11: Buffer Register 0  |
| EP11_BUF1 | fc    | 32    | RW     | Endpoint 11: Buffer Register 1  |
| EP12_CSR  | 100   | 32    | RW     | Endpoint 12: CSR                |
| EP12_INT  | 104   | 32    | RW     | Endpoint 12: Interrupt Register |
| EP12_BUF0 | 108   | 32    | RW     | Endpoint 12: Buffer Register 0  |
| EP12_BUF1 | 10c   | 32    | RW     | Endpoint 12: Buffer Register 1  |
| EP13_CSR  | 110   | 32    | RW     | Endpoint 13: CSR                |
| EP13_INT  | 114   | 32    | RW     | Endpoint 13: Interrupt Register |
| EP13_BUF0 | 118   | 32    | RW     | Endpoint 13: Buffer Register 0  |
| EP13_BUF1 | 11c   | 32    | RW     | Endpoint 13: Buffer Register 1  |
| EP14_CSR  | 120   | 32    | RW     | Endpoint 14: CSR                |
| EP14_INT  | 124   | 32    | RW     | Endpoint 14: Interrupt Register |
| EP14_BUF0 | 128   | 32    | RW     | Endpoint 14: Buffer Register 0  |
| EP14_BUF1 | 12c   | 32    | RW     | Endpoint 14: Buffer Register 1  |
| EP15_CSR  | 130   | 32    | RW     | Endpoint 15: CSR                |
| EP15_INT  | 134   | 32    | RW     | Endpoint 15: Interrupt Register |
| EP15_BUF0 | 138   | 32    | RW     | Endpoint 15: Buffer Register 0  |
| EP15_BUF1 | 13c   | 32    | RW     | Endpoint 15: Buffer Register 1  |

#### 4.1. Control Status Register (CSR)

This is the main configuration and status register of the USB core.

**Table 3: CSR Register**

| Bit # | Access | Description                    |
|-------|--------|--------------------------------|
| 7:5   | RO     | RESERVED                       |
| 4:3   | RO     | UTMI Line State                |
| 2     | RO     | Interface Status<br>1=Attached |

**Table 3: CSR Register**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>                                      |
|--------------|---------------|---------------------------------------------------------|
| 1            | RO            | Interface Speed<br>1=High Speed Mode; 0=Full Speed Mode |
| 0            | RO            | 1=Suspend Mode                                          |

*Value after reset:*

CSR: 00 h

## 4.2. Function Address Register (FA)

The function address is set by the function controller when the function is configured. This is done by exchanging control and status information with the host.

*Value after reset:*

FA: 00h

## 4.3. Interrupt Mask Register (INT\_MSK)

The interrupt mask register defines the functionality of *int\_a* and *int\_b* outputs in regard to events without associated endpoints.

A bit set to a logical 1 enables the generation of the interrupt for that source, a zero disables the generation of an interrupt.

**Table 4: Interrupt Mask Register**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>                                  |
|--------------|---------------|-----------------------------------------------------|
| 31:25        | RO            | RESERVED                                            |
| 24           | RW            | Interrupt B Enable: Received a USB Reset            |
| 23           | RW            | Interrupt B Enable: Received a UTMI Rx Error        |
| 22           | RW            | Interrupt B Enable: Assert interrupt when Detached  |
| 21           | RW            | Interrupt B Enable: Assert interrupt when Attached  |
| 20           | RW            | Interrupt B Enable: Leave Suspend Mode (Resume)     |
| 19           | RW            | Interrupt B Enable: Enter Suspend Mode (Suspend)    |
| 18           | RW            | Interrupt B Enable: No Such Endpoint                |
| 17           | RW            | Interrupt B Enable: PID Error (PID check sum error) |
| 16           | RW            | Interrupt B Enable: Bad Token (CRC 5 error)         |
| 15:9         | RO            | RESERVED                                            |

**Table 4: Interrupt Mask Register**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>                                  |
|--------------|---------------|-----------------------------------------------------|
| 8            | RW            | Interrupt A Enable: Received a USB reset            |
| 7            | RW            | Interrupt A Enable: Received a UTMI Rx Error        |
| 6            | RW            | Interrupt A Enable: Assert interrupt when Detached  |
| 5            | RW            | Interrupt A Enable: Assert interrupt when Attached  |
| 4            | RW            | Interrupt A Enable: Leave Suspend Mode (Resume)     |
| 3            | RW            | Interrupt A Enable: Enter Suspend Mode (Suspend)    |
| 2            | RW            | Interrupt A Enable: No such endpoint                |
| 1            | RW            | Interrupt A Enable: PID Error (PID check sum error) |
| 0            | RW            | Interrupt A Enable: Bad Token (CRC 5 error)         |

*Value after reset:*

INT\_MSK: 0000h

#### 4.4. Interrupt Source Register (INR\_SRC)

This register identifies the source of an interrupt. Whenever the function controller receives an interrupt, the interrupt handler must read this register to determine the source and cause of the interrupt. Some of the bits in this register will be cleared after a read. The software interrupt handler must make sure it keeps whatever information is required to handle the interrupt.

**Table 5: Interrupt Source Register**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>              |
|--------------|---------------|---------------------------------|
| 31:29        | RO            | RESERVED                        |
| 28           | ROC           | USB Reset                       |
| 27           | ROC           | UTMI Rx Error                   |
| 26           | ROC           | Detached                        |
| 25           | ROC           | Attached                        |
| 24           | ROC           | Resume                          |
| 23           | ROC           | Suspend                         |
| 22           | ROC           | No Such Endpoint                |
| 21           | ROC           | PID Error (PID check sum error) |
| 20           | ROC           | Bad Token (CRC 5 error)         |

**Table 5: Interrupt Source Register**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>              |
|--------------|---------------|---------------------------------|
| 19:16        | RO            | RESERVED                        |
| 15           | RO            | Endpoint 15 caused an Interrupt |
| 14           | RO            | Endpoint 14 caused an Interrupt |
| 13           | RO            | Endpoint 13 caused an Interrupt |
| 12           | RO            | Endpoint 12 caused an Interrupt |
| 11           | RO            | Endpoint 11 caused an Interrupt |
| 10           | RO            | Endpoint 10 caused an Interrupt |
| 9            | RO            | Endpoint 9 caused an Interrupt  |
| 8            | RO            | Endpoint 8 caused an Interrupt  |
| 7            | RO            | Endpoint 7 caused an Interrupt  |
| 6            | RO            | Endpoint 6 caused an Interrupt  |
| 5            | RO            | Endpoint 5 caused an Interrupt  |
| 4            | RO            | Endpoint 4 caused an Interrupt  |
| 3            | RO            | Endpoint 3 caused an Interrupt  |
| 2            | RO            | Endpoint 2 caused an Interrupt  |
| 1            | RO            | Endpoint 1 caused an Interrupt  |
| 0            | RO            | Endpoint 0 caused an Interrupt  |

*Value after reset:*

INT\_SRC: 0000h

#### 4.5. Frame Number and time register (FRM\_NAT)

This register tracks the frame number as received from the SOF token, and the frame time.

**Table 6: Frame Number and Time Register**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>                                                                                   |
|--------------|---------------|------------------------------------------------------------------------------------------------------|
| 31:28        | RO            | Number of frames with the same frame number (this field may be used to determine current microframe) |
| 27           | RO            | Reserved                                                                                             |
| 26:16        | RO            | Frame number as received from SOF token                                                              |
| 15:12        | RO            | Reserved                                                                                             |

**Table 6: Frame Number and Time Register**

| Bit # | Access | Description                              |
|-------|--------|------------------------------------------|
| 11:0  | RO     | Time since last SOF in 0.5 uS resolution |

*Value after reset:*

FRM\_NAT: 0000h

## 4.6. Vendor Specific IO Port (UTMI\_VEND)

The UTMI specification allows for a vendor defined IO port. This port consists of a 4 bit write port (to the UTMI device) and an 8 bit status port (status of the UTMI device). This register provides access to this vendor specific control/status port. A write to this register will write bits 3:0 to the VControl bus and assert VControlLoad line. A read from this register will return the value present on the VStatus lines 7:0. The actual meaning of the control and status bits is vendor specific and should be determined from the UTMI device vendors specification.

## 4.7. Endpoint Registers

Each endpoint has 4 registers associated with it. These registers have exactly the same definition for each endpoint.

**Figure 16: Endpoint Registers**

|           |                    |               |                  |                  |
|-----------|--------------------|---------------|------------------|------------------|
| EPn_CSR:  | Config/Status Bits |               |                  |                  |
| EPn_INT:  | Interrupt Mask     |               | Interrupt Source |                  |
| EPn_BUFO: | U                  | Buffer 0 Size |                  | Buffer 0 Pointer |
| EPn_BUF1: | U                  | Buffer 1 Size |                  | Buffer 1 Pointer |
|           | 31 30              | 27 26         | 17 16 15         | 0                |

#### 4.7.1. Endpoint CSR Register (EP\_CSR)

The configuration and status bits specify the operation mode of the endpoint and report any specific endpoint status back to the controller.

**Table 7: Endpoint CSR**

| Bit # | Access | Description                                                                                                                                                                                                                                            |
|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO     | <b>UC_BSEL</b><br>Buffer Select<br>This bits must be initialized to zero (first Buffer 0 is used). The USB core will toggle these bits, in order to know which buffer to use for the next transaction.<br>00: Buffer 0<br>01: Buffer 1<br>1x: RESERVED |
| 29:28 | RO     | <b>UC_DPD</b><br>These two bits are used by the USB core to keep track of the data PIDs for high speed endpoints and for DATA0/DATA1 toggling.                                                                                                         |
| 27:26 | RW     | <b>EP_TYPE</b><br>Endpoint Type<br>00: Control Endpoint<br>01: IN Endpoint<br>10: OUT Endpoint<br>11: RESERVED                                                                                                                                         |
| 25:24 | RW     | <b>TR_TYPE</b><br>Transfer Type<br>00: Interrupt<br>01: Isochronous<br>10: Bulk<br>11: RESERVED                                                                                                                                                        |
| 23:22 | RW     | <b>EP_DIS</b><br>Temporarily Disable The Endpoint<br>00: Normal Operation<br>01: Force the core to ignore all transfers to this endpoint<br>10: Force the endpoint in to HALT state<br>11: RESERVED                                                    |
| 21:18 | RW     | <b>EP_NO</b><br>Endpoint Number                                                                                                                                                                                                                        |
| 17    | RW     | <b>LRG_OK</b><br>1 - Accept data packets of more than MAX_PL_SZ bytes (RX only)<br>0 - Ignore data packet with more than MAXPL_SZ bytes (RX only)                                                                                                      |
| 16    | RW     | <b>SML_OK</b><br>1 - Accept data packets with less than MAX_PL_SZ bytes (RX only)<br>0 - Ignore data packet with less than MAXPL_SZ bytes (RX only)                                                                                                    |

**Table 7: Endpoint CSR**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>                                                                                                                                                                                  |
|--------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15           | RW            | DMAEN<br>1: Enables external DMA interface and operation<br>0: No DMA operation                                                                                                                     |
| 14           | RO            | RESERVED                                                                                                                                                                                            |
| 13           | RW            | OTS_STOP<br>When set, this bit enables the disabling of the endpoint when in DMA mode, an OUT endpoint receives a packet smaller than MAX_PL_SZ. The disabling is achieved by setting EP_DIS to 01b |
| 12:11        | RW            | TR_FR<br>Number of transactions per micro frame (HS mode only)                                                                                                                                      |
| 10:0         | RW            | MAX_PL_SZ<br>Maximum payload size (MaxPacketSize) in bytes                                                                                                                                          |

*Value after reset:*

EPn\_CSR: 0000h

#### 4.7.2. Endpoint Interrupt Mask/Source Register (EP\_IMS)

The interrupt register for each endpoint has mask bits for interrupt *int\_a* and interrupt *int\_b* outputs and bits that indicate the interrupt source when an interrupt has been received.

**Table 8: Endpoint Interrupt Register**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>                                            |
|--------------|---------------|---------------------------------------------------------------|
| 31:30        | RO            | RESERVED                                                      |
| 29           | RW            | Interrupt A Enable: OUT packet smaller than MAX_PL_SZ         |
| 28           | RW            | Interrupt A Enable: PID Sequencing Error                      |
| 27           | RW            | Interrupt A Enable: Buffer Full/Empty                         |
| 26           | RW            | Interrupt A Enable: Unsupported PID                           |
| 25           | RW            | Interrupt A Enable: Bad packet (CRC 16 error)                 |
| 24           | RW            | Interrupt A Enable: Time Out (waiting for ACK or DATA packet) |
| 23:22        | RO            | RESERVED                                                      |
| 21           | RW            | Interrupt B Enable: OUT packet smaller than MAX_PL_SZ         |
| 20           | RW            | Interrupt B Enable: PID Sequencing Error                      |
| 19           | RW            | Interrupt B Enable: Buffer Full/Empty                         |

**Table 8: Endpoint Interrupt Register**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>                                            |
|--------------|---------------|---------------------------------------------------------------|
| 18           | RW            | Interrupt B Enable: Unsupported PID                           |
| 17           | RW            | Interrupt B Enable: Bad packet (CRC 16 error)                 |
| 16           | RW            | Interrupt B Enable: Time Out (waiting for ACK or DATA packet) |
| 15:7         | RO            | RESERVED                                                      |
| 6            | ROC           | Interrupt Status: OUT packet smaller than MAX_PL_SZ           |
| 5            | ROC           | Interrupt Status: PID Sequencing Error                        |
| 4            | ROC           | Interrupt Status: Buffer 1 Full/Empty                         |
| 3            | ROC           | Interrupt Status: Buffer 0 Full/Empty                         |
| 2            | ROC           | Interrupt Status: Unsupported PID                             |
| 1            | ROC           | Interrupt Status: Bad packet (CRC 16 error)                   |
| 0            | ROC           | Interrupt Status: Time Out (waiting for ACK or DATA packet)   |

*Value after reset:*

EPn\_INT: 0000h

#### 4.7.3. Endpoint Buffer Registers (EP\_BUF)

The endpoint buffer registers hold the buffer pointers for each endpoint. Each endpoint has two buffer registers, thus allowing double buffering. Each buffer register has exactly the same definition and functionality (see discussion in section 3.1.1. “Buffer Pointers” on page 12 for more information).

**Table 9: Endpoint Buffer Register**

| <b>Bit #</b> | <b>Access</b> | <b>Description</b>                                                                                                                                                                                     |
|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31           | RW            | USED<br>This bit is set by the USB core after it has used this buffer. The function controller must clear this bit again after it has emptied/refilled this buffer. This bit must be initialized to 0. |
| 30:17        | RW            | BUF_SZ<br>Buffer size (number of bytes in the buffer) 16383 bytes max.                                                                                                                                 |
| 16:0         | RW            | BUF_PTR<br>Buffer pointer (byte address of the buffer)                                                                                                                                                 |

*Value after reset:*

EPn\_BUFl: FFFFFFFFh

# 5

## Core IOs

This chapter lists all IOs of the USB core. Each clock domain is contained in a separate subsection.

### 5.1. Host Interface IOs

The host interface is a WISHBONE Rev. B compliant interface. This USB core works as a slave device only. When the intervention of the local microcontroller is needed, it will assert *inta\_o* or *intb\_o*.

**Table 10: Host Interface (WISHBONE)**

| Name                                                             | Width | Direction | Description                                                                              |
|------------------------------------------------------------------|-------|-----------|------------------------------------------------------------------------------------------|
| clk_i                                                            | 1     | I         | Clock Input                                                                              |
| rst_i                                                            | 1     | I         | Reset Input                                                                              |
| wb_addr_i                                                        | 18    | I         | Address Input<br>See Appendix A “Core HW Configuration” on page 43 for more information. |
| wb_data_i                                                        | 32    | I         | Data Input                                                                               |
| wb_data_o                                                        | 32    | O         | Data Output                                                                              |
| wb_ack_o                                                         | 1     | O         | Acknowledgment Output. Indicates a normal Cycle termination.                             |
| wb_we_i                                                          | 1     | I         | Indicates a Write Cycle when asserted high.                                              |
| wb_stb_i                                                         | 1     | I         | Indicates the beginning of a valid transfer cycle for this core.                         |
| wb_cyc_i                                                         | 1     | I         | Encapsulates a valid transfer cycle                                                      |
| <b>Below signals extend the WISHBONE SoC standard interface.</b> |       |           |                                                                                          |
| inta_o                                                           | 1     | O         | Interrupt Output A                                                                       |
| intb_o                                                           | 1     | O         | Interrupt Output A                                                                       |

**Table 10: Host Interface (WISHBONE)**

| Name         | Width | Direction | Description                                                                                         |
|--------------|-------|-----------|-----------------------------------------------------------------------------------------------------|
| dma_req_o    | 15    | O         | DMA Request<br>For each endpoint one line. Unused endpoints will tie their DMA_REQ output to zero.  |
| dma_ack_i    | 15    | I         | DMA Acknowledgement<br>For each endpoint one line. Unused endpoints will ignore their DMA_ACK line. |
| susp_o       | 1     | O         | Suspend Output                                                                                      |
| resume_req_i | 1     | I         | Resume Request<br>(Connect to 0 (zero) when not used.)                                              |

Address line 17 selects between the core's buffer memory and register file. When asserted high, the memory buffer is selected, when low, the register file.

## 5.2. UTMI IOs

The UTMI interface is a USB 2.0 UTMI specification Version 1.04 compliant interface.

**Table 11: UTMI Interface**

| Name            | Width | Direction | Description                                                              |
|-----------------|-------|-----------|--------------------------------------------------------------------------|
| phy_clk_pad_i   | 1     | I         | Clock                                                                    |
| phy_rst_pad_o   | 1     | O         | Reset Output                                                             |
| DataIn_pad_i    | 8     | I         | Input Data                                                               |
| DataOut_pad_o   | 8     | O         | Output Data                                                              |
| TxValid_pad_o   | 1     | O         | Transmit Valid                                                           |
| TxReady_pad_i   | 1     | I         | Transmit Ready                                                           |
| RxActive_pad_i  | 1     | I         | Receiver Active                                                          |
| RxValid_pad_i   | 1     | I         | Receive Data Valid                                                       |
| RxError_pad_i   | 1     | I         | Receive Error                                                            |
| XcvSelect_pad_o | 1     | O         | 1: Full speed transceiver selected<br>0: High Speed transceiver selected |
| TermSel_pad_o   | 1     | O         | 1: Full speed termination enabled<br>0: High speed termination enabled   |
| SuspendM_pad_o  | 1     | O         | Places PHY into suspend mode                                             |
| LineState_pad_i | 2     | I         | Line State                                                               |

**Table 11: UTMI Interface**

| Name                                                     | Width | Direction | Description                                                                                                                                                                                                                                                                           |
|----------------------------------------------------------|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OpMode_pad_o                                             | 2     | O         | Operation Mode Select                                                                                                                                                                                                                                                                 |
| VControlLoad_pad_o                                       | 1     | O         | Vendor Control Load                                                                                                                                                                                                                                                                   |
| VControl_pad_o                                           | 4     | O         | Vendor Control data                                                                                                                                                                                                                                                                   |
| VStatus_pad_i                                            | 8     | I         | Vendor Status data                                                                                                                                                                                                                                                                    |
| <b>Below signals extend the UTMI standard interface.</b> |       |           |                                                                                                                                                                                                                                                                                       |
| usb_vbus_pad_i                                           | 1     | I         | <p>This signal should be connected to the Vcc pin of the USB connector. It is used to detect if the core is connected to an USB interface.</p> <p>This input can also be tight to the core Vcc line if the core is powered from the USB bus and this functionality is not needed.</p> |

### 5.3. Buffer Memory Interface

This is the interface to the buffer memory that is internally used by the USB core. It is a standard Synchronous SRAM.

**Table 12: Synchronous SRAM Interface**

| Name        | Width | Direction | Description                                                                                   |
|-------------|-------|-----------|-----------------------------------------------------------------------------------------------|
| sram_adr_o  | 14    | O         | SRAM Address lines<br>See Appendix A “Core HW Configuration” on page 43 for more information. |
| sram_data_o | 32    | O         | Output Data (To SRAM)                                                                         |
| sram_data_i | 32    | I         | Input Data (From SRAM)                                                                        |
| sram_re_o   | 1     | O         | SRAM Read Enable                                                                              |
| sram_we_o   | 1     | O         | SRAM Write Enable                                                                             |

The SRAM must use the PHY clock (phy\_clk) as its clock input.