# Chapter 26 USB OTG 2.0

# 26.1 Overview

USB OTG 2.0 is a Dual-Role Device controller, which supports both device and host functions and is fully compliant with OTG Supplement to USB2.0 specification, and support high-speed (480Mbps), full-speed (12Mbps), low-speed (1.5Mbps) transfer.

USB OTG 2.0 is optimized for portable electronic devices, point-to-point applications (no hub, direct connection to device) and multi-point applications to devices. USB OTG 2.0 interface supports both device and host functions and is fully compliant with OTG Supplement to USB2.0 specification, and support high-speed (480Mbps), full-speed (12Mbps), low-speed (1.5Mbps) transfer. It is optimized for portable electronic device, point-to-point applications (no hub, direct connection to device) and multi-point applications to devices.

### 26.1.1 Features

- Compliant with the OTG Supplement to the USB2.0 Specification
- Operates in High-Speed and Full-Speed mode
- Support 9 channels in host mode
- 9 Device mode endpoints in addition to control endpoint 0, 4 in, 3 out and 2 IN/OUT
- ♦ Built-in one 1024x35 bits FIFO
- Internal DMA with scatter/gather function
- Supports packet-based, dynamic FIFO memory allocation for endpoints for flexible, efficient use of RAM
- Support dynamic FIFO sizing





Fig. 26-1 USB OTG 2.0 Architecture

Fig.26-1 shows the architecture of USB OTG 2.0. It is broken up into two separate units: USB OTG 2.0 controller and USB OTG 2.0 PHY. The two units are interconnected with UTMI interface.

### 26.2.1 USB OTG 2.0 Controller Function

The USB OTG 2.0 Controller controls SIE (Serial Interface Engine) logic, the endpoint logic, the channel logic and the internal DMA logic.

The SIE logic contains the USB PID and address recognition logic, and other sequencing and state machine logic to handle USB packets and transactions.

1036

Generally the SIE Logic is required for any USB implementation while the number and types of endpoints will vary as function of application and performance requirements.

The endpoint logic contains the endpoint specific logic: endpoint number recognition, FIFOs and FIFO control, etc.

The channel Logic contains the channel tasks schedule, FIFOs and FIFO control, etc.

The internal DMA logic controls data transaction between system memory and USB FIFOs.

### 26.2.2 USB OTG 2.0 PHY Function

The USB OTG 2.0 PHY handles the low level USB protocol and signaling. This includes features such as; data serialization and deserialization, bit stuffing and clock recovery and synchronization. The primary focus of this block is to shift the clock domain of the data from the USB 2.0 rate to the frequency of UTMI clock which is 30MHz.

### 26.2.3 UTMI Interface

• Transmit

Transmit must be asserted to enable any transmissions.

The USB OTG2.0 CONTROLLER asserts TXValid to begin a transmission and negates TXValid to end a transmission. After the USB OTG2.0 CONTROLLER asserts TXValid it can assume that the transmission has started when it detects TXReady asserted.

The USB OTG2.0 CONTROLLER assumes that the USB OTG2.0 PHY has consumed a data byte if TXReady and TXValid are asserted.

The USB OTG2.0 CONTROLLER must have valid packet information (PID) asserted on the Data In bus coincident with the assertion of TXValid. Depending on the USB OTG2.0 PHY implementation, TXReady may be asserted by the Transmit State Machine as soon as one CLK after the assertion of TXValid. TXValid and TXReady are sampled on the rising edge of CLK.

The Transmit State Machine does NOT automatically generate Packet ID's (PIDs) or CRC. When transmitting, the USB OTG2.0 CONTROLLER is always expected to present a PID as the first byte of the data stream and if appropriate, CRC as the last bytes of the data stream.

The USB OTG2.0 CONTROLLER must use LineState to verify a Bus Idle condition before asserting TXValid in the TX Wait state.

The state of TXReady in the TX Wait and Send SYNC states is undefined. An MTU implementation may prepare for the next transmission immediately after the Send EOP state and assert TXReady in the TX Wait state. An MTU implementation may also assert TXReady in the Send SYNC state. The first assertion of TXReady is Macrocell implementation dependent. The USB OTG2.0 CONTROLLER must prepare DataIn for the first byte to be transmitted before asserting TXValid.



Receive

RXActive and RXValid are sampled on the rising edge of CLK.

In the RX Wait state the receiver is always looking for SYNC.

The USB OTG 2.0 PHY asserts RXActive when SYNC is detected (Strip SYNC state).

The USB OTG 2.0 PHY negates RXActive when an EOP is detected (Strip EOP state).

When RxActive is asserted, RXValid will be asserted if the RX Holding Register is full.

RXValid will be negated if the RX Holding Register was not loaded during the previous byte time.

This will occur if 8 stuffed bits have been accumulated.

The USB OTG2.0 Controller must be ready to consume a data byte if RXActive and RXValid are asserted (RX Data state).

In FS mode, if a bit stuff error is detected then the Receive State Machine will negate RXActive and RXValid, and return to the RX Wait state.



# 26.3 USB OTG2.0 Controller

Fig.26-4 shows the main components and flow of the USB OTG 2.0 controller

Rockchip RK3128 Technical Reference Manual Rev 1.0





Fig. 26-4 USB OTG2.0 Controller Architecture

1). AHB Slave Bus Interface Unit (BIUS)

The AHB Slave interface unit converts AHB cycles to CSR write/read, Data-FIFO read/write, and DFIFO push/pop signals.

2) Control and Status Registers (CSR)

The CSR block resides in the AHB clock domain, and contains all registers except the Power and Clock Gating Control Register (PCGCCTL) and bits 31:29 of the Core Interrupt register (GINTSTS).

3) Application Interface Unit (AIU)

The application Interface Unit (AIU) consists of the following interfaces:

- AHB Master
- AHB Slave
- Packet FIFO Controller
- Control and Status registers
- 4). DMA Scheduler (DSCH)

This block is used only in DMA mode. It controls the transfer of data packets between the system memory and the USB OTG 2.0 Controller for both Internal and External DMA.

5). Packet FIFO Controller (PFC)

Several FIFOs are used in Device and Host modes to store data inside the core before transmitting it on either the AHB or the USB. PFC connect the Data FIFO interface to an industry-standard, single-port synchronous SRAM. Address, write data, and control outputs are driven late by the USB OTG 2.0 Controller, but in time to meet the SRAM setup requirements. Input read data is expected late from the SPRAM and registered inside the core before being used.



Fig. 26-5 DFIFO single-port synchronous SRAM interface

6).Media Access Controller (MAC)

The Media Access Controller (MAC) module handles USB transactions, and device, host, and OTG protocols.

7) PHY Interface Unit (PIU)

The core uses 16-bit UTMI+ Interface.

8) Wakeup and Power Controller (WPC)

When the USB is suspended or the session is not valid, the PHY is driven into Suspend mode and the PHY clock is stopped to reduce PHY and the core power consumption. To reduce power consumption further, the core also supports AHB clock gating and partial power-down.

### 26.3.1 Host Architecture

The host uses one transmit FIFO for all non-periodic OUT transactions and one transmit FIFO for all periodic OUT transactions. These transmit FIFOs are used as transmit buffers to hold the data (payload of the transmit packet) to be transmitted over USB.

The host pipes the USB transactions through Request queues (one for periodic and one for non-periodic). Each entry in the Request - queue holds the IN or OUT channel number along with other information to perform a transaction on the USB. The order in which the requests are written into the queue determines the sequence of transactions on the USB. The host processes the periodic Request queue first, followed by the non-periodic Request queue, at the beginning of each (micro) frame.

The host uses one Receive-FIFO for all periodic and non-periodic transactions. The FIFO is used as a Receive-buffer to hold the received data (payload of the received packet) from the USB until it is transferred to the system memory. The status of each packet received also goes into the FIFO. The status entry holds the IN channel number along with other information, such as received byte count and validity status, to perform a transaction on the AHB.

### **26.3.2 Device Architecture**

The core uses Dedicated Transmit FIFO Operation. In this mode, there are individual transmit FIFOs for each IN endpoint.

The OTG device uses a single receive FIFO to receive the data for all the OUT endpoints. The receive FIFO holds the status of the received data packet, such as byte count, data PID and the validity of the received data. The DMA or the application reads the data out of the receive FIFO as it is received.

### 26.3.3 FIFO Mapping

• Fig.26-6 shows FIFO mapping in Host mode.



Fig. 26-6 USB OTG 2.0 Controller host mode FIFO address mapping

*Note: When the device is operating in Internal DMA mode, the last locations of the SPRAM are used to store the DMAADDR values for each channel.* 

• Fig.26-7 shows FIFO mapping in Device mode.

When the device is operating in non-Descriptor Internal DMA mode, the last locations of the SPRAM are used to store the DMAADDR values for each channel. When the device is operating in Descriptor mode, then the last locations of the SPRAM store the Base Descriptor address, Current Descriptor address, Current Buffer address, and status quad let information for each endpoint direction.



Fig. 26-7 USB OTG 2.0 Controller device mode FIFO address mapping

Note: When the device is operating in non-Scatter Gather Internal DMA mode, the last locations of the SPRAM are used to store the DMAADDR values for each Endpoint (1 location per endpoint). When the device is operating in Scatter Gather mode, then the last locations of the SPRAM store the Base Descriptor address, Current Descriptor address, Current Buffer address, and status quadlet information for each endpoint direction (4 locations per Endpoint). If an Endpoint is bidirectional, then 4 locations will be used for IN, and another 4 for OUT).

# 26.4 USB OTG2.0 PHY

USB PHY supports dual OTG ports' functions and is fully compliant with USB2.0 specification, and support High-speed (480Mbps), full-speed (12Mbps), low-speed (1.5Mbps) transfer. It provides a complete on-chip transceiver physical solution with ESD protection. A minimum number of external components are needed, which include a 45 ohm resistor for resistance calibration purpose. Its feature contains:

- provide dual UTMI ports
- OTG0 Support UART Bypass Function

• Fully compliant with USB specifications Rev 2.0, 1.1 HOST/Device and OTG V1.2.

- Supports 480Mbps (HS), 12Mbps (FS) & 1.5Mbps(LS) serial data transmission
- Supports low latency hub mode with 40 bit time round trip delay
- 8 bit or 16 bit UTMI interface compliant with UTMI+ specification level 3 Rev 1.
- Loop back BIST mode supported
- Built-in I/O and ESD structure

- On-die self-calibrated HS/FS/LS termination
- 12MHz crystal oscillator with integrated phase-locked loop (PLL) oscillator
- Manufactured in SMIC 65/55nm LL process
- Dual 3.3V / 1.2V supply

### 26.4.1 Block Diagram



#### **HS AFE**

The HS AFE contains the low-level analog circuitry, and also the HS differential data transmitter and receiver, to perform HS transmission envelope detection and host disconnection detection. It works in HS mode only.

#### **HS Transmit driver**

The HS transmit driver is active only when transmit is asserted. In HS transceiver enabled mode and the transmit state machine has data to send, the XCVR selects input. Data from transmit data path will be driven onto the DP/DM signal lines when enabled.

#### **HS Differential Receiver**

When enabled, received HS data will be multiplexed through the receive data path to the receive shift and hold registers. It is active only in HS mode.

transmission envelope detector (Squelch detector)

When the amplitude of the differential signal at a receiver's inputs falls below the squelch threshold, the envelope detector will indicate the invalid data. It must indicate squelch when the signal drops below 100mV differential amplitude, and also, it must indicate that the line is not in the squelch state when the signal exceeds 150mV differential amplitude.

#### **Disconnection envelope detector**

In host mode, this envelope detector is active to detect the high speed disconnect state on the line. Disconnection must be indicated when the amplitude of the differential signal at the downstream facing driver's connector is more than 625 mV, and it must not be indicated when the signal amplitude is less than 525 mV.

#### FS/LS AFE

In FS or LS mode, the FS/LS AFE is active to send and receive the FS or LS data on the USB bus. Also it supports the reset, suspend and resume detection through the data line single ended receivers.

#### **FS/LS** Transmitter

The FS/LHS transmitter is active only when transmit is asserted. In FS or LS transceiver enabled mode and the transmit state machine has data to send, the XCVR selects input. Data from transmit data path will be driven onto the DP/DM signal lines when enabled.

#### **FS/LS Differential Receiver**

When enabled, received FS or LS data will be multiplexed through the receive data path to the receive shift and hold registers. It is active only in FS or LS modes.

#### Single ended receivers

The single ended receivers are used for low-speed and full-speed signaling detection.

#### **Digital Core TX Path**

The digital core TX path has some blocks responsible for SYNC and EOP generation, data encoding, bit stuffing and data serialization. And meanwhile, also a TX state machine is involved to manage the communication with the controller.

#### TX Shift/Hold Register

The TX shift/Hold register module consists of an 8-bit primary shift register for parallel/serial conversion and 8-bit hold register used to buffer the next data to serialize. This module is responsible for reading parallel data from the parallel application bus interface upon command and serializing for transmission over USB.

#### **Bit stuffer**

To ensure adequate signal transitions, when sending a packet on USB, a bit stuffer is employed by the transmitter. A '0' has to be inserted after every six consecutive ones in the data stream before the data in NRZI encoded, to force a transition in the NRZI data stream.

#### NRZI Encoder

The High speed, Full speed or low speed serial transmitted data are encoded by The NRZI encoder. As a state transition, a '0' is encoded, and as no state transition, a '1' is encoded.

#### Transmit state machine

The communication between the controller and the PHY in TX path is controlled by the transmit state machine, which synchronizes the Data with the Sync and the EOP, and also supports the LS, FS and HS Modes.

#### Digital Core RX Path

The digital core RX path includes blocks responsible for SYNC and EOP detection and stripping, data decoding, bit un-stuffing and data de-serialization. Also a RX state machine is involved to manage the communication with the controller. FS/LS data and clock is recovered in this section.

#### **Elasticity buffer**

To compensate for differences between transmitting and receiving clocks, the Elasticity Buffer is used to synchronize the HS extracted data with the PLL internal clock.

#### Mux

The Mux block allows the data from the HS or FS/LS receivers to be routed to the shared receive logic. The state of the Mux is determined by the Xcvr Select input.

#### **NRZI Decoder**

The NRZI is responsible for decoding the High speed or Full speed received NRZI encoded data. A change in level is decoded as '0' and no change in level is decoded as '1'.

#### Bit Un-stuffer

The Bit Un-stuffer not only recognizes the stuffed bits from the data stream, but also discards them. Also it detects bit stuff error, which is interpreted as HS EOP.

#### **RX Shift/Hold Register**

This module de-serializes received data and transmits 8-bit parallel data to the application bus interface. It consists of an 8-bit primary shit register for serial to parallel conversion and an 8-bit hold register for buffering the last de-serialized data byte.

#### **Receiver state machine**

The receiver state machine controls the communication between the controller and the PHY in the RX path, strips the SYNC and the EOP from the Data and supports the LS, FS and HS Modes.

#### **PLL Clock Multiplier**

This module is composed of the off-chip crystal and the on-chip clock multiplier. It generates the appropriate internal clocks for the UTM and the CLK output signal. All data transfer signals are synchronized with the CLK signal.

#### **External Crystal**

The external crystal is composed of a precise resonance frequency crystal and a crystal oscillator. It is optional to have this crystal oscillator integrated on-chip

or have it off-chip. This crystal/crystal oscillator provides a very precise clock of 12 MHz with deviation of  $\pm 100$  ppm. The oscillator is not a part of the PHY, but external.

#### **Clock Multiplier**

The UTM interface is described as an un-directional/bi-directional 8-bit/16-bit parallel interface and the CLK signal is a 60/30 MHz signal. All data transfer signals should be synchronized with the CLK signal. CLK usable signal is internally implemented which blocks any transitions of CLK until it is usable. Meanwhile, the clock multiplier provides another three clocks in addition to the CLK signal. That is a480 MHz and 7.5 MHz clock signals.

#### **Clock MUX**

The Clock Multiplexer supplies both the transmitter and receiver paths with the adequate bit clock depending on the XcvrSelect signal and to ensure smooth clock switching. It also includes clock gating and power-down features.

#### **Control Logic Block**

This block is responsible for controlling, enabling and disabling the different blocks in the system.

#### **OTG Circuitry** (optional)

With the OTG circuitry, the system has the capability to dynamically switch between host and peripheral, enable dual role device behavior and point-to-point communication. The OTG circuitry functions as VBUS generation and detection. Both ID detection and terminations control are implemented in it.

#### **ID Detector** (optional)

To provide the ID signal that is used to indicate the state of the ID pin on the USB mini receptacle. This pin makes it able to determine which kind of plug is connected and to confirm if the device default state is A device or B device.

#### **VBUS Detector and termination control**

The VBUS detector is a set of comparators, functions to monitor and sense the voltage on USB bus power line. For VBUS signaling and discharging, VBUS pull up and pull-down resistors are also implemented.

#### **Automatic Test Functions**

• Loop-back test to address all IP components.

In loop-back test mode, all transmitted data packets are received back in an internal loop to check IP functional integrity. There are some digital components that cannot be tested with the scan technique due to the high-speed nature of the digital part. To be regarded as a good idea, Loop-back allows testing full design paths at speed. It should complement the testing suite for digital core to achieve the highest coverage possible. According to the UTMI specification Section 5.18, version 1.05 Page 34, the 8 bits un-directional data bus can be implemented as 8 bits bi-directional one. This implementation will hinder the loop-back test functionality.

# **26.5 UART BYPASS FUNCITON**

When in UART bypass mode, UART2 is connect to USB interface; Otherwise, UART2 use normal UART interface.

| Rockchip<br><sub>瑞志徽电子</sub> RK3128 | Technical Reference Manual Rev 1.0 |
|-------------------------------------|------------------------------------|
|-------------------------------------|------------------------------------|

| Signal        | CONNECT      | I/O | Description                                                                                                                                                                                                                                                                                                                                    |
|---------------|--------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BYPASSDMDATA0 | uart2_sout   | I   | Data for DM0 Transmitter Digital<br>Bypass                                                                                                                                                                                                                                                                                                     |
| BYPASSDMEN0   | uoc0_con0[8] | Ι   | DM0 Transmitter Digital Bypass<br>Enable                                                                                                                                                                                                                                                                                                       |
| BYPASSSEL0    | uoc0_con0[9] | Ι   | Transmitter Digital Bypass mode<br>Enable                                                                                                                                                                                                                                                                                                      |
| FSVPLUS0      | uart2_sin    | 0   | Single-Ended D- Indicator<br>The controller signal indicates the<br>state of the DP during normal<br>operation or UART data reception                                                                                                                                                                                                          |
| OTGDISABLE0   | uoc0_con0[4] | Ι   | 1'b1: OTG0 disable;<br>1'b0: OTG0 normal mode                                                                                                                                                                                                                                                                                                  |
| COMMONONN     | uoc0_con0[0] | Ι   | Common Block Power-Down Control<br>This signal controls the power-down<br>signals in PLL blocks when the USB<br>PHY is in Suspend Mode.<br>1: PLL blocks are powered down.<br>0: PLL blocks remain powered<br>This signal is a strapping option that<br>must be set prior to a power-on<br>reset and remain static during<br>normal operation. |

#### Note: USB OTG2.0 PHY support UART Bypass Function.



To use UART and Auto resume functions:

1. Disable the OTG block by setting OTGDISABLE0 to 1'b1.

2. Disable the pull-up resistance on the D+ line by setting OPMODE0[1:0] to 2'b01.

3. To ensure that the XO, Bias, and PLL blocks are powered down in Suspend mode, set COMMONONN to 1'b1.

- 4. Place the USB PHY in Suspend mode by setting SUSPENDM0 to 1'b0.
- 5. Set BYPASSSEL0 to 1'b1.
- 6. To transmit data, controls BYPASSDMEN0, and BYPASSDMDATA0.

To receive data, monitor FSVPLUS0.

To return to normal operating mode:

- 1. Ensure that there is no activity on the USB.
- 2. Set BYPASSSEL0 to 1'b0.
- 3. Set SUSPENDM0 to 1'b1.Resume the USB PHY.
- 4. Set COMMONONN to 1'b0.
- 5. set OTGDISABLE0 to 1'b0.

### **26.6 Register Description**

#### 26.6.1 Register Summary

| 1                |        |      |                |                                                     |
|------------------|--------|------|----------------|-----------------------------------------------------|
| Name             | Offset | Size | Reset<br>Value | Description                                         |
| USBOTG_GOTGCTL   | 0x0000 | W    | 0x0000000      | Control and Status Register                         |
| USBOTG_GOTGINT   | 0x0004 | W    | 0x0000000      | Interrupt Register                                  |
| USBOTG_GAHBCFG   | 0x0008 | W    | 0x0000000      | AHB Configuration Register                          |
| USBOTG_GUSBCFG   | 0x000c | W    | 0x00001400     | USB Configuration Register                          |
| USBOTG_GRSTCTL   | 0x0010 | W    |                | Reset Register                                      |
| USBOTG_GINTSTS   | 0x0014 | W    | 0x0000000      | Interrupt Register                                  |
| USBOTG_GINTMSK   | 0x0018 | W    | 0x0000000      | Interrupt Mask Register                             |
| USBOTG_GRXSTSR   | 0x001c | w    | 0×00000000     | Receive Status Debug Read<br>Register               |
| USBOTG_GRXSTSP   | 0x0020 | w    | 0x00000000     | Receive Status Read and Pop<br>Register             |
| USBOTG_GRXFSIZ   | 0x0024 | W    | 0x0000000      | Receive FIFO Size Register                          |
| USBOTG_GNPTXFSIZ | 0x0028 | w    | 0x00000000     | Non-Periodic Transmit FIFO<br>Size Register         |
| USBOTG_GNPTXSTS  | 0x002c | W    | 0x0000000      | Non-Periodic Transmit<br>FIFO/Queue Status Register |
| USBOTG_GI2CCTL   | 0x0030 | W    | 0x11000000     | I2C Address Register                                |
| USBOTG_GPVNDCTL  | 0x0034 | W    | 0x0000000      | PHY Vendor Control Register                         |
| USBOTG_GGPIO     | 0x0038 | w    | 0x00000000     | General Purpose Input /<br>Output Register          |
| USBOTG_GUID      | 0x003c | W    | 0x0000000      | User ID Register                                    |
| USBOTG_GSNPSID   | 0x0040 | W    | 0x00004f54     | Core ID Register                                    |
| USBOTG_GHWCFG1   | 0x0044 | W    | 0x0000000      | User HW Config1 Register                            |
| USBOTG_GHWCFG2   | 0x0048 | W    | 0x0000000      | User HW Config2 Register                            |
| USBOTG_GHWCFG3   | 0x004c | W    | 0x0000000      | User HW Config3 Register                            |
| USBOTG_GHWCFG4   | 0x0050 | W    | 0x0000000      | User HW Config4 Register                            |

Sett

|                      |                        | <b>.</b> | Reset      | <b>_</b>                                                       |
|----------------------|------------------------|----------|------------|----------------------------------------------------------------|
| Name                 | Offset                 | Size     | Value      | Description                                                    |
| USBOTG_GLPMCFG       | 0x0054                 | W        | 0x00000000 | Core LPM Configuration<br>Register                             |
| USBOTG_GPWRDN        | 0x0058                 | W        | 0x0000000  | Global Power Down Register                                     |
| USBOTG_GDFIFOCF<br>G | 0x005c                 | w        | 0x00000000 | Global DFIFO Software<br>Configuration Register                |
| USBOTG_GADPCTL       | 0x0060                 | W        | 0x00000000 | ADP Timer, Control and<br>Status Register                      |
| USBOTG_HPTXFSIZ      | 0x0100                 | W        | 0x00000000 | Host Periodic Transmit FIFO                                    |
| USBOTG_DIEPTXFn      | 0x0104<br>+4*(n-<br>1) |          | 0x00000000 | Device Periodic Transmit<br>FIFO-n Size Register<br>n = 1 - 15 |
| USBOTG_HCFG          | 0x0400                 | W        | 0x0000000  | Host Configuration Register                                    |
| USBOTG_HFIR          | 0x0404                 | W        | 0x0000000  | Host Frame Interval Register                                   |
| USBOTG_HFNUM         | 0x0408                 | w        | 0x0000ffff | Host Frame Number/Frame<br>Time Remaining Register             |
| USBOTG_HPTXSTS       | 0x0410                 | W        | 0×00000000 | Host Periodic Transmit<br>FIFO/Queue Status Register           |
| USBOTG_HAINT         | 0x0414                 | W        | 0×00000000 | Host All Channels Interrupt<br>Register                        |
| USBOTG_HAINTMSK      | 0x0418                 | W        | 0×00000000 | Host All Channels Interrupt<br>Mask Register                   |
| USBOTG_HPRT          | 0x0440                 | W        | 0x0000000  | Host Port Control and Status<br>Register                       |
| USBOTG_HCCHARn       | 0x0500<br>+0x20<br>*n  | w        | 0x0000000  | Host Channel-n<br>Characteristics Register<br>n = 0 - 15       |
| USBOTG_HCSPLTn       | 0x0504<br>+0x20<br>*n  | w        | 0x00000000 | Host Channel-n Split Control<br>Register<br>n = 0 - 15         |
| USBOTG_HCINTn        | 0x0508<br>+0x20<br>*n  | W        | 0x00000000 | Host Channel-n Interrupt<br>Register<br>n = 0 - 15             |
| USBOTG_HCINTMSK<br>n | 0x050c<br>+0x20<br>*n  | w        | 0x00000000 | Host Channel-n Interrupt<br>Mask Register<br>n = 0 - 15        |
| USBOTG_HCTSIZn       | 0x0510<br>+0x20<br>*n  | W        | 0×00000000 | Host Channel-n Transfer Size<br>Register<br>n = 0 - 15         |
| USBOTG_HCDMAn        | 0x0514<br>+0x20<br>*n  | w        | 0×00000000 | n = 0 - 15                                                     |
| USBOTG_HCDMABn       | 0x051c<br>+0x20<br>*n  | w        | 0×00000000 | Host Channel-n DMA Buffer<br>Address Register<br>n = 0 - 15    |
| USBOTG_DCFG          | 0x0800                 |          |            | Device Configuration Register                                  |
| USBOTG_DCTL          | 0x0804                 |          |            | Device Control Register                                        |
| USBOTG_DSTS          | 0x0808                 | W        | 0x0000000  | Device Status Register                                         |
| USBOTG_DIEPMSK       | 0x0810                 | W        | 0x0000000  | Device IN Endpoint common<br>interrupt mask register           |

| Name                    | Offset                    | Size | Reset<br>Value | Description                                                       |
|-------------------------|---------------------------|------|----------------|-------------------------------------------------------------------|
|                         |                           |      | Value          | Device OUT Endpoint                                               |
| USBOTG_DOEPMSK          | 0x0814                    | W    | 0×00000000     | common interrupt mask<br>register                                 |
| USBOTG_DAINT            | 0x0818                    | W    | 0×00000000     | Device All Endpoints interrupt<br>register                        |
| USBOTG_DAINTMSK         | 0x081c                    | w    | 0×00000000     | Device All Endpoint interrupt<br>mask register                    |
| USBOTG_DTKNQR1          | 0x0820                    | w    | 0x00000000     | Device IN token sequence<br>learning queue read register1         |
| USBOTG_DTKNQR2          | 0x0824                    | w    | 0x00000000     | Device IN token sequence<br>learning queue read register2         |
| USBOTG_DVBUSDIS         | 0x0828                    | W    | 0x00000b8f     | Device VBUS discharge time<br>register                            |
| USBOTG_DVBUSPUL<br>SE   | 0x082c                    | W    | 0x0000000      | Device VBUS Pulsing Timer<br>Register                             |
| USBOTG_DTHRCTL          | 0x0830                    | W    | 0x08100020     | Device Threshold Control<br>Register                              |
| USBOTG_DIEPEMPM<br>SK   | 0x0834                    | W    | 0×00000000     | Device IN endpoint FIFO<br>empty interrupt mask<br>register       |
| USBOTG_DEACHINT         | 0x0838                    | W    | 0x00000000     | Device each endpoint<br>interrupt register                        |
| USBOTG_DEACHINT<br>MSK  | 0x083c                    | W    | 0×00000000     | Device each endpoint<br>interrupt register mask                   |
| USBOTG_DIEPEACH<br>MSKn | 0x0840<br>+4*n            | w    | 0x00000000     | Device each IN endpoint -n<br>interrupt Register<br>n = 0 - 15    |
| USBOTG_DOEPEACH<br>MSKn | 0x0880<br>+4*n            | w    | 0x00000000     | Device each out endpoint-n<br>interrupt register<br>n = 0 - 15    |
| USBOTG_DIEPCTL0         | 0x0900                    | W    | 0x00008000     | Device control IN endpoint 0 control register                     |
| USBOTG_DIEPINTn         | 0x0908<br>+0x20<br>*n     | w    | 0x00000000     | Device Endpoint-n Interrupt<br>Register<br>n = 0 - 15             |
| USBOTG_DIEPTSIZn        | 0x0910<br>+0x20<br>*n     | W    | 0x00000000     | Device endpoint n transfer<br>size register<br>n = 0 - 15         |
| USBOTG_DIEPDMAn         | 0x0914<br>+0x20<br>*n     | w    | 0x00000000     | Device endpoint-n DMA<br>address register<br>n = 0 - 15           |
| USBOTG_DTXFSTSn         | 0x0918<br>+0x20<br>*n     | w    |                | Device IN endpoint transmit<br>FIFO status register<br>n = 0 - 15 |
| USBOTG_DIEPDMAB<br>n    | 0x091c                    | w    | 0×00000000     | Device endpoint-n DMA buffer<br>address register                  |
| USBOTG_DIEPCTLn         | 0x0920<br>+0x20<br>*(n-1) | W    | 0x00000000     | Device endpoint-n control                                         |
| USBOTG_DOEPCTL0         | 0x0b00                    | W    | 0×00000000     | Device control OUT endpoint<br>0 control register                 |

| Name                 | Offset                    | Size | Reset<br>Value | Description                                                    |
|----------------------|---------------------------|------|----------------|----------------------------------------------------------------|
| USBOTG_DOEPINTn      | 0x0b08<br>+0x20<br>*n     | w    | 0×00000000     | Device endpoint-n control<br>register<br>n = 0 - 15            |
| USBOTG_DOEPTSIZn     | 0x0b10<br>+0x20<br>*n     | w    | 0x00000000     | Device endpoint n transfer<br>size register<br>n = 0 - 15      |
| USBOTG_DOEPDMAn      | 0x0b14<br>+0x20<br>*n     | w    | 0×00000000     | Device Endpoint-n DMA<br>Address Register<br>n = 0 - 15        |
| USBOTG_DOEPDMAB<br>n | 0x0b1c<br>+0x20<br>*n     | W    | 0×00000000     | Device endpoint-n DMA buffer<br>address register<br>n = 0 - 15 |
| USBOTG_DOEPCTLn      | 0x0b20<br>+0x20<br>*(n-1) | W    | 0×00000000     | Device endpoint-n control<br>register<br>n = 1 - 15            |
| USBOTG_PCGCR         | 0x0b24                    | W    | 0x200b8000     | Power and clock gating<br>control register                     |

Notes: <u>Size</u> : **B** - Byte (8 bits) access, **HW** - Half WORD (16 bits) access, **W** - WORD (32 bits) access

# 26.6.2 Detail Register Description

#### USBOTG\_GOTGCTL

Address: Operational Base + offset (0x0000) Control and Status Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                        |
| 27    | RW   | 0×0         | ChirpEn<br>Chirp on enable<br>This bit when programmed to 1'b1 results in<br>the core asserting chirp_on before sending an<br>actual Chirp "K" signal on USB. This bit is<br>present only if OTG_BC_SUPPORT = 1. If<br>OTG_BC_SUPPORT != 1, this bit is a reserved<br>bit.                                      |
| 26:22 | RO   | 0×00        | MultValidBc<br>Multi Valued ID pin<br>Battery Charger ACA inputs in the following<br>order:<br>Bit 26 - rid_float.<br>Bit 25 - rid_gnd<br>Bit 24 - rid_a<br>Bit 23 - rid_b<br>Bit 22 - rid_c<br>These bits are present only if<br>OTG_BC_SUPPORT = 1. Otherwise, these bits<br>are reserved and will read 5'h0. |
| 21    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                        |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr     | Reset Value | Description                                       |
|-------|----------|-------------|---------------------------------------------------|
|       |          |             | OTGVer                                            |
|       |          |             | OTG version                                       |
|       |          |             | Indicates the OTG revision.                       |
|       |          |             | 1'b0: OTG Version 1.3. In this version the core   |
| 20    | RW       | 0x0         | supports Data line pulsing and VBus pulsing       |
|       |          |             | for SRP.                                          |
|       |          |             | 1'b1: OTG Version 2.0. In this version the core   |
|       |          |             | supports only Data line pulsing for SRP.          |
|       |          |             | BSesVId                                           |
|       |          |             | B-session valid                                   |
|       |          |             | Indicates the Device mode transceiver status.     |
|       |          |             | 1'b0: B-session is not valid.                     |
|       |          |             | 1'b1: B-session is valid.                         |
|       |          |             | In OTG mode, you can use this bit to              |
| 19    | RO       | 0x0         | determine if the device is connected or           |
|       |          |             | disconnected. Note: If you do not enabled         |
|       |          |             | OTG features (such as SRP and HNP), the read      |
|       |          |             | reset value will be 1. The vbus assigns the       |
|       |          |             | values internally for non-SRP or non-HNP          |
|       |          |             | configurations.                                   |
|       |          |             | ASesVId                                           |
|       |          |             | A-session valid                                   |
|       |          |             | Indicates the Host mode transceiver status.       |
|       |          |             | 1'b0: A-session is not valid                      |
| 18    | RO       | 0x0         | 1'b1: A-session is valid                          |
| 10    | ĸŪ       | 0.00        | Note: If you do not enabled OTG features          |
|       |          |             | (such as SRP and HNP), the read reset value       |
|       |          |             | will be 1.The vbus assigns the values             |
|       |          |             | internally for non-SRP or non-HNP                 |
|       |          | • 4         | configurations.                                   |
|       |          |             | DbnTime                                           |
|       |          |             | Long/short debounce time                          |
|       |          |             | Indicates the debounce time of a detected         |
| 17    | RO       | 0x0         | connection.                                       |
|       |          |             | 1'b0: Long debounce time, used for physical       |
|       |          |             | connections (100 ms + 2.5 us)                     |
|       |          | )           | 1'b1: Short debounce time, used for soft          |
|       | $\frown$ |             | connections (2.5 us)                              |
|       |          |             | ConIDSts                                          |
|       |          |             | Connector ID Status                               |
| 16    | RO       | 0x0         | Indicates the connector ID status on a connect    |
|       |          |             | event.                                            |
|       |          |             | 1'b0: The core is in A-Device mode                |
| 15.12 |          | 0.20        | 1'b1: The core is in B-Device mode                |
| 15:12 | RO       | 0x0         | reserved                                          |
|       |          |             | DevHNPEn                                          |
|       |          |             | Device HNP Enable                                 |
|       |          |             | The application sets this bit when it             |
| 11    | RW       | 0x0         | successfully receives a SetFeature.               |
|       |          |             | SetHNPEnable command from the connected USB host. |
|       |          |             |                                                   |
|       |          |             | 1'b0: HNP is not enabled in the application       |
|       |          |             | 1'b1: HNP is enabled in the application           |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                          |
|-----|------|-------------|----------------------------------------------------------------------|
|     |      |             | HstSetHNPEn                                                          |
|     |      |             | Host set HNP enable                                                  |
|     |      |             | The application sets this bit when it has                            |
| 1.0 |      | 00          | successfully enabled HNP (using the                                  |
| 10  | RW   | 0x0         | SetFeature.SetHNPEnable command) on the                              |
|     |      |             | connected device.                                                    |
|     |      |             | 1'b0: Host Set HNP is not enabled                                    |
|     |      |             | 1'b1: Host Set HNP is enabled                                        |
|     |      |             | HNPReq                                                               |
|     |      |             | HNP request                                                          |
|     |      |             | The application sets this bit to initiate an HNP                     |
|     |      |             | request to the connected USB host. The                               |
|     |      |             | application can clear this bit by writing a 0                        |
| 9   | RW   | 0x0         | when the Host Negotiation Success Status                             |
| -   |      |             | Change bit in the OTG Interrupt register                             |
|     |      |             | (GOTGINT.HstNegSucStsChng) is set. The                               |
|     |      |             | core clears this bit when the                                        |
|     |      |             | HstNegSucStsChng bit is cleared.                                     |
|     |      |             | 1'b0: No HNP request<br>1'b1: HNP request                            |
|     |      |             | HstNegScs                                                            |
|     |      |             | Host Negotiation Success                                             |
|     |      |             | The core sets this bit when host negotiation is                      |
|     |      |             | successful. The core clears this bit when the                        |
| 8   | RO   | 0x0         | HNP Request (HNPReq) bit in this register is                         |
|     |      |             | set.                                                                 |
|     |      |             | 1'b0: Host negotiation failure                                       |
|     |      |             | 1'b1: Host negotiation success                                       |
| 7:2 | RO   | 0x0         | reserved                                                             |
|     |      | • •         | SesReq                                                               |
|     |      |             | Session Request                                                      |
|     |      |             | The application sets this bit to initiate a                          |
|     |      |             | session request on the USB. The application                          |
|     |      |             | can clear this bit by writing a 0 when the Host                      |
|     |      |             | Negotiation Success Status Change bit in the                         |
|     | C    |             | OTG Interrupt register                                               |
|     |      |             | (GOTGINT.HstNegSucStsChng) is set. The core clears this bit when the |
|     | ()   |             | HstNegSucStsChng bit is cleared. If you use                          |
| 1   | RW   | 0x0         | the USB 1.1 Full-Speed Serial Transceiver                            |
|     |      |             | interface to initiate the session request, the                       |
| Y   |      |             | application must wait until the VBUS                                 |
|     |      |             | discharges to 0.2 V, after the B-Session Valid                       |
|     |      |             | bit in this register (GOTGCTL.BSesVId) is                            |
|     |      |             | cleared. This discharge time varies between                          |
|     |      |             | different PHYs and can be obtained from the                          |
|     |      |             | PHY vendor.                                                          |
|     |      |             | 1'b0: No session request                                             |
|     |      |             | 1'b1: Session request                                                |

| Bit | Attr | Reset Value | Description                                                                                                                                                                          |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x0         | SesReqScs<br>Session Request Success<br>The core sets this bit when a session request<br>initiation is successful.<br>1'b0: Session request failure<br>1'b1: Session request success |

#### USBOTG\_GOTGINT

Address: Operational Base + offset (0x0004) Interrupt Register

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 20    | W1C  | 0×0                | MultiValueChg<br>Multi-Valued input changed<br>This bit when set indicates that there is a<br>change in the value of at least one ACA pin<br>value. This bit is present only if<br>OTG_BC_SUPPORT = 1, otherwise it is<br>reserved.                                                                                                                                           |
| 19    | W1C  | 0×0                | DbnceDone<br>Debounce Done<br>The core sets this bit when the debounce is<br>completed after the device connection. The<br>application can start driving USB reset after<br>seeing this interrupt. This bit is only valid<br>when the HNP Capable or SRP Capable bit is<br>set in the Core USB Configuration register<br>(GUSBCFG.HNPCap or GUSBCFG.SRPCap,<br>respectively). |
| 18    | W1C  | 0×0                | ADevTOUTChg<br>A-Device Timeout Change<br>The core sets this bit to indicate that the<br>A-device has timed out while waiting for the<br>B-device to connect.                                                                                                                                                                                                                 |
| 17    | W1C  | 0×0                | HstNegDet<br>Host Negotiation Detected<br>The core sets this bit when it detects a host<br>negotiation request on the USB                                                                                                                                                                                                                                                     |
| 16:10 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 9     | W1C  | 0×0                | HstNegSucStsChng<br>Host Negotiation Success Status Change<br>The core sets this bit on the success or failure<br>of a USB host negotiation request. The<br>application must read the Host Negotiation<br>Success bit of the OTG Control and Status<br>register (GOTGCTL.HstNegScs) to check for<br>success or failure                                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | W1C  | 0×0         | SesReqSucStsChng<br>Session Request Success Status Change<br>The core sets this bit on the success or failure<br>of a session request.The application must read<br>the Session Request Success bit in the OTG<br>Control and Status register<br>(GOTGCTL.SesReqScs) to check for success or<br>failure. |
| 7:3 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                |
| 2   | W1C  | 0×0         | SesEndDet<br>Session End Detected<br>The core sets this bit when the utmisrp_bvalid<br>signal is deasserted                                                                                                                                                                                             |
| 1:0 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                |

#### USBOTG\_GAHBCFG

| 1:0     | RU                                                                                          | UXU         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|---------|---------------------------------------------------------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Address | USBOTG_GAHBCFG<br>Address: Operational Base + offset (0x0008)<br>AHB Configuration Register |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| Bit     | Attr                                                                                        | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 31:23   | RO                                                                                          | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| 22      | RW                                                                                          | 0×0         | NotiAllDmaWrit<br>Notify All Dma Write Transactions<br>This bit is programmed to enable the System<br>DMA Done functionality for all the DMA write<br>Transactions corresponding to the<br>Channel/Endpoint. This bit is valid only when<br>GAHBCFG.RemMemSupp is set to 1.<br>GAHBCFG.NotiAllDmaWrit = 1.<br>HSOTG core asserts int_dma_req for all the<br>DMA write transactions on the AHB interface<br>along with int_dma_done, chep_last_transact<br>and chep_number signal informations. The<br>core waits for sys_dma_done signal for all the<br>DMA write transactions in order to complete<br>the transfer of a particular Channel/Endpoint.<br>GAHBCFG.NotiAllDmaWrit = 0.<br>HSOTG core asserts int_dma_req signal only<br>for the last transaction of DMA write transfer<br>corresponding to a particular<br>Channel/Endpoint. Similarly, the core waits<br>for sys_dma_done signal only for that<br>transaction of DMA write to complete the<br>transfer of a particular Channel/Endpoint. |  |  |  |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit  | Attr                                    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|------|-----------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|      | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |             | RemMemSupp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| 21   | RW                                      | 0×0         | Remote Memory Support<br>This bit is programmed to enable the<br>functionality to wait for the system DMA Done<br>Signal for the DMA Write Transfers.<br>GAHBCFG.RemMemSupp=1.<br>The int_dma_req output signal is asserted<br>when HSOTG DMA starts write transfer to the<br>external memory. When the core is done with<br>the Transfers it asserts int_dma_done signal<br>to flag the completion of DMA writes from<br>HSOTG. The core then waits for<br>sys_dma_done signal from the system to<br>proceed further and complete the Data<br>Transfer corresponding to a particular<br>Channel/Endpoint.<br>GAHBCFG.RemMemSupp=0.<br>The int_dma_req and int_dma_done signals<br>are not asserted and the core proceeds with<br>the assertion of the XferComp interrupt as<br>soon as the DMA write transfer is done at the<br>HSOTG Core Boundary and it does not wait for<br>the sys_dma_done signal to complete the<br>DATA transfers. |  |  |  |
| 20:9 | RO                                      | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| 8    | RW                                      | 0×0         | PTxFEmpLvl<br>Periodic TxFIFO Empty Level<br>Indicates when the Periodic TxFIFO Empty<br>Interrupt bit in the Core Interrupt register<br>(GINTSTS.PTxFEmp) is triggered. This bit is<br>used only in Slave mode.<br>1'b0: GINTSTS.PTxFEmp interrupt indicates<br>that the Periodic TxFIFO is half empty<br>1'b1: GINTSTS.PTxFEmp interrupt indicates<br>that the Periodic TxFIFO is completely empty                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 8    | Rock                                    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit         | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|-------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|             |      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| 7           | RW   | 0×0         | NPTxFEmpLvl<br>Non-Periodic TxFIFO Empty Level<br>This bit is used only in Slave mode. In host<br>mode and with Shared FIFO with device mode,<br>this bit indicates when the Non-Periodic<br>TxFIFO Empty Interrupt bit in the Core<br>Interrupt register GINTSTS.NPTxFEmp) is<br>triggered. With dedicated FIFO in device<br>mode, this bit indicates when IN endpoint<br>Transmit FIFO empty interrupt<br>(DIEPINTn.TxFEmp) is triggered.<br>Host mode and with Shared FIFO with device<br>mode:<br>1'b0: GINTSTS.NPTxFEmp interrupt indicates<br>that the Non-Periodic TxFIFO is half empty<br>1'b1: GINTSTS.NPTxFEmp interrupt indicates<br>that the Non-Periodic TxFIFO is completely<br>empty<br>Dedicated FIFO in device mode:<br>1'b0: DIEPINTn.TxFEmp interrupt indicates<br>that the IN Endpoint TxFIFO is half empty<br>1'b1: DIEPINTn.TxFEmp interrupt indicates |  |  |
|             |      |             | that the IN Endpoint TxFIFO is completely<br>empty                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 6           | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 5           | RW   | 0x0         | DMAEn<br>DMA Enable<br>1'b0: Core operates in Slave mode<br>1'b1: Core operates in a DMA mode<br>This bit is always 0 when Slave-Only mode has<br>been selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Referenced. |      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:1 | RW   | 0x0         | HBstLen<br>Burst Length/Type<br>This field is used in both External and Internal<br>DMA modes. In External DMA mode, these<br>bits appear on dma_burst[3:0] ports, External<br>DMA Mode defines the DMA burst length in<br>terms of 32-bit words:<br>4'b0000: 1 word<br>4'b0001: 4 words<br>4'b0010: 8 words<br>4'b0101: 6 words<br>4'b0101: 64 words<br>4'b0101: 64 words<br>4'b0101: 64 words<br>4'b0111: 256 words<br>0thers: Reserved<br>Internal DMA Mode AHB Master burst type:<br>4'b0001: INCR<br>4'b0011: INCR4<br>4'b0011: INCR4<br>4'b0111: INCR16<br>Others: Reserved |
| 0   | RW   | 0×0         | GlblIntrMsk<br>Global Interrupt Mask<br>The application uses this bit to mask or<br>unmask the interrupt line assertion to itself.<br>Irrespective of this bit's setting, the interrupt<br>status registers are updated by the core.<br>1'b0: Mask the interrupt assertion to the<br>application.<br>1'b1: Unmask the interrupt assertion to the<br>application.                                                                                                                                                                                                                  |

### USBOTG\_GUSBCFG

Address: Operational Base + offset (0x000c) USB Configuration Register

| Bit | Attr | Reset Value | Description                                                                                              |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------|
| 31  | RW   | 0×0         | CorruptTxpacket<br>Corrupt Tx packet<br>This bit is for debug purposes only. Never set<br>this bit to 1. |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                |
|-----|------|-------------|--------------------------------------------------------------------------------------------|
|     |      |             | ForceDevMode                                                                               |
|     |      |             | Force Device Mode                                                                          |
|     |      |             | Writing a 1 to this bit forces the core to device                                          |
|     |      |             | mode irrespective of utmiotg_iddig input pin.                                              |
|     |      |             | 1'b0: Normal Mode                                                                          |
| 20  |      | 0.40        | 1'b1: Force Device Mode                                                                    |
| 30  | RW   | 0x0         | After setting the force bit, the application                                               |
|     |      |             | must wait at least 25 ms before the change to                                              |
|     |      |             | take effect. When the simulation is in scale                                               |
|     |      |             | down mode, waiting for 500 us is sufficient.                                               |
|     |      |             | This bit is valid only when $OTG\_MODE = 0, 1$                                             |
|     |      |             | or 2. In all other cases, this bit reads 0.                                                |
|     |      |             | ForceHstMode                                                                               |
|     |      |             | Force Host Mode                                                                            |
|     |      |             | Writing a 1 to this bit forces the core to host                                            |
|     |      |             | mode irrespective of utmiotg_iddig input pin.                                              |
|     |      |             | 1'b0: Normal Mode                                                                          |
| 29  | RW   | 0x0         | 1'b1: Force Host Mode                                                                      |
|     |      |             | After setting the force bit, the application must wait at least 25 ms before the change to |
|     |      |             | take effect. When the simulation is in scale                                               |
|     |      |             | down mode, waiting for 500 us is sufficient.                                               |
|     |      |             | This bit is valid only when $OTG_MODE = 0, 1$ or                                           |
|     |      |             | 2. In all other cases, this bit reads 0.                                                   |
| -   |      |             | TxEndDelay                                                                                 |
|     |      |             | Tx End Delay                                                                               |
| 20  |      | 00          | Writing a 1 to this bit enables the TxEndDelay                                             |
| 28  | RW   | 0x0         | timers in the core.                                                                        |
|     |      |             | 1'b0: Normal mode                                                                          |
|     |      | • •         | 1'b1: Introduce Tx end delay timers                                                        |
|     |      |             | IC_USBTrafCtl                                                                              |
|     |      |             | IC_USB Traffic Pull Remove Control                                                         |
|     |      |             | When this bit is set, pullup/pulldown resistors                                            |
| 27  | RW   | 0x0         | are detached from the USB                                                                  |
|     |      |             | during traffic signaling. This bit is valid only when configuration parameter              |
|     | C    |             | $OTG_ENABLE_IC_USB = 1$ and register field                                                 |
|     |      |             | GUSBCFG.IC_USBCap is set to 1.                                                             |
|     |      |             | IC_USBCap                                                                                  |
|     |      |             | IC_USB-Capable                                                                             |
|     |      |             | The application uses this bit to control the                                               |
| Y   |      |             | IC_USB capabilities.                                                                       |
|     |      |             | 1'b0: IC_USB PHY Interface is not selected.                                                |
|     |      |             | 1'b1: IC_USB PHY Interface is selected.                                                    |
| 26  | RW   | 0x0         | This bit is writable only if                                                               |
|     |      |             | OTG_ENABLE_IC_USB=1 and                                                                    |
|     |      |             | OTG_FSPHY_INTERFACE!=0.The reset value                                                     |
|     |      |             | depends on the configuration parameter                                                     |
|     |      |             | OTG_SELECT_IC_USB when                                                                     |
|     |      |             | OTG_ENABLE_IC_USB = 1. In all other cases,                                                 |
|     |      |             | this bit is set to 1'b0 and the bit is read only.                                          |

| Bit | Attr | Reset Value | Description                                      |
|-----|------|-------------|--------------------------------------------------|
|     |      |             | ULPIIfDis                                        |
|     |      |             | ULPI Interface Protect Disable                   |
|     |      |             | Controls circuitry built into the PHY for        |
|     |      |             | protecting the ULPI interface when the link      |
|     |      |             | tri-states STP and data. Any pull-ups or         |
| 25  | RW   | 0x0         | pull-downs employed by this feature can be       |
|     |      |             | disabled. Please refer to the ULPI Specification |
|     |      |             | for more detail.                                 |
|     |      |             | 1'b0: Enables the interface protect circuit      |
|     |      |             | 1'b1: Disables the interface protect circuit     |
|     |      |             | IndPassThrough                                   |
|     |      |             | Indicator Pass Through                           |
|     |      |             | Controls whether the Complement Output is        |
|     |      |             | qualified with the Internal Vbus Valid           |
|     |      |             | comparator before being used in the Vbus         |
|     |      |             | State in the RX CMD. Please refer to the ULPI    |
| 24  | RW   | 0x0         | Specification for more detail.                   |
|     |      |             | 1'b0: Complement Output signal is qualified      |
|     |      |             | with the Internal VbusValid comparator.          |
|     |      |             | 1'b1: Complement Output signal is not            |
|     |      |             | qualified with the Internal VbusValid            |
|     |      |             | comparator.                                      |
|     |      |             | IndComple                                        |
|     |      |             | Indicator Complement                             |
|     |      |             | Controls the PHY to invert the                   |
|     |      |             | ExternalVbusIndicator input signal,              |
| ~~  |      |             | generating the Complement Output. Please         |
| 23  | RW   | 0x0         | refer to the ULPI Specification for more detail  |
|     |      |             | 1'b0: PHY does not invert External Vbus          |
|     |      | •           | Indicator signal                                 |
|     |      |             | 1'b1: PHY does invert External Vbus Indicator    |
|     |      |             | signal                                           |
|     |      |             | TermSelDLPulse                                   |
|     |      |             | TermSel DLine Pulsing Selection                  |
|     |      | 1           | This bit selects utmi_termselect to drive data   |
| 22  | RW   | 0x0         | line pulse during SRP.                           |
|     |      |             | 1'b0: Data line pulsing using utmi_txvalid       |
|     |      |             | (default).                                       |
|     |      |             | 1'b1: Data line pulsing using utmi_termsel.      |
|     |      |             | ULPIExtVbusIndicator                             |
|     |      |             | ULPI External VBUS Indicator                     |
|     |      |             | This bit indicates to the ULPI PHY to use an     |
|     |      |             | external VBUS over-current indicator.            |
| 21  | RW   | 0x0         | 1'b0: PHY uses internal VBUS valid               |
|     | KVV  |             | comparator.                                      |
|     |      |             | 1'b1: PHY uses external VBUS valid               |
|     |      |             | comparator.                                      |
|     |      |             | (Valid only when RTL parameter                   |
|     |      |             | OTG_HSPHY_INTERFACE = 2 or 3)                    |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                          |
|-----|------|-------------|----------------------------------------------------------------------|
|     |      | _           | ULPIExtVbusDrv                                                       |
|     |      |             | ULPI External VBUS Drive                                             |
|     |      |             | This bit selects between internal or external                        |
|     |      |             | supply to drive 5V on VBUS, in ULPI PHY.                             |
| 20  | RW   | 0x0         | 1'b0: PHY drives VBUS using internal charge                          |
|     |      |             | pump (default).                                                      |
|     |      |             | 1'b1: PHY drives VBUS using external supply.                         |
|     |      |             | (Valid only when RTL parameter                                       |
|     |      |             | OTG_HSPHY_INTERFACE = 2 or 3)                                        |
|     |      |             | ULPIClkSusM                                                          |
|     |      |             | ULPI Clock SuspendM                                                  |
|     |      |             | This bit sets the ClockSuspendM bit in the                           |
|     |      |             | Interface Control register on the ULPI PHY.                          |
| 19  | RW   | 0x0         | This bit applies only in serial or carkit modes.                     |
|     |      |             | 1'b0: PHY powers down internal clock during                          |
|     |      |             | suspend.                                                             |
|     |      |             | 1'b1: PHY does not power down internal clock.                        |
|     |      |             | (Valid only when RTL parameter<br>OTG HSPHY INTERFACE = 2 or 3)      |
|     |      |             | ULPIAutoRes                                                          |
|     |      |             | ULPI Auto Resume                                                     |
|     |      |             | This bit sets the AutoResume bit in the                              |
|     |      |             | Interface Control register on the ULPI PHY.                          |
| 18  | RW   | 0x0         | 1'b0: PHY does not use AutoResume feature.                           |
|     |      |             | 1'b1: PHY uses AutoResume feature.                                   |
|     |      |             | (Valid only when RTL parameter                                       |
|     |      |             | $OTG_HSPHY_INTERFACE = 2 \text{ or } 3)$                             |
|     |      |             | ULPIFsLs                                                             |
|     |      |             | ULPI FS/LS Select                                                    |
|     |      | • •         | The application uses this bit to select the                          |
|     |      |             | FS/LS serial interface for the ULPI PHY. This                        |
|     |      |             | bit is valid only when the FS serial transceiver                     |
| 17  | RW   | 0x0         | is selected on the ULPI PHY.                                         |
|     |      |             | 1'b0: ULPI interface                                                 |
|     |      | A.          | 1'b1: ULPI FS/LS serial interface                                    |
|     |      |             | (Valid only when RTL parameters<br>OTG_HSPHY_INTERFACE = 2 or 3 and  |
|     |      |             | $OTG_FSPHY_INTERFACE = 2 of 3 and OTG_FSPHY_INTERFACE = 1, 2, or 3)$ |
|     |      |             | $Otg_rspin_interface = 1, 2, 013)$                                   |
|     |      |             | UTMIFS or I2C Interface Select                                       |
|     |      |             | The application uses this bit to select the I2C                      |
| Y   |      |             | interface.                                                           |
|     |      |             | 1'b0: UTMI USB 1.1 Full-Speed interface for                          |
| 16  | RW   | 0x0         | OTG signals                                                          |
|     |      |             | 1'b1: I2C interface for OTG signals                                  |
|     |      |             | This bit is writable only if I2C and UTMIFS                          |
|     |      |             | were specified for Enable I2C Interface?                             |
|     |      |             | (parameter OTG_I2C_INTERFACE = 2).                                   |
|     |      |             | Otherwise, reads return 0.                                           |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | PhyLPwrClkSel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15    | RW   | 0×0         | PHY Low-Power Clock Select<br>Selects either 480-MHz or 48-MHz<br>(low-power) PHY mode. In FS and LS modes,<br>the PHY can usually operate on a 48-MHz clock<br>to save power.<br>1'b0: 480-MHz Internal PLL clock<br>1'b1: 48-MHz External Clock<br>In 480 MHz mode, the UTMI interface<br>operates at either 60 or 30-MHz, depending<br>upon whether 8- or 16-bit data width is<br>selected. In 48-MHz mode, the UTMI interface<br>operates at 48 MHz in FS and LS modes. This<br>bit drives the utmi_fsls_low_power core<br>output signal, and is valid only for UTMI+<br>PHYs.                                                                                                          |
| 14    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13:10 | RW   | 0×5         | USBTrdTim<br>USB Turnaround Time<br>Sets the turnaround time in PHY clocks.<br>Specifies the response time for a MAC request<br>to the Packet FIFO Controller (PFC) to fetch<br>data from the DFIF(SPRAM). This must be<br>programmed to<br>4'h5: When the MAC interface is 16-bit<br>UTMI+.<br>4'h9: When the MAC interface is 8-bit UTMI+.<br>Note: The values above are calculated for the<br>minimum AHB frequency of 30 MHz. USB<br>turnaround time is critical for certification<br>where long cables and 5-Hubs are used, so if<br>you need the AHB to run at less than 30 MHz,<br>and if USB turnaround time is not critical,<br>these bits can be programmed to a larger<br>value. |
| 9     | RW   | 0×0         | HNPCap<br>HNP-Capable<br>The application uses this bit to control the Otg<br>core's HNP capabilities.<br>1'b0: HNP capability is not enabled.<br>1'b1: HNP capability is enabled.<br>This bit is writable only if an HNP mode was<br>specified for Mode of Operation (parameter<br>OTG_MODE). Otherwise, reads return 0.                                                                                                                                                                                                                                                                                                                                                                    |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | RW   | 0×0         | SRPCap<br>SRP-Capable<br>The application uses this bit to control the Otg<br>core SRP capabilities. If the core operates as a<br>non-SRP-capable B-device, it cannot request<br>the connected A-device (host) to activate<br>VBUS and start a session.<br>0: SRP capability is not enabled.<br>1: SRP capability is enabled.<br>This bit is writable only if an SRP mode was<br>specified for Mode of Operation (parameter<br>OTG_MODE). Otherwise, reads return 0.                                                                                                                                                                                                                                                                                                                                     |
| 7   | RW   | 0×0         | DDRSel<br>ULPI DDR Select<br>The application uses this bit to select a Single<br>Data Rate (SDR) or Double Data Rate (DDR)<br>or ULPI interface.<br>1'b0: Single Data Rate ULPI Interface, with<br>8-bit-wide data bus<br>1'b1: Double Data Rate ULPI Interface, with<br>4-bit-wide data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6   | RW   | 0×0         | PHYSel<br>USB 2.0 High-Speed PHY or USB 1.1<br>Full-Speed Serial Transceiver<br>The application uses this bit to select either a<br>high-speed UTMI+ or ULPI PHY, or a<br>full-speed transceiver.<br>1'b0: USB 2.0 high-speed UTMI+ or ULPI PHY<br>1'b1: USB 1.1 full-speed serial transceiver<br>If a USB 1.1 Full-Speed Serial Transceiver<br>interface was not selected (parameter<br>OTG_FSPHY_INTERFACE = 0), this bit is<br>always 0, with Write Only access. If a<br>high-speed PHY interface was not selected<br>(parameter OTG_HSPHY_INTERFACE = 0),<br>this bit is always 1, with Write Only access.<br>If both interface types were selected<br>(parameters have non-zero values), the<br>application uses this bit to select which<br>interface is active, and access is Read and<br>Write. |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0×0         | FSIntf<br>Full-Speed Serial Interface Select<br>The application uses this bit to select either a<br>unidirectional or bidirectional USB 1.1<br>full-speed serial transceiver interface.<br>1'b0: 6-pin unidirectional full-speed serial<br>interface<br>1'b1: 3-pin bidirectional full-speed serial<br>interface<br>If a USB 1.1 Full-Speed Serial Transceiver<br>interface was not selected (parameter<br>OTG_FSPHY_INTERFACE = 0), this bit is<br>always 0, with Write Only access. If a USB 1.1<br>FS interface was selected (parameter<br>OTG_FSPHY_INTERFACE! = 0), then the<br>application can set this bit to select between<br>the 3- and 6-pin interfaces, and access is Read<br>and Write. |
| 4   | RW   | 0×0         | ULPI_UTMI_Sel<br>ULPI or UTMI+ Select<br>The application uses this bit to select either a<br>UTMI+ interface or ULPI Interface.<br>1'b0: UTMI+ Interface<br>1'b1: ULPI Interface<br>This bit is writable only if UTMI+ and ULPI was<br>specified for High-Speed<br>PHY Interface(s) (parameter<br>OTG_HSPHY_INTERFACE = 3). Otherwise,<br>reads return either 0 or 1,<br>depending on the interface selected using the<br>OTG_HSPHY_INTERFACE parameter.                                                                                                                                                                                                                                             |
| 3   | RW   | 0×0         | PHYIf<br>PHY Interface<br>The application uses this bit to configure the<br>core to support a UTMI+ PHY with an 8- or<br>16-bit interface. When a ULPI PHY is chosen,<br>this must be set to 8-bit mode.<br>1'b0: 8 bits<br>1'b1: 16 bits<br>This bit is writable only if UTMI+ and ULPI<br>were selected (parameter<br>OTG_HSPHY_DWIDTH = 3). Otherwise, this<br>bit returns the value for the power-on<br>interface selected during configuration.                                                                                                                                                                                                                                                 |

| <ul> <li>2:0 RW 0x0</li> <li>2:0 RW 0x0</li> <li>ToutCal HS/FS Timeout Calibration<br/>The number of PHY clocks that the application programs in this field is added to the high-speed/full-speed inter-packet timeout duration in the core to account for any additional delays introduced by the PHY. This can be required, because the delay introduced by the PHY in generating the line state condition can vary from one PHY to another. The USB standard timeout value for high-speed operation is 736 to 816 (inclusive) bit times. The USB standard timeout value for full-speed operation is 16 to 18 (inclusive) bit times. The application must program this field based on the speed of enumeration. The number of bit times added per PHY clock are: High-speed operation: One 30-MHz PHY clock = 16 bit times Full-speed operation: One 30-MHz PHY clock = 0.4 bit times full-speed operation: One 30-MHz PHY clock = 0.2 bit times One 60-MHz PHY clock = 0.2 bit times One 60-MHz PHY clock = 0.2 bit times</li> </ul> | Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 2:0 | RW   | 0×0         | TOutCal<br>HS/FS Timeout Calibration<br>The number of PHY clocks that the application<br>programs in this field is added to the<br>high-speed/full-speed inter-packet timeout<br>duration in the core to account for any<br>additional delays introduced by the PHY. This<br>can be required, because the delay introduced<br>by the PHY in generating the line state<br>condition can vary from one PHY to another.<br>The USB standard timeout value for<br>high-speed operation is 736 to 816 (inclusive)<br>bit times. The USB standard timeout value for<br>full-speed operation is 16 to 18 (inclusive) bit<br>times. The application must program this field<br>based on the speed of enumeration. The<br>number of bit times added per PHY clock are:<br>High-speed operation:<br>One 30-MHz PHY clock = 16 bit times<br>Full-speed operation:<br>One 30-MHz PHY clock = 0.4 bit times<br>Full-speed operation:<br>One 30-MHz PHY clock = 0.2 bit times |

**USBOTG\_GRSTCTL** Address: Operational Base + offset (0x0010)

| Reset | Register |
|-------|----------|
|       |          |

|    | 0x1 | AHBIdle                                        |
|----|-----|------------------------------------------------|
| RO |     | AHB Master Idle                                |
|    |     | Indicates that the AHB Master State Machine    |
|    |     | is in the IDLE condition.                      |
| RO | 0×0 | DMAReq                                         |
|    |     | DMA Request Signal                             |
|    |     | Indicates that the DMA request is in progress. |
|    |     | Used for debug.                                |
| RO | 0x0 | reserved                                       |
| F  | 20  | RO 0x0                                         |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit  | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:6 | RW    | 0×00        | TxFNum<br>TxFIFO Number<br>This is the FIFO number that must be flushed<br>using the TxFIFO Flush bit. This field must not<br>be changed until the core clears the TxFIFO<br>Flush bit.<br>5'h0: Non-periodic TxFIFO flush in Host mode;<br>Non-periodic TxFIFO flush in device mode<br>when in shared FIFO operation. Tx FIFO 0<br>flush in device mode when in dedicated FIFO<br>mode.<br>5'h1: Periodic TxFIFO flush in Host mode:<br>Periodic TxFIFO 1 flush in Device mode when<br>in shared FIFO operation; TXFIFO 1 flush in<br>device mode when in dedicated FIFO mode.<br>5'h2: Periodic TxFIFO 2 flush in Device mode<br>when in shared FIFO operation: TXFIFO 2<br>flush in device mode when in dedicated FIFO<br>mode.<br><br>5'hF: Periodic TxFIFO 15 flush in Device mode<br>when in shared FIFO operation: TXFIFO 15<br>flush in device mode when in dedicated FIFO<br>mode.<br>                                 |
| 5    | R/WSC | 0×0         | TxFFIsh<br>TxFIFO Flush<br>This bit selectively flushes a single or all<br>transmit FIFOs, but cannot do so if<br>the core is in the midst of a transaction. The<br>application must write this bit only after<br>checking that the core is neither writing to the<br>TxFIFO nor reading from the TxFIFO. Verify<br>using these registers: Read NAK Effective<br>Interrupt ensures the core is not reading from<br>the FIFO. Write GRSTCTL.AHBIdle ensures the<br>core is not writing anything to the FIFO.<br>Flushing is normally recommended when<br>FIFOs are re-configured or when switching<br>between Shared FIFO and Dedicated Transmit<br>FIFO operation. FIFO flushing is also<br>recommended during device endpoint disable.<br>The application must wait until the core clears<br>this bit before performing any operations. This<br>bit takes eight clocks to clear, using the slower<br>clock of phy_clk or hclk. |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | R/WSC | 0×0         | RxFFlsh<br>RxFIFO Flush<br>The application can flush the entire RxFIFO<br>using this bit, but must first ensure that the<br>core is not in the middle of a transaction. The<br>application must only write to this bit after<br>checking that the core is neither reading from<br>the RxFIFO nor writing to the RxFIFO. The<br>application must wait until the bit is cleared<br>before performing any other operations. This<br>bit requires 8 clocks (slowest of PHY or AHB<br>clock) to clear. |
| 3   | R/WSC | 0×0         | INTknQFlsh<br>IN Token Sequence Learning Queue Flush<br>This bit is valid only if OTG_EN_DED_TX_FIFO<br>= 0. The application writes this bit to flush the<br>IN Token Sequence Learning Queue.                                                                                                                                                                                                                                                                                                    |
| 2   | W1C   | 0×0         | FrmCntrRst<br>Host Frame Counter Reset<br>The application writes this bit to reset the<br>(micro) frame number counter inside the core.<br>When the (micro) frame counter is reset, the<br>subsequent SOF sent out by the core has a<br>(micro) frame number of 0.                                                                                                                                                                                                                                |
| 1   | R/WSC | 0×0         | Reset<br>A write to this bit issues a soft reset to the<br>Otg_power_dn module of the core.                                                                                                                                                                                                                                                                                                                                                                                                       |

Rockey

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr  | Reset Value | Description                                                                            |
|-----|-------|-------------|----------------------------------------------------------------------------------------|
|     |       |             | CSftRst                                                                                |
|     |       |             | Core Soft Reset                                                                        |
|     |       |             | Resets the hclk and phy_clock domains as                                               |
|     |       |             | follows: Clears the interrupts and all the CSR                                         |
|     |       |             | registers except the following register bits:                                          |
|     |       |             | PCGCCTL.RstPdwnModule                                                                  |
|     |       |             | PCGCCTL.GateHclk                                                                       |
|     |       |             | PCGCCTL.PwrClmp                                                                        |
|     |       |             | PCGCCTL.StopPPhyLPwrClkSelclk                                                          |
|     |       |             | GUSBCFG.PhyLPwrClkSel                                                                  |
|     |       |             | GUSBCFG.DDRSel                                                                         |
|     |       |             | GUSBCFG.PHYSel                                                                         |
|     |       |             | GUSBCFG.FSIntf                                                                         |
|     |       |             | GUSBCFG.ULPI_UTMI_Sel                                                                  |
|     |       |             | GUSBCFG.PHYIf                                                                          |
|     |       |             | HCFG.FSLSPclkSel                                                                       |
|     |       |             | DCFG.DevSpd                                                                            |
|     |       |             | GGPIO                                                                                  |
|     |       |             | GPWRDN                                                                                 |
|     |       |             | GADPCTL                                                                                |
|     |       |             | All module state machines (except the AHB                                              |
|     |       |             | Slave Unit) are reset to the IDLE state, and all                                       |
|     |       |             | the transmit FIFOs and the receive FIFO are                                            |
|     |       |             | flushed. Any transactions on the AHB Master                                            |
| 0   | R/WSC | 0x0         | are terminated as soon as possible, after gracefully completing the last data phase of |
|     |       |             | an AHB transfer. Any transactions on the USB                                           |
|     |       |             | are terminated immediately. When                                                       |
|     |       |             | Hibernation or ADP feature is enabled, the                                             |
|     |       |             | PMU module is not reset by the Core Soft                                               |
|     |       |             | Reset. The application can write to this bit any                                       |
|     |       |             | time it wants to reset the core. This is a                                             |
|     |       |             | self-clearing bit and the core clears this bit                                         |
|     |       | CY          | after all the necessary logic is reset in the                                          |
|     |       | 1           | core, which can take several clocks,                                                   |
|     |       |             | depending on the current state of the core.                                            |
|     | C     |             | Once this bit is cleared software must wait at                                         |
|     |       | /           | least 3 PHY clocks before doing any access to                                          |
|     |       |             | the PHY domain (synchronization delay).                                                |
|     |       |             | Software must also must check that bit 31 of                                           |
|     |       |             | this register is 1 (AHB Master is IDLE) before                                         |
| Y   |       |             | starting any operation. Typically software                                             |
|     |       |             | reset is used during software development                                              |
|     |       |             | and also when you dynamically change the                                               |
|     |       |             | PHY selection bits in the USB configuration                                            |
|     |       |             | registers listed above. When you change the                                            |
|     |       |             | PHY, the corresponding clock for the PHY is                                            |
|     |       |             | selected and used in the PHY domain. Once a                                            |
|     |       |             | new clock is selected, the PHY domain has to                                           |
|     | 1     |             | be reset for proper operation.                                                         |

#### USBOTG\_GINTSTS

Address: Operational Base + offset (0x0014) Interrupt Register

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | W1C  | 0x0         | WkUpInt<br>Resume/Remote Wakeup Detected Interrupt<br>Wakeup Interrupt during Suspend (L2) or<br>LPM(L1) state.<br>During Suspend(L2):<br>Device Mode: This interrupt is asserted only<br>when Host Initiated Resume is detected on<br>USB.<br>Host Mode: This interrupt is asserted only<br>when Device Initiated Remote Wakeup is<br>detected on USB.<br>During LPM(L1):<br>Device Mode: This interrupt is asserted for<br>either Host Initiated Resume or Device<br>Initiated Remote Wakeup on USB.<br>Host Mode: This interrupt is asserted for<br>either Host Initiated Resume or Device<br>Initiated Remote Wakeup on USB. |
| 30  | W1C  | 0x0         | SessReqInt<br>Session Request/New Session Detected<br>Interrupt<br>In Host mode, this interrupt is asserted when<br>a session request is detected from the device.<br>In Host mode, this interrupt is asserted when<br>a session request is detected from the device.<br>In Device mode, this interrupt is asserted<br>when the utmisrp_bvalid signal goes high.                                                                                                                                                                                                                                                                 |
| 29  | W1C  | 0x0         | DisconnInt<br>Disconnect Detected Interrupt<br>This interrupt is asserted when a device<br>disconnect is detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 28  | W1C  | 0×0         | ConIDStsChng<br>Connector ID Status Change<br>This interrupt is asserted when there is a<br>change in connector ID status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 27  | W1C  | 0×0         | LPM_Int<br>LPM Transaction Received Interrupt<br>Device Mode : This interrupt is asserted when<br>the device receives an LPM transaction and<br>responds with a non-ERRORed response. Host<br>Mode :This interrupt is asserted when the<br>device responds to an LPM transaction with a<br>non-ERRORed response or when the host core<br>has completed LPM transactions for the<br>programmed number of times<br>(GLPMCFG.RetryCnt). This field is valid only if<br>the Core LPM Configuration register's<br>LPMCapable (LPMCap) field is set to 1.                                                                              |

| Bit | Attr | Reset Value | Description                                                                                  |
|-----|------|-------------|----------------------------------------------------------------------------------------------|
|     |      |             | PTxFEmp                                                                                      |
|     |      |             | Periodic TxFIFO Empty                                                                        |
|     |      |             | This interrupt is asserted when the Periodic                                                 |
|     |      |             | Transmit FIFO is either half or completely                                                   |
| 26  | RO   | 0x0         | empty and there is space for at least one entry                                              |
|     |      |             | to be written in the Periodic Request Queue.<br>The half or completely empty status is       |
|     |      |             | determined by the Periodic TxFIFO Empty                                                      |
|     |      |             | Level bit in the Core AHB Configuration                                                      |
|     |      |             | register (GAHBCFG.PTxFEmpLvl).                                                               |
|     |      |             | HChInt                                                                                       |
|     |      |             | Host Channels Interrupt                                                                      |
|     |      |             | The core sets this bit to indicate that an                                                   |
|     |      |             | interrupt is pending on one of the channels of                                               |
|     |      |             | the core (in Host mode). The application must                                                |
| 25  | 50   |             | read the Host All Channels Interrupt (HAINT)                                                 |
| 25  | RO   | 0x0         | register to determine the exact number of the                                                |
|     |      |             | channel on which the interrupt occurred, and then read the corresponding Host Channel-n      |
|     |      |             | Interrupt (HCINTn) register to determine the                                                 |
|     |      |             | exact cause of the interrupt. The application                                                |
|     |      |             | must clear the appropriate status bit in the                                                 |
|     |      |             | HCINTn register to clear this bit.                                                           |
|     |      |             | PrtInt                                                                                       |
|     |      | 0x0         | Host Port Interrupt                                                                          |
|     |      |             | The core sets this bit to indicate a change in                                               |
|     |      |             | port status of one of the OTG core ports in<br>Host mode. The application must read the      |
| 24  | RO   |             | Host Port Control and Status (HPRT) register                                                 |
|     |      |             | to determine the exact event that caused this                                                |
|     |      |             | interrupt. The application must clear the                                                    |
|     |      |             | appropriate status bit in the Host Port Control                                              |
|     |      |             | and Status register to clear this bit.                                                       |
|     |      |             | ResetDet                                                                                     |
|     |      |             | Reset Detected Interrupt                                                                     |
| 22  | RW   | 0x0         | The core asserts this interrupt in Device mode when it detects a reset on the USB in Partial |
| 23  |      | 0.0         | Power-Down mode when the device is in                                                        |
|     | ()   |             | Suspend. This interrupt is not asserted in Host                                              |
|     |      |             | mode.                                                                                        |
|     |      |             | FetSusp                                                                                      |
| 22  | W1C  | 0×0         | Data Fetch Suspended                                                                         |
|     |      |             | This interrupt is valid only in DMA mode. This                                               |
|     |      |             | interrupt indicates that the core has stopped                                                |
|     |      |             | fetching data for IN endpoints due to the                                                    |
|     |      |             | unavailability of TxFIFO space or Request                                                    |
|     |      |             | Queue space. This interrupt is used by the application for an endpoint mismatch              |
|     |      |             |                                                                                              |
|     |      |             | algorithm.                                                                                   |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21  | W1C  | 0x0                | incomplP<br>Incomplete Periodic Transfer<br>In Host mode, the core sets this interrupt bit<br>when there are incomplete periodic<br>transactions still pending which are scheduled<br>for the current micro-frame. Incomplete<br>Isochronous OUT Transfer (incompISOOUT)<br>The Device mode, the core sets this interrupt<br>to indicate that there is at least one<br>isochronous OUT endpoint on which the<br>transfer is not completed in the current<br>micro-frame. This interrupt is asserted along<br>with the End of Periodic Frame Interrupt<br>(EOPF) bit in this register.                                  |
| 20  | W1C  | 0x0                | incompISOIN<br>Incomplete Isochronous IN Transfer<br>The core sets this interrupt to indicate that<br>there is at least one isochronous IN endpoint<br>on which the transfer is not completed in the<br>current micro-frame. This interrupt is<br>asserted along with the End of Periodic Frame<br>Interrupt (EOPF) bit in this register. Note: This<br>interrupt is not asserted in Scatter/Gather<br>DMA mode.                                                                                                                                                                                                       |
| 19  | RO   | 0x0                | OEPInt<br>OUT Endpoints Interrupt<br>The core sets this bit to indicate that an<br>interrupt is pending on one of the OUT<br>endpoints of the core (in Device mode). The<br>application must read the Device All Endpoints<br>Interrupt (DAINT) register to determine the<br>exact number of the OUT endpoint on which<br>the interrupt occurred, and then read the<br>corresponding Device OUT Endpoint-n<br>Interrupt (DOEPINTn) register to determine<br>the exact cause of the interrupt. The<br>application must clear the appropriate status<br>bit in the corresponding DOEPINTn register to<br>clear this bit. |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | IEPInt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 18  | RO   | 0×0         | IN Endpoints Interrupt<br>The core sets this bit to indicate that an<br>interrupt is pending on one of the IN<br>endpoints of the core (in Device mode). The<br>application must read the Device All Endpoints<br>Interrupt (DAINT) register to determine the<br>exact number of the IN endpoint on which the<br>interrupt occurred, and then read the<br>corresponding Device IN Endpoint-n Interrupt<br>(DIEPINTn) register to determine the exact<br>cause of the interrupt. The application must<br>clear the appropriate status bit in the<br>corresponding DIEPINTn register to clear this<br>bit. |
| 17  | W1C  | 0×0         | EPMis<br>Endpoint Mismatch Interrupt<br>Note: This interrupt is valid only in shared<br>FIFO operation. Indicates that an IN token has<br>been received for a non-periodic endpoint, but<br>the data for another endpoint is present in the<br>top of the Non-periodic Transmit FIFO and the<br>IN endpoint mismatch count programmed by<br>the application has expired.                                                                                                                                                                                                                                 |
| 16  | W1C  | 0×0         | RstrDoneInt<br>Restore Done Interrupt<br>The core sets this bit to indicate that the<br>restore command after Hibernation was<br>completed by the core. The core continues<br>from Suspended state into the mode dictated<br>by PCGCCTL.RestoreMode field.This bit is<br>valid only when Hibernation feature is<br>enabled.                                                                                                                                                                                                                                                                              |
| 15  | W1C  | 0×0         | EOPF<br>End of Periodic Frame Interrupt<br>Indicates that the period specified in the<br>Periodic Frame Interval field of the Device<br>Configuration register (DCFG.PerFrInt) has<br>been reached in the current microframe.                                                                                                                                                                                                                                                                                                                                                                            |
| 14  | W1C  | 0×0         | ISOOutDrop<br>Isochronous OUT Packet Dropped Interrupt<br>The core sets this bit when it fails to write an<br>isochronous OUT packet into the RxFIFO<br>because the RxFIFO does not have enough<br>space to accommodate a maximum packet<br>size packet for the isochronous OUT endpoint.                                                                                                                                                                                                                                                                                                                |
| 13  | W1C  | 0×0         | EnumDone<br>Enumeration Done<br>The core sets this bit to indicate that speed<br>enumeration is complete. The application<br>must read the Device Status (DSTS) register<br>to obtain the enumerated speed.                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12  | W1C  | 0x0         | USBRst<br>USB Reset<br>The core sets this bit to indicate that a reset is<br>detected on the USB.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11  | W1C  | 0×0         | USBSusp<br>USB Suspend<br>The core sets this bit to indicate that a<br>suspend was detected on the USB. The core<br>enters the Suspended state when there is no<br>activity on the utmi_linestate signal for an<br>extended period of time.                                                                                                                                                                                                                                                                                                             |
| 10  | W1C  | 0×0         | ErlySusp<br>Early Suspend<br>The core sets this bit to indicate that an Idle<br>state has been detected on the USB for 3 ms.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9   | W1C  | 0×0         | I2CINT<br>I2C Interrupt<br>The core sets this interrupt when I2C access is<br>completed on the I2C interface. This field is<br>used only if the I2C interface was enabled .<br>Otherwise, reads return 0.                                                                                                                                                                                                                                                                                                                                               |
| 8   | W1C  | 0×0         | ULPICKINT<br>ULPI Carkit Interrupt<br>This field is used only if the Carkit interface<br>was enabled . Otherwise, reads return 0. The<br>core sets this interrupt when a ULPI Carkit<br>interrupt is received. The core's PHY sets ULPI<br>Carkit interrupt in UART or Audio mode. I2C<br>Carkit Interrupt (I2CCKINT) This field is used<br>only if the I2C interface was enabled .<br>Otherwise, reads return 0.The core sets this<br>interrupt when a Carkit interrupt is received.<br>The core's PHY sets the I2C Carkit interrupt in<br>Audio mode. |
| 7   | RO   | 0×0         | GOUTNakEff<br>Global OUT NAK Effective<br>Indicates that the Set Global OUT NAK bit in<br>the Device Control register DCTL.SGOUTNak),<br>set by the application, has taken effect in the<br>core. This bit can be cleared by writing the<br>Clear Global OUT NAK bit in the Device Control<br>register (DCTL.CGOUTNak).                                                                                                                                                                                                                                 |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | GINNakEff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6   | RO   | 0x0         | Global IN Non-Periodic NAK Effective<br>Indicates that the Set Global Non-periodic IN<br>NAK bit in the Device Control register<br>(DCTL.SGNPInNak), set by the application,<br>has taken effect in the core. That is, the core<br>has sampled the Global IN NAK bit set by the<br>application. This bit can be cleared by clearing<br>the Clear Global Nonperiodic IN NAK bit in the<br>Device Control register (DCTL.CGNPInNak).<br>This interrupt does not necessarily mean that<br>a NAK handshake is sent out on the USB. The             |
| 5   | RO   | 0×0         | STALL bit takes precedence over the NAK bit.<br>NPTxFEmp<br>Non-Periodic TxFIFO Empty<br>This interrupt is valid only when<br>OTG_EN_DED_TX_FIFO = 0. This interrupt is<br>asserted when the Non-periodic TxFIFO is<br>either half or completely empty, and there is<br>space for at least one entry to be written to<br>the Non-periodic Transmit Request Queue.<br>The half or completely empty status is<br>determined by the Non-periodic TxFIFO<br>Empty Level bit in the Core AHB Configuration<br>register(GAHBCFG.NPTxFEmpLvI).        |
| 4   | RO   | 0x0         | RxFLvI<br>RxFIFO Non-Empty<br>Indicates that there is at least one packet<br>pending to be read from the RxFIFO.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3   | w1C  | 0×0         | Sof<br>Start of (micro)Frame<br>In Host mode, the core sets this bit to indicate<br>that an SOF (FS), micro-SOF(HS), or<br>Keep-Alive (LS) is transmitted on the USB.<br>The application must write a 1 to this bit to<br>clear the interrupt. In Device mode, in the<br>core sets this bit to indicate that an SOF token<br>has been received on the USB. The application<br>can read the Device Status register to get the<br>current (micro) frame number. This interrupt<br>is seen only when the core is operating at<br>either HS or FS. |
| 2   | RO   | 0x0         | OTGInt<br>OTG Interrupt<br>The core sets this bit to indicate an OTG<br>protocol event. The application must read the<br>OTG Interrupt Status (GOTGINT) register to<br>determine the exact event that caused this<br>interrupt. The application must clear the<br>appropriate status bit in the GOTGINT register<br>to clear this bit.                                                                                                                                                                                                         |

| Bit     | Attr                                                          | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|---------|---------------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1       | W1C                                                           | 0×0         | ModeMis<br>Mode Mismatch Interrupt<br>The core sets this bit when the application is<br>trying to access: A Host mode register, when<br>the core is operating in Device mode; A Device<br>mode register, when the core is operating in<br>Host mode. The register access is completed<br>on the AHB with an OKAY response, but is<br>ignored by the core internally and does not<br>affect the operation of the core. |  |
| 0       | RO                                                            | 0x0         | CurMod<br>Current Mode of Operation<br>Indicates the current mode.<br>1'b0: Device mode<br>1'b1: Host mode                                                                                                                                                                                                                                                                                                            |  |
| Address | USBOTG_GINTMSK<br>Address: Operational Base + offset (0x0018) |             |                                                                                                                                                                                                                                                                                                                                                                                                                       |  |

### USBOTG\_GINTMSK

Address: Operational Base + offset (0x0018) Interrupt Mask Register

| Bit | Attr | Reset Value | Description                                                                                                                             |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31  | RW   | 0x0         | WkUpIntMsk<br>Resume/Remote Wakeup Detected Interrupt<br>Mask                                                                           |
| 30  | RW   | 0x0         | SessReqIntMsk<br>Session Request/New Session Detected<br>Interrupt Mask                                                                 |
| 29  | RW   | 0x0         | DisconnIntMsk<br>Disconnect Detected Interrupt Mask                                                                                     |
| 28  | RW   | 0x0         | ConIDStsChngMsk<br>Connector ID Status Change Mask                                                                                      |
| 27  | RW   | 0x0         | LPM_IntMsk<br>LPM Transaction Received Interrupt Mask                                                                                   |
| 26  | RW   | 0x0         | PTxFEmpMsk<br>Periodic TxFIFO Empty Mask                                                                                                |
| 25  | RW   | 0x0         | HChIntMsk<br>Host Channels Interrupt Mask                                                                                               |
| 24  | RW   | 0x0         | PrtIntMsk<br>Host Port Interrupt Mask                                                                                                   |
| 23  | RW   | 0x0         | ResetDetMsk<br>Reset Detected Interrupt Mask                                                                                            |
| 22  | RW   | 0x0         | FetSuspMsk<br>Data Fetch Suspended Mask                                                                                                 |
| 21  | RW   | 0×0         | incomplPMsk_incompISOOUTMsk<br>Incomplete Periodic Transfer Mask(Host only)<br>Incomplete Isochronous OUT Transfer<br>Mask(Device only) |
| 20  | RW   | 0x0         | incompISOINMsk<br>Incomplete Isochronous IN Transfer Mask                                                                               |
| 19  | RW   | 0x0         | OEPIntMsk<br>OUT Endpoints Interrupt Mask                                                                                               |

| Bit | Attr    | Reset Value | Description                               |
|-----|---------|-------------|-------------------------------------------|
| 10  | RW      | 00          | IEPIntMsk                                 |
| 18  | RVV     | 0x0         | IN Endpoints Interrupt Mask               |
| 17  | 17 D\4/ | 0.20        | EPMisMsk                                  |
| 1/  | RW      | 0x0         | Endpoint Mismatch Interrupt Mask          |
|     |         |             | RstrDoneIntMsk                            |
| 16  | RW      | 0x0         | Restore Done Interrupt Mask               |
| 10  | K VV    | 0.00        | This field is valid only when Hibernation |
|     |         |             | feature is enabled.                       |
| 15  | RW      | 0x0         | EOPFMsk                                   |
| 13  |         | 0.00        | End of Periodic Frame Interrupt Mask      |
|     |         |             | ISOOutDropMsk                             |
| 14  | RW      | 0x0         | Isochronous OUT Packet Dropped Interrupt  |
|     |         |             | Mask                                      |
| 13  | RW      | 0x0         | EnumDoneMsk                               |
| 12  | RVV     | 0.00        | Enumeration Done Mask                     |
| 12  | RW      | 0x0         | USBRstMsk                                 |
| 12  | RVV     | UXU         | USB Reset Mask                            |
| 11  | RW      | 0x0         | USBSuspMsk                                |
| 11  | RVV     |             | USB Suspend Mask                          |
| 10  | RW      | 0x0         | ErlySuspMsk                               |
| 10  | RVV     |             | Early Suspend Mask                        |
| 9   | RW      | 0x0         | I2CIntMsk                                 |
| 9   | RVV     | 0.00        | I2C Interrupt Mask                        |
|     |         |             | ULPICKINTMsk_I2CCKINTMsk                  |
| 8   | RW      | 0x0         | ULPI Carkit Interrupt Mask (ULPICKINTMsk) |
|     |         |             | I2C Carkit Interrupt Mask (I2CCKINTMsk)   |
| 7   | RW      | 0x0         | GOUTNakEffMsk                             |
| /   |         | 0.00        | Global OUT NAK Effective Mask             |
| 6   | RW      | 0.00        | GINNakEffMsk                              |
| 0   |         | 0x0         | Global Non-periodic IN NAK Effective Mask |
| 5   | RW      |             | NPTxFEmpMsk                               |
| 5   | RVV     | 0x0         | Non-periodic TxFIFO Empty Mask            |
| 4   | DW      | 0x0         | RxFLvIMsk                                 |
| 4   | RW      | UXU         | Receive FIFO Non-Empty Mask               |
| 2   | RW      | 0.40        | SofMsk                                    |
| 3   |         | 0x0         | Start of (micro)Frame Mask                |
| 2   | DWA     | W 0x0       | OTGIntMsk                                 |
| 2   | RW      |             | OTG Interrupt Mask                        |
|     | DW/     | 0.0         | ModeMisMsk                                |
| 1   | RW      | 0x0         | Mode Mismatch Interrupt Mask              |
| 0   | RO      | 0x0         | reserved                                  |

#### USBOTG\_GRXSTSR

Address: Operational Base + offset (0x001c) Receive Status Debug Read Register

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
| -   | RO   | 0x0         | reserved    |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _     |      |             | FN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 24:21 | RO   | 0×0         | Frame Number<br>(Device Only)This is the least significant 4 bits<br>of the (micro) frame number in which the<br>packet is received on the USB. This field is<br>supported only when isochronous OUT<br>endpoints are supported.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 20:17 | RO   | 0×0         | PktSts<br>Packet Status<br>Indicates the status of the received<br>packet(Host Only)<br>4'b0010: IN data packet received<br>4'b0011: IN transfer completed (triggers an<br>interrupt)<br>4'b0101: Data toggle error (triggers an<br>interrupt)<br>4'b0111: Channel halted (triggers an<br>interrupt)<br>Others: Reserved<br>Indicates the status of the received<br>packet(Device only)<br>4'b0001: Global OUT NAK (triggers an<br>interrupt)<br>4'b0010: OUT data packet received<br>4'b0011: OUT transfer completed (triggers<br>an interrupt)<br>4'b0100: SETUP transaction completed<br>(triggers an interrupt)<br>4'b0110: SETUP data packet received<br>Others: Reserved |
| 16:15 | RO   | 0×0         | DPID<br>Data PID<br>Indicates the Data PID of the received packet<br>2'b00: DATA0<br>2'b10: DATA1<br>2'b01: DATA2<br>2'b11: MDATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14:4  | RW   | 0×000       | BCnt<br>Byte Count<br>Indicates the byte count of the received data<br>packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3:0   | RO   | 0×0         | ChNum_EPNum<br>Channel Number(Host) Endpoint<br>Number(Device)<br>(Host Only) Indicates the channel number to<br>which the current received packet belongs.<br>(Device Only) Indicates the endpoint number<br>to which the current received packet belongs.                                                                                                                                                                                                                                                                                                                                                                                                                    |

### USBOTG\_GRXSTSP

Address: Operational Base + offset (0x0020) Receive Status Read and Pop Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 24:21 | RO   | 0x0         | FN<br>Frame Number<br>(Device Only) This is the least significant 4<br>bits of the (micro) frame number in which the<br>packet is received on the USB. This field is<br>supported only when isochronous OUT<br>endpoints are supported.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 20:17 | RO   | 0×0         | PktSts<br>Packet Status<br>Indicates the status of the received<br>packet(Host Only)<br>4'b0010: IN data packet received<br>4'b0011: IN transfer completed (triggers an<br>interrupt)<br>4'b0101: Data toggle error (triggers an<br>interrupt)<br>4'b0111: Channel halted (triggers an<br>interrupt)<br>Others: Reserved<br>Indicates the status of the received<br>packet(Device only)<br>4'b0001: Global OUT NAK (triggers an<br>interrupt)<br>4'b0010: OUT data packet received<br>4'b0011: OUT transfer completed (triggers<br>an interrupt)<br>4'b0100: SETUP transaction completed<br>(triggers an interrupt)<br>4'b0110: SETUP data packet received<br>Others: Reserved |
| 16:15 | RO   | 0×0         | DPID<br>Data PID<br>Indicates the Data PID of the received OUT<br>data packet<br>2'b00: DATA0<br>2'b10: DATA1<br>2'b01: DATA2<br>2'b11: MDATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14:4  | RO   | 0×000       | BCnt<br>Byte Count<br>Indicates the byte count of the received data<br>packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3:0   | RO   | 0×0         | ChNum_EPNum<br>Channel Number(Host) Endpoint<br>Number(Device)<br>(Host Only) Indicates the channel number to<br>which the current received packet belongs.<br>(Device Only) Indicates the endpoint number<br>to which the current received packet belongs.                                                                                                                                                                                                                                                                                                                                                                                                                    |

### USBOTG\_GRXFSIZ

#### Address: Operational Base + offset (0x0024) Receive FIFO Size Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:0  | RW   | 0×0000      | RxFDep<br>RxFIFO Depth<br>This value is in terms of 32-bit words.<br>Minimum value is 16, Maximum value is<br>32,768. The power-on reset value of this<br>register is specified as the Largest Rx Data<br>FIFO Depth. If Enable Dynamic FIFO Sizing?<br>was deselected, these flops are optimized,<br>and reads return the power-on value. If<br>Enable Dynamic FIFO Sizing? was selected ,<br>you can write a new value in this field. You can<br>write a new value in this field. Programmed<br>values must not exceed the power-on value. |

### USBOTG\_GNPTXFSIZ

Address: Operational Base + offset (0x0028) Non-Periodic Transmit FIFO Size Register

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000             | NPTxFDep<br>Non-periodic TxFIFO<br>For host mode, this field is always valid. For<br>Device mode, this field is valid only when<br>OTG_EN_DED_TX_FIFO==0. This value is in<br>terms of 32-bit words. Minimum value is 16<br>Maximum value is 32,768<br>This field is determined by Enable Dynamic<br>FIFO Sizing.<br>OTG_DFIFO_DYNAMIC = 0: These flops are<br>optimized, and reads return the<br>Power on value.<br>OTG_DFIFO_DYNAMIC = 1: The application<br>can write a new value in this field.<br>Programmed values must not exceed the<br>power-on value.<br>The power-on reset value of this field is<br>specified by OTG_EN_DED_TX_FIFO:<br>OTG_EN_DED_TX_FIFO = 0:The reset value<br>is the Largest Non-periodic Tx<br>Data FIFO Depth parameter,<br>OTG_TX_NPERIO_DFIFO_DEPTH.<br>OTG_EN_DED_TX_FIFO = 1: The reset value<br>is parameter<br>OTG_TX_HNPERIO_DFIFO_DEPTH. |

| Bit   | Attr   | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | RW     | 0x0000      | NPTxFStAddr<br>Non-periodic Transmit RAM<br>For host mode, this field is always valid. This<br>field contains the memory start address for<br>Non-periodic Transmit FIFO RAM. This field is<br>determined by Enable Dynamic FIFO<br>Sizing?(OTG_DFIFO_DYNAMIC):<br>OTG_DFIFO_DYNAMIC = 0: These flops are<br>optimized, and reads return the power-on<br>value.<br>OTG_DFIFO_DYNAMIC = 1: The application<br>can write a new value in this field.<br>Programmed values must not exceed the<br>power-on value.<br>The power-on reset value of this field is<br>specified by Largest Rx Data FIFO Depth<br>(parameter OTG_RX_DFIFO_DEPTH). |
| USBOT | G_GNPT | XSTS        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

### USBOTG\_GNPTXSTS

Address: Operational Base + offset (0x002c) Non-Periodic Transmit FIFO/Oueue Status Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 30:24 | RO   | 0×00        | NPTxQTop<br>Top of the Non-periodic Transmit Request<br>Queue<br>Entry in the Non-periodic Tx Request Queue<br>that is currently being processed by the MAC.<br>Bits [30:27]: Channel/endpoint number<br>Bits [26:25]:<br>2'b00: IN/OUT token<br>2'b01: Zero-length transmit packet (device<br>IN/host OUT)<br>2'b10: PING/CSPLIT token<br>2'b11: Channel halt command<br>Bit [24]: Terminate (last entry for selected<br>channel/endpoint)                 |
| 23:16 | RO   | 0×00        | NPTxQSpcAvail<br>Non-periodic Transmit Request Queue Space<br>Available<br>Indicates the amount of free space available in<br>the Non-periodic Transmit Request Queue.<br>This queue holds both IN and OUT requests in<br>Host mode. Device mode has only IN<br>requests.<br>8'h0: Non-periodic Transmit Request Queue<br>is full<br>8'h1: 1 location available<br>8'h2: 2 locations available<br>n: n locations available (0 <=n <= 8)<br>Others: Reserved |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit                                                                                   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                           |  |
|---------------------------------------------------------------------------------------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15:0                                                                                  | RO   | 0×0000      | NPTxFSpcAvail<br>Non-periodic TxFIFO Space Avail<br>Indicates the amount of free space available in<br>the Non-periodic TxFIFO. Values are in terms<br>of 32-bit words.<br>16'h0: Non-periodic TxFIFO is full<br>16'h1: 1 word available<br>16'h2: 2 words available<br>16'hn: n words available<br>(where 0 <=n<br><=32,768)<br>16'h8000: 32,768 words available<br>Others: Reserved |  |
| USBOTG_GI2CCTL<br>Address: Operational Base + offset (0x0030)<br>I2C Address Register |      |             |                                                                                                                                                                                                                                                                                                                                                                                       |  |

### USBOTG\_GI2CCTL

| Bit   | Attr  | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                        |
|-------|-------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/WSC | 0×0                | BsyDne<br>I2C Busy/Done<br>The application sets this bit to 1'b1 to start a<br>request on the I2C interface. When the<br>transfer is complete, the core de-asserts this<br>bit to 1'b0. As long as the bit is set, indicating<br>that the I2C interface is busy, the application<br>cannot start another request on the interface. |
| 30    | RW    | 0×0                | RW<br>Read/Write Indicator<br>Indicates whether a read or write register<br>transfer must be performed on the interface.<br>Read/write bursting is not supported for<br>registers.<br>1'b1: Read<br>1'b0: Write                                                                                                                    |
| 29    | RO 🔨  | 0x0                | reserved                                                                                                                                                                                                                                                                                                                           |
| 28    | RW    | 0×1                | I2CDatSe0<br>I2C DatSe0 USB Mode<br>Selects the FS interface USB mode.<br>1'b1: VP_VM USB mode<br>1'b0: DAT_SE0 USB mode                                                                                                                                                                                                           |
| 27:26 | RW    | 0×0                | I2CDevAdr<br>I2C Device Address<br>Selects the address of the I2C Slave on the<br>USB 1.1 full-speed serial transceiver that the<br>core uses for OTG signaling.<br>2'b00: 7'h2C<br>2'b01: 7'h2D<br>2'b10: 7'h2E<br>2'b11: 7'h2F                                                                                                   |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr | Reset Value | Description                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------|
|       |      |             | I2CSuspCtl                                                                     |
|       |      |             | I2C Suspend Control                                                            |
|       |      |             | Selects how Suspend is connected to a                                          |
| 25    | RW   | 0x0         | full-speed transceiver in I2C mode.                                            |
|       |      |             | 1'b0: Use the dedicated utmi_suspend_n pin                                     |
|       |      |             | 1'b1: Use an I2C write to program the                                          |
|       |      |             | Suspend bit in the PHY register                                                |
|       |      |             | Ack                                                                            |
|       |      |             | I2C ACK                                                                        |
|       |      |             | Indicates whether an ACK response was                                          |
| 24    | RO   | 0x1         | received from the I2C Slave. This bit is valid                                 |
| 27    | KO   | 0.11        | when BsyDne is cleared by the core, after                                      |
|       |      |             | application has initiated an I2C access.                                       |
|       |      |             | 1'b0: NAK                                                                      |
|       |      |             | 1'b1: ACK                                                                      |
|       | RW   | 0×0         | I2CEn                                                                          |
| 23    |      |             | I2C Enable                                                                     |
|       |      |             | Enables the I2C Master to initiate I2C                                         |
|       |      |             | transactions on the I2C interface                                              |
|       |      |             | Addr                                                                           |
|       |      |             | I2C Address                                                                    |
|       |      |             | This is the 7-bit I2C device address used by                                   |
| 22:16 | RW   | 0x00        | software to access any external I2C Slave,                                     |
| _     |      |             | including the I2C Slave on a USB 1.1 OTG                                       |
|       |      |             | full-speed serial transceiver. Software can                                    |
|       |      |             | change this address to access different I2C                                    |
|       |      |             | Slaves.                                                                        |
|       |      |             | RegAddr                                                                        |
| 15:8  | RW   | 0x00        | I2C Register Addr                                                              |
|       |      |             | This field programs the address of the register to be read from or written to. |
|       |      |             | RWData                                                                         |
|       |      | X Y         | I2C Read/Write Data                                                            |
|       |      |             | After a register read operation, this field holds                              |
|       |      | $1 \vee$    | the read data for the application. During a                                    |
| 7:0   | RW   | 0x00        | write operation, the application can use this                                  |
|       | C    |             | register to program the write data to be                                       |
|       |      | /           | written to a register. During writes, this field                               |
|       |      |             | holds the write data.                                                          |
|       |      |             |                                                                                |

### USBOTG\_GPVNDCTL

Address: Operational Base + offset (0x0034) PHY Vendor Control Register

| Bit Attr Reset Value Description |
|----------------------------------|
|----------------------------------|

| Bit   | Attr   | Reset Value | Description                                        |
|-------|--------|-------------|----------------------------------------------------|
|       | 1      |             | DisUlpiDrvr                                        |
|       |        |             | Disable ULPI Drivers                               |
|       |        |             | This field is used only if the Carkit interface    |
|       |        |             | was enabled (OTG_ULPI_CARKIT = 1).                 |
|       |        |             | Otherwise, reads return 0. The application         |
|       |        |             | sets this bit when it has finished processing      |
| 31    | R/WSC  | 0x0         |                                                    |
|       |        |             | the ULPI Carkit Interrupt                          |
|       |        |             | (GINTSTS.ULPICKINT). When set, the Otg             |
|       |        |             | core disables drivers for output signals and       |
|       |        |             | masks input signal for the ULPI interface. Otg     |
|       |        |             | clears this bit before enabling the ULPI           |
|       |        |             | interface.                                         |
| 30:28 | RO     | 0x0         | reserved                                           |
|       |        |             | VStsDone                                           |
|       |        |             | VStatus Done                                       |
| 27    | R/WSC  | 0.00        | The core sets this bit when the vendor control     |
| 27    | R/ WSC | 0.00        | access is done. This bit is cleared by the core    |
|       |        |             | when the application sets the New Register         |
|       |        |             | Request bit (bit 25).                              |
|       |        |             | VStsBsy                                            |
|       | RO     |             | VStatus Busy                                       |
| 26    | RO     | 0x0         | The core sets this bit when the vendor control     |
| 20    |        |             | access is in progress and clears this bit when     |
|       |        |             | done.                                              |
|       |        |             | NewRegReq                                          |
|       |        |             | New Register Request                               |
| 25    | R/WSC  | 0x0         | The application sets this bit for a new vendor     |
|       |        |             | control access.                                    |
| 24:23 | RO     | 0x0         | reserved                                           |
| 27.25 |        |             | RegWr                                              |
|       |        |             | Register Write                                     |
| 22    | RW     | 0x0         | Set this bit for register writes, and clear it for |
|       |        | Y           | register reads.                                    |
|       |        |             |                                                    |
|       |        | $1 \cup$    | RegAddr                                            |
| 21.10 | DW     | 0x00        | Register Address                                   |
| 21:16 | RW     | 000         | The 6-bit PHY register address for immediate       |
|       |        |             | PHY Register Set access. Set to                    |
|       |        |             | 6'h2F for Extended PHY Register Set access.        |
|       |        |             | VCtrl                                              |
|       |        |             | UTMI+ Vendor Control Register Address              |
|       |        |             | The 4-bit register address a vendor defined        |
| 15:8  | RW     | 0x00        | 4-bit parallel output bus. Bits 11:8 of this field |
|       |        |             | are placed on utmi_vcontrol[3:0]. ULPI             |
|       |        |             | Extended Register Address (ExtRegAddr) The         |
|       | ļ      |             | 6-bit PHY extended register address.               |
|       |        |             | RegData                                            |
|       |        |             | Register Data                                      |
| 17.0  | 1      | 000         | Contains the sumiter data for neglister sumiter    |
| 7:0   | RW     | 0x00        | Contains the write data for register write.        |
| 7:0   | RW     | UXUU        | Read data for register read, valid when            |

### USBOTG\_GGPIO

Address: Operational Base + offset (0x0038) General Purpost Input/Output Register

Bit Attr Deget Value

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                  |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000      | GPO<br>General Purpose Output<br>This field is driven as an output from the core,<br>gp_o[15:0]. The application can program this<br>field to determine the corresponding value on<br>the gp_o[15:0] output. |
| 15:0  | RO   | 0×0000      | GPI<br>General Purpose Input<br>This field's read value reflects the gp_i[15:0]<br>core input value.                                                                                                         |

#### USBOTG\_GUID

Address: Operational Base + offset (0x003c) User ID Register

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:0 | RW   | 0x00000000  | UserID<br>Application-programmable ID field. |

#### USBOTG\_GSNPSID

Address: Operational Base + offset (0x0040)

Core ID Register

| Bit  | Attr | <b>Reset Value</b> | Description                                     |
|------|------|--------------------|-------------------------------------------------|
| 31:0 | RO   | 0x00004f54         | CoreID<br>Release number of the core being used |

#### USBOTG\_GHWCFG1

Address: Operational Base + offset (0x0044) User HW Config1 Register

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                   |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S    |      |                    | epdir<br>Endpoint Direction<br>This 32-bit field uses two bits per endpoint to<br>determine the endpoint direction.<br>Endpoint<br>Bits [31:30]: Endpoint 15 direction<br>Bits [29:28]: Endpoint 14 direction |
| 31:0 | RO   | 0x0000000          | <br>Bits [3:2]: Endpoint 1 direction<br>Bits[1:0]: Endpoint 0 direction (always<br>BIDIR)<br>Direction<br>2'b00: BIDIR (IN and OUT) endpoint<br>2'b01: IN endpoint<br>2'b10: OUT endpoint<br>2'b11: Reserved  |

#### USBOTG\_GHWCFG2

Address: Operational Base + offset (0x0048) User HW Config2 Register

| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
|       |      |             | OTG_ENABLE_IC_USB                            |
|       |      |             | IC_USB mode specified for mode of operation  |
| 21    |      | 0.40        | (parameter OTG_ENABLE_IC_USB). To            |
| 31    | RO   | 0x0         | choose IC_USB_MODE, both                     |
|       |      |             | OTG_FSPHY_INTERFACE and                      |
|       |      |             | OTG_ENABLE_IC_USB must be 1.                 |
|       |      |             | TknQDepth                                    |
| 20.20 |      | 000         | Device Mode IN Token Sequence Learning       |
| 30:26 | RO   | 0x00        | Queue Depth                                  |
|       |      |             | Range: 0-30                                  |
|       |      |             | PTxQDepth                                    |
|       |      |             | Host Mode Periodic Request Queue Depth       |
| 25.24 |      | 00          | 2'b00: 2                                     |
| 25:24 | RO   | 0x0         | 2'b01: 4                                     |
|       |      |             | 2'b10: 8                                     |
|       |      |             | Others: Reserved                             |
|       |      |             | NPTxQDepth                                   |
|       |      |             | Non-periodic Request Queue Depth             |
| ~~ ~~ | 50   |             | 2'b00: 2                                     |
| 23:22 | RO   | 0x0         | 2'b01: 4                                     |
|       |      |             | 2'b10: 8                                     |
|       |      |             | Others: Reserved                             |
| 21    | RO   | 0x0         | reserved                                     |
|       | _    |             | MultiProcIntrpt                              |
|       |      |             | Multi-Processor Interrupt Enabled            |
| 20    | RO   | 0x0         | 1'b0: No                                     |
|       |      |             | 1'b1: Yes                                    |
|       |      |             | DynFifoSizing                                |
| 10    |      |             | Dynamic FIFO Sizing Enabled                  |
| 19    | RO   | 0x0         | 1'b0: No                                     |
|       |      | 1           | 1'b1: Yes                                    |
|       |      |             | PerioSupport                                 |
|       |      |             | Periodic OUT Channels Supported in Host      |
| 18    | RO   | 0x0         | Mode                                         |
|       |      |             | 1'b0: No                                     |
|       |      |             | 1'b1: Yes                                    |
|       |      |             | NumHstChnl                                   |
|       |      |             | Number of Host Channels                      |
| 17.14 |      | 00          | Indicates the number of host channels        |
| 17:14 | RO   | 0x0         | supported by the core in Host mode. The      |
|       |      |             | range of this field is 0-15: 0 specifies 1   |
|       |      |             | channel, 15 specifies 16 channels.           |
|       |      |             | NumDevEps                                    |
|       |      |             | Number of Device Endpoints                   |
| 12.10 |      | 0.40        | Indicates the number of device endpoints     |
| 13:10 | RO   | 0x0         | supported by the core in Device mode in      |
|       |      |             | addition to control endpoint 0. The range of |
|       |      |             | this field is 1-15.                          |
|       |      |             | this field is 1-15.                          |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8 | RO   | 0×0         | FSPhyType<br>Full-Speed PHY Interface Type<br>2'b00: Full-speed interface not supported<br>2'b01: Dedicated full-speed interface<br>2'b10: FS pins shared with UTMI+ pins<br>2'b11: FS pins shared with ULPI pins                                                                                                                                                |
| 7:6 | RO   | 0×0         | HSPhyType<br>High-Speed PHY Interface Type<br>2'b00: High-Speed interface not supported<br>2'b01: UTMI+<br>2'b10: ULPI<br>2'b11: UTMI+ and ULPI                                                                                                                                                                                                                  |
| 5   | RO   | 0x0         | SingPnt<br>Point-to-Point<br>1'b0: Multi-point application (hub and split<br>support)<br>1'b1: Single-point application (no hub and no<br>split support)                                                                                                                                                                                                         |
| 4:3 | RO   | 0x0         | OtgArch<br>Architecture<br>2'b00: Slave-Only<br>2'b01: External DMA<br>2'b10: Internal DMA<br>Others: Reserved                                                                                                                                                                                                                                                   |
| 2:0 | RO   | 0×0         | OtgMode<br>Mode of Operation<br>3'b000: HNP- and SRP-Capable OTG (Host<br>and Device)<br>3'b001: SRP-Capable OTG (Host and Device)<br>3'b010: Non-HNP and Non-SRP Capable OTG<br>(Host and Device)<br>3'b011: SRP-Capable Device<br>3'b101: SRP-Capable Device<br>3'b100: Non-OTG Device<br>3'b101: SRP-Capable Host<br>3'b110: Non-OTG Host<br>Others: Reserved |

### USBOTG\_GHWCFG3

Address: Operational Base + offset (0x004c) User HW Config3 Register

| Bit   | Attr | Reset Value | Description                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------|
|       |      |             | DfifoDepth<br>DFIFO Depth                                                                 |
| 31:16 | RO   | 0x0000      | This value is in terms of 32-bit words.<br>Minimum value is 32<br>Maximum value is 32,768 |
| 15    | RO   | 0×0         | OTG_ENABLE_LPM<br>LPM mode specified for Mode of Operation<br>(parameter OTG_ENABLE_LPM). |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                   |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Dit | 7.0  | Reset value | OTG BC SUPPORT                                                                                                                                                                                                                                                |
| 14  | RO   | 0x0         | This bit indicates the HS OTG controller<br>support for Battery Charger.<br>1'b0: No Battery Charger Support<br>1'b1: Battery Charger support present.                                                                                                        |
| 13  | RO   | 0×0         | OTG_ENABLE_HSIC<br>HSIC mode specified for Mode of Operation<br>(parameter OTG_ENABLE_HSIC).<br>Value Range: 0-1<br>1'b1: HSIC-capable with shared UTMI PHY<br>interface<br>1'b0: Non-HSIC-capable                                                            |
| 12  | RO   | 0×0         | OTG_ADP_SUPPORT<br>This bit indicates whether ADP logic is present<br>within or external to the HS OTG<br>controller<br>1'b0: No ADP logic present with HSOTG<br>controller<br>1'b1: ADP logic is present along with HSOTG<br>controller.                     |
| 11  | RO   | 0×0         | RstType<br>Reset Style for Clocked always Blocks in RTL<br>1'b0: Asynchronous reset is used in the core<br>1'b1: Synchronous reset is used in the core                                                                                                        |
| 10  | RO   | 0×0         | OptFeature<br>Optional Features Removed<br>Indicates whether the User ID register, GPIO<br>interface ports, and SOF toggle and counter<br>ports were removed for gate count<br>optimization by enabling Remove Optional<br>Features?<br>1'b0: No<br>1'b1: Yes |
| 9   | RO   | 0x0         | VndctlSupt<br>Vendor Control Interface Support<br>1'b0: Vendor Control Interface is not<br>available on the core.<br>1'b1: Vendor Control Interface is available.                                                                                             |
| 8   | RO   | 0×0         | I2CIntSel<br>I2C Selection<br>1'b0: I2C Interface is not available on the<br>core.<br>1'b1: I2C Interface is available on the core.                                                                                                                           |
| 7   | RO   | 0×0         | OtgEn<br>OTG Function Enabled<br>The application uses this bit to indicate the<br>Otg core's OTG capabilities.<br>1'b0: Not OTG capable<br>1'b1: OTG Capable                                                                                                  |

| Bit | Attr         | Reset Value                        | Description                                                                                                                                                                                      |
|-----|--------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | RO           | 0x0                                | PktSizeWidth<br>Width of Packet Size Counters<br>3'b000: 4 bits<br>3'b001: 5 bits<br>3'b010: 6 bits<br>3'b011: 7 bits<br>3'b100: 8 bits<br>3'b101: 9 bits<br>3'b110: 10 bits<br>Others: Reserved |
| 3:0 | RO           | 0x0                                | XferSizeWidth<br>Width of Transfer Size Counters<br>4'b0000: 11 bits<br>4'b0001: 12 bits<br><br>4'b1000: 19 bits<br>Others: Reserved                                                             |
|     | <b>G_GHW</b> | ' <b>CFG4</b><br>tional Base + off | Set (0x0050)                                                                                                                                                                                     |

**USBOTG\_GHWCFG4** Address: Operational Base + offset (0x0050) User HW Config4 Register

| Bit   | Attr | Reset Value | Description                                  |
|-------|------|-------------|----------------------------------------------|
|       |      |             | SGDMA                                        |
| 31    | RO   | 0x0         | Scatter/Gather DMA                           |
|       |      |             | 1'b1: Dynamic configuration                  |
|       |      |             | SGDMACon                                     |
| 30    | RO   | 0x0         | Scatter/Gather DMA configuration             |
| 50    | NO   |             | 1'b0: Non-Scatter/Gather DMA configuration   |
|       |      | •           | 1'b1: Scatter/Gather DMA configuration       |
|       |      |             | INEps                                        |
|       |      |             | Number of Device Mode IN Endpoints           |
|       |      |             | Including Control Endpoint                   |
| 29:26 | RO   | 0x0         | Range 0 -15                                  |
| 25120 |      |             | 0:1 IN Endpoint                              |
|       |      |             | 1:2 IN Endpoints                             |
|       |      |             |                                              |
|       |      |             | 15:16 IN Endpoints                           |
|       |      |             | DedFifoMode                                  |
|       |      |             | Enable Dedicated Transmit FIFO for device IN |
|       |      | 0.40        | Endpoints                                    |
| 25    | RW   | 0x0         | 1'b0: Dedicated Transmit FIFO Operation not  |
|       |      |             | enabled.                                     |
|       |      |             | 1'b1: Dedicated Transmit FIFO Operation      |
|       |      |             | enabled.<br>SessEndFltr                      |
|       |      |             | session_end Filter Enabled                   |
| 24    | RW   | 0x0         | 1'b0: No filter                              |
|       |      |             | 1'b1: Filter                                 |
|       |      | l           |                                              |

| Bit                    | Attr | Reset Value | Description                                  |
|------------------------|------|-------------|----------------------------------------------|
|                        |      |             | BValidFltr                                   |
| ~~                     | 5.44 |             | "b_valid" Filter Enabled                     |
| 23                     | RW   | 0x0         | 1'b0: No filter                              |
|                        |      |             | 1'b1: Filter                                 |
|                        |      |             | AValidFltr                                   |
| ~~                     |      |             | "a valid" Filter Enabled                     |
| 22                     | RO   | 0x0         | 1'b0: No filter                              |
|                        |      |             | 1'b1: Filter                                 |
|                        |      |             | VBusValidFltr                                |
|                        |      |             | "vbus valid" Filter Enabled                  |
| 21                     | RO   | 0x0         | 1'b0: No filter                              |
|                        |      |             | 1'b1: Filter                                 |
|                        |      |             | IddgFltr                                     |
|                        |      |             | "iddig" Filter Enable                        |
| 20                     | RO   | 0x0         | 1'b0: No filter                              |
|                        |      |             | 1'b1: Filter                                 |
|                        |      |             | NumCtlEps                                    |
|                        |      |             | Number of Device Mode Control Endpoints in   |
| 19:16                  | RO   | 0x0         | Addition to Endpoint                         |
|                        |      |             | Range: 0-15                                  |
|                        |      |             | PhyDataWidth                                 |
|                        |      |             | UTMI+ PHY/ULPI-to-Internal UTMI+ Wrapper     |
|                        |      |             | Data Width                                   |
|                        |      |             | When a ULPI PHY is used, an internal wrapper |
| 15:14                  | RO   | 0x0         | converts ULPI to UTMI+.                      |
| 13.14                  | KO   | 0.00        | 2'b00: 8 bits                                |
|                        |      |             | 2'b01: 16 bits                               |
|                        |      |             | 2'b10: 8/16 bits, software selectable        |
|                        |      |             | Others: Reserved                             |
| 13:7                   | RO   | 0x0         | reserved                                     |
| 15.7                   | ĸu   | UXU         | EnHiber                                      |
|                        |      |             | Enable Hibernation                           |
| 6                      | RO   | 0x0         |                                              |
|                        |      |             | 1'b0: Hibernation feature not enabled        |
|                        |      | 1           | 1'b1: Hibernation feature enabled            |
|                        |      |             | AhbFreq                                      |
| 5                      | RO 🦳 | 0x0         | Minimum AHB Frequency Less Than 60 MHz       |
|                        |      |             | 1'b0: No                                     |
|                        |      |             | 1'b1: Yes                                    |
| $\boldsymbol{\lambda}$ |      |             | EnParPwrDown                                 |
| 4                      | RO   | 0x0         | Enable Partial Power Down                    |
|                        | _    |             | 1'b0: Partial Power Down Not Enabled         |
|                        |      |             | 1'b1: Partial Power Down Enabled             |
|                        |      |             | NumDevPerioEps                               |
| 3:0                    | RO   | 0x0         | Number of Device Mode Periodic IN Endpoints  |
|                        |      |             | Range: 0-15                                  |

### USBOTG\_GLPMCFG

| Address: Operational | Base + offset ( | (0x0054) |
|----------------------|-----------------|----------|
|----------------------|-----------------|----------|

Core LPM Configuration Register

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr | <b>Reset Value</b> | Description                                                                               |
|-------|------|--------------------|-------------------------------------------------------------------------------------------|
|       |      |                    | InvSelHsic                                                                                |
|       |      |                    | HSIC-Invert Select HSIC                                                                   |
|       |      |                    | The application uses this bit to control the Otg                                          |
|       |      |                    | core HSIC enable/disable. This bit overrides                                              |
|       |      |                    | and functionally inverts the if_sel_hsic input                                            |
|       |      |                    | port signal. If the core operates as                                                      |
|       |      |                    | non-HSIC-capable, it can only connect to                                                  |
|       |      |                    | non-HSIC-capable PHYs. If the core operates                                               |
|       |      |                    | as HSIC-capable, it can only connect to HSIC                                              |
|       |      |                    | capable PHYs. If the if_sel_hsic input signal                                             |
| 31    | RW   | 0x0                | is1:                                                                                      |
|       |      |                    | 1'b1: HSIC capability is not enabled.                                                     |
|       |      |                    | 1'b0: HSIC capability is enabled,                                                         |
|       |      |                    | If InvSelHsic = 1'b0: HSIC capability is                                                  |
|       |      |                    | enabled. If the if_sel_hsic input signal is 0:                                            |
|       |      |                    | 1'b1: HSIC capability is enabled,                                                         |
|       |      |                    | 1'b0: HSIC capability is not enabled.                                                     |
|       |      |                    | This bit is writable only if an HSIC mode was                                             |
|       |      |                    | specified for Mode of Operation (parameter                                                |
|       |      |                    | OTG_ENABLE_HSIC). This bit is valid only if                                               |
|       |      |                    | OTG_ENABLE_HSIC is enabled.                                                               |
|       |      |                    | HSICCon                                                                                   |
|       |      |                    | HSIC-Connect                                                                              |
|       |      |                    | The application must use this bit to initiate the                                         |
|       |      |                    | HSIC Attach sequence. Host Mode: Once this                                                |
|       |      |                    | bit is set, the host core configures to drive the                                         |
|       |      |                    | HSIC Idle state (STROBE = 1 & DATA = 0) on                                                |
| 30    | RW   | 0x0                | the bus. It then waits for the device to initiate                                         |
|       |      |                    | the Connect sequence. Device Mode: Once                                                   |
|       |      | • • •              | this bit is set, the device core waits for the                                            |
|       |      |                    | HSIC Idle line state on the bus. Upon receiving                                           |
|       |      |                    | the Idle line state, it initiates the HSIC<br>Connect sequence. This bit is valid only if |
|       |      |                    | OTG_ENABLE_HSIC is 1, if_sel_hsic = 1 and                                                 |
|       |      |                    | InvSelHSIC is 0. Otherwise, it is read-only.                                              |
| 29:28 | RO   | 0x0                | reserved                                                                                  |
| 27.20 |      |                    | LPM_RetryCnt_Sts                                                                          |
|       |      |                    | LPM Retry Count Status                                                                    |
| 27:25 | RO   | 0x0                | Number of LPM host retries remaining to be                                                |
|       |      |                    | transmitted for the current LPM sequence.                                                 |
|       |      |                    | SndLPM                                                                                    |
| Y     |      |                    | Send LPM Transaction                                                                      |
|       |      |                    | Host Mode: When the application software                                                  |
|       |      |                    | sets this bit, an LPM transaction containing                                              |
|       |      |                    | two tokens, EXT and LPM, is sent. The                                                     |
| 24    | RW   | 0x0                | hardware clears this bit once a valid response                                            |
|       |      |                    | (STALL, NYET, or ACK) is received from the                                                |
|       |      |                    | device or the core has finished transmitting                                              |
|       |      |                    | the programmed number of LPM retries. Note:                                               |
|       |      |                    | This bit must only be set when the host is                                                |
|       |      |                    | connected to a local port.                                                                |
|       |      |                    | the programmed number of LPM retries. Note:<br>This bit must only be set when the host is |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:21 | R/WSC | 0x0         | LPM_Retry_Cnt<br>LPM Retry Count<br>When the device gives an ERROR response,<br>this is the number of additional LPM retries<br>that the host performs until a valid device<br>response (STALL, NYET, or ACK) is received.                                                                                                                                                                                                          |
| 20:17 | RW    | 0x0         | LPM_Chnl_Indx<br>LPM Channel Index<br>The channel number on which the LPM<br>transaction must be applied while sending an<br>LPM transaction to the local device. Based on<br>the LPM channel index, the core automatically<br>inserts the device address and endpoint<br>number programmed in the corresponding<br>channel into the LPM transaction.                                                                               |
| 16    | RO    | 0x0         | L1ResumeOK<br>Sleep State Resume OK<br>Indicates that the application or host can start<br>a resume from the Sleep state. This bit is valid<br>in the LPM Sleep (L1) state. It is set in Sleep<br>mode after a delay of 50 us (TL1Residency).<br>The bit is reset when SlpSts is 0<br>1'b1: The application/core can start resume<br>from the Sleep state<br>1'b0: The application/core cannot start<br>resume from the Sleep state |

Rockettil

Rockchip RK3128 Technical Reference Manual Rev 1.0

|    |     | Description<br>SlpSts<br>Port Sleep Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RO | 0×0 | Device Mode: This bit is set as long as a Sleep<br>condition is present on the USB bus. The core<br>enters the Sleep state when an ACK response<br>is sent to an LPM transaction and the timer<br>TL1TokenRetry. has expired. To stop the PHY<br>clock, the application must set the Port Clock<br>Stop bit, which asserts the PHY Suspend input<br>pin. The application must rely on SlpSts and<br>not ACK in CoreL1Res to confirm transition<br>into sleep.<br>The core comes out of sleep:<br>When there is any activity on the USB<br>line_state<br>When the application writes to the Remote<br>Wakeup Signaling bit in the Device Control<br>register (DCTL.RmtWkUpSig) or when the<br>application resets or soft-disconnects the<br>device.<br>Host Mode: The host transitions to the Sleep<br>(L1) state as a sideeffect of a successful LPM<br>transaction by the core to the local port with<br>an ACK response from the device. The read<br>value of this bit reflects the port's current<br>sleep status. The core clears this bit after:<br>The core detects a remote L1 Wakeup signal<br>The application sets the Port Reset bit or the<br>Port L1Resume bit in the HPRT register or<br>The application sets the L1Resume/ Remote<br>Wakeup Detected Interrupt bit or Disconnect<br>Detected Interrupt bit in the Core Interrupt<br>register (GINTSTS.L1WkUpInt or<br>GINTSTS.DisconnInt, respectively).<br>Values:<br>1'b0: Core not in L1<br>1'b1: Core in L1 |
| RO | 0x0 | CoreL1Res<br>LPM Response<br>Device Mode: The core's response to the<br>received LPM transaction is reflected in these<br>two bits. Host Mode: The handshake response<br>received from the local device for LPM<br>transaction.<br>2'b11: ACK<br>2'b10: NYET<br>2'b01: STALL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| put the PHY i<br>when the HIF<br>to the value o<br>(GLPMCFG.HJ<br>HIRD_Thres[<br>Host Mode: T<br>put the PHY i<br>when HIRD_T<br>HIRD_Thres[<br>resume signa<br>TL1HubDrvRe<br>detects devic<br>must not be p<br>than 4'b1100 | The core asserts L1SuspendM to<br>nto Deep Low-Power mode in L1<br>RD value is greater than or equal<br>defined in this field<br>IRD_Thres[3:0]), and<br>4] is set to 1'b1.<br>The core asserts L1SuspendM to<br>nto Deep Low-Power mode in L1<br>Thres[4] is set to 1'b1.<br>3:0] specifies the time for which<br>ling is to be reflected by the host |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                               | 1       135         0       210         1       285         0       360         1       435         0       510         1       585         0       660         1       735         0       810         1       885         0       960         1       invalid         0       invalid                                                                |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RW   | 0x0         | EnblSlpM<br>Enable utmi_sleep_n<br>For ULPI interface: The application uses this<br>bit to write to the function control [7] in the L1<br>state, to enable the PHY to go into Low Power<br>mode. For the host, this bit is valid only in<br>Local Device mode.<br>1'b0: Writes to the ULPI Function Control Bit<br>[7] are disabled.<br>1'b1: The core is enabled to write to the ULPI<br>Function Control Bit [7], which enables the<br>PHY to enter Low-Power mode.<br>Note: When a ULPI interface is configured,<br>enabling this bit results in a write to Bit 7 of<br>the ULPI Function Control register. The ULPI<br>PHY supports writing to this bit, and in the L1<br>state asserts SleepM when<br>utmi_l1_suspend_n cannot be asserted.<br>When a ULPI interface is configured, this bit<br>must always be set if you are using the ULPI<br>PHY. Note: For ULPI interface, do not clear this<br>bit during the resume. For all other interfaces:<br>The application uses this bit to control<br>utmi_sleep_n assertion to the PHY in the L1<br>state. For the host, this bit is valid only in<br>Local Device mode.<br>1'b0: utmi_sleep_n assertion from the core is<br>not transferred to the external PHY.<br>1'b1: utmi_sleep_n assertion from the core is<br>transferred to the external PHY when<br>utmi_l1_suspend_n cannot be asserted. |
| 6   | RW   | 0×0         | bRemoteWake<br>RemoteWakeEnable<br>Host Mode: The remote wakeup value to be<br>sent in the LPM transaction's wIndex field.<br>Device Mode: This field is updated with the<br>received bRemoteWake LPM token's<br>bmAttribute when an ACK/NYET/STALL<br>response is sent to an LPM transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| X   |      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Bit | Attr                                    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |             | HIRD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5:2 | RW                                      | 0×0         | Host-Initiated Resume DurationHost Mode: The value of HIRD to be sent in anLPM transaction. This value is also used toinitiate resume for a duration $.T_{L1HubDrvResume1}$ for host initiated resume. Device Mode: Thisfield is updated with the Received LPM TokenHIRD bmAttribute when an ACK/NYET/STALLresponse is sent to an LPM transactionSI. NoHIRD[3:0]THIRD (us)14'b00005024'b00112534'b001127554'b01014'b010142574'b011157594'b0101104'b1001124'b1011800124'b1010134'b1101144'b1101154'b110101100                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     | RW                                      | 0×0         | 164'b11111175AppL1ResLPM response programmed by applicationHandshake response to LPM tokenpre-programmed by device applicationsoftware. The response depends onGLPMCFG.LPMCap. If GLPMCFG.LPMCap is1'b0, the core always responds with a NYET. IfGLPMCFG.LPMCap is 1'b1, the core respondsas follows:1'b1: ACK. Even though an ACK ispre-programmed, the core responds with anACK only on a successful LPM transaction. TheLPM transaction is successful if: There are noPID/CRC5 errors in both the EXT token andthe LPM token (else ERROR); A validbLinkState = 0001B (L1) is received in theLPM transaction (else STALL); No data ispending in the Transmit queue (else NYET)1'b0: NYET. The pre-programmed software bitis overridden for response to LPM token when:(1) The received bLinkState is not L1 (STALLresponse); (2) An error is detected in either ofthe LPM token packets due to corruption(ERROR response). |

| Bit                                                          | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------------------------------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                                            | RW   | 0×0                | LPMCap<br>LPM-Capable<br>The application uses this bit to control the OTG<br>core LPM capabilities. If the core operates as a<br>non-LPM-capable host, it cannot request the<br>connected device/hub to activate LPM mode.<br>If the core operates as a non-LPM-capable<br>device, it cannot respond to any LPM<br>transactions.<br>1'b0: LPM capability is not enabled.<br>1'b1: LPM capability is enabled.<br>This bit is writable only if an LPM mode was<br>specified for Mode of Operation (parameter<br>OTG_ENABLE_LPM). Otherwise, reads return<br>0. |
| USBOTG_GPWRDN<br>Address: Operational Base + offset (0x0058) |      |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

### USBOTG\_GPWRDN

Address: Operational Base + offset (0x0058) Global Power Down Register

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                        |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                           |
| 28:24 | RO   | 0×00               | MultValIdBC<br>Multi Valued ID pin<br>Battery Charger ACA inputs in the following<br>order:<br>Bit 26 - rid_float.<br>Bit 25 - rid_gnd<br>Bit 24 - rid_a<br>Bit 23 - rid_b<br>Bit 22 - rid_c<br>These bits are present only if<br>OTG_BC_SUPPORT = 1.<br>Otherwise, these bits are reserved and will<br>read 5'h0. |
| 23    | W1C  | 0×0                | ADPInt<br>ADP Interupt<br>This bit is set whenever there is a ADP event.                                                                                                                                                                                                                                           |
| 22    | RO   | 0×0                | BSessVld<br>B Session Valid<br>This field reflects the B session valid status<br>signal from the PHY.<br>1'b0: B-Valid is 0.<br>1'b1: B-Valid is 1.<br>This bit is valid only when GPWRDN.PMUActv<br>is 1.                                                                                                         |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21    | RO   | 0×0         | IDDIG<br>This bit indicates the status of the signal<br>IDDIG. The application must read this bit after<br>receiving GPWRDN.StsChngInt and decode<br>based on the previous value stored by the<br>application. Indicates the current mode.<br>1'b1: Device mode<br>1'b0: Host mode<br>This bit is valid only when GPWRDN.PMUActv<br>is 1.                        |
| 20:19 | RO   | 0×0         | LineState<br>This field indicates the current linestate on<br>USB as seen by the PMU module.<br>2'b00: DM = 0, DP = 0.<br>2'b01: DM = 0, DP = 1.<br>2'b10: DM = 1, DP = 0.<br>2'b11: Not-defined.<br>This bit is valid only when GPWRDN.PMUActv<br>is 1.                                                                                                         |
| 18    | RW   | 0x0         | StsChngIntMsk<br>Mask For StsChng Interrupt                                                                                                                                                                                                                                                                                                                      |
| 17    | W1C  | 0×0         | StsChngInt<br>This field indicates a status change in either<br>the IDDIG or BSessVld signal.<br>1'b0: No Status change<br>1'b1: status change detected<br>After receiving this interrupt the application<br>should read the GPWRDN register and<br>interpret the change in IDDIG or BSesVld with<br>respect to the previous value stored by the<br>application. |
| 16    | RW   | 0x0         | SRPDetectMsk<br>Mask For SRPDetect Interrupt                                                                                                                                                                                                                                                                                                                     |
| 15    | w1C  | 0×0         | SRPDetect<br>This field indicates that SRP has been detected<br>by the PMU. This field generates an interrupt.<br>After detecting SRP during hibernation the<br>application should not restore the core. The<br>application should get into the initialization<br>process.<br>1'b0: SRP not detected<br>1'b1: SRP detected                                       |
| 14    | RW   | 0×0         | ConnDetMsk<br>Mask for ConnectDet interrupt<br>This bit is valid only when OTG_EN_PWROPT<br>= 2.                                                                                                                                                                                                                                                                 |
| 13    | W1C  | 0×0         | ConnectDet<br>This field indicates that a new connect has<br>been detected<br>1'b0: Connect not detected<br>1'b1: Connect detected<br>This bit is valid only when OTG_EN_PWROPT<br>= 2.                                                                                                                                                                          |

| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
|     |      |             | DisconnectDetectMsk                            |
|     |      |             | Mask For DisconnectDetect Interrupt            |
| 12  | RW   | 0x0         | This bit is valid only when OTG_EN_PWROPT      |
|     |      |             | = 2.                                           |
|     |      |             | DisconnectDetect                               |
|     |      |             | This field indicates that Disconnect has been  |
|     |      |             | detected by the PMU. This field generates an   |
|     |      |             | interrupt. After detecting disconnect during   |
|     |      |             | hibernation the application must not restore   |
| 11  | W1C  | 0x0         | the core, but instead start the initialization |
| 11  | WIC  | 0.0         | process.                                       |
|     |      |             | 1'b0: Disconnect not detected                  |
|     |      |             | 1'b1: Disconnect detected                      |
|     |      |             | This bit is valid only when OTG_EN_PWROPT      |
|     |      |             | = 2.                                           |
|     |      |             | ResetDetMsk                                    |
| 10  | RW   | 0x0         |                                                |
| 10  | RVV  | UXU         | Mask For ResetDetected interrupt. This bit is  |
|     |      |             | valid only when OTG_EN_PWROPT = 2.             |
|     |      |             | ResetDetected                                  |
|     |      |             | This field indicates that Reset has been       |
|     |      |             | detected by the PMU module. This field         |
| 9   | W1C  | 0x0         | generates an interrupt.                        |
|     |      |             | 1'b0: Reset Not Detected                       |
|     |      |             | 1'b1: Reset Detected                           |
|     |      |             | This bit is valid only when OTG_EN_PWROPT      |
|     |      |             | = 2.                                           |
|     |      |             | LineStageChangeMsk                             |
| 8   | RW   | 0x0         | Mask For LineStateChange interrupt             |
|     |      |             | This bit is valid only when OTG_EN_PWROPT      |
|     |      |             | = 2.                                           |
|     |      |             | LnStsChng                                      |
|     |      |             | Line State Change                              |
|     |      |             | This interrupt is asserted when there is a     |
|     |      |             | Linestate Change detected by the PMU. The      |
| _   |      | 0.0         | application should read GPWRDN.Linestate to    |
| /   | W1C  | 0x0         | determine the current linestate on USB.        |
|     |      |             | 1'b0: No LineState change on USB               |
|     |      |             | 1'b1: LineState change on USB                  |
|     |      |             | This bit is valid only when GPWRDN.PMUActv     |
|     |      |             | is 1. This bit is valid only when $D_{1} = 2$  |
|     |      |             | $OTG_EN_PWROPT = 2.$                           |
|     |      |             | DisableVBUS                                    |
| 6   |      | 0×0         | The application should program this bit if     |
|     |      |             | HPRT0.PrtPwr was programmed to 0 before        |
|     | RW   |             | entering Hibernation. This is to indicate PMU  |
|     |      |             | whether session was ended before entering      |
|     |      |             | Hibernation.                                   |
|     |      |             | 1'b0: HPRT0.PrtPwr was not programed to 0.     |
|     |      |             | 1'b1: HPRT0.PrtPwr was programmed to 0.        |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                  |
|-----|------|-------------|--------------------------------------------------------------|
|     |      |             | PwrDnSwtch                                                   |
|     |      |             | Power Down Switch                                            |
|     |      |             | This bit indicates to the OTG core VDD switch                |
| 5   | RW   | 0.40        | is in ON/OFF state                                           |
| 5   | K VV | 0x0         | 1'b0: OTG is in ON state                                     |
|     |      |             | 1'b1: OTG is in OFF state                                    |
|     |      |             | Note: This bit must not be written to during                 |
|     |      |             | normal mode of operation.                                    |
|     |      |             | PwrDnRst_n                                                   |
|     |      |             | Power Down ResetN                                            |
|     |      |             | The application must program this bit to reset               |
|     |      |             | the DWC OTG core during the Hibernation exit                 |
|     | DW   |             | process or during ADP when powering up the                   |
| 4   | RW   | 0x0         | core (in case the DWC OTG core was powered                   |
|     |      |             | off during ADP process).<br>1'b1: OTG is in normal operation |
|     |      |             | 1'b0: reset OTG                                              |
|     |      |             | Note: This bit must not be written to during                 |
|     |      |             | normal mode of operation.                                    |
|     |      |             | PwrDnClmp                                                    |
|     |      |             | Power Down Clamp                                             |
|     |      |             | The application must program this bit to                     |
| -   | 5.44 |             | enable or disable the clamps to all the outputs              |
| 3   | RW   | 0x0         | of the DWC OTG core module to prevent the                    |
|     |      |             | corruption of other active logic.                            |
|     |      |             | 1'b0: Disable PMU power clamp                                |
|     |      |             | 1'b1: Enable PMU power clamp                                 |
|     |      |             | Restore                                                      |
|     |      | C           | The application should program this bit to                   |
|     |      | • •         | enable or disable restore mode from the PMU                  |
| _   |      |             | module.                                                      |
| 2   | RW   | 0x0         | 1'b0: OTG in normal mode of operation                        |
|     |      | CY          | 1'b1: OTG in restore mode                                    |
|     |      |             | Note: This bit must not be written to during                 |
|     |      |             | normal mode of operation. This bit is valid                  |
|     |      |             | only when OTG_EN_PWROPT = 2.                                 |
|     |      |             | PMUActv<br>PMU Active                                        |
|     | ( )  |             | This is bit is to enable or disable the PMU logic.           |
|     | RW   | 0x0         | 1'b0: Disable PMU module                                     |
|     |      |             | 1'b1: Enable PMU module                                      |
|     |      |             | Note: This bit must not be written to during                 |
|     |      |             | normal mode of operation.                                    |
|     |      | l           |                                                              |

| Bit                                                             | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------------------------------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                                               | RW   | 0×0         | PMUIntSel<br>PMU Interrupt Select<br>When the hibernation functionality is selected<br>using the configuration option<br>OTG_EN_PWR_OPT = 2, a write to this bit with<br>1'b1 enables the PMU to generate interrupts<br>to the application. During this state all<br>interrupts from the core module are blocked<br>to the application. Note: This bit must be set<br>to 1'b1 before the core is put into hibernation<br>1'b0: Internal OTG_core interrupt is selected<br>1'b1: the external OTG_pmu interrupt is<br>selected<br>Note: This bit must not be written to during<br>normal mode of operation. |
| USBOTG_GDFIFOCFG<br>Address: Operational Base + offset (0x005c) |      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### USBOTG\_GDFIFOCFG

Address: Operational Base + offset (0x005c) Global DFIFO Software Config Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | EPInfoBaseAddr<br>This field provides the start address of the EP<br>info controller.                                                                                                                                                                                        |
| 15:0  | RW   | 0×0000      | GDFIFOCfg<br>This field is for dynamic programming of the<br>DFIFO Size. This value takes effect<br>only when the application programs a<br>non-zero value to this register. The core does<br>not have any corrective logic if the FIFO sizes<br>are programmed incorrectly. |

### USBOTG\_GADPCTL

Address: Operational Base + offset (0x0060) ADP Timer, Control and Status Register

| Bit   | Attr  | Reset Value | Description                                    |
|-------|-------|-------------|------------------------------------------------|
| 31:29 | RO    | 0x0         | reserved                                       |
|       |       |             | AR                                             |
|       |       |             | Access Request                                 |
|       |       |             | 2'b00 Read/Write Valid (updated by the         |
| 28:27 | R/WSC | 0x0         | core)                                          |
|       |       |             | 2'b01 Read                                     |
|       |       |             | 2'b10 Write                                    |
|       |       |             | 2'b11 Reserved                                 |
|       |       |             | AdpTmoutMsk                                    |
|       |       |             | ADP Timeout Interrupt Mask                     |
| 26    | RW    | 0x0         | When this bit is set, it unmasks the interrupt |
|       |       |             | because of AdpTmoutInt. This bit is valid only |
|       |       |             | if $OTG_Ver = 1'b1(GOTGCTL[20])$ .             |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr  | Reset Value | Description                                     |
|-----|-------|-------------|-------------------------------------------------|
|     |       |             | AdpSnsIntMsk                                    |
|     |       |             | ADP Sense Interrupt Mask                        |
| 25  | RW    | 0x0         | When this bit is set, it unmasks the interrupt  |
| 20  |       | UNC         | due to AdpSnsInt. This bit is valid only if     |
|     |       |             | $OTG_Ver = 1'b1(GOTGCTL[20]).$                  |
|     |       |             | AdpPrbIntMsk                                    |
|     |       |             | ADP Probe Interrupt Mask                        |
| 24  | RW    | 0x0         | When this bit is set, it unmasks the interrupt  |
| 27  |       | 0.0         | due to AdpPrbInt.This bit is valid only if      |
|     |       |             | $OTG_Ver = 1'b1(GOTGCTL[20]).$                  |
|     |       |             | AdpTmoutInt                                     |
|     |       |             | ADP Timeout Interrupt                           |
|     |       |             | This bit is relevant only for an ADP probe.     |
|     |       |             | When this bit is set, it means that the         |
|     |       |             | ramp time has completed (GADPCTL.RTIM has       |
| 23  | W1C   | 0x0         | reached its terminal value of                   |
|     |       |             | 0x7FF). This is a debug feature that allows     |
|     |       |             | software to read the ramp time after            |
|     |       |             | each cycle. This bit is valid only if OTG_Ver = |
|     |       |             |                                                 |
|     |       |             | AdpSnsInt                                       |
|     |       |             | ADP Sense Interrupt                             |
|     |       |             | When this bit is set, it means that the VBUS    |
| 22  | W1C   | 0x0         | voltage is greater than VadpSns                 |
|     |       |             | value or VadpSns is reached. This bit is valid  |
|     |       |             | only if OTG_Ver = 1'b1 (GOTGCTL[20]).           |
|     |       |             | AdpPrbInt                                       |
|     |       |             | ADP Probe Interrupt                             |
|     |       |             | When this bit is set, it means that the VBUS    |
| 21  | W1C   | 0x0         | voltage is greater than VadpPrb or              |
|     |       |             | VadpPrb is reached. This bit is valid only if   |
|     |       |             | $OTG_Ver = 1'b1 (GOTGCTL[20]).$                 |
|     |       |             | ADPEn                                           |
|     |       |             | ADP Enable                                      |
|     |       | $1 \cup$    | When set, the core performs either ADP          |
| 20  | RW    | 0x0         | probing or sensing based on EnaPrb or           |
|     |       |             | EnaSns. This bit is valid only if OTG_Ver =     |
|     |       | /           | 1'b1 (GOTGCTL[20]).                             |
|     |       |             | ADPRes                                          |
|     |       |             | ADP Reset                                       |
|     |       |             | When set, ADP controller is reset. This bit is  |
| 19  | R/WSC | 0x0         | auto-cleared after the reset procedure is       |
|     |       |             | complete in ADP controller. This bit is valid   |
|     |       |             | only if OTG_Ver = 1'b1 (GOTGCTL[20]).           |
|     |       |             | EnaSns                                          |
|     |       |             | Enable Sense                                    |
| 18  | RW    | 0×0         | When programmed to 1'b1, the core performs      |
| 10  |       |             | a sense operation. This bit is valid only if    |
|     |       |             | $OTG_Ver = 1'b1 (GOTGCTL[20]).$                 |
|     | 1     |             |                                                 |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit  | Attr | Reset Value | Description                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------|
|      |      |             | EnaPrb                                                                               |
|      |      |             | Enable Probe                                                                         |
| 17   | RW   | 0x0         | When programmed to 1'b1, the core performs                                           |
|      |      |             | a probe operation. This bit is valid only if                                         |
|      |      |             | $OTG_Ver = 1'b1 (GOTGCTL[20]).$                                                      |
|      |      |             | RTIM                                                                                 |
|      |      |             | RAMP TIME                                                                            |
|      |      |             | These bits capture the latest time it took for                                       |
|      |      |             | VBUS to ramp from VADP SINK to VADP PRB.                                             |
|      |      |             | The bits are defined in units of 32 kHz clock                                        |
|      |      |             | cycles as follows:                                                                   |
|      |      |             | 3'b000 - 1 cycles                                                                    |
|      |      |             | 3'b001 - 2 cycles                                                                    |
| 16:6 | RO   | 0x000       | 3'b010 - 3 cycles                                                                    |
| 10.0 | ĸŪ   | 0000        | and so on till                                                                       |
|      |      |             | 0x7FF - 2048 cycles                                                                  |
|      |      |             | A time of 1024 cycles at 32 kHz corresponds                                          |
|      |      |             | to a time of 32 msec.                                                                |
|      |      |             | (Note for scaledown ramp_timeout =                                                   |
|      |      |             | prb_delta == 2'b00 => 200 cycles                                                     |
|      |      |             | $prb_delta == 2'b01 => 100 cycles$                                                   |
|      |      |             | $prb_delta == 2'b01 => 50 cycles$                                                    |
|      |      |             | prb_delta == 2'b01 => 25 cycles.)                                                    |
|      |      |             | PrbPer                                                                               |
|      |      |             | Probe Period                                                                         |
|      |      |             | These bits sets the TadpPrd as follows:<br>2'b00 - 0.625 to 0.925 sec (typical 0.775 |
|      |      |             | sec)                                                                                 |
|      |      |             | 2'b01 - 1.25 to 1.85 sec (typical 1.55 sec)                                          |
| 5:4  | RW   | 0x0         | 2'b10 - 1.9 to 2.6 sec (typical 1.55 sec)                                            |
| 5.4  |      |             | 2'b11 - Reserved                                                                     |
|      |      |             | (PRB PER is also scaledown                                                           |
|      |      | Y           | $prb_per = 2'b00 => 400 ADP clocks$                                                  |
|      |      |             | $prb_per = 2'b01 = > 600 ADP clocks$                                                 |
|      | A    | 1           | $prb_per = 2'b10 = 800 ADP clocks$                                                   |
|      |      |             | $prb_per = 2'b11 = > 1000 ADP clocks)$                                               |
|      |      |             | PrbDelta                                                                             |
|      |      | /           | Probe Delta                                                                          |
|      |      |             | These bits set the resolution for RTIM value.                                        |
|      |      |             | The bits are defined in units of 32                                                  |
|      |      |             | kHz clock cycles as follows:                                                         |
| 3:2  | RW   | 0x0         | 2'b00 - 1 cycles                                                                     |
| 5.2  |      |             | 2'b01 - 2 cycles                                                                     |
|      |      |             | 2'b10 - 3 cycles                                                                     |
|      |      |             | 2'b11 - 4 cycles                                                                     |
|      |      |             | For example if this value is chosen to 2'b01, it                                     |
|      |      |             | means that RTIM increments for                                                       |
|      |      |             | every three 32Khz clock cycles.                                                      |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                     |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | RW   | 0×0                | PrbDschg<br>Probe Discharge<br>These bits set the times for TadpDschg. These<br>bits are defined as follows:<br>2'b00 4 msec (Scaledown 2 32Khz clock<br>cycles)<br>2'b01 8 msec (Scaledown 4 32Khz clock<br>cycles)<br>2'b10 16 msec (Scaledown 8 32Khz clock<br>cycles)<br>2'b11 32 msec (Scaledown 16 32Khz clock<br>cycles) |

### USBOTG\_HPTXFSIZ

Address: Operational Base + offset (0x0100) Host Periodic Transmit FIFO Size Register

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:16 | RW   | 0×0000             | PTxFSize<br>Host Periodic TxFIFO Depth<br>This value is in terms of 32-bit words.<br>Minimum value is 16<br>Maximum value is 32,768<br>The power-on reset value of this register is<br>specified as the Largest Host Mode Periodic Tx<br>Data FIFO Depth (parameter<br>OTG_TX_HPERIO_DFIFO_DEPTH). If Enable<br>Dynamic FIFO Sizing? Was deselected<br>(parameter OTG_DFIFO_DYNAMIC = 0),<br>these flops are optimized, and reads return<br>the power-on value. If Enable Dynamic FIFO<br>Sizing? was selected (parameter<br>OTG_DFIFO_DYNAMIC = 1), you can write a<br>new value in this field. Programmed values<br>must not exceed the power-on value set . |  |
| Rock  |      |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |

XIV'

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0×0000      | PTxFStAddr<br>Host Periodic TxFIFO Start Address<br>The power-on reset value of this register is the<br>sum of the Largest Rx Data FIFO<br>Depth and Largest Non-periodic Tx Data FIFO<br>Depth specified.<br>These parameters are:<br>In shared FIFO operation:<br>OTG_RX_DFIFO_DEPTH +<br>OTG_TX_NPERIO_DFIFO_DEPTH.<br>In dedicated FIFO mode:<br>OTG_RX_DFIFO_DEPTH +<br>OTG_TX_HNPERIO_DFIFO_DEPTH.<br>If Enable Dynamic FIFO Sizing? was<br>deselected (parameter OTG_DFIFO_DYNAMIC<br>= 0 ), these flops are optimized, and reads<br>return the power-on value.<br>If Enable Dynamic FIFO Sizing? was selected<br>(parameter OTG_DFIFO_DYNAMIC = 1), you<br>can write a new value in this field.<br>Programmed values must not exceed the<br>power-on value. |

#### USBOTG\_DIEPTXFn

Address: Operational Base + offset  $(0x0104+0x4^*(n-1))$ , n = 1 - 15 Device Periodic Transmit FIFO-n Size Register

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000             | INEP1TxFDep<br>IN Endpoint TxFIFO Depth<br>This value is in terms of 32-bit words.<br>Minimum value is 16<br>Maximum value is 32,768<br>The power-on reset value of this register is<br>specified as the Largest IN Endpoint FIFO<br>number Depth (parameter<br>OTG_TX_DINEP_DFIFO_DEPTH_n)(0 < n <=<br>15).<br>If Enable Dynamic FIFO Sizing? was<br>deselected (parameter<br>OTG_DFIFO_DYNAMIC = 0), these flops are<br>optimized, and reads return the<br>Power-on value.<br>If Enable Dynamic FIFO Sizing? was selected<br>(parameter OTG_DFIFO_DYNAMIC = 1), you<br>can write a new value in this field.<br>Programmed values must not exceed the<br>Power-on value . |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0×0000      | INEP1TxFStAddr<br>IN Endpoint FIFO1 Transmit RAM Start<br>Address<br>This field contains the memory start address<br>for IN endpoint Transmit FIFOn<br>(0 < n <= 15). The power-on reset value of<br>this register is specified as the Largest Rx<br>Data FIFO Depth (parameter<br>OTG_RX_DFIFO_DEPTH).<br>OTG_RX_DFIFO_DEPTH + SUM 0 to n-1<br>(OTG_DINEP_TXFIFO_DEPTH_n)<br>For example start address of IN endpoint FIFO<br>1 is OTG_RX_DFIFO_DEPTH +<br>OTG_DINEP_TXFIFO_DEPTH_0. The start<br>address of IN endpoint FIFO 2 is<br>OTG_RX_DFIFO_DEPTH +<br>OTG_DINEP_TXFIFO_DEPTH_0 +<br>OTG_DINEP_TXFIFO_DEPTH_1. If Enable<br>Dynamic FIFO Sizing? was deselected<br>(parameter OTG_DFIFO_DYNAMIC = 0),<br>these flops are optimized, and reads return<br>the power-on value. If Enable Dynamic FIFO<br>Sizing? was selected (parameter<br>OTG_DFIFO_DYNAMIC = 1), and you have<br>programmed a new value for RxFIFO depth,<br>you can write that value in this field.<br>Programmed values must not exceed the<br>power-on value set . |

### USBOTG\_HCFG

Address: Operational Base + offset (0x0400) Host Configuration Register

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | RO 🔨 | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 26    | RW   | 0×0                | PerSchedEna<br>Enable Periodic Scheduling<br>Applicable in Scatter/Gather DMA mode only.<br>Enables periodic scheduling within the core.<br>Initially, the bit is reset. The core will not<br>process any periodic channels. As soon as this<br>bit is set, the core will get ready to start<br>scheduling periodic channels and sets<br>HCFG.PerSchedStat. The setting of<br>HCFG.PerSchedStat indicates the core has<br>enabled periodic scheduling. Once<br>HCFG.PerSchedEna is set, the application is<br>not supposed to again reset the bit unless<br>HCFG.PerSchedStat is set. As soon as this bit<br>is reset, the core will get ready to stop<br>scheduling periodic channels and resets<br>HCFG.PerSchedStat. In non-Scatter/Gather<br>DMA mode, this bit is reserved. |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr  | Reset Value | Description                                                       |
|-------|-------|-------------|-------------------------------------------------------------------|
|       | 71001 |             | FrListEn                                                          |
|       |       |             | Frame List Entries                                                |
| 25:24 | RW    | 0x0         | The value in the register specifies the number                    |
|       |       |             | of entries in the Frame list. This field is valid                 |
|       |       |             | only in Scatter/Gather DMA mode.                                  |
|       |       |             | DescDMA                                                           |
|       |       |             | Enable Scatter/gather DMA in Host mode                            |
|       |       |             | When the Scatter/Gather DMA option selected                       |
|       |       |             | during configuration of the RTL, theapplication                   |
|       |       |             | can set this bit during initialization to enable                  |
|       |       |             | the Scatter/Gather DMA operation. NOTE:                           |
|       |       |             | This bit must be modified only once after a                       |
|       |       |             | reset. The following combinations are                             |
| 22    |       | 0.40        | available for programming:                                        |
| 23    | RW    | 0x0         | GAHBCFG.DMAEn=0, HCFG.DescDMA=0 =><br>Slave mode                  |
|       |       |             | GAHBCFG.DMAEn=0, HCFG.DescDMA=1 =>                                |
|       |       |             | Invalid                                                           |
|       |       |             | GAHBCFG.DMAEn=1, HCFG.DescDMA=0 =>                                |
|       |       |             | Buffered DMA mode                                                 |
|       |       |             | GAHBCFG.DMAEn=1, HCFG.DescDMA=1 =>                                |
|       |       |             | Scatter/Gather DMA mode                                           |
|       |       |             | In non-Scatter/Gather DMA mode, this bit is                       |
|       |       |             | reserved.                                                         |
| 22:16 | RO    | 0x0         | reserved                                                          |
|       |       |             | ResValid                                                          |
|       | RW    | 0×00        | Resume Validation Period                                          |
|       |       |             | This field is effective only when                                 |
| 15:8  |       |             | HCFG.Ena32KHzS is set. It controls the                            |
|       |       |             | resume period when the core resumes from                          |
|       |       |             | suspend. The core counts the ResValid                             |
|       |       |             | number of clock cycles to detect a valid resume when this is set. |
|       |       |             | Ena32KHzS                                                         |
|       |       | 1           | Enable 32-KHz Suspend Mode                                        |
|       | RW    | 0×0         | This bit can only be set if the USB 1.1                           |
|       |       |             | Full-Speed Serial Transceiver Interface has                       |
|       |       |             | been selected. If USB 1.1 Full-Speed Serial                       |
| 7     |       |             | Transceiver Interface has not been selected,                      |
|       |       |             | this bit must be zero. When the USB 1.1                           |
|       |       |             | Full-Speed Serial Transceiver Interface is                        |
|       |       |             | chosen and this bit is set, the core expects the                  |
|       |       |             | 48-MHz PHY clock to be switched to 32 KHz                         |
|       |       |             | during a suspend.                                                 |
| 6:3   | RO    | 0x0         | reserved                                                          |

| Bit | Attr                                                       | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|-----|------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 2   | RW                                                         | 0x0         | FSLSSupp<br>FS- and LS-Only Support<br>The application uses this bit to control the core<br>enumeration speed. Using this bit, the<br>application can make the core enumerate as a<br>FS host, even if the connected device supports<br>HS traffic. Do not make changes to this field<br>after initial programming.<br>1'b0: HS/FS/LS, based on the maximum<br>speed supported by the connected device<br>1'b1: FS/LS-only, even if the connected<br>device can support HS |  |  |
| 1:0 | RW                                                         | 0x0         | FSLSPclkSel<br>FS/LS PHY Clock Select<br>2'b00: PHY clock is running at 30/60 MHz<br>2'b01: PHY clock is running at 48 MHz<br>Others: Reserved                                                                                                                                                                                                                                                                                                                             |  |  |
|     | USBOTG_HFIR<br>Address: Operational Base + offset (0x0404) |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |

# USBOTG\_HFIR

Address: Operational Base + offset (0x0404) Host Frame Interval Register

|       |      | rval Register |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Attr | Reset Value   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:16 | RO   | 0x0           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:0  | RW   | 0×0000        | FrInt<br>Frame Interval<br>The value that the application programs to<br>this field specifies the interval between two<br>consecutive SOFs (FS) or micro-SOFs (HS) or<br>Keep-Alive tokens (HS). This field contains the<br>number of PHY clocks that constitute the<br>required frame interval. The default value set<br>in this field for a FS operation when the PHY<br>clock frequency is 60 MHz. The application can<br>write a value to this register only after the Port<br>Enable bit of the Host Port Control and Status<br>register (HPRT.PrtEnaPort) has been set. If no<br>value is programmed, the core calculates the<br>value based on the PHY clock specified in the<br>FS/LS PHY Clock Select field of the Host<br>Configuration register (HCFG.FSLSPclkSel).<br>Do not change the value of this field after the<br>initial configuration.<br>125 us * (PHY clock frequency for HS)<br>1 ms * (PHY clock frequency for FS/LS) |

## **USBOTG\_HFNUM**

Address: Operational Base + offset (0x0408)

Host Frame Number/Frame Time Remaining Register

|  | Bit | Attr | <b>Reset Value</b> | Description |
|--|-----|------|--------------------|-------------|
|--|-----|------|--------------------|-------------|

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0×0000      | FrRem<br>Frame Time Remaining<br>Indicates the amount of time remaining in the<br>current micro-frame (HS) or frame<br>(FS/LS), in terms of PHY clocks. This field<br>decrements on each PHY clock. When it<br>reaches zero, this field is reloaded with the<br>value in the Frame Interval register and a new<br>SOF is transmitted on the USB. |
| 15:0  | RO   | 0xffff      | FrNum<br>Frame Number<br>This field increments when a new SOF is<br>transmitted on the USB, and is reset to 0 when<br>it reaches 16'h3FFF. This field is writable only<br>if Remove Optional Features? was not<br>selected (OTG_RM_OTG_FEATURES = 0).<br>Otherwise, reads return the frame number<br>value.                                      |

**USBOTG\_HPTXSTS** Address: Operational Base + offset (0x0410) Host Periodic Transmit FIFO/Queue Status Register

| Bit Att  | r Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 RO | 0×00          | PTxQTop<br>Top of the Periodic Transmit Request Queue<br>This indicates the entry in the Periodic Tx<br>Request Queue that is currently being<br>processed by the MAC. This register is used for<br>debugging.<br>Bit [31]: Odd/Even (micro)frame<br>1'b0: send in even (micro)frame<br>1'b1: send in odd (micro)frame<br>Bits [30:27]: Channel/endpoint number<br>Bits [26:25]: Type<br>2'b00: IN/OUT<br>2'b01: Zero-length packet<br>2'b10: CSPLIT<br>2'b11: Disable channel command<br>Bit [24]: Terminate (last entry for the<br>selected channel/endpoint) |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:16 | RO   | 0×00        | PTxQSpcAvail<br>Periodic Transmit Request Queue Space<br>Available<br>Indicates the number of free locations<br>available to be written in the Periodic Transmit<br>Request Queue. This queue holds both IN and<br>OUT requests.<br>8'h0: Periodic Transmit Request Queue is<br>full<br>8'h1: 1 location available<br>8'h2: 2 locations available<br>n: n locations available (0 <=n <= 16)<br>Others: Reserved       |
| 15:0  | RW   | 0×0000      | PTxFSpcAvail<br>Periodic Transmit Data FIFO Space Available<br>Indicates the number of free locations<br>available to be written to in the Periodic<br>TxFIFO. Values are in terms of 32-bit words<br>. 16'h0: Periodic TxFIFO is full<br>. 16'h1: 1 word available<br>. 16'h2: 2 words available<br>. 16'hn: n words available (where 0 . n .<br>32,768)<br>. 16'h8000: 32,768 words available<br>. Others: Reserved |

## USBOTG\_HAINT

Address: Operational Base + offset (0x0414) Host All Channels Interrupt Reigster

| Bit   | Attr | <b>Reset Value</b> | Description           |
|-------|------|--------------------|-----------------------|
| 31:16 | RO   | 0x0                | reserved              |
|       |      |                    | HAINT                 |
|       |      |                    | Channel Interrupts    |
|       |      |                    | One bit per channel:  |
| 15:0  | RO   | 0x0000             | Bit 0 for Channel 0   |
|       |      |                    | Bit 1 for Channel 1   |
|       |      |                    |                       |
|       |      |                    | Bit 15 for Channel 15 |

## USBOTG\_HAINTMSK

Address: Operational Base + offset (0x0418) Host All Channels Interrupt Mask Register

| Bit   | Attr | Reset Value | Description                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                 |
| 15:0  | RW   | 0×0000      | HAINTMsk<br>Channel Interrupt Mask<br>One bit per channel: Bit 0 for channel 0, bit 15<br>for channel 15 |

# USBOTG\_HPRT

Address: Operational Base + offset (0x0440) Host Port Control and Status Register

| Bit   | Attr  | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RO    | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 18:17 | RO    | 0×0                | PrtSpd<br>Port Speed<br>Indicates the speed of the device attached to<br>this port.<br>2'b00: High speed<br>2'b01: Full speed<br>2'b10: Low speed<br>2'b11: Reserved                                                                                                                                                                                                              |
| 16:13 | RW    | 0×0                | PrtTstCtl<br>Port Test Control<br>The application writes a nonzero value to this<br>field to put the port into a Test mode, and the<br>corresponding pattern is signaled on the port.<br>4'b0000: Test mode disabled<br>4'b0001: Test_J mode<br>4'b0010: Test_K mode<br>4'b0011: Test_SE0_NAK mode<br>4'b0100: Test_Packet mode<br>4'b0101: Test_Force_Enable<br>Others: Reserved |
| 12    | R/WSC | 0×0                | PrtPwr<br>Port Power<br>The application uses this field to control power<br>to this port (write 1'b1 to set to 1'b1and write<br>1'b0 to set to 1'b0), and the core can clear this<br>bit on an over current condition.<br>1'b0: Power off<br>1'b1: Power on                                                                                                                       |
| 11:10 | RO    | 0×0                | PrtLnSts<br>Port Line Status<br>Indicates the current logic level USB data lines<br>Bit [10]: Logic level of D+<br>Bit [11]: Logic level of D                                                                                                                                                                                                                                     |
| 9     | RO    | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 8     | 9     |                    |                                                                                                                                                                                                                                                                                                                                                                                   |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | RW    | 0×0         | PrtRst<br>Port Reset<br>When the application sets this bit, a reset<br>sequence is started on this port. The<br>application must time the reset period and<br>clear this bit after the reset sequence is<br>complete.<br>1'b0: Port not in reset<br>1'b1: Port in reset<br>To start a reset on the port, the application<br>must leave this bit set for at least the<br>minimum duration mentioned below, as<br>specified in the USB 2.0 specification,<br>Section 7.1.7.5. The application can leave it<br>set for another 10 ms in addition to the<br>required minimum duration, before clearing<br>the bit, even though there is no<br>maximum limit set by the USB standard.<br>High speed: 50 ms<br>Full speed/Low speed: 10 ms                                                                 |
| 7   | R/WSC | 0×0         | PrtSusp<br>Port Suspend<br>The application sets this bit to put this port in<br>Suspend mode. The core only stops sending<br>SOFs when this is set. To stop the PHY clock,<br>the application must set the Port Clock Stop<br>bit, which asserts the suspended input pin of<br>the PHY.<br>The read value of this bit reflects the current<br>suspend status of the port. This bit is cleared<br>by the core after a remote wakeup signal is<br>detected or the application sets the Port Reset<br>bit or Port Resume bit in this register or the<br>Resume/Remote Wakeup Detected Interrupt<br>bit or Disconnect Detected Interrupt bit in the<br>Core Interrupt register (GINTSTS.WkUpInt or<br>GINTSTS.DisconnInt, respectively).<br>1'b0: Port not in Suspend mode<br>1'b1: Port in Suspend mode |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr  | Reset Value | Description                                      |
|-----|-------|-------------|--------------------------------------------------|
|     |       |             | PrtRes                                           |
|     |       |             | Port Resume                                      |
|     |       |             | The application sets this bit to drive resume    |
|     |       |             | signaling on the port. The core                  |
|     |       |             | continues to drive the resume signal until the   |
|     |       |             | application clears this bit.                     |
|     |       |             | If the core detects a USB remote wakeup          |
|     |       |             | sequence, as indicated by the Port               |
|     |       |             | Resume/Remote Wakeup Detected Interrupt          |
|     |       |             | bit of the Core Interrupt register               |
|     |       |             |                                                  |
|     |       |             | (GINTSTS.WkUpInt), the core starts driving       |
|     |       |             | resume signaling without application             |
|     |       |             | intervention and clears this bit when it detects |
|     |       |             | a disconnect condition. The read                 |
|     |       |             | value of this bit indicates whether the core is  |
|     |       |             | currently driving resume signaling.              |
|     |       |             | 1'b0: No resume driven                           |
| 6   | R/WSC | 0x0         | 1'b1: Resume driven                              |
|     | ,     |             | When LPM is enabled and the core is in the L1    |
|     |       |             | (Sleep) state, setting this bit results in the   |
|     |       |             | following behavior:                              |
|     |       |             | The core continues to drive the resume signal    |
|     |       |             | until a pre-determined time specified in the     |
|     |       |             | GLPMCFG.HIRD_Thres[3:0] field.                   |
|     |       |             | If the core detects a USB remote wakeup          |
|     |       |             | sequence, as indicated by the Port L1            |
|     |       |             | Resume/Remote L1 Wakeup Detected                 |
|     |       |             | Interrupt bit of the Core Interrupt register     |
|     |       |             | (GINTSTS.L1WkUpInt), the core starts driving     |
|     |       | • •         | resume signaling without application             |
|     |       |             | intervention and clears this bit at the end of   |
|     |       |             | the resume. The read value of this bit           |
|     |       |             | indicates whether the core is currently driving  |
|     |       |             | resume signaling.                                |
|     |       | 1           | 1'b0: No resume driven                           |
|     |       |             | 1'b1: Resume driven                              |
|     |       |             | PrtOvrCurrChng                                   |
|     |       |             | Port Overcurrent Change                          |
| 5   | W1C   | 0x0         | The core sets this bit when the status of the    |
|     |       |             | Port Overcurrent Active bit (bit 4) in this      |
|     |       |             | register changes.                                |
| Y   |       |             | PrtOvrCurrAct                                    |
|     |       |             | Port Overcurrent Active                          |
| 4   | RO    | 0x0         | Indicates the overcurrent condition of the       |
| -   |       | 0.0         | port.                                            |
|     |       |             | 1'b0: No overcurrent condition                   |
|     |       |             | 1'b1: Overcurrent condition                      |
|     |       |             | PrtEnChng                                        |
|     |       |             | Port Enable/Disable Change                       |
| 3   | W1C   | 0x0         | The core sets this bit when the status of the    |
|     |       | _           | Port Enable bit [2] of this register             |
|     |       |             | changes.                                         |
| L   | I     | 1           |                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | W1C  | 0×0         | PrtEna<br>Port Enable<br>A port is enabled only by the core after a reset<br>sequence, and is disabled by an<br>overcurrent condition, a disconnect condition,<br>or by the application clearing this bit.The<br>application cannot set this bit by a register<br>write. It can only clear it to disable the port.<br>This bit does not trigger any interrupt to the<br>application.<br>1'b0: Port disabled<br>1'b1: Port enabled |
| 1   | W1C  | 0×0         | PrtConnDet<br>Port Connect Detected<br>The core sets this bit when a device<br>connection is detected to trigger an interrupt<br>to the application using the Host Port<br>Interrupt bit of the Core Interrupt register<br>(GINTSTS.PrtInt). The application must write<br>a 1 to this bit to clear the interrupt.                                                                                                                |
| 0   | RO   | 0x0         | PrtConnSts<br>Port Connect Status<br>1'b0: No device is attached to the port.<br>1'b1: A device is attached to the port.                                                                                                                                                                                                                                                                                                          |

# USBOTG\_HCCHARn

Address: Operational Base + offset (0x0500) Host Channel-n Characteristics Register

| -   | Host Channel-n Characteristics Register |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|-----|-----------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit | Attr                                    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 31  | R/WSC                                   | 0×0         | ChEna<br>Channel Enable<br>When Scatter/Gather mode is enabled<br>1'b0: Indicates that the descriptor structure<br>is not yet ready.<br>1'b1: Indicates that the descriptor structure<br>and data buffer with data is setup and this<br>channel can access the descriptor.<br>When Scatter/Gather mode is disabled, This<br>field is set by the application and cleared by<br>the OTG host.<br>1'b0: Channel disabled<br>1'b1: Channel enabled |  |
| 30  | R/WSC                                   | 0×0         | ChDis<br>Channel Disable<br>The application sets this bit to stop<br>transmitting/receiving data on a channel,<br>even before the transfer for that channel is<br>complete. The application must wait for the<br>Channel Disabled interrupt before treating the<br>channel as disabled.                                                                                                                                                        |  |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr     | Reset Value | Description                                                                                 |
|-------|----------|-------------|---------------------------------------------------------------------------------------------|
|       |          |             | OddFrm                                                                                      |
|       |          |             | Odd Frame                                                                                   |
|       |          |             | This field is set (reset) by the application to                                             |
|       |          |             | indicate that the OTG host must perform a                                                   |
|       |          |             | transfer in an odd (micro) frame. This field is                                             |
| 20    |          | 00          | applicable for only periodic (isochronous and                                               |
| 29    | RW       | 0x0         | interrupt) transactions.                                                                    |
|       |          |             | 1'b0: Even (micro)frame                                                                     |
|       |          |             | 1'b1: Odd (micro)frame                                                                      |
|       |          |             | This field is not applicable for Scatter/Gather                                             |
|       |          |             | DMA mode and need not be programmed by                                                      |
|       |          |             | the application and is ignored by the core.                                                 |
|       |          |             | DevAddr                                                                                     |
| 20.22 |          | 0.00        | Device Address                                                                              |
| 28:22 | RW       | 0x00        | This field selects the specific device serving as                                           |
|       |          |             | the data source or sink.                                                                    |
|       |          |             | MC_EC                                                                                       |
|       |          |             | Multi Count (MC) / Error Count (EC)                                                         |
|       |          |             | When the Split Enable bit of the Host                                                       |
|       |          |             | Channel-n Split Control register                                                            |
|       |          |             | (HCSPLTn.SpltEna) is reset (1'b0), this field                                               |
|       |          |             | indicates to the host the number of                                                         |
|       |          |             | transactions that must be executed per                                                      |
|       |          |             | micro-frame for this periodic endpoint. For                                                 |
|       |          |             | non periodic transfers, this field is used only in                                          |
|       |          |             | DMA mode, and specifies the                                                                 |
|       |          |             | number packets to be fetched for this channel                                               |
|       |          |             | before the internal DMA engine                                                              |
| 21:20 | RW       | 0x0         | changes arbitration.                                                                        |
|       |          | • •         | 2'b00: Reserved This field yields undefined                                                 |
|       |          |             | results.                                                                                    |
|       |          |             | 2'b01: 1 transaction                                                                        |
|       |          |             | 2'b10: 2 transactions to be issued for this                                                 |
|       |          |             | endpoint per micro-frame                                                                    |
|       |          |             | 2'b11: 3 transactions to be issued for this                                                 |
|       |          | Y           | endpoint per micro-frame                                                                    |
|       |          |             | When HCSPLTn.SpltEna is set (1'b1), this field indicates the number of immediate retries to |
|       | $\frown$ |             | be performed for a periodic split transactions                                              |
|       |          |             | on transaction errors. This field must be set to                                            |
|       | <b>~</b> |             | at least 2'b01.                                                                             |
|       |          |             | EPType                                                                                      |
|       |          |             | Endpoint Type                                                                               |
|       |          |             | Indicates the transfer type selected.                                                       |
| 19:18 | RW       | 0x0         | 2'b00: Control                                                                              |
|       |          |             | 2'b01: Isochronous                                                                          |
|       |          |             | 2'b10: Bulk                                                                                 |
|       |          |             | 2'b11: Interrupt                                                                            |
|       |          |             | LSpdDev                                                                                     |
|       |          |             | Low-Speed Device                                                                            |
| 17    | RW       | 0x0         | This field is set by the application to indicate                                            |
|       |          |             |                                                                                             |
|       |          |             | that this channel is communicating to a                                                     |

| Bit   | Attr                                                          | Reset Value | Description                                                                                                    |
|-------|---------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------|
| 16    | RO                                                            | 0x0         | reserved                                                                                                       |
| 15    | RW                                                            | 0x0         | EPDir<br>Endpoint Direction<br>Indicates whether the transaction is IN or<br>OUT.<br>1'b0: OUT<br>1'b1: IN     |
| 14:11 | RW                                                            | 0×0         | EPNum<br>Endpoint Number<br>Indicates the endpoint number on the device<br>serving as the data source or sink. |
| 10:0  | RW                                                            | 0x000       | MPS<br>Maximum Packet Size<br>Indicates the maximum packet size of the<br>associated endpoint.                 |
|       | USBOTG_HCSPLTn<br>Address: Operational Base + offset (0x0504) |             |                                                                                                                |

## USBOTG\_HCSPLTn

Address: Operational Base + offset (0x0504) Host Channel-n Split Control Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0×0         | SpltEna<br>Split Enable<br>The application sets this field to indicate that<br>this channel is enabled to perform split<br>transactions.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 30:17 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 16    | RW   | 0x0         | CompSplt<br>Do Complete Split<br>The application sets this field to request the<br>OTG host to perform a complete split<br>transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15:14 | RW   | 0×0         | XactPos<br>Transaction Position<br>This field is used to determine whether to send<br>all, first, middle, or last payloads with each<br>OUT transaction.<br>2'b11: All. This is the entire data payload is of<br>this transaction (which is less than or equal to<br>188 bytes).<br>2'b10: Begin. This is the first data payload of<br>this transaction (which is larger than 188<br>bytes).<br>2'b00: Mid. This is the middle payload of this<br>transaction (which is larger than 188bytes).<br>2'b01: End. This is the last payload of this<br>transaction (which is larger than 188bytes). |
| 13:7  | RW   | 0×00        | HubAddr<br>Hub Address<br>This field holds the device address of the<br>transaction translator's hub.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit | Attr | Reset Value | Description                                                                                          |
|-----|------|-------------|------------------------------------------------------------------------------------------------------|
| 6:1 | RO   | 0x0         | reserved                                                                                             |
| 0   | RW   | 0x0         | PrtAddr<br>Port Address<br>This field is the port number of the recipient<br>transaction translator. |

# USBOTG\_HCINTn

Address: Operational Base + offset (0x0508) Host Channel-n Interrupt Register

|       |      | Interrupt Registe |                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Attr | Reset Value       | Description                                                                                                                                                                                                                                                                                                                                          |
| 31:14 | RO   | 0x0               | reserved                                                                                                                                                                                                                                                                                                                                             |
| 13    | W1C  | 0×0               | DESC_LST_ROLLIntr<br>Descriptor rollover interrupt<br>This bit is valid only when Scatter/Gather DMA<br>mode is enabled. The core sets this bit when<br>the corresponding channel's descriptor list<br>rolls over. For non-Scatter/Gather DMA mode,<br>this bit is reserved.                                                                         |
| 12    | W1C  | 0×0               | XCS_XACT_ERR<br>Excessive Transaction Error<br>This bit is valid only when Scatter/Gather DMA<br>mode is enabled. The core sets this bit when 3<br>consecutive transaction errors occurred on<br>the USB bus. XCS_XACT_ERR will not be<br>generated for Isochronous channels. For<br>non-Scatter/Gather DMA mode, this bit is<br>reserved.           |
| 11    | W1C  | 0×0               | BNAIntr<br>BNA (Buffer Not Available) Interrupt<br>This bit is valid only when Scatter/Gather DMA<br>mode is enabled. The core generates this<br>interrupt when the descriptor accessed is not<br>ready for the Core to process. BNA will not be<br>generated for Isochronous channels. For<br>non-Scatter/Gather DMA mode, this bit is<br>reserved. |
| 10    | W1C  | 0×0               | DataTglErr<br>Data Toggle Error<br>In Scatter/Gather DMA mode, the interrupt<br>due to this bit is masked in the core.                                                                                                                                                                                                                               |
| 9     | W1C  | 0×0               | FrmOvrun<br>Frame Overrun<br>In Scatter/Gather DMA mode, the interrupt<br>due to this bit is masked in the core                                                                                                                                                                                                                                      |
| 8     | W1C  | 0×0               | BblErr<br>Babble Error<br>In Scatter/Gather DMA mode, the interrupt<br>due to this bit is masked in the core.                                                                                                                                                                                                                                        |

| Bit | Attr  | Reset Value | Description                                      |
|-----|-------|-------------|--------------------------------------------------|
|     |       |             | XactErr                                          |
|     |       |             | Transaction Error                                |
|     |       |             | Indicates one of the following errors occurred   |
| 7   | W1C   | 0x0         | on the USB: CRC check failure,                   |
|     |       |             | Timeout, Bit stuff error, False EOP. In          |
|     |       |             | Scatter/Gather DMA mode, the interrupt due       |
|     |       |             | to this bit is masked in the core.               |
|     |       |             | NYET                                             |
| -   |       |             | NYET Response Received Interrupt                 |
| 6   | WO    | 0x0         | In Scatter/Gather DMA mode, the interrupt        |
|     |       |             | due to this bit is masked in the core.           |
|     |       |             | ACK                                              |
|     |       |             | ACK Response Received/Transmitted                |
| 5   | W1C   | 0x0         | Interrupt                                        |
| 5   |       | 0,0         | In Scatter/Gather DMA mode, the interrupt        |
|     |       |             | due to this bit is masked in the core.           |
|     |       |             | NAK                                              |
|     |       |             | NAK<br>NAK Response Received Interrupt           |
| 4   | W1C   | 0x0         | In Scatter/Gather DMA mode, the interrupt        |
|     |       |             | due to this bit is masked in the core.           |
|     |       |             | STALL                                            |
|     |       |             |                                                  |
| 3   | W1C   | 0x0         | STALL Response Received Interrupt                |
|     |       |             | In Scatter/Gather DMA mode, the interrupt        |
|     |       |             | due to this bit is masked in the core.           |
|     |       |             | AHBErr                                           |
|     |       |             | AHB Error                                        |
| _   |       |             | This is generated only in DMA mode when          |
| 2   | W1C   | 0x0         | there is an AHB error during AHB                 |
|     |       |             | read/write. The application can read the         |
|     |       |             | corresponding channel's DMA address register     |
|     |       |             | to get the error address.                        |
|     |       |             | ChHltd                                           |
|     |       |             | Channel Halted                                   |
|     |       |             | In non-Scatter/Gather DMA mode, it indicates     |
|     |       |             | the transfer completed abnormally either         |
|     |       |             | because of any USB transaction error or in       |
|     |       |             | response to disable request by the application   |
| 1   | W1C   | 0x0         | or because of a completed transfer. In           |
|     | WIG . | 0,0         | Scatter/Gather DMA mode, this indicates that     |
|     |       |             | transfer completed due to any of the             |
|     |       |             | following: EOL being set in descriptor, AHB      |
| × * |       |             | error, Excessive transaction errors, In          |
|     |       |             | response to disable request by the               |
|     |       |             | application, Babble, Stall, Buffer Not           |
|     |       |             | Available (BNA)                                  |
|     |       |             | XferCompl                                        |
|     |       |             | Transfer Completed                               |
|     |       |             | For Scatter/Gather DMA mode, it indicates        |
| 0   | W1C   | 0.40        | that current descriptor processing got           |
| 0   | W1C   | 0x0         | completed with IOC bit set in its descriptor. In |
|     |       |             | non-Scatter/Gather DMA mode, it indicates        |
|     |       |             | that Transfer completed normally without any     |
|     |       |             | errors.                                          |
| L   | I     | 1           |                                                  |

# USBOTG\_HCINTMSKn

Address: Operational Base + offset (0x050c) Host Channel-n Interrupt Mask Register

| Bit   | Attr |     | Description                                                                                                                                                                                        |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14 | RO   | 0x0 | reserved                                                                                                                                                                                           |
| 13    | RW   | 0x0 | DESC_LST_ROLLIntrMsk<br>Descriptor rollover interrupt Mask register<br>This bit is valid only when Scatter/Gather DMA<br>mode is enabled. In non-Scatter/Gather DMA<br>mode, this bit is reserved. |
| 12    | RO   | 0x0 | reserved                                                                                                                                                                                           |
| 11    | RW   | 0×0 | BNAIntrMsk<br>BNA (Buffer Not Available) Interrupt mask<br>register<br>This bit is valid only when Scatter/Gather DMA<br>mode is enabled. In non-Scatter/Gather DMA<br>mode, this bit is reserved. |
| 10    | RW   | 0×0 | DataTglErrMsk<br>Data Toggle Error Mask<br>This bit is not applicable in Scatter/Gather<br>DMA mode.                                                                                               |
| 9     | RW   | 0×0 | FrmOvrunMsk<br>Frame Overrun Mask<br>This bit is not applicable in Scatter/Gather<br>DMA mode.                                                                                                     |
| 8     | RW   | 0×0 | BblErrMsk<br>Babble Error Mask<br>This bit is not applicable in Scatter/Gather<br>DMA mode.                                                                                                        |
| 7     | RW   | 0×0 | XactErrMsk<br>Transaction Error Mask<br>This bit is not applicable in Scatter/Gather<br>DMA mode                                                                                                   |
| 6     | RW   | 0×0 | NyetMsk<br>NYET Response Received Interrupt Mask<br>This bit is not applicable in Scatter/Gather<br>DMA mode.                                                                                      |
| 5     | RW   | 0×0 | AckMsk<br>ACK Response Received/Transmitted<br>Interrupt Mask<br>This bit is not applicable in Scatter/Gather<br>DMA mode.                                                                         |
| 4     | RW   | 0×0 | NakMsk<br>NAK Response Received Interrupt Mask<br>This bit is not applicable in Scatter/Gather<br>DMA mode.                                                                                        |
| 3     | RW   | 0×0 | StallMsk<br>STALL Response Received Interrupt Mask<br>This bit is not applicable in Scatter/Gather<br>DMA mode.                                                                                    |

| Bit | Attr | Reset Value | Description                                    |
|-----|------|-------------|------------------------------------------------|
|     |      |             | AHBErrMsk                                      |
| 2   | RW   | 0x0         | AHB Error Mask                                 |
| 2   |      | 0.00        | Note: This bit is only accessible when         |
|     |      |             | $OTG_ARCHITECTURE = 2$                         |
| 1   |      | 00          | ChHltdMsk                                      |
| T   | RW   | 0x0         | Channel Halted Mask                            |
|     |      |             | XferComplMsk                                   |
|     |      |             | Transfer Completed Mask                        |
| 0   | RW   | 0×0         | This bit is valid only when Scatter/Gather DMA |
|     |      |             | mode is enabled. In non-Scatter/Gather DMA     |
|     |      |             | mode, this bit is reserved.                    |

# USBOTG\_HCTSIZn

Address: Operational Base + offset (0x0510) Host Channel-n Transfer Size Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0×0         | DoPng<br>Do Ping<br>This bit is used only for OUT transfers. Setting<br>this field to 1 directs the host to do PING<br>protocol. Note: Do not set this bit for IN<br>transfers. If this bit is set for IN transfers it<br>disables the channel.                                                                                                                                                                                                                                    |
| 30:29 | RW   | 0×0         | Pid<br>PID<br>The application programs this field with the<br>type of PID to use for the initial transaction.<br>The host maintains this field for the rest of the<br>transfer.<br>2'b00: DATA0<br>2'b01: DATA2<br>2'b10: DATA1<br>2'b11: MDATA (non-control)/SETUP (control)                                                                                                                                                                                                      |
| 28:19 | RW   | 0×000       | PktCnt<br>Packet Count<br>This field is programmed by the application<br>with the expected number of packets to be<br>transmitted (OUT) or received (IN).The host<br>decrements this count on every successful<br>transmission or reception of an OUT/IN<br>packet. Once this count reaches zero, the<br>application is interrupted to indicate normal<br>completion. The width of this counter is<br>specified as Width of Packet Counters<br>(parameter OTG_PACKET_COUNT_WIDTH). |

XIDI

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0 | RW   | 0×00000     | XferSize<br>Transfer Size<br>For an OUT, this field is the number of data<br>bytes the host sends during the transfer. For<br>an IN, this field is the buffer size that the<br>application has Reserved for the transfer. The<br>application is expected to program this field as<br>an integer multiple of the maximum packet<br>size for IN transactions (periodic and<br>non-periodic). The width of this counter is<br>specified as Width of Transfer Size Counters<br>(parameter OTG_TRANS_COUNT_WIDTH). |

# USBOTG\_HCDMAn

Address: Operational Base + offset (0x0514) Host Channel-n DMA Address Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | DMAAddr<br>DMA Address<br>This field holds the start address in the<br>external memory from which the data for<br>the endpoint must be fetched or to which it<br>must be stored. This register is<br>incremented on every AHB transaction. |

## USBOTG\_HCDMABn

Address: Operational Base + offset (0x051c) Host Channel-n DMA Buffer Address Register

| Bit  | Attr         | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                   |
|------|--------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO           | 0×00000000         | HCDMABn<br>Holds the current buffer address<br>This register is updated as and when the data<br>transfer for the corresponding end point is in<br>progress. This register is present only in<br>Scatter/Gather DMA mode. Otherwise this<br>field is reserved. |
|      | $\mathbf{O}$ |                    |                                                                                                                                                                                                                                                               |

# USBOTG\_DCFG

Address: Operational Base + offset (0x0800) Device Cconfiguration Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | RW   | 0x02        | ResValid<br>Resume Validation Period<br>This field controls the period when the core<br>resumes from a suspend. When this bit is set,<br>the core counts for the ResValid number of<br>clock cycles to detect a valid resume. This field<br>is effective only when DCFG.Ena32KHzSusp is<br>set. |

| Bit   | Attr     | Reset Value | Description                                                                            |
|-------|----------|-------------|----------------------------------------------------------------------------------------|
|       |          |             | PerSchIntvl                                                                            |
|       |          |             | Periodic Scheduling Interval                                                           |
|       |          |             | PerSchIntvl must be programmed only for                                                |
|       |          |             | Scatter/Gather DMA mode. Description: This                                             |
|       |          |             | field specifies the amount of time the Internal                                        |
|       |          |             | DMA engine must allocate for fetching periodic                                         |
|       |          |             | IN endpoint data. Based on the number of                                               |
|       |          |             | periodic endpoints, this value must be                                                 |
|       |          |             | specified as 25,50 or 75% of (micro)frame.                                             |
|       |          |             | When any periodic endpoints are active, the                                            |
| 25:24 | RW       | 0x0         | internal DMA engine allocates the specified                                            |
|       |          |             | amount of time in fetching periodic IN                                                 |
|       |          |             | endpoint data. When no periodic endpoints                                              |
|       |          |             | are active, then the internal DMA engine                                               |
|       |          |             | services nonperiodic endpoints, ignoring this field. After the specified time within a |
|       |          |             | (micro) frame, the DMA switches to fetching                                            |
|       |          |             | for nonperiodic endpoints.                                                             |
|       |          |             | 2'b00: 25% of (micro) frame.                                                           |
|       |          |             | 2'b01: 50% of (micro) frame.                                                           |
|       |          |             | 2'b10: 75% of (micro) frame.                                                           |
|       |          |             | 2'b11: Reserved.                                                                       |
|       |          |             | DescDMA                                                                                |
|       |          |             | Enable Scatter/Gather DMA in Device mode                                               |
|       |          |             | When the Scatter/Gather DMA option selected                                            |
|       |          |             | during configuration of the RTL, the                                                   |
|       |          |             | application can set this bit during initialization                                     |
|       |          |             | to enable the Scatter/Gather DMA operation. NOTE: This bit must be modified            |
|       |          |             | only once after a reset. The following                                                 |
| 23    | RW       | 0x0         | combinations are available for programming:                                            |
|       |          |             | GAHBCFG.DMAEn=0,DCFG.DescDMA=0 =>                                                      |
|       |          | Y           | Slave mode                                                                             |
|       |          |             | GAHBCFG.DMAEn=0,DCFG.DescDMA=1 =>                                                      |
|       |          | 1           | Invalid                                                                                |
|       |          |             | GAHBCFG.DMAEn=1,DCFG.DescDMA=0 =>                                                      |
|       |          |             | Buffered DMA mode                                                                      |
|       | $\frown$ | ſ           | GAHBCFG.DMAEn=1,DCFG.DescDMA=1 =>                                                      |
|       |          |             | Scatter/Gather DMA mode<br>EPMisCnt                                                    |
|       |          |             | IN Endpoint Mismatch Count                                                             |
|       |          |             | This field is valid only in shared FIFO                                                |
|       |          |             | operation. The application programs this filed                                         |
|       |          |             | with a count that determines when the core                                             |
| 22.10 |          | 0.400       | generates an Endpoint Mismatch interrupt                                               |
| 22:18 | RW       | 0x08        | (GINTSTS.EPMis). The core loads this value                                             |
|       |          |             | into an internal counter and decrements it.                                            |
|       |          |             | The counter is reloaded whenever there is a                                            |
|       |          |             | match or when the counter expires. The width                                           |
|       |          |             | of this counter depends on the depth of the                                            |
| 17.10 |          | 00          | Token Queue.                                                                           |
| 17:13 | RO       | 0x0         | reserved                                                                               |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:11 | RW   | 0x0         | PerFrInt<br>Periodic Frame Interval<br>Indicates the time within a (micro) frame at<br>which the application must be notified using<br>the End Of Periodic Frame Interrupt. This can<br>be used to determine if all the isochronous<br>traffic for that (micro) frame is complete.<br>2'b00: 80% of the (micro)frame interval<br>2'b01: 85%<br>2'b10: 90%<br>2'b11: 95%                                                                                                                                                                                                                                                     |
| 10:4  | RW   | 0x00        | DevAddr<br>Device Address<br>The application must program this field after<br>every SetAddress control command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3     | RW   | 0x0         | Ena32KHzS<br>Enable 32-KHz Suspend Mode<br>When the USB 1.1 Full-Speed Serial<br>Transceiver Interface is chosen and this bit is<br>set, the core expects the 48-MHz PHY clock to<br>be switched to 32 KHz during a suspend. This<br>bit can only be set if USB 1.1 Full-Speed Serial<br>Transceiver Interface has been selected. If<br>USB 1.1 Full-Speed Serial Transceiver<br>Interface has not been selected, this bit must<br>be zero.                                                                                                                                                                                 |
| 2     | RW   | 0×0         | NZStsOUTHShk<br>Non-Zero-Length Status OUT Handshake<br>The application can use this field to select the<br>handshake the core sends on receiving a<br>nonzero-length data packet during the OUT<br>transaction of a control transfer's Status<br>stage.<br>1'b1: Send a STALL handshake on a<br>nonzero-length status OUT transaction and do<br>not send the received OUT packet to the<br>application.<br>1'b0: Send the received OUT packet to the<br>application (zero-length or nonzerolength)<br>and send a handshake based on the NAK and<br>STALL bits for the endpoint in the Device<br>Endpoint Control register. |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | RW   | 0x0                | DevSpd<br>Device Speed<br>Indicates the speed at which the application<br>requires the core to enumerate, or the<br>maximum speed the application can support.<br>However, the actual bus speed is determined<br>only after the chirp sequence is completed,<br>and is based on the speed of the USB host to<br>which the core is connected.<br>2'b00: High speed (USB 2.0 PHY clock is 30<br>MHz or 60 MHz)<br>2'b01: Full speed (USB 2.0 PHY clock is 30<br>MHz or 60 MHz)<br>2'b10: Reserved<br>2'b11: Full speed (USB 1.1 transceiver clock<br>is 48 MHz) |

## USBOTG\_DCTL

Address: Operational Base + offset (0x0804) Device Control Register

| Bit   | Attr | Reset Value | Description                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | RO   | 0x0         | reserved                                                                                                                         |
| 16    | RW   | 0×0         | NakOnBble<br>Set NAK automatically on babble<br>The core sets NAK automatically for the<br>endpoint on which babble is received. |

2004 chik

| Bit   | Attr | Reset Value | Description                                      |
|-------|------|-------------|--------------------------------------------------|
|       |      |             | IgnrFrmNum                                       |
|       |      |             | Ignore frame number for isochronous              |
|       |      |             | endpoints in case of Scatte                      |
|       |      |             | Do NOT program IgnrFrmNum bit to 1'b1            |
|       |      |             | when the core is operating in Threshold mode.    |
|       |      |             |                                                  |
|       |      |             | Note: When Scatter/Gather DMA mode is            |
|       |      |             | enabled this feature is not applicable to        |
|       |      |             | highspeed, high-bandwidth transfers. When        |
|       |      |             | this bit is enabled, there must be only one      |
|       |      |             | packet per descriptor.                           |
|       |      |             | 1'b0: The core transmits the packets only in     |
|       |      |             | the frame number in which they are               |
|       |      |             | intended to be transmitted.                      |
|       |      |             | 1'b1: The core ignores the frame number,         |
|       |      |             | sending packets immediately as the packets       |
|       |      |             | are ready.                                       |
|       |      |             | Scatter/Gather:                                  |
|       |      |             | In Scatter/Gather DMA mode, when this bit is     |
| 15    | RW   | 0x0         | enabled, the packets are not flushed when an     |
| 15    | 1    | 0,0         | ISOC IN token is received for an elapsed         |
|       |      |             | frame.                                           |
|       |      |             | When Scatter/Gather DMA mode is disabled,        |
|       |      |             | this field is used by the application to enable  |
|       |      |             | periodic transfer interrupt. The application     |
|       |      |             | can program periodic endpoint transfers for      |
|       |      |             | multiple (micro) frames.                         |
|       |      |             | 1'b0: Periodic transfer interrupt feature is     |
|       |      |             | disabled; the application must program           |
|       |      |             | transfers for periodic endpoints every           |
|       |      | • •         | (micro)frame                                     |
|       |      |             | 1'b1: Periodic transfer interrupt feature is     |
|       |      |             | enabled; the application can program             |
|       |      |             | transfers for multiple (micro)frames for         |
|       |      |             | periodic endpoints.                              |
|       |      | 1           | In non-Scatter/Gather DMA mode, the              |
|       |      |             | application receives transfer complete           |
|       |      | <b>Y</b>    | interrupt after transfers for multiple (micro)   |
|       |      | /           | frames are completed.                            |
|       |      |             | GMC                                              |
|       |      |             | Global Multi Count                               |
|       |      |             | GMC must be programmed only once after           |
| Y     |      |             | initialization. Applicable only for              |
|       |      |             | Scatter/Gather DMA mode. This indicates the      |
|       |      |             | number of packets to be serviced for that end    |
| 14:13 | RW   | 0x1         | point before moving to the next end point. It is |
| 17.13 | 1    | 0.7.1       | only for nonperiodic end points.                 |
|       |      |             | 2'b00: Invalid.                                  |
|       |      |             | 2'b01: 1 packet.                                 |
|       |      |             | 2'b10: 2 packets.                                |
|       |      |             | 2'b11: 3 packets.                                |
|       |      |             | When Scatter/Gather DMA mode is disabled,        |
|       |      |             | this field is reserved. and reads 2'b00.         |
| 12    | RO   | 0x0         | reserved                                         |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                           |
|-----|------|-------------|-------------------------------------------------------|
|     |      |             | PWROnPrgDone                                          |
|     |      |             | Power-On Programming Done                             |
| 11  | RW   | 0x0         | The application uses this bit to indicate that        |
|     |      |             | register programming is completed after a             |
|     |      |             | wake-up from Power Down mode.                         |
|     |      |             | CGOUTNak                                              |
| 10  | wo   | 0x0         | Clear Global OUT NAK                                  |
| 10  |      | 0,0         | A write to this field clears the Global OUT NAK.      |
|     |      |             | SGOUTNak                                              |
|     |      |             | Set Global OUT NAK                                    |
|     |      |             | A write to this field sets the Global OUT NAK.        |
|     |      |             | The application uses this bit to send a NAK           |
| 9   | wo   | 0x0         | handshake on all OUT endpoints. The                   |
| 5   |      |             | application must set this bit only after making       |
|     |      |             | sure that the Global OUT NAK Effective bit in         |
|     |      |             | the Core Interrupt Register                           |
|     |      |             | (GINTSTS.GOUTNakEff) is cleared.                      |
|     |      |             | CGNPInNak                                             |
| 0   | wo   |             | Clear Global Non-periodic IN NAK                      |
| 8   | WO   | 0x0         | A write to this field clears the Global               |
|     |      |             | Non-periodic IN NAK.                                  |
|     |      |             | SGNPInNak                                             |
|     |      |             | Set Global Non-periodic IN NAK                        |
|     |      |             | A write to this field sets the Global                 |
|     |      |             | Non-periodic IN NAK. The application uses this        |
|     |      |             | bit to send a NAK handshake on all                    |
| 7   | wo   | 0x0         | non-periodic IN endpoints. The core can also          |
| /   | **0  | 0.00        | set this bit when a timeout condition is              |
|     |      |             | detected on a non-periodic endpoint in shared         |
|     |      | •           | FIFO operation. The application must set this         |
|     |      |             | bit only after making sure that the Global IN         |
|     |      |             | NAK Effective bit in the Core Interrupt               |
|     |      |             | Register (GINTSTS.GINNakEff) is cleared.              |
|     |      |             | TstCtl                                                |
|     |      |             | Test Control                                          |
|     | C    |             | 3'b000: Test mode disabled                            |
| 6:4 | DW   | 0.40        | 3'b001: Test_J mode                                   |
| 0:4 | RW   | 0x0         | 3'b010: Test_K mode                                   |
|     |      |             | 3'b011: Test_SE0_NAK mode<br>3'b100: Test Packet mode |
|     |      |             | 3'b101: Test Force Enable                             |
|     |      |             | Others: Reserved                                      |
|     |      |             | GOUTNakSts                                            |
|     |      |             | Global OUT NAK Status                                 |
|     |      |             | 1'b0: A handshake is sent based on the FIFO           |
|     |      |             | Status and the NAK and STALL bit                      |
|     |      |             | settings.                                             |
| 3   | RO   | 0x0         | 1'b1: No data is written to the RxFIFO,               |
|     |      |             | irrespective of space availability. Sends a NAK       |
|     |      |             | handshake on all packets, except on SETUP             |
|     |      |             | transactions. All isochronous OUT packets are         |
|     |      |             | dropped                                               |
| L   | 1    | I           |                                                       |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | GNPINNakSts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2   | RO   | 0x0         | Global Non-periodic IN NAK Status<br>1'b0: A handshake is sent out based on the<br>data availability in the transmit FIFO.<br>1'b1: A NAK handshake is sent out on all<br>non-periodic IN endpoints, irrespective of the<br>data availability in the transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1   | RW   | 0×0         | SftDiscon<br>Soft Disconnect<br>The application uses this bit to signal the Otg<br>core to do a soft disconnect. As long as this bit<br>is set, the host does not see that the device is<br>connected, and the device does not receive<br>signals on the USB. The core stays in the<br>disconnected state until the application clears<br>this bit.<br>1'b0: Normal operation. When this bit is<br>cleared after a soft disconnect, the core<br>drives the phy_opmode_o signal on the<br>UTMI+ to 2'b00, which generates a device<br>connect event to the USB host. When the<br>device is reconnected, the USB host restarts<br>device enumeration.<br>1'b1: The core drives the phy_opmode_o<br>signal on the UTMI+ to 2'b01, which<br>generates a device disconnect event to the<br>USB host.                                                                                             |
| 0   | RW   |             | RmtWkUpSig<br>Remote Wakeup Signaling<br>When the application sets this bit, the core<br>initiates remote signaling to wake the USB<br>host. The application must set this bit to<br>instruct the core to exit the Suspend state. As<br>specified in the USB 2.0 specification, the<br>application must clear this bit 1-15 ms after<br>setting it. If LPM is enabled and the core is in<br>the L1 (Sleep) state, when the application sets<br>this bit, the core initiates L1 remote signaling<br>to wake up the USB host. The application must<br>set this bit to instruct the core to exit the<br>Sleep state. As specified in the LPM<br>specification, the hardware automatically<br>clears this bit 50 us (TL1DevDrvResume) after<br>being set by the application. The application<br>must not set this bit when GLPMCFG<br>bRemoteWake from the previous LPM<br>transaction is zero. |

## USBOTG\_DSTS

Address: Operational Base + offset (0x0808)

Device Status Register

|  | Bit | Attr | Reset Value | Description |
|--|-----|------|-------------|-------------|
|--|-----|------|-------------|-------------|

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 21:8  | RW   | 0×0000      | SOFFN<br>Frame or Micro-frame Number of the Received<br>SOF<br>When the core is operating at high speed, this<br>field contains a micro-frame number. When<br>the core is operating at full or low speed, this                                                                                                                                                                                                                                                                                                                                   |
| 7.4   |      | 0.0         | field contains a frame number.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7:4   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3     | RW   | 0×0         | ErrticErr<br>Erratic Error<br>The core sets this bit to report any erratic<br>errors (phy_rxvalid_i/phy_rxvldh_i or<br>phy_rxactive_i is asserted for at least 2 ms,<br>due to PHY error) seen on the UTMI+. Due to<br>erratic errors, the Otg core goes into<br>Suspended state and an interrupt is generated<br>to the application with Early Suspend bit of the<br>Core Interrupt register (GINTSTS.ErlySusp).<br>If the early suspend is asserted due to an<br>erratic error, the application can only perform<br>a soft disconnect recover. |
| 2:1   | RW   | 0×0         | EnumSpd<br>Enumerated Speed<br>Indicates the speed at which the OTG core has<br>come up after speed detection through a chirp<br>sequence.<br>2'b00: High speed (PHY clock is running at 30<br>or 60 MHz)<br>2'b01: Full speed (PHY clock is running at 30<br>or 60 MHz)<br>2'b10: Low speed (PHY clock is running at 48<br>MHz, internal phy_clk at 6 MHz)<br>2'b11: Full speed (PHY clock is running at 48<br>MHz)<br>Low speed is not supported for devices using a<br>UTMI+ PHY.                                                             |
| 0     | RW   | 0×0         | SuspSts<br>Suspend Status<br>In Device mode, this bit is set as long as a<br>Suspend condition is detected on the USB.<br>The core enters the Suspended state when<br>there is no activity on the utmi_linestate<br>signal for an extended period of time. The core<br>comes out of the suspend: When there is any<br>activity on the utmi_linestate signal, When<br>the application writes to the Remote Wakeup<br>Signaling bit in the Device Control register<br>(DCTL.RmtWkUpSig).                                                           |

## USBOTG\_DIEPMSK

Address: Operational Base + offset (0x0810)

| Bit   | Attr | Reset Value  | Description                              |
|-------|------|--------------|------------------------------------------|
| 31:14 | RO   | 0x0          | reserved                                 |
| 13    | RW   | 0x0          | NAKMsk                                   |
|       |      |              | NAK interrupt Mask                       |
| 12:10 | RO   | 0x0          | reserved                                 |
| 9 RW  | 0x0  | BNAInIntrMsk |                                          |
| 5     |      | 0.00         | BNA Interrupt Mask                       |
| 8     | RW   | V 0x0        | TxfifoUndrnMsk                           |
| -     |      | 0.00         | Fifo Underrun Mask                       |
| 7     | RO   | 0x0          | reserved                                 |
| 6     | 5 RW | 0x0          | INEPNakEffMsk                            |
| 0     |      |              | IN Endpoint NAK Effective Mask           |
| 5     | RW   | W 0x0        | INTknEPMisMsk                            |
| J     |      | 0.00         | IN Token received with EP Mismatch Mask  |
| 4     | RW   | V 0x0        | INTknTXFEmpMsk                           |
| -     |      | 0.00         | IN Token Received When TxFIFO Empty Mask |
| 3     | RW   | 0x0          | TimeOUTMsk                               |
| 5     |      | 0.00         | Timeout Condition Mask                   |
| 2     | RW   |              | AHBErrMsk                                |
| Ζ     |      | CW 0x0       | AHB Error Mask                           |
| 1     | RW   | W 0x0        | EPDisbldMsk                              |
| T     |      | 0.00         | Endpoint Disabled Interrupt Mask         |
| 0     | RW   | 0x0          | XferComplMsk                             |
| 0     |      | 0.00         | Transfer Completed Interrupt Mask        |

Device IN Endpoint common interrupt mask register

# USBOTG\_DOEPMSK

Address: Operational Base + offset (0x0814)

Device OUT Endpoint common interrupt mask register

| Bit   | Attr | Reset Value | Description                               |
|-------|------|-------------|-------------------------------------------|
| 31:15 | RO   | 0x0         | reserved                                  |
| 14    | RW   | 0x0         | NYETMsk                                   |
| 14    |      | 0.00        | NYET Interrupt Mask                       |
| 13    | RW 🔨 | 0x0         | NAKMsk                                    |
| 1.5   |      | 0.00        | NAK Interrupt Mask                        |
| 12    | RW   | 0x0         | BbleErrMsk                                |
| 12    |      | 0.00        | Babble Interrupt Mask                     |
| 11:10 | RO   | 0x0         | reserved                                  |
| 9     | RW   | 0x0         | BnaOutIntrMsk                             |
| 9     |      |             | BNA interrupt Mask                        |
| 8     | RW   | 0x0         | OutPktErrMsk                              |
| 0     |      |             | OUT Packet Error Mask                     |
| 7     | RO   | 0x0         | reserved                                  |
|       |      |             | Back2BackSETup                            |
| 6     | RW   | 0x0         | Back-to-Back SETUP Packets Received Mask  |
|       |      |             | Applies to control OUT endpoints only.    |
| 5     | RO   | 0x0         | reserved                                  |
|       |      |             | OUTTknEPdisMsk                            |
| 4     | RW   | 0x0         | OUT Token Received when Endpoint Disabled |
| 4     | K VV |             | Mask                                      |
|       |      |             | Applies to control OUT endpoints only.    |

| Bit | Attr | Reset Value | Description                        |
|-----|------|-------------|------------------------------------|
|     |      |             | SetUPMsk                           |
| 3   | RW   | 0x0         | SETUP Phase Done Mask              |
|     |      |             | Applies to control endpoints only. |
| 2   |      | 0x0         | AHBErrMsk                          |
| Z   | RW   |             | AHB Error                          |
| 4   | RW   | 0x0         | EPDisbldMsk                        |
| 1   |      |             | Endpoint Disabled Interrupt Mask   |
| 0   |      | 0x0         | XferComplMsk                       |
| 0   | RW   |             | Transfer Completed Interrupt Mask  |

## USBOTG\_DAINT

Address: Operational Base + offset (0x0818) Device All Endpoints interrupt register

| Bit   | Attr | Reset Value | Description                                    |
|-------|------|-------------|------------------------------------------------|
|       |      |             | OutEPInt                                       |
| 31:16 | RO   | 0x0000      | OUT Endpoint Interrupt Bits                    |
| 51:10 | ĸŪ   | 0x0000      | One bit per OUT endpoint: Bit 16 for OUT       |
|       |      |             | endpoint 0, bit 31 for OUT endpoint 15         |
|       |      |             | InEpInt                                        |
| 1     |      |             | IN Endpoint Interrupt Bits                     |
| 15:0  | RO   |             | One bit per IN Endpoint: Bit 0 for IN endpoint |
|       |      |             | 0, bit 15 for endpoint 15                      |

## USBOTG\_DAINTMSK

Address: Operational Base + offset (0x081c)

Device All Endpoint interrupt mask register

| Bit   | Attr | Reset Value                             | Description                                     |
|-------|------|-----------------------------------------|-------------------------------------------------|
|       |      | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | OutEpMsk                                        |
| 31:16 | RW   | 0x0000                                  | OUT EP Interrupt Mask Bits                      |
| 51:10 | ĸv   | 0x0000                                  | One per OUT Endpoint: Bit 16 for OUT EP 0, bit  |
|       |      |                                         | 31 for OUT EP 15                                |
|       | RW   |                                         | InEpMsk                                         |
| 15:0  |      | 0x0000                                  | IN EP Interrupt Mask Bits                       |
| 15:0  |      |                                         | One bit per IN Endpoint: Bit 0 for IN EP 0, bit |
|       |      |                                         | 15 for IN EP 15                                 |

## USBOTG\_DTKNQR1

Address: Operational Base + offset (0x0820)

Device IN token sequence learning queue read register1

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0×000000    | EPTkn<br>Endpoint Token<br>Four bits per token represent the endpoint<br>number of the token:<br>Bits [31:28]: Endpoint number of Token 5<br>Bits [27:24]: Endpoint number of Token 4<br><br>Bits [15:12]: Endpoint number of Token 1<br>Bits [11:8]: Endpoint number of Token 0 |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                               |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 7   | RO   | 0×0                | WrapBit<br>Wrap Bit<br>This bit is set when the write pointer wraps. It<br>is cleared when the learning queue is cleared. |
| 6:5 | RO   | 0x0                | reserved                                                                                                                  |
| 4:0 | RO   | 0x00               | INTknWPtr<br>IN Token Queue Write Pointer                                                                                 |

## USBOTG\_DTKNQR2

Address: Operational Base + offset (0x0824) Device IN token sequence learning queue read register2

| Bit A   | ttr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                     |
|---------|-----|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 RW | I   | 0x00000000         | EPTkn<br>Endpoint Token<br>Four bits per token represent the endpoint<br>number of the token:<br>Bits [31:28]: Endpoint number of Token 13<br>Bits [27:24]: Endpoint number of Token 12<br><br>Bits [7:4]: Endpoint number of Token 7<br>Bits [3:0]: Endpoint number of Token 6 |

## USBOTG\_DVBUSDIS

Address: Operational Base + offset (0x0828) Device VBUS discharge time register

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                     |
| 15:0  | RW   | 0×0b8f             | DVBUSDis<br>Device VBUS Discharge Time<br>Specifies the VBUS discharge time after VBUS<br>pulsing during SRP. This value<br>equals: VBUS discharge time in PHY clocks /<br>1,024.The value you use depends whether the<br>PHY is operating at 30 MHz (16-bit data width)<br>or 60 MHz (8-bit data width). Depending on<br>your VBUS load, this value can need<br>adjustment. |

## USBOTG\_DVBUSPULSE

Address:  $\overline{O}$  Operational Base + offset (0x082c)

Device VBUS Pulsing Timer Register

| Bit   | Attr | <b>Reset Value</b> | Description |
|-------|------|--------------------|-------------|
| 31:12 | RO   | 0x0                | reserved    |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                       |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0 | RW   | 0x000              | DVBUSPulse<br>Device VBUS Pulsing Time<br>Specifies the VBUS pulsing time during SRP.<br>This value equals:VBUS pulsing time in PHY<br>clocks / 1,024.The value you use depends<br>whether the PHY is operating at 30 MHz<br>(16-bit data width) or 60 MHz (8-bit data<br>width). |

# USBOTG\_DTHRCTL

Address: Operational Base + offset (0x0830) Device Threshold Control Register

| Bit   | Attr |       | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0   | reserved                                                                                                                                                                                                                                                                                                                                                                                                  |
| 27    | RW   | 0×1   | ArbPrkEn<br>Arbiter Parking Enable<br>This bit controls internal DMA arbiter parking<br>for IN endpoints. When threshold is enabled<br>and this bit is set to one, then the arbiter<br>parks on the IN endpoint for which there is a<br>token received on the USB. This is done to<br>avoid getting into under-run conditions. By<br>default the parking is enabled.                                      |
| 26    | RO   | 0x0   | reserved                                                                                                                                                                                                                                                                                                                                                                                                  |
| 25:17 | RW   | 0×008 | RxThrLen<br>Receive Threshold Length<br>This field specifies Receive threshold size in<br>DWORDS. This field also specifies the amount<br>of data received on the USB before the core<br>can start transmitting on the AHB. The<br>threshold length has to be at least eight<br>DWORDS.<br>The recommended value for ThrLen is to be<br>the same as the programmed AHB Burst<br>Length (GAHBCFG.HBstLen). |
| 16    | RW   | 0×0   | RxThrEn<br>Receive Threshold Enable<br>When this bit is set, the core enables<br>thresholding in the receive direction.                                                                                                                                                                                                                                                                                   |
| 15:13 | RO   | 0x0   | reserved                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit   | Attr | Reset Value | Description                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------|
|       |      |             | AHBThrRatio                                                                           |
|       |      |             | AHB Threshold Ratio                                                                   |
|       |      |             | These bits define the ratio between the AHB                                           |
|       |      |             | threshold and the MAC threshold for the                                               |
|       |      |             | transmit path only. The AHB threshold always                                          |
|       |      |             | remains less than or equal to the USB                                                 |
|       |      |             | threshold, because this does not increase                                             |
|       |      |             | overhead. Both the AHB and the MAC                                                    |
|       |      |             | threshold must be DWORD-aligned. The                                                  |
|       |      |             | -                                                                                     |
|       |      |             | application needs to program TxThrLen and the AHBThrRatio to make the AHB Threshold   |
| 12:11 | RW   | 0x0         |                                                                                       |
|       |      |             | value DWORD aligned. If the AHB threshold                                             |
|       |      |             | value is not DWORD aligned, the core might                                            |
|       |      |             | not behave correctly. When programming the                                            |
|       |      |             | TxThrLen and AHBThrRatio, the application                                             |
|       |      |             | must ensure that the minimum AHB threshold                                            |
|       |      |             | value does not go below 8 DWORDS to meet                                              |
|       |      |             | the USB turnaround time requirements.                                                 |
|       |      |             | 2'b00: AHB threshold = MAC threshold                                                  |
|       |      |             | 2'b01: AHB threshold = MAC threshold / 2                                              |
|       |      |             | 2'b10: AHB threshold = MAC threshold / 4                                              |
|       |      |             | 2'b11: AHB threshold = MAC threshold / 8                                              |
|       |      |             | TxThrLen                                                                              |
|       |      |             | Transmit Threshold Length                                                             |
|       |      |             | This field specifies Transmit threshold size in DWORDS. This field also forms the MAC |
|       |      |             |                                                                                       |
|       |      |             | threshold and specifies the amount of data, in                                        |
|       |      |             | bytes, to be in the corresponding endpoint transmit FIFO before the core can start a  |
|       |      |             | transaction on the USB. When the value of                                             |
|       |      |             | AHBThrRatio is 2'h00, the threshold length                                            |
| 10:2  | RW   | 0x008       | must be at least 8 DWORDS. If the                                                     |
|       |      |             | AHBThrRatio is nonzero, the application must                                          |
|       |      |             | ensure that the AHB threshold value does not                                          |
|       |      | 1           | go below the recommended 8 DWORDs.                                                    |
|       |      |             | This field controls both isochronous and                                              |
|       |      |             | non-isochronous IN endpoint thresholds.                                               |
|       |      | 2           | The recommended value for ThrLen is to be                                             |
|       |      |             | the same as the programmed AHB Burst                                                  |
|       |      |             | Length (GAHBCFG.HBstLen).                                                             |
|       |      |             | ISOThrEn                                                                              |
|       |      |             | ISO IN Endpoints Threshold Enable                                                     |
| 1     | RW   | 0x0         | When this bit is set, the core enables                                                |
|       |      |             | threshold for isochronous IN endpoints.                                               |
|       |      |             | NonISOThrEn                                                                           |
|       |      |             | Non-ISO IN Endpoints Threshold Enable                                                 |
| 0     | RW   | 0x0         | When this bit is set, the core enables                                                |
|       |      |             | threshold for Non Isochronous IN endpoints.                                           |
| L     |      |             | the shou for non isochronous in chupolits.                                            |

**USBOTG\_DIEPEMPMSK** Address: Operational Base + offset (0x0834) Device IN endpoint FIFO empty interrupt mask register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                 |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0         | reserved                                                                                                                                                                                                    |
| 15:0  | RW   | 0x0000      | InEpTxfEmpMsk<br>IN EP Tx FIFO Empty Interrupt Mask Bits<br>These bits act as mask bits for DIEPINTn.<br>TxFEmp interrupt One bit per IN Endpoint:<br>Bit 0 for IN endpoint 0<br><br>Bit 15 for endpoint 15 |

# USBOTG\_DEACHINT

Address: Operational Base + offset (0x0838) Device each endpoint interrupt register

| Bit   | Attr | Reset Value | Description                                                                                                                            |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | EchOutEPInt<br>OUT Endpoint Interrupt Bits<br>One bit per OUT endpoint:<br>Bit 16 for OUT endpoint 0<br><br>Bit 31 for OUT endpoint 15 |
| 15:0  | RO   | 0×0000      | EchInEpInt<br>IN Endpoint Interrupt Bits<br>One bit per IN Endpoint:<br>Bit 0 for IN endpoint 0<br><br>Bit 15 for endpoint 15          |

## USBOTG\_DEACHINTMSK

Address: Operational Base + offset (0x083c) Device each endpoint interrupt register mask

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                            |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000             | EchOutEpMsk<br>OUT EP Interrupt Mask Bits<br>One per OUT Endpoint:<br>Bit 16 for IN endpoint 0<br><br>Bit 21 for endpoint 15                           |
| 15:0  | RW   | 0×0000             | Bit 31 for endpoint 15<br>EchInEpMsk<br>IN EP Interrupt Mask Bits<br>One bit per IN Endpoint:<br>Bit 0 for IN endpoint 0<br><br>Bit 15 for endpoint 15 |

## USBOTG\_DIEPEACHMSKn

Address: Operational Base + offset (0x0840)

Device each IN endpoint -n interrupt Register

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:14 | RO   | 0x0         | reserved    |

| Bit      | Attr | Reset Value | Description                              |
|----------|------|-------------|------------------------------------------|
| 13       | RW   | 0x0         | NAKMsk                                   |
| 13       |      | 0.00        | NAK interrupt Mask                       |
| 12:10    | RO   | 0x0         | reserved                                 |
| 9        | RW   | 0x0         | BNAInIntrMsk                             |
| 5        |      | 0.00        | BNA interrupt Mask                       |
| 8        | RW   | 0x0         | TxfifoUndrnMsk                           |
|          |      | 0.00        | Fifo Under run Mask                      |
| 7        | RO   | 0x0         | reserved                                 |
| 6        | RW   | 0x0         | INEPNakEffMsk                            |
| 0        |      | UXU         | IN Endpoint NAK Effective Mask           |
| 5        | RW   | 0x0         | INTknEPMisMsk                            |
| 5        |      |             | IN Token received with EP Mismatch Mask  |
| 4        | RW   | 0x0         | INTknTXFEmpMsk                           |
| -        |      | 0.00        | IN Token Received When TxFIFO Empty Mask |
|          |      |             | TimeOUTMsk                               |
| 3        | RW   | 0x0         | Timeout Condition Mask(Non-isochronous   |
|          |      |             | endpoints)                               |
| 2        | RW   | 0x0         | AHBErrMsk                                |
| 2        |      | 0.00        | AHB Error Mask                           |
| 1        | RW   | V 0x0       | EPDisbldMsk                              |
| <u> </u> |      |             | Endpoint Disabled Interrupt Mask         |
| 0        | RW   | 0x0         | XferComplMsk                             |
| Ŭ        |      |             | Transfer Completed Interrupt Mask        |

# USBOTG\_DOEPEACHMSKn

Address: Operational Base + offset (0x0880) Device each out endpoint-n interrupt register

| Bit   | Attr | Reset Value | Description                               |
|-------|------|-------------|-------------------------------------------|
| 31:15 | RO   | 0x0         | reserved                                  |
| 14    | RW   | 0x0         | NYETMsk                                   |
| 14    |      | 0.00        | NYET interrupt Mask                       |
| 13    | RW   | 0x0         | NAKMsk                                    |
| 15    |      |             | NAK interrupt Mask                        |
| 12    | RW   | 0x0         | BbleErrMsk                                |
|       |      |             | Babble interrupt Mask                     |
| 11:10 | RO   | 0x0         | reserved                                  |
| 9     | RW   | 0x0         | BnaOutIntrMsk                             |
|       |      |             | BNA interrupt Mask                        |
| 8     | RW   |             | OutPktErrMsk                              |
| 0     |      |             | OUT Packet Error Mask                     |
| 7     | RO   | 0x0         | reserved                                  |
|       |      |             | Back2BackSETup                            |
| 6     | RW   | 0x0         | Back-to-Back SETUP Packets Received Mask  |
|       |      |             | Applies to control OUT endpoints only.    |
| 5     | RO   | 0x0         | reserved                                  |
|       |      |             | OUTTknEPdisMsk                            |
| 4     | RW   | 0x0         | OUT Token Received when Endpoint Disabled |
| 4     | KW   |             | Mask                                      |
|       |      |             | Applies to control OUT endpoints only.    |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                        |
|-----|------|-------------|------------------------------------|
|     |      |             | SetUPMsk                           |
| 3   | RW   | 0x0         | SETUP Phase Done Mask              |
|     |      |             | Applies to control endpoints only. |
| 2   | RW   | 0x0         | AHBErrMsk                          |
| Z   |      |             | AHB Error                          |
| 4   | RW   | 0x0         | EPDisbldMsk                        |
| T   |      |             | Endpoint Disabled Interrupt Mask   |
| 0   |      | 0x0         | XferComplMsk                       |
|     | RW   |             | Transfer Completed Interrupt Mask  |

# USBOTG\_DIEPCTL0

| Address  | USBOTG_DIEPCTLO<br>Address: Operational Base + offset (0x0900)<br>Device control IN endpoint 0 control register |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|----------|-----------------------------------------------------------------------------------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Device c | ontrol II<br>Attr                                                                                               | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| DIL      | Atti                                                                                                            | Reset value | EPEna                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 31       | R/WSC                                                                                                           | 0x0         | Endpoint Enable<br>When Scatter/Gather DMA mode is enabled,<br>for IN endpoints this bit indicates that the<br>descriptor structure and data buffer with data<br>ready to transmit is setup. When<br>Scatter/Gather DMA mode is disabled-such as<br>in buffer-pointer based<br>DMA mode-this bit indicates that data is ready<br>to be transmitted on the endpoint.<br>The core clears this bit before setting the<br>following interrupts on this endpoint:<br>Endpoint Disabled; Transfer Completed. |  |  |
| 30       | R/WSC                                                                                                           |             | EPDis<br>Endpoint Disable<br>The application sets this bit to stop<br>transmitting data on an endpoint, even before<br>the transfer for that endpoint is complete. The<br>application must wait for the Endpoint<br>Disabled interrupt before treating the<br>endpoint as disabled. The core clears this bit<br>before setting the Endpoint Disabled<br>Interrupt. The application must set this bit<br>only if Endpoint Enable is already set for this<br>endpoint.                                   |  |  |
| 29:28    | RO                                                                                                              | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 27       | wo                                                                                                              | 0x0         | SNAK<br>Set NAK<br>A write to this bit sets the NAK bit for the<br>endpoint. Using this bit, the application can<br>control the transmission of NAK handshakes<br>on an endpoint. The core can also set this bit<br>for an endpoint after a SETUP packet is<br>received on that endpoint.                                                                                                                                                                                                              |  |  |

| Bit   | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26    | WO    | 0x0         | CNAK<br>Clear NAK<br>A write to this bit clears the NAK bit for the<br>endpoint.                                                                                                                                                                                                                                                                                                                                                                                              |
| 25:23 | RO    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 22    | RW    | 0×0         | TxFNum<br>TxFIFO Number<br>For Shared FIFO operation, this value is<br>always set to 0, indicating that control IN<br>endpoint 0 data is always written in the<br>Non-Periodic Transmit FIFO. For Dedicated<br>FIFO operation, this value is set to the FIFO<br>number that is assigned to IN Endpoint 0.                                                                                                                                                                     |
| 21    | R/WSC | 0×0         | Stall<br>STALL Handshake<br>The application can only set this bit, and the<br>core clears it, when a SETUP token is received<br>for this endpoint. If a NAK bit, Global<br>Non-periodic IN NAK, or Global OUT NAK is set<br>along with this bit, the STALL bit takes<br>priority.                                                                                                                                                                                             |
| 20    | RO    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 19:18 | RO    | 0x0         | EPType<br>Endpoint Type<br>Hardcoded to 00 for control                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 17    | RO    | 0×0         | NAKSts<br>NAK Status<br>Indicates the following:<br>1'b0: The core is transmitting non-NAK<br>handshakes based on the FIFO status<br>1'b1: The core is transmitting NAK<br>handshakes on this endpoint.<br>When this bit is set, either by the application<br>or core, the core stops transmitting data, even<br>if there is data available in the TxFIFO.<br>Irrespective of this bit's setting, the core<br>always responds to SETUP data packets with<br>an ACK handshake. |
| 16    | RO    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15    | RO    | 0x1         | USBActEP<br>USB Active Endpoint<br>This bit is always set to 1, indicating that<br>control endpoint 0 is always active in all<br>configurations and interfaces.                                                                                                                                                                                                                                                                                                               |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:11 | RW   | 0×0         | NextEp<br>Next Endpoint<br>Applies to non-periodic IN endpoints only.<br>Indicates the endpoint number to be fetched<br>after the data for the current endpoint is<br>fetched. The core can access this field, even<br>when the Endpoint Enable (EPEna) bit is not<br>set. This field is not valid in Slave mode. Note:<br>This field is valid only for Shared FIFO<br>operations. |
| 10:2  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                           |
| 1:0   | RW   | 0×0         | MPS<br>Maximum Packet Size<br>Applies to IN and OUT endpoints. The<br>application must program this field with the<br>maximum packet size for the current logical<br>endpoint.<br>2'b00: 64 bytes<br>2'b01: 32 bytes<br>2'b10: 16 bytes<br>2'b11: 8 bytes                                                                                                                          |

## USBOTG\_DIEPINTn

Address: Operational Base + offset (0x0908) Device Endpoint-n Interrupt Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                    |
| 14    | W1C  | 0×0         | NYETIntrpt<br>NYET interrupt<br>The core generates this interrupt when a NYET<br>response is transmitted for a non-<br>isochronous OUT endpoint.                                                                                                                                            |
| 13    | W1C  | 0×0         | NAKIntrpt<br>NAK interrupt<br>The core generates this interrupt when a NAK<br>is transmitted or received by the device. In<br>case of isochronous IN endpoints the interrupt<br>gets generated when a zero length packet is<br>transmitted due to un-availability of data in<br>the TXFifo. |
| 12    | W1C  | 0x0         | BbleErrIntrpt<br>BbleErr (Babble Error) interrupt<br>The core generates this interrupt when babble<br>is received for the endpoint.                                                                                                                                                         |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11  | W1C  | 0×0         | PktDrpSts<br>Packet Dropped Status<br>This bit indicates to the application that an<br>ISOC OUT packet has been dropped. This bit<br>does not have an associated mask bit and<br>does not generate an interrupt. Dependency:<br>This bit is valid in non-Scatter/Gather DMA<br>mode when periodic transfer interrupt feature<br>is selected.                                                                                                                                                                                                                                                                                                                              |
| 10  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9   | W1C  | 0×0         | BNAIntr<br>BNA (Buffer Not Available) Interrupt<br>The core generates this interrupt when the<br>descriptor accessed is not ready for the Core<br>to process, such as Host busy or DMA done<br>Dependency: This bit is valid only when<br>Scatter/Gather DMA mode is enabled.                                                                                                                                                                                                                                                                                                                                                                                             |
| 8   | W1C  | 0×0         | TxfifoUndrn<br>FIFO Under-run<br>Applies to IN endpoints only. The core<br>generates this interrupt when it detects a<br>transmit FIFO under-run condition for this<br>endpoint. Dependency: This interrupt is valid<br>only when both of the following conditions are<br>true: Parameter OTG_EN_DED_TX_FIFO==1;<br>Threshold is enabled; OUT Packet<br>Error(OutPktErr). Applies to OUT endpoints<br>only. This interrupt is asserted when the core<br>detects an overflow or a CRC error for an OUT<br>packet. Dependency: This interrupt is valid<br>only when both of the following conditions are<br>true: Parameter OTG_EN_DED_TX_FIFO==1;<br>Threshold is enabled. |
| 7   | W1C  | 0×0         | TxFEmp<br>Transmit FIFO Empty<br>This bit is valid only for IN Endpoints. This<br>interrupt is asserted when the TxFIFO for this<br>endpoint is either half or completely empty.<br>The half or completely empty status is<br>determined by the TxFIFO Empty Level bit in<br>the Core AHB Configuration register<br>(GAHBCFG.NPTxFEmpLvl)).                                                                                                                                                                                                                                                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | W1C  | 0x0         | INEPNakEff<br>IN Endpoint NAK Effective<br>Applies to periodic IN endpoints only. This bit<br>can be cleared when the application clears the<br>IN endpoint NAK by writing to<br>DIEPCTLn.CNAK. This interrupt indicates that<br>the core has sampled the NAK bit set (either<br>by the<br>application or by the core). The interrupt<br>indicates that the IN endpoint NAK bit set by<br>the application has taken effect in the core.<br>This interrupt does not guarantee that a NAK<br>handshake is sent on the USB. A STALL bit<br>takes priority over a NAK bit. This bit is<br>applicable only when the endpoint is enabled.<br>Back-to-Back SETUP Packets Received<br>(Back2BackSETup) Applies to Control OUT<br>endpoints only.<br>This bit indicates that the core has received<br>more than three back-to-back SETUP<br>packets for this particular endpoint.<br>INTknEPMis                                                                                                                                                                                          |
| 5   | W1C  | 0×0         | INTRITERING<br>INTRITERING<br>INTRICERNIS<br>INTOKEN Received with EP Mismatch<br>Applies to non-periodic IN endpoints only.<br>Indicates that the data in the top of the<br>non-periodic TxFIFO belongs to an endpoint<br>other than the one for which the IN token was<br>received. This interrupt is asserted on the<br>endpoint for which the IN token was received.<br>Status Phase Received For Control Write<br>(StsPhseRcvd)<br>This interrupt is valid only for Control OUT<br>endpoints and only in Scatter Gather DMA<br>mode. This interrupt is generated only after<br>the core has transferred all the data that the<br>host has sent during the data phase of a<br>control write transfer, to the system memory<br>buffer. The interrupt indicates to the<br>application that the host has switched from<br>data phase to the status phase of a Control<br>Write transfer. The application can use this<br>interrupt to ACK or STALL the Status phase,<br>after it has decoded the data phase. This is<br>applicable only in case of Scatter Gather DMA<br>mode. |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | W1C  | 0×0         | INTknTXFEmp<br>IN Token Received When TxFIFO is Empty<br>Indicates that an IN token was received when<br>the associated TxFIFO periodic/nonperiodic)<br>was empty. This interrupt is asserted on the<br>endpoint for which the IN token was received.<br>OUT Token Received When Endpoint Disabled<br>(OUTTknEPdis) Indicates that an OUT token<br>was received when the endpoint was not yet<br>enabled. This interrupt is asserted on the<br>endpoint for which the OUT token was<br>received.                                                                                                                                                                                                      |
| 3   | W1C  | 0×0         | TimeOUT<br>Timeout Condition<br>In shared TX FIFO mode, applies to<br>non-isochronous IN endpoints only. In<br>dedicated FIFO mode, applies only to Control<br>IN endpoints. In Scatter/Gather DMA mode,<br>the TimeOUT interrupt is not asserted.<br>Indicates that the core has detected a timeout<br>condition on the USB for the last IN token on<br>this endpoint.<br>SETUP Phase Done (SetUp) Applies to control<br>OUT endpoints only. Indicates that the SETUP<br>phase for the control endpoint is complete and<br>no more back-to-back SETUP packets were<br>received for the current control transfer. On<br>this interrupt, the application can decode the<br>received SETUP data packet. |
| 2   | W1C  | 0x0         | AHBErr<br>AHB Error<br>Applies to IN and OUT endpoints. This is<br>generated only in Internal DMA mode when<br>there is an AHB error during an AHB<br>read/write. The application can read the<br>corresponding endpoint DMA address register<br>to get the error address.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1   | W1C  | 0x0         | EPDisbld<br>Endpoint Disabled Interrupt<br>Applies to IN and OUT endpoints. This bit<br>indicates that the endpoint is disabled per the<br>application's request.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | W1C  | 0×0         | XferCompl<br>Transfer Completed Interrupt<br>Applies to IN and OUT endpoints. When<br>Scatter/Gather DMA mode is enabled: For IN<br>endpoint this field indicates that the requested<br>data from the descriptor is moved from<br>external system memory to internal FIFO.<br>For OUT endpoint this field indicates that the<br>requested data from the internal FIFO is<br>moved to external system memory. This<br>interrupt is generated only when the<br>corresponding endpoint descriptor is closed,<br>and the IOC bit for the corresponding<br>descriptor is set. When Scatter/Gather DMA<br>mode is disabled, this field indicates that the<br>programmed transfer is complete on the AHB<br>as well as on the USB, for this endpoint. |

**USBOTG\_DIEPTSIZn** Address: Operational Base + offset (0x0910) Device endpoint n transfer size register

2002

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
| 31  | RO   | 0x0                | reserved    |
|     |      | •                  |             |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit                 | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |      |             | MC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>Bit</b><br>30:29 | RW   | 0×0         | Multi Count<br>Applies to IN endpoints only. For periodic IN<br>endpoints, this field indicates the number of<br>packets that must be transmitted per<br>microframe on the USB. The core uses this<br>field to calculate the data PID for isochronous<br>IN endpoints.<br>2'b01: 1 packet<br>2'b10: 2 packets<br>2'b11: 3 packets<br>For non-periodic IN endpoints, this field is<br>valid only in Internal DMA mode. It specifies<br>the number of packets the core must fetch for<br>an IN endpoint before it switches to the<br>endpoint pointed to by the Next Endpoint field<br>of the Device Endpoint-n Control register<br>(DIEPCTLn.NextEp). Received Data PID |
|                     |      |             | (RxDPID)<br>Applies to isochronous OUT endpoints only.<br>This is the data PID received in the last packet<br>for this endpoint.<br>2'b00: DATA0<br>2'b01: DATA2<br>2'b10: DATA1<br>2'b11: MDATA<br>SETUP Packet Count (SUPCnt).Applies to<br>control OUT Endpoints only. This field<br>specifies the number of back-to-back SETUP<br>data packets the endpoint can receive.<br>2'b01: 1 packet<br>2'b10: 2 packets<br>2'b11: 3 packets                                                                                                                                                                                                                                |
| 28:19               | RW   | 0×000       | PktCnt<br>Packet Count<br>Indicates the total number of USB packets<br>that constitute the Transfer Size amount of<br>data for this endpoint. The power-on value is<br>specified for Width of Packet Counters during<br>coreConsultant configuration (parameter<br>OTG_PACKET_COUNT_WIDTH). IN<br>Endpoints: This field is decremented every<br>time a packet (maximum size or short packet)<br>is read from the TxFIFO. OUT Endpoints: This<br>field is decremented every time a packet<br>(maximum size or<br>short packet) is written to the RxFIFO.                                                                                                                |

| Bit             | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0            | RW   | 0×00000     | XferSize<br>Transfer Size<br>This field contains the transfer size in bytes for<br>the current endpoint. The power-on value is<br>specified for Width of Transfer Size Counters<br>during configuration (parameter<br>OTG_TRANS_COUNT_WIDTH). The core only<br>interrupts the application after it has<br>exhausted the transfer size amount of data.<br>The transfer size can be set to the maximum<br>packet size of the endpoint, to be interrupted<br>at the end of each packet. IN Endpoints: The<br>core decrements this field every time a packet<br>from the external memory is written to the<br>TxFIFO.OUT Endpoints: The core decrements<br>this field every time a packet is read from the<br>RxFIFO and written to the external memory. |
| USBOTG_DIEPDMAn |      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### USBOTG\_DIEPDMAn

Address: Operational Base + offset (0x0914) Device endpoint-n DMA address register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×0000000   | DMAAddr<br>DMA Address<br>Holds the start address of the external<br>memory for storing or fetching endpoint<br>data. Note: For control endpoints, this field<br>stores control OUT data packets as well as<br>SETUP transaction data packets. When more<br>than three SETUP packets are received<br>back-to-back, the SETUP data packet in the<br>memory is overwritten.<br>This register is incremented on every AHB<br>transaction. The application can give<br>only a DWORD-aligned address. When<br>Scatter/Gather DMA mode is not enabled, the<br>application programs the start address value<br>in this field. When Scatter/Gather DMA mode<br>is enabled, this field indicates the base pointer<br>for the descriptor list. |

#### USBOTG\_DTXFSTSn

Address: Operational Base + offset (0x0918)

Device IN endpoint transmit FIFO status register

| Bit   | Attr | <b>Reset Value</b> | Description |
|-------|------|--------------------|-------------|
| 31:16 | RO   | 0x0                | reserved    |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0×0000      | INEPTxFSpcAvail<br>IN Endpoint TxFIFO Space Avail<br>Indicates the amount of free space available in<br>the Endpoint TxFIFO. Values are in terms of<br>32-bit words.<br>16'h0: Endpoint TxFIFO is full<br>16'h1: 1 word available<br>16'h2: 2 words available<br>16'hn: n words available (where 0 . n .<br>32,768)<br>16'h8000: 32,768 words available<br>Others: Reserved |

#### USBOTG\_DIEPDMABn

Address: Operational Base + offset (0x091c) Device endpoint-n DMA buffer address register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000  | DMABufferAddr<br>DMA Buffer Address<br>Holds the current buffer address.This register<br>is updated as and when the data<br>transfer for the corresponding end point is in<br>progress. This register is present only in<br>Scatter/Gather DMA mode. Otherwise this<br>field is reserved. |

#### USBOTG\_DIEPCTLn

2004

Address: Operational Base + offset (0x0920) Device endpoint-n control register

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    |             |

| Bit | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |       |             | EPEna                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31  | R/WSC | 0×0         | Endpoint Enable<br>Applies to IN and OUT endpoints. When<br>Scatter/Gather DMA mode is enabled, For IN<br>endpoints this bit indicates that the descriptor<br>structure and data buffer with data ready to<br>transmit is setup. For OUT endpoint it<br>indicates that the descriptor structure and<br>data buffer to receive data is setup. When<br>Scatter/Gather DMA mode is enabled-such as<br>for buffer-pointer based DMA mode: For IN<br>endpoints, this bit indicates that data is ready<br>to be transmitted on the endpoint ; For OUT<br>endpoints, this bit indicates that the<br>application has allocated the memory to start<br>receiving data from the USB. The core clears<br>this bit before setting any of the following<br>interrupts on this endpoint: SETUP Phase<br>Done, Endpoint Disabled, Transfer<br>Completed. Note: For control endpoints in<br>DMA mode, this bit must be set to be able to |
| 30  | R/WSC | 0×0         | transfer SETUP data packets in memory.<br>EPDis<br>Endpoint Disable<br>Applies to IN and OUT endpoints. The<br>application sets this bit to stop<br>transmitting/receiving data on an endpoint,<br>even before the transfer for that endpoint is<br>complete. The application must wait for the<br>Endpoint Disabled interrupt before treating<br>the endpoint as disabled. The core clears this<br>bit before setting the Endpoint Disabled<br>interrupt. The application must set this bit<br>only if Endpoint Enable is already set for this<br>endpoint.                                                                                                                                                                                                                                                                                                                                                             |
| 29  | wo    | 0×0         | SetD1PID<br>Set DATA1 PID<br>Applies to interrupt/bulk IN and OUT<br>endpoints only. Writing to this field sets the<br>Endpoint Data PID (DPID) field in this register<br>to DATA1.This field is applicable both for<br>Scatter/Gather DMA mode and<br>non-Scatter/Gather DMA mode. Set Odd<br>(micro) frame (SetOddFr). Applies to<br>isochronous IN and OUT endpoints only.<br>Writing to this field sets the Even/Odd (micro)<br>frame (EO_FrNum) field to odd (micro) frame.<br>This field is not applicable for Scatter/Gather<br>DMA mode.                                                                                                                                                                                                                                                                                                                                                                         |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 28   | wo   | 0x0         | SetD0PID<br>Set DATA0 PID<br>Applies to interrupt/bulk IN and OUT<br>endpoints only. Writing to this field sets the<br>Endpoint Data PID (DPID) field in this register<br>to DATA0.This field is applicable both for<br>Scatter/Gather DMA mode and<br>non-Scatter/Gather DMA mode. In<br>non-Scatter/Gather DMA mode: Set Even<br>(micro) frame (SetEvenFr) Applies to<br>isochronous IN and OUT endpoints only.<br>Writing to this field sets the Even/Odd (micro)<br>frame (EO_FrNum) field to even (micro)<br>frame. When Scatter/Gather DMA mode is<br>enabled, this field is reserved. The frame<br>number in which to send data is in the<br>transmit descriptor structure. The frame in<br>which to receive data is updated in recept<br>descriptor structure. |  |
| 27   | wo   | 0×0         | SNAK<br>Set NAK<br>Applies to IN and OUT endpoints. A write to<br>this bit sets the NAK bit for the endpoint.<br>Using this bit, the application can control the<br>transmission of NAK handshakes on an<br>endpoint. The core can also set this bit for OUT<br>endpoints on a Transfer Completed interrupt,<br>or after a SETUP is received on the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 26   | wo   | 0×0         | CNAK<br>Clear NAK<br>Applies to IN and OUT endpoints. A write to<br>this bit clears the NAK bit for the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Rock |      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |

| Bit   | Attr | Reset Value | Description                                        |
|-------|------|-------------|----------------------------------------------------|
|       |      | _           | TxFNum                                             |
|       |      |             | TxFIFO Number                                      |
|       |      |             | Shared FIFO Operation:non-periodic                 |
|       |      |             | endpoints must set this bit to zero. Periodic      |
|       |      |             | endpoints must map this to the corresponding       |
|       |      |             | Periodic TxFIFO number. 4'h0: Non-Periodic         |
|       |      |             | TxFIFO; Others: Specified Periodic TxFIFO          |
|       |      |             | number. Note: An interrupt IN endpoint can         |
|       |      |             | be configured as a non-periodic endpoint for       |
|       |      |             | applications such as mass storage. The core        |
|       |      |             | treats an IN endpoint as a non-periodic            |
| 25:22 | RW   | 0x0         | endpoint if the TxFNum field is set to 0.          |
| 23122 |      | 0,00        | Otherwise, a separate periodic FIFO must be        |
|       |      |             | allocated for an interrupt IN endpoint, and the    |
|       |      |             | number of this FIFO must be programmed into        |
|       |      |             | the TxFNum field. Configuring an interrupt IN      |
|       |      |             | endpoint as a non-periodic endpoint saves the      |
|       |      |             | extra periodic FIFO area. Dedicated FIFO           |
|       |      |             | Operation: these bits specify the FIFO number      |
|       |      |             | associated with this endpoint. Each active IN      |
|       |      |             | endpoint must be programmed to a separate          |
|       |      |             | FIFO number. This field is valid only for IN       |
|       |      |             | endpoints.                                         |
|       |      |             | Stall                                              |
|       |      |             | STALL Handshake                                    |
|       |      |             | Applies to non-control, non-isochronous IN         |
|       |      |             | and OUT endpoints only. The application sets       |
|       |      |             | this bit to stall all tokens from the USB host to  |
|       |      |             | this endpoint. If a NAK bit, Global                |
|       |      | •           | Non-periodic IN NAK, or Global OUT NAK is set      |
|       |      |             | along with this bit, the STALL bit takes           |
|       |      |             | priority. Only the application can clear this bit, |
| 21    | RW   | 0x0         | never the core.                                    |
|       |      |             | Applies to control endpoints only. The             |
|       |      | 1           | application can only set this bit, and the core    |
|       |      |             | clears it, when a SETUP token is received for      |
|       | C    | Y           | this endpoint. If a NAK bit, Global                |
|       |      |             | Non-periodic IN NAK, or Global OUT NAK is set      |
|       |      |             | along with this bit, the STALL bit takes           |
|       |      |             | priority. Irrespective of this bit's setting, the  |
|       |      |             | core always responds to SETUP data packets         |
| Y     |      |             | with an ACK handshake.                             |
|       |      |             | Snp                                                |
|       |      |             | Snoop Mode                                         |
|       |      |             | Applies to OUT endpoints only. This bit            |
| 20    | RW   | 0x0         | configures the endpoint to Snoop mode. In          |
|       |      |             | Snoop mode, the core does not check the            |
|       |      |             | correctness of OUT packets before                  |
|       |      |             | transferring them to application memory.           |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:18 | RW   | 0×0         | EPType<br>Endpoint Type<br>Applies to IN and OUT endpoints. This is the<br>transfer type supported by this logical<br>endpoint.<br>2'b00: Control<br>2'b01: Isochronous<br>2'b10: Bulk<br>2'b11: Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 17    | RO   | 0×0         | NAKSts<br>NAK Status<br>Applies to IN and OUT endpoints. Indicates<br>the following:<br>1'b0: The core is transmitting non-NAK<br>handshakes based on the FIFO status.<br>1'b1: The core is transmitting NAK<br>handshakes on this endpoint.<br>When either the application or the core sets<br>this bit: The core stops receiving any data on<br>an OUT endpoint, even if there is space in the<br>RxFIFO to accommodate the incoming packet.<br>For non-isochronous IN endpoints: The core<br>stops transmitting any data on an IN<br>endpoint, even if there data is available in the<br>TxFIFO. For isochronous IN endpoints: The<br>core sends out a zero-length data packet,<br>even if there data is available in the TxFIFO.<br>Irrespective of this bit's setting, the core<br>always responds to SETUP data packets with<br>an ACK handshake. |

Rockentr

| Bit | Attr  | Reset Value | Description                                        |
|-----|-------|-------------|----------------------------------------------------|
|     |       |             | DPID                                               |
|     |       |             | Endpoint Data PID                                  |
|     |       |             | Applies to interrupt/bulk IN and OUT               |
|     |       |             | endpoints only. Contains the PID of the packet     |
|     |       |             | to be received or transmitted on this endpoint.    |
|     |       |             |                                                    |
|     |       |             | The application must program the PID of the        |
|     |       |             | first packet to be received or transmitted on      |
|     |       |             | this endpoint, after the endpoint is activated.    |
|     |       |             | The applications use the SetD1PID and              |
|     |       |             | SetD0PID fields of this register to program        |
|     |       |             | either DATA0 or DATA1 PID.                         |
|     |       |             | 1'b0: DATA0                                        |
|     |       |             | 1'b1: DATA1                                        |
|     |       |             | This field is applicable both for Scatter/Gather   |
|     |       |             | DMA mode and non-Scatter/Gather                    |
|     |       |             | DMA mode. Even/Odd (Micro)Frame                    |
|     |       |             | (EO_FrNum) In non-Scatter/Gather DMA               |
| 16  | RO    | 0x0         | mode:                                              |
|     |       |             | Applies to isochronous IN and OUT endpoints        |
|     |       |             | only. Indicates the (micro) frame number in        |
|     |       |             | which the core transmits/receives                  |
|     |       |             | isochronous data for this endpoint. The            |
|     |       |             | application must program the even/odd              |
|     |       |             | (micro) frame number in which it intends to        |
|     |       |             | transmit/receive isochronous data for this         |
|     |       |             | endpoint using the SetEvnFr and SetOddFr           |
|     |       |             | fields in this register.                           |
|     |       |             | 1'b0: Even (micro)frame                            |
|     |       |             | 1'b1: Odd (micro)frame                             |
|     |       | •           | When Scatter/Gather DMA mode is enabled,           |
|     |       |             | this field is reserved. The frame number in        |
|     |       |             | which to send data is provided in the transmit     |
|     |       | Y           | descriptor structure. The frame in which data      |
|     |       |             | is received is updated in receive descriptor       |
|     |       | 1           | structure.                                         |
|     |       |             | USBActEP                                           |
|     |       |             | USB Active Endpoint                                |
|     |       |             | Applies to IN and OUT endpoints. Indicates         |
|     |       |             | whether this endpoint is active in the current     |
|     |       |             | configuration and interface. The core clears       |
| 15  | R/WSC | 0x0         | this bit for all endpoints (other than EP 0) after |
|     |       |             | detecting a USB reset. After receiving the         |
|     |       |             | SetConfiguration and SetInterface                  |
|     |       |             | commands, the application must program             |
|     |       |             | , , , , , , , , , , , , , , , , , , , ,            |
|     |       |             | endpoint registers accordingly and set this bit.   |

| Bit                                                            | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                              |  |
|----------------------------------------------------------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 14:11                                                          | RW   | 0x0         | NextEp<br>Next Endpoint<br>Applies to non-periodic IN endpoints only.<br>Indicates the endpoint number to be fetched<br>after the data for the current endpoint is<br>fetched. The core can access this field, even<br>when the Endpoint Enable (EPEna) bit is low.<br>This field is not valid in Slave mode operation.<br>Note: This field is valid only for Shared FIFO<br>operations. |  |
| 10:0                                                           | RW   | 0x000       | MPS<br>Maximum Packet Size<br>Applies to IN and OUT endpoints. The<br>application must program this field with the<br>maximum packet size for the current logical<br>endpoint. This value is in bytes.                                                                                                                                                                                   |  |
| USBOTG_DOEPCTLO<br>Address: Operational Base + offset (0x0b00) |      |             |                                                                                                                                                                                                                                                                                                                                                                                          |  |

#### USBOTG\_DOEPCTL0

Address: Operational Base + offset (0x0b00) Device control OUT endpoint 0 control register *C* 

| Bit   | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/WSC | •           | EPEna<br>Endpoint Enable<br>When Scatter/Gather DMA mode is enabled,<br>for OUT endpoints this bit indicates that the<br>descriptor structure and data buffer to receive<br>data is setup. When Scatter/Gather DMA<br>mode is disabled? such as for buffer-pointer<br>based DMA mode)-this bit indicates that the<br>application has allocated the memory to<br>start receiving data from the USB. The core<br>clears this bit before setting any of the<br>following interrupts on this endpoint: SETUP<br>Phase Done, Endpoint Disabled, Transfer<br>Completed.<br>Note: In DMA mode, this bit must be set for<br>the core to transfer SETUP data packets into<br>memory. |
| 30    | wo    | 0x0         | EPDis<br>Endpoint Disable<br>The application cannot disable control OUT<br>endpoint 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 29:28 | RO    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 27    | wo    | 0x0         | SNAK<br>Set NAK<br>A write to this bit sets the NAK bit for the<br>endpoint. Using this bit, the application can<br>control the transmission of NAK handshakes<br>on an endpoint. The core can also set bit on a<br>Transfer Completed interrupt, or after a<br>SETUP is received on the endpoint.                                                                                                                                                                                                                                                                                                                                                                          |

| Bit   | Attr                  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                       |             | CNAK                                                                                                                                                                                                                                                                                                                                                              |
| 26    | wo                    | 0x0         | Clear NAK                                                                                                                                                                                                                                                                                                                                                         |
| 20    | WU                    | 0.00        | A write to this bit clears the NAK bit for the                                                                                                                                                                                                                                                                                                                    |
|       |                       |             | endpoint.                                                                                                                                                                                                                                                                                                                                                         |
| 25:22 | RO                    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 21    | R/WSC                 | 0x0         | Stall<br>STALL Handshake<br>The application can only set this bit, and the<br>core clears it, when a SETUP token is received<br>for this endpoint. If a NAK bit or Global OUT<br>NAK is set along with this bit, the STALL bit<br>takes priority. Irrespective of this bit's setting,<br>the core always responds to SETUP data<br>packets with an ACK handshake. |
|       |                       |             | Snp                                                                                                                                                                                                                                                                                                                                                               |
|       |                       |             | Snoop Mode                                                                                                                                                                                                                                                                                                                                                        |
| 20    | RW                    | 0x0         | This bit configures the endpoint to Snoop                                                                                                                                                                                                                                                                                                                         |
|       |                       |             | mode. In Snoop mode, the core does not check the correctness of OUT packets before                                                                                                                                                                                                                                                                                |
|       |                       |             | transferring them to application memory.                                                                                                                                                                                                                                                                                                                          |
|       |                       |             | EPType                                                                                                                                                                                                                                                                                                                                                            |
| 19:18 | RO                    | 0x0         | Endpoint Type                                                                                                                                                                                                                                                                                                                                                     |
|       |                       |             | Hardcoded to 2'b00 for control.                                                                                                                                                                                                                                                                                                                                   |
|       |                       |             | NAKSts                                                                                                                                                                                                                                                                                                                                                            |
|       |                       |             | NAK Status                                                                                                                                                                                                                                                                                                                                                        |
|       |                       |             | Indicates the following:                                                                                                                                                                                                                                                                                                                                          |
|       |                       |             | 1'b0: The core is transmitting non-NAK                                                                                                                                                                                                                                                                                                                            |
|       |                       |             | handshakes based on the FIFO status.                                                                                                                                                                                                                                                                                                                              |
|       |                       |             | 1'b1: The core is transmitting NAK                                                                                                                                                                                                                                                                                                                                |
| 17    | RO                    | 0x0         | handshakes on this endpoint.                                                                                                                                                                                                                                                                                                                                      |
|       |                       |             | When either the application or the core sets this bit, the core stops receiving data, even if                                                                                                                                                                                                                                                                     |
|       |                       | Y           | there is space in the RxFIFO to accommodate                                                                                                                                                                                                                                                                                                                       |
|       |                       |             | the incoming packet.                                                                                                                                                                                                                                                                                                                                              |
|       |                       | 1           | Irrespective of this bit setting, the core always                                                                                                                                                                                                                                                                                                                 |
|       |                       |             | responds to SETUP data packets with an ACK                                                                                                                                                                                                                                                                                                                        |
|       |                       |             | handshake.                                                                                                                                                                                                                                                                                                                                                        |
| 16    | RO                    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                          |
|       | $\mathbf{\nabla}^{-}$ |             | USBActEP                                                                                                                                                                                                                                                                                                                                                          |
|       |                       |             | USB Active Endpoint                                                                                                                                                                                                                                                                                                                                               |
| 15    | RO                    | 0x0         | This bit is always set to 1, indicating that a                                                                                                                                                                                                                                                                                                                    |
|       |                       |             | control endpoint 0 is always active in all                                                                                                                                                                                                                                                                                                                        |
| 14.2  |                       | 00          | configurations and interfaces.                                                                                                                                                                                                                                                                                                                                    |
| 14:2  | RO                    | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                          |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value Description |                                                                              |
|-----|------|-------------------------|------------------------------------------------------------------------------|
|     |      |                         | MPS<br>Maximum Packet Size                                                   |
|     |      |                         | The maximum packet size for control OUT<br>endpoint 0 is the same as what is |
| 1:0 | RO   | 0x0                     | programmed in control IN Endpoint 0.<br>2'b00: 64 bytes                      |
|     |      |                         | 2'b01: 32 bytes                                                              |
|     |      |                         | 2'b10: 16 bytes                                                              |
|     |      |                         | 2'b11: 8 bytes                                                               |

#### USBOTG\_DOEPINTn

| Address: Operational Base + offset (0x0b08)<br>Device endpoint-n control register |      |             |                                                                                          |
|-----------------------------------------------------------------------------------|------|-------------|------------------------------------------------------------------------------------------|
| Bit                                                                               | Attr | Reset Value | Description                                                                              |
| 31:15                                                                             | RO   | 0x0         | reserved                                                                                 |
|                                                                                   |      |             | NYETIntrpt                                                                               |
|                                                                                   |      |             | NYET interrupt                                                                           |
| 14                                                                                | W1C  | 0x0         | The core generates this interrupt when a NYET                                            |
|                                                                                   |      |             | response is transmitted for a non-isochronous                                            |
|                                                                                   |      |             | OUT endpoint.                                                                            |
|                                                                                   |      |             | NAKIntrpt                                                                                |
|                                                                                   |      |             | NAK interrupt                                                                            |
|                                                                                   |      |             | The core generates this interrupt when a NAK                                             |
| 13                                                                                | W1C  | 0x0         | is transmitted or received by the device. In                                             |
|                                                                                   |      |             | case of isochronous IN endpoints the interrupt                                           |
|                                                                                   |      |             | gets generated when a zero length packet is                                              |
|                                                                                   |      |             | transmitted due to un-availability of data in                                            |
|                                                                                   |      |             | the TXFifo.<br>BbleErrIntrpt                                                             |
|                                                                                   |      |             | BbleErr (Babble Error) interrupt                                                         |
| 12                                                                                | W1C  | 0x0         | The core generates this interrupt when babble                                            |
|                                                                                   |      |             | is received for the endpoint.                                                            |
|                                                                                   |      |             | PktDrpSts                                                                                |
|                                                                                   |      | 1           | Packet Dropped Status                                                                    |
|                                                                                   |      |             | This bit indicates to the application that an                                            |
|                                                                                   |      |             | ISOC OUT packet has been dropped. This bit                                               |
| 11                                                                                | W1C  | 0x0         | does not have an associated mask bit and                                                 |
|                                                                                   |      |             | does not generate an interrupt. Dependency:                                              |
|                                                                                   |      |             | This bit is valid in non-Scatter/Gather DMA                                              |
|                                                                                   | -    |             | mode when periodic transfer interrupt feature                                            |
| 10                                                                                |      |             | is selected.                                                                             |
| 10                                                                                | RO   | 0x0         | reserved                                                                                 |
|                                                                                   |      |             | BNAIntr                                                                                  |
|                                                                                   |      |             | BNA (Buffer Not Available) Interrupt                                                     |
| 9                                                                                 | W1C  | 0x0         | The core generates this interrupt when the descriptor accessed is not ready for the Core |
| 7                                                                                 | WIC  |             | to process, such as Host busy or DMA done.                                               |
|                                                                                   |      |             | Dependency: This bit is valid only when                                                  |
|                                                                                   |      |             | Scatter/Gather DMA mode is enabled.                                                      |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | TxfifoUndrn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8   | W1C  | 0×0         | FIFO Underrun<br>Applies to IN endpoints only. The core<br>generates this interrupt when it detects a<br>transmit FIFO under-run condition for this<br>endpoint. Dependency: This interrupt is valid<br>only when both of the following conditions are<br>true: Parameter<br>OTG_EN_DED_TX_FIFO==1, Threshold is<br>enabled, OUT Packet Error (OutPktErr).<br>Applies to OUT endpoints only. This interrupt<br>is asserted when the core detects an overflow<br>or a CRC error for an OUT packet.<br>Dependency: This interrupt is valid only when<br>both of the following conditions are true:<br>Parameter OTG_EN_DED_TX_FIFO==1,<br>Thresholding is enabled.                                                                                                                                                                                                      |
| 7   | W1C  | 0×0         | TxFEmp<br>Transmit FIFO Empty<br>This bit is valid only for IN Endpoints. This<br>interrupt is asserted when the TxFIFO for this<br>endpoint is either half or completely empty.<br>The half or completely empty status is<br>determined by the TxFIFO Empty Level bit in<br>the Core AHB Configuration<br>register(GAHBCFG.NPTxFEmpLvl)).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6   | W1C  | 0×0         | INEPNakEff<br>IN Endpoint NAK Effective<br>Applies to periodic IN endpoints only. This bit<br>can be cleared when the application clears the<br>IN endpoint NAK by writing to<br>DIEPCTLn.CNAK. This interrupt indicates that<br>the core has sampled the NAK bit set (either<br>by the application or by the core). The<br>interrupt indicates that the IN endpoint NAK<br>bit set by the application has taken effect in<br>the core. This interrupt does not guarantee<br>that a NAK handshake is sent on the USB. A<br>STALL bit takes priority over a NAK bit. This bit<br>is applicable only when the endpoint is<br>enabled. Back-to-Back SETUP Packets<br>Received (Back2BackSETup) Applies to<br>Control OUT endpoints only.<br>This bit indicates that the core has received<br>more than three back-to-back SETUP<br>packets for this particular endpoint. |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | INTknEPMis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5   | W1C  | 0x0         | IN Token Received with EP Mismatch<br>Applies to non-periodic IN endpoints only.<br>Indicates that the data in the top of the<br>non-periodic TxFIFO belongs to an endpoint<br>other than the one for which the IN token was<br>received. This interrupt is asserted on the<br>endpoint for which the IN token was received.<br>Status Phase Received For Control Write<br>(StsPhseRcvd)<br>This interrupt is valid only for Control OUT<br>endpoints and only in Scatter Gather DMA<br>mode.                                                                                                                                                                                                          |
| 4   | W1C  | 0x0         | INTknTXFEmp<br>IN Token Received When TxFIFO is Empty<br>Indicates that an IN token was received when<br>the associated TxFIFO periodic/non-periodic)<br>was empty. This interrupt is asserted on the<br>endpoint for which the IN token was received.<br>OUT Token Received When Endpoint Disabled<br>(OUTTknEPdis) Indicates that an OUT token<br>was received when the endpoint was not yet<br>enabled. This interrupt is asserted on the<br>endpoint for which the OUT token was<br>received.                                                                                                                                                                                                      |
| 3   | W1C  | 0×0         | TimeOUT<br>Timeout Condition<br>In shared TX FIFO mode, applies to<br>non-isochronous IN endpoints only. In<br>dedicated FIFO mode, applies only to Control<br>IN endpoints. In Scatter/Gather DMA mode,<br>the Timeout interrupt is not asserted.<br>Indicates that the core has detected a timeout<br>condition on the USB for the last IN token on<br>this endpoint. SETUP Phase Done (SetUp).<br>Applies to control OUT endpoints only.<br>Indicates that the SETUP phase for the control<br>endpoint is complete and no more<br>back-to-back SETUP packets were received<br>for the current control transfer. On this<br>interrupt, the application can decode the<br>received SETUP data packet. |
| 2   | W1C  | 0x0         | AHBErr<br>AHB Error<br>Applies to IN and OUT endpoints. This is<br>generated only in Internal DMA mode when<br>there is an AHB error during an AHB<br>read/write. The application can read the<br>corresponding endpoint DMA address register<br>to get the error address.                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | W1C  | 0x0         | EPDisbld<br>Endpoint Disabled Interrupt<br>Applies to IN and OUT endpoints. This bit<br>indicates that the endpoint is disabled per the<br>application's request.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0   | W1C  | 0×0         | XferCompl<br>Transfer Completed Interrupt<br>Applies to IN and OUT endpoints. When<br>Scatter/Gather DMA mode is enabled<br>For IN endpoint this field indicates that the<br>requested data from the descriptor is moved<br>from external system memory to internal<br>FIFO. For OUT endpoint this field indicates<br>that the requested data from the internal FIFO<br>is moved to external system memory. This<br>interrupt is generated only when the<br>corresponding endpoint descriptor is closed,<br>and the IOC bit for the corresponding<br>descriptor is set. When Scatter/Gather DMA<br>mode is disabled, this field indicates that the<br>programmed transfer is complete on the AHB<br>as well as on the USB, for this endpoint. |

#### USBOTG\_DOEPTSIZn

Address: Operational Base + offset (0x0b10) Device endpoint n transfer size register

Rockey

| Bit | Åttr | <b>Reset Value</b> |          | Description |
|-----|------|--------------------|----------|-------------|
| 31  | RO   | 0x0                | reserved |             |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | ,    | ACCEL FUILE | MC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 30:29 | RW   | 0×0         | Multi Count<br>Applies to IN endpoints only. For periodic IN<br>endpoints, this field indicates the number of<br>packets that must be transmitted per<br>micro-frame on the USB. The core uses this<br>field to calculate the data PID for isochronous<br>IN endpoints.<br>2'b01: 1 packet<br>2'b10: 2 packets<br>2'b11: 3 packets<br>For non-periodic IN endpoints, this field is<br>valid only in Internal DMA mode. It specifies<br>the number of packets the core must fetch for<br>an IN endpoint before it switches to the<br>endpoint pointed to by the Next Endpoint field<br>of the Device Endpoint-n Control register<br>(DIEPCTLn.NextEp). Received Data PID<br>(RxDPID)<br>Applies to isochronous OUT endpoints only.<br>This is the data PID received in the last packet<br>for this endpoint.<br>2'b00: DATA0<br>2'b01: DATA2<br>2'b11: MDATA<br>SETUP Packet Count (SUPCnt).Applies to<br>control OUT Endpoints only. This field<br>specifies the number of back-to-back SETUP<br>data packets the endpoint can receive.<br>2'b01: 1 packet<br>2'b10: 2 packets<br>2'b11: 3 packets |
| 28:19 | RW   | 0×000       | PktCnt<br>Packet Count<br>Indicates the total number of USB packets<br>that constitute the Transfer Size amount of<br>data for this endpoint. The power-on value is<br>specified for Width of Packet Counters<br>(parameter OTG_PACKET_COUNT_WIDTH).<br>IN Endpoints: This field is decremented every<br>time a packet (maximum size or short packet)<br>is read from the TxFIFO. OUT Endpoints: This<br>field is decremented every time a packet<br>(maximum size or short packet) is written to<br>the RxFIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Bit  | Attr                                                           | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0 | RW                                                             | 0×00000     | XferSize<br>Transfer Size<br>This field contains the transfer size in bytes for<br>the current endpoint. The power-on value is<br>specified for Width of Transfer Size Counters<br>(parameter OTG_TRANS_COUNT_WIDTH).<br>The core only interrupts the application after it<br>has exhausted the transfer size amount of<br>data. The transfer size can be set to the<br>maximum packet size of the endpoint, to be<br>interrupted at the end of each packet. IN<br>Endpoints: The core decrements this field<br>every time a packet from the external<br>memory is written to the TxFIFO.<br>OUT Endpoints: The core decrements this<br>field every time a packet is read from the<br>RxFIFO and written to the external memory. |
|      | USBOTG_DOEPDMAn<br>Address: Operational Base + offset (0x0b14) |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### USBOTG\_DOEPDMAn

Address: Operational Base + offset (0x0b14) Device Endpoint-n DMA Address Register

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | RW   | 0×0000000          | DMAAddr<br>DMA Address<br>Holds the start address of the external<br>memory for storing or fetching endpoint<br>data. Note: For control endpoints, this field<br>stores control OUT data packets as well as<br>SETUP transaction data packets. When more<br>than three SETUP packets are received<br>back-to-back, the SETUP data packet in the<br>memory is overwritten.<br>This register is incremented on every AHB<br>transaction. The application can give only a<br>DWORD-aligned address. When<br>Scatter/Gather DMA mode is not enabled, the<br>application programs the start address value<br>in this field. When Scatter/Gather DMA mode<br>is enabled, this field indicates the base pointer<br>for the descriptor list. |

#### USBOTG\_DOEPDMABn

Address: Operational Base + offset (0x0b1c)

Device endpoint-n DMA buffer address register

| Bit Attr Reset Value | Description |
|----------------------|-------------|
|----------------------|-------------|

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000         | DMABufferAddr<br>DMA Buffer Address<br>Holds the current buffer address. This register<br>is updated as and when the data<br>transfer for the corresponding end point is in<br>progress. This register is present only in<br>Scatter/Gather DMA mode. Otherwise this<br>field is reserved. |

#### USBOTG\_DOEPCTLn

Address: Operational Base + offset (0x0b20) Device endpoint-n control register

| Bit | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | R/WSC | 0×0         | EPEna<br>Endpoint Enable<br>Applies to IN and OUT endpoints. When<br>Scatter/Gather DMA mode is enabled,<br>For IN endpoints this bit indicates that the<br>descriptor structure and data buffer with data<br>ready to transmit is setup. For OUT endpoint it<br>indicates that the descriptor structure and<br>data buffer to receive data is setup. When<br>Scatter/Gather DMA mode is enabled-such as<br>for buffer-pointer based DMA mode:<br>For IN endpoints, this bit indicates that data<br>is ready to be transmitted on the<br>endpoint; For OUT endpoints, this bit indicates<br>that the application has allocated the memory<br>to start receiving data from the USB. The core<br>clears this bit before setting any of the<br>following interrupts on this endpoint: SETUP<br>Phase Done, Endpoint Disabled, Transfer<br>Completed. Note: For control endpoints in<br>DMA mode, this bit must be set to be able to<br>transfer SETUP data packets in memory. |
| 30  | R/WSC | 0x0         | EPDis<br>Endpoint Disable<br>Applies to IN and OUT endpoints. The<br>application sets this bit to stop<br>transmitting/receiving data on an endpoint,<br>even before the transfer for that endpoint is<br>complete. The application must wait for the<br>Endpoint Disabled interrupt before treating<br>the endpoint as disabled. The core clears this<br>bit before setting the Endpoint Disabled<br>interrupt. The application must set this bit<br>only if Endpoint Enable is already set for this<br>endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | SetD1PID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 29  | RO   | 0×0         | Field0001 Abstract<br>Applies to interrupt/bulk IN and OUT<br>endpoints only.Writing to this field sets the<br>Endpoint Data PID (DPID) field in this register<br>to DATA1.This field is applicable both for<br>Scatter/Gather DMA mode and<br>non-Scatter/Gather DMA mode. Set Odd<br>(micro) frame (SetOddFr). Applies to<br>isochronous IN and OUT endpoints only.<br>Writing to this field sets the Even/Odd (micro)<br>frame (EO_FrNum) field to odd (micro) frame.<br>This field is not applicable for Scatter/Gather<br>DMA mode.                                                                                                                                                                                                                               |
| 28  | wo   | 0×0         | SetD0PID<br>Set DATA0 PID<br>Applies to interrupt/bulk IN and OUT<br>endpoints only. Writing to this field sets the<br>Endpoint Data PID (DPID) field in this register<br>to DATA0.This field is applicable both for<br>Scatter/Gather DMA mode and<br>non-Scatter/Gather DMA mode. In<br>non-Scatter/Gather DMA mode: Set Even<br>(micro) frame (SetEvenFr) Applies to<br>isochronous IN and OUT endpoints only.<br>Writing to this field sets the Even/Odd (micro)<br>frame (EO_FrNum) field to even (micro)<br>frame. When Scatter/Gather DMA mode is<br>enabled, this field is reserved. The frame<br>number in which to send data is in the<br>transmit descriptor structure. The frame in<br>which to receive data is updated in recept<br>descriptor structure. |
| 27  | wo   | 0×0         | SNAK<br>Set NAK<br>Applies to IN and OUT endpoints. A write to<br>this bit sets the NAK bit for the endpoint.<br>Using this bit, the application can control the<br>transmission of NAK handshakes on an<br>endpoint. The core can also set this bit for OUT<br>endpoints on a Transfer Completed interrupt,<br>or after a SETUP is received on the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                          |
| 26  | wo   | 0×0         | CNAK<br>Clear NAK<br>Applies to IN and OUT endpoints. A write to<br>this bit clears the NAK bit for the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit                    | Attr | Reset Value | Description                                                                              |
|------------------------|------|-------------|------------------------------------------------------------------------------------------|
|                        |      |             | TxFNum                                                                                   |
|                        |      |             | TxFIFO Number                                                                            |
|                        |      |             | Shared FIFO Operation: non-periodic                                                      |
|                        |      |             | endpoints must set this bit to zero. Periodic                                            |
|                        |      |             | endpoints must map this to the corresponding                                             |
|                        |      |             | Periodic TxFIFO number. 4'h0: Non-Periodic                                               |
|                        |      |             | TxFIFO; Others: Specified Periodic TxFIFO                                                |
|                        |      |             | number. Note: An interrupt IN endpoint can                                               |
|                        |      |             | be configured as a non-periodic endpoint for                                             |
|                        |      |             | applications such as mass storage. The core                                              |
|                        |      |             | treats an IN endpoint as a non-periodic                                                  |
| 25:22                  | RW   | 0x0         | endpoint if the TxFNum field is set to 0.                                                |
|                        |      |             | Otherwise, a separate periodic FIFO must be                                              |
|                        |      |             | allocated for an interrupt IN endpoint using                                             |
|                        |      |             | coreConsultant, and the number of this FIFO                                              |
|                        |      |             | must be programmed into the TxFNum field.                                                |
|                        |      |             | Configuring an interrupt IN endpoint as a non-periodic endpoint saves the extra periodic |
|                        |      |             | FIFO area. Dedicated FIFO Operation: these                                               |
|                        |      |             | bits specify the FIFO number associated with                                             |
|                        |      |             | this endpoint. Each active IN endpoint must                                              |
|                        |      |             | be programmed to a separate FIFO number.                                                 |
|                        |      |             | This field is valid only for IN endpoints.                                               |
|                        |      |             | Stall                                                                                    |
|                        |      |             | STALL Handshake                                                                          |
|                        |      |             | Applies to non-control, non-isochronous IN                                               |
|                        |      |             | and OUT endpoints only. The application sets                                             |
|                        |      |             | this bit to stall all tokens from the USB host to                                        |
|                        |      | C           | this endpoint. If a NAK bit, Global                                                      |
|                        |      | • •         | Non-periodic IN NAK, or Global OUT NAK is set                                            |
|                        |      |             | along with this bit, the STALL bit takes                                                 |
| 21                     | RW   |             | priority. Only the application can clear this bit, never the core.                       |
| 21                     | RW   | 0x0         | Applies to control endpoints only. The                                                   |
|                        |      |             | application can only set this bit, and the core                                          |
|                        |      |             | clears it, when a SETUP token is received for                                            |
|                        | C    |             | this endpoint. If a NAK bit, Global                                                      |
|                        |      |             | Non-periodic IN NAK, or Global OUT NAK is set                                            |
|                        |      |             | along with this bit, the STALL bit takes                                                 |
| $\boldsymbol{\lambda}$ |      |             | priority. Irrespective of this bit's setting, the                                        |
|                        |      |             | core always responds to SETUP data packets                                               |
| Y                      |      |             | with an ACK handshake.                                                                   |
|                        |      |             | Snp                                                                                      |
|                        |      |             | Snoop Mode                                                                               |
|                        |      |             | Applies to OUT endpoints only. This bit                                                  |
| 20                     | RW   | 0x0         | configures the endpoint to Snoop mode. In                                                |
|                        |      |             | Snoop mode, the core does not check the                                                  |
|                        |      |             | correctness of OUT packets before                                                        |
|                        |      |             | transferring them to application memory.                                                 |

| Bit   | Attr | Reset Value | Description                                                                                      |
|-------|------|-------------|--------------------------------------------------------------------------------------------------|
|       |      |             | ЕРТуре                                                                                           |
|       |      |             | Endpoint Type<br>Applies to IN and OUT endpoints. This is the                                    |
|       |      |             | transfer type supported by this logical                                                          |
| 19:18 | RW   | 0x0         | endpoint.                                                                                        |
|       |      |             | 2'b00: Control                                                                                   |
|       |      |             | 2'b01: Isochronous<br>2'b10: Bulk                                                                |
|       |      |             | 2'b11: Interrupt                                                                                 |
|       |      |             | NAKSts                                                                                           |
|       |      |             | NAK Status                                                                                       |
|       |      |             | Applies to IN and OUT endpoints. Indicates                                                       |
|       |      |             | the following:<br>1'b0: The core is transmitting non-NAK                                         |
|       |      |             | handshakes based on the FIFO status.                                                             |
| 17    | RO   | 0x0         | 1'b1: The core is transmitting NAK                                                               |
|       |      |             | handshakes on this endpoint.                                                                     |
|       |      |             | When either the application or the core sets                                                     |
|       |      |             | this bit: The core stops receiving any data on<br>an OUT endpoint, even if there is space in the |
|       |      |             | RxFIFO to accommodate the incoming packet.                                                       |
|       |      |             |                                                                                                  |
|       |      |             |                                                                                                  |
|       |      |             | A Y                                                                                              |
|       |      |             | $\sim$ O'                                                                                        |
|       |      |             |                                                                                                  |
|       |      |             |                                                                                                  |
|       |      |             |                                                                                                  |
|       |      | •           | )                                                                                                |
|       |      |             | Y                                                                                                |
|       |      | Y           |                                                                                                  |
|       |      |             |                                                                                                  |
|       |      | 1           |                                                                                                  |
|       | C    | Y           |                                                                                                  |
|       |      |             |                                                                                                  |
|       |      | J.C.        |                                                                                                  |
|       |      |             |                                                                                                  |
|       |      |             |                                                                                                  |
|       |      |             |                                                                                                  |
|       |      |             |                                                                                                  |
|       |      |             |                                                                                                  |

| Bit | Attr  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16  | RO    | 0x0         | DPID<br>Endpoint Data PID<br>Applies to interrupt/bulk IN and OUT<br>endpoints only. Contains the PID of the packet<br>to be received or transmitted on this endpoint.<br>The application must program the PID of the<br>first packet to be received or transmitted on<br>this endpoint, after the endpoint is activated.<br>The applications use the SetD1PID and<br>SetD0PID fields of this register to program<br>either DATA0 or DATA1 PID.<br>1'b0: DATA0<br>1'b1: DATA1<br>This field is applicable both for Scatter/Gather<br>DMA mode and non-Scatter/Gather<br>DMA mode. Even/Odd (Micro) Frame<br>(EO_FrNum). In non-Scatter/Gather DMA<br>mode: Applies to isochronous IN and OUT<br>endpoints only. Indicates the (micro) frame<br>number in which the core transmits/receives<br>isochronous data for this endpoint. The<br>application must program the even/odd<br>(micro) frame number in which it intends to<br>transmit/receive isochronous data for this<br>endpoint using the SetEvnFr and SetOddFr<br>fields in this register.<br>1'b0: Even (micro)frame<br>1'b1: Odd (micro)frame<br>1'b1: Odd (micro)frame<br>When Scatter/Gather DMA mode is enabled,<br>this field is reserved. The frame number in<br>which to send data is provided in the transmit<br>descriptor structure. The frame in which data<br>is received is updated in receive descriptor<br>structure. |
| 15  | R/WSC | 0×0         | USBActEP<br>USB Active Endpoint<br>Applies to IN and OUT endpoints. Indicates<br>whether this endpoint is active in the current<br>configuration and interface. The core clears<br>this bit for all endpoints (other than EP 0) after<br>detecting a USB reset. After receiving the<br>SetConfiguration and SetInterface<br>commands, the application must program<br>endpoint registers accordingly and set this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                              |  |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 14:11 | RW   | 0x0                | NextEp<br>Next Endpoint<br>Applies to non-periodic IN endpoints only.<br>Indicates the endpoint number to be fetched<br>after the data for the current endpoint is<br>fetched. The core can access this field, even<br>when the Endpoint Enable (EPEna) bit is low.<br>This field is not valid in Slave mode operation.<br>Note: This field is valid only for Shared FIFO<br>operations. |  |
| 10:0  | RW   | 0x000              | MPS<br>Maximum Packet Size<br>Applies to IN and OUT endpoints. The<br>application must program this field with the<br>maximum packet size for the current logical<br>endpoint. This value is in bytes.                                                                                                                                                                                   |  |

#### USBOTG\_PCGCR

Address: Operational Base + offset (0x0b24) Power and clock gating control register

octor

| Bit | Attr | <b>Reset Value</b> | Description |  |  |
|-----|------|--------------------|-------------|--|--|
|     |      |                    |             |  |  |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| 31:14       RW       0x0802e       Restore Value<br>Restore Value<br>(Applicable only when Hibernation is enabled<br>(OTG_EN_PWROPT=2). Defines port clock<br>select for different speeds.<br>[31] if_dev_mode<br>- 1: Device mode, core restored as device<br>- 0: Host mode, core restored as host<br>[30:29] p2hd_prt_spd (PRT speed)<br>- 00: HS<br>- 01: FS<br>- 10: LS<br>- 11: Reserved<br>[28:27] p2hd_dev_enum_spd (Device<br>enumerated speed)<br>- 00: HS<br>- 01: FS (30/60 MHz clock)<br>- 10: LS<br>- 11: FS (48 MHz clock)<br>[26:20] mac_dev_addr (MAC device address)<br>Device address<br>[19] mac_termselect (Termination selection)<br>- 0: HS_TERM (Program for High Speed)<br>- 11: FS_TERM (Program for High Speed)<br>- 11: FS_TERM (Program for Full Speed)<br>[18:17] mac_xcvrselect (Transceiver select)<br>- 00: HS_XCVR (High Speed)<br>- 01: FS_XCVR (High Speed)<br>- 10: LS_XCVR (Kull Speed)<br>- 11: LFS_XCVR (Reserved)<br>[16] sh2pl_prt_ctl[0]<br>- 1: port_power enabled<br>- 0: port_power disabled<br>[15:14] prt_ck_sel (Refer prt_clk_sel table)<br>EssRegRestored<br>Essential Register Values Restored<br>(Applicable only when Hibernation is enabled<br>(Applicable only when Hibernation is enab | Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13RW0x0EssRegRestored<br>Essential Register Values Restored<br>(Applicable only when Hibernation is enabled<br>(OTG_EN_PWROPT=2). When a value of 1 is<br>written to this field, it indicates that register<br>values of essential registers have been                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |      |             | RestoreValue<br>Restore Value<br>(Applicable only when Hibernation is enabled<br>(OTG_EN_PWROPT=2). Defines port clock<br>select for different speeds.<br>[31] if_dev_mode<br>- 1: Device mode, core restored as device<br>- 0: Host mode, core restored as host<br>[30:29] p2hd_prt_spd (PRT speed)<br>- 00: HS<br>- 01: FS<br>- 10: LS<br>- 11: Reserved<br>[28:27] p2hd_dev_enum_spd (Device<br>enumerated speed)<br>- 00: HS<br>- 01: FS (30/60 MHz clock)<br>- 10: LS<br>- 11: FS (30/60 MHz clock)<br>- 10: LS<br>- 11: FS (48 MHz clock)<br>[26:20] mac_dev_addr (MAC device address)<br>Device address<br>[19] mac_termselect (Termination selection)<br>- 0: HS_TERM (Program for High Speed)<br>- 1: FS_TERM (Program for Full Speed)<br>[18:17] mac_xcvrselect (Transceiver select)<br>- 00: HS_XCVR (High Speed)<br>- 01: FS_XCVR (High Speed)<br>- 11: LFS_XCVR (Reserved)<br>[16] sh2pl_prt_ctl[0]<br>- 1: port_power enabled<br>- 0: port_power disabled |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 13    | RW   | 0×0         | EssRegRestored<br>Essential Register Values Restored<br>(Applicable only when Hibernation is enabled<br>(OTG_EN_PWROPT=2). When a value of 1 is<br>written to this field, it indicates that register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12:10 RO 0x0 reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 12:10 | RO   | 0x0         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Attr              | Reset Value                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |                            | RestoreMode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                   |                            | Restore Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            | (Applicable only when Hibernation is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            | (OTG_EN_PWROPT=2). The application                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                   |                            | should program this bit to specify the restore                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   |                            | mode during RESTORE POINT before                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                   |                            | programming PCGCCTL.EssRegRest bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RO                | 0x0                        | Host Mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                   |                            | 1'b0: Host Initiated Resume, Host Initiated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                   |                            | Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                   |                            | 1'b1: Device Initiated Remote Wake up                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                   |                            | Device Mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            | 1'b0: Device Initiated Remote Wake up                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                   |                            | 1'b1: Host Initiated Resume, Host Initiated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                   |                            | Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                   |                            | ResetAfterSusp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   |                            | Reset After Suspend                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   |                            | Applicable in Partial power-down mode. In                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                   |                            | partial power-down mode of operation, this bit needs to be set in host mode before clamp is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                   |                            | removed if the host needs to issue reset after                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   |                            | suspend. If this bit is not set, then the host                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| RW                | 0x0                        | issues resume after suspend. This bit is not                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            | applicable in device mode and non-partial                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                   |                            | power-down mode. In Hibernation mode, this                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                   |                            | bit needs to be set at RESTORE POINT before                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                   |                            | PCGCCTL.EssRegRestored is set. In this case,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            | PCGCCTL.restore_mode needs to be set to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                   |                            | wait_restore.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| RO                | • 🔨                        | L1Suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                   | 0×0                        | Deep Sleep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                   | 0×0                        | This bit indicates that the PHY is in deep sleep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                   |                            | when in L1 state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                   |                            | PhySleep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RO                | 0x0                        | PHY in Sleep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            | This bit indicates that the PHY is in the Sleep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   |                            | state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| $\frown$          |                            | Enbl_L1Gating                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| $\mathbf{\nabla}$ | 0.40                       | Enable Sleep Clock Gating                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DW/               |                            | When this bit is set, core internal clock gating                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| rt vv             | UXU                        | is enabled in Sleep state if the core cannot assert utmi_l1_suspend_n. When this bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                   |                            | not set, the PHY clock is not gated in Sleep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            | state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RO                | 0x0                        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                   |                            | RstPdwnModule                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                   |                            | Reset Power-Down Modules                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RW                | 0×0                        | This bit is valid only in Partial Power-Down                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            | mode. The application sets this bit when the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            | power is turned off. The application clears this                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                   |                            | bit after the power is turned on and the PHY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | RO<br>RW<br>RO<br>RO<br>RO | RO 0x0 RW 0x0 RO |

Rockchip RK3128 Technical Reference Manual Rev 1.0

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | RW   | 0x0         | PwrClmp<br>Power Clamp<br>This bit is valid only in Partial Power-Down<br>mode (OTG_EN_PWROPT = 1). The<br>application sets this bit before the power is<br>turned off to clamp the signals between the<br>power-on modules and the power-off<br>modules. The application clears the bit to<br>disable the clamping before the power is<br>turned on. |
| 1   | RW   | 0x0         | GateHclk<br>Gate Hclk<br>The application sets this bit to gate hclk to<br>modules other than the AHB Slave and<br>Master and wakeup logic when the USB is<br>suspended or the session is not valid.<br>The application clears this bit when the USB is<br>resumed or a new session starts.                                                            |
| 0   | RW   | 0x0         | StopPclk<br>Stop Pclk<br>The application sets this bit to stop the PHY<br>clock (phy_clk) when the USB is<br>suspended, the session is not valid, or the<br>device is disconnected. The application clears<br>this bit when the USB is resumed or a new<br>session starts.                                                                            |

### 26.7 Interface description

Table 26-1 USB OTG 2.0 Interface Description

| Module Pin | Direction | Pad Name   | pinmux |
|------------|-----------|------------|--------|
| VSSA       | AG        | VSSA       | -      |
| VCCA3P3    | AP        | VCCA3P3    | -      |
| VCCCORE1P2 | AP        | VCCCORE1P2 | -      |
| USBOPN     | A         | USBOPN     | -      |
| USBRBIAS   | А         | USBRBIAS   | -      |
| USB0PP     | A         | USBOPP     | -      |
| VBUS_0     | А         | VBUS_0     | -      |
| USB0ID     | A         | USB0ID     | -      |

**Note: A**—Analog pad ; **AP**—Analog power; **AG**—Analog ground ;**DP**—Digital power ;**DG**–Digital ground;

### 26.8 Application Note

#### 26.8.1 Resume from Suspend Mode



When COMMONONN = 1'b1, T1 < T0 + 805 us When COMMONONN = 1'b0, T1 < T0 + 16 us

### 26.8.2 Reset a port

Because the assertion of PORTRESET can occur during data reception or transmission, PORTRESET must be de-asserted as follows:

- Reception:
- ◆ FS device: After a minimum of 3 µs of stable SE0 on LINESTATE [1:0]
- FS/LS host: After a minimum of 8 bit times of J state on LINESTATE [1:0]
- ♦ HS host/device: A minimum of 150 µs after asserting PORTRESET
- Transmission:

+ FS device: After the controller sets both TXVALID and TXVALIDH to 1'b0, followed by a minimum of 3  $\mu$ s of stable SE0 on LINESTATE [1:0]

◆ FS/LS host: After the controller sets both TXVALID0 and TXVALIDH0 to 1'b0, followed by a minimum of 8 bit times of J state on LINESTATE [1:0]

♦ HS host/device: A minimum of 150 µs after the controller sets both TXVALID0 and TXVALIDH0 to 1'b0. The preceding requirements ensure that there is no activity on the USB when PORTRESET0 is de-asserted.

To avoid any data glitches during port reset, the controller must place the USB 2.0 PHY into a safe state. A safe state for host and device ports is defined as follows:

\* Host: The USB 2.0 PHY is set to Non-Driving (OPMODE [1:0] = 2'b01), and the 15-kΩ pull-down resistors are enabled (DPPULLDOWN and

#### DMPULLDOWN = 1'b1).

♦ Device: The USB 2.0 PHY is set to Non-Driving (OPMODE [1:0] = 2'b01), which disconnects the 1.5-kΩ resistor from the D+ line.



CRU\_SOFTRST4\_CON contains the OTG reset signal. Please refer to "Chapter CRU" for more details.

#### 26.8.3 Relative GRF Registers

 $\label{eq:GRF_UOC0_CON0} $$ \ \mbox{GRF}_UOC0_CON2$ is OTG PHY register. $$ GRF_UOC0_CON3$ is OTG Controller register. $$ Please refer to ``Chapter GRF'' for more details. $$ \end{tabular}$ 

ontidentia