#### Bit 17 NAKSTS: NAK status

It indicates the following:

0: The core is transmitting non-NAK handshakes based on the FIFO status.

1: The core is transmitting NAK handshakes on this endpoint.

When either the application or the core sets this bit:

For non-isochronous IN endpoints: The core stops transmitting any data on an IN endpoint, even if there are data available in the TxFIFO.

For isochronous IN endpoints: The core sends out a zero-length data packet, even if there are data available in the TxFIFO.

Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.

#### Bit 16 EONUM: Even/odd frame

Applies to isochronous IN endpoints only.

Indicates the frame number in which the core transmits/receives isochronous data for this endpoint. The application must program the even/odd frame number in which it intends to transmit/receive isochronous data for this endpoint using the SEVNFRM and SODDFRM fields in this register.

0: Even frame

1: Odd frame

**DPID:** Endpoint data PID

Applies to interrupt/bulk IN 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 application uses the SD0PID register field to program either DATA0 or DATA1 PID.

0: DATA0

1: DATA1

#### Bit 15 **USBAEP:** USB active endpoint

Indicates whether this endpoint is active in the current configuration and interface. The core clears 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.

Bits 14:11 Reserved, must be kept at reset value.

#### Bits 10:0 MPSIZ: Maximum packet size

The application must program this field with the maximum packet size for the current logical endpoint. This value is in bytes.



# OTG\_FS device control OUT endpoint 0 control register (OTG\_FS\_DOEPCTL0)

Address offset: 0xB00

Reset value: 0x0000 8000

This section describes the OTG\_FS\_DOEPCTL0 register. Nonzero control endpoints use registers for endpoints 1–3.

| 31    | 30    | 29 | 28      | 27   | 26   | 25 | 24   | 23    | 22 | 21    | 20   | 19              | 18  | 17     | 16      | 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7  | 6 | 5 | 4 | 3 | 2 | 1  | 0   |
|-------|-------|----|---------|------|------|----|------|-------|----|-------|------|-----------------|-----|--------|---------|--------|----|----|----|----|----|----|-------|----|---|---|---|---|---|----|-----|
| EPENA | EPDIS |    | eseiveu | SNAK | CNAK |    | Rese | erved | I  | Stall | MANS | EP <sup>.</sup> | TYP | NAKSTS | eserved | USBAEP |    |    |    |    |    | Re | eserv | ed |   |   |   |   |   | MP | SIZ |
| w     | r     | ٥  | C       | w    | w    |    |      |       |    | rs    | rw   | r               | r   | r      | Я       | r      |    |    |    |    |    |    |       |    |   |   |   |   |   | r  | r   |

#### Bit 31 EPENA: Endpoint enable

The application sets this bit to start transmitting data on endpoint 0.

The core clears this bit before setting any of the following interrupts on this endpoint:

- SETUP phase done
- Endpoint disabled
- Transfer completed

#### Bit 30 EPDIS: Endpoint disable

The application cannot disable control OUT endpoint 0.

Bits 29:28 Reserved, must be kept at reset value.

#### Bit 27 SNAK: Set NAK

A write to this bit sets the NAK bit for the endpoint.

Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set this bit on a Transfer completed interrupt, or after a SETUP is received on the endpoint.

#### Bit 26 CNAK: Clear NAK

A write to this bit clears the NAK bit for the endpoint.

- Bits 25:22 Reserved, must be kept at reset value.
  - Bit 21 STALL: STALL handshake

The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit 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 with an ACK handshake.

Bit 20 SNPM: Snoop mode

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.

#### Bits 19:18 **EPTYP:** Endpoint type

Hardcoded to 2'b00 for control.



#### Bit 17 NAKSTS: NAK status

Indicates the following:

0: The core is transmitting non-NAK handshakes based on the FIFO status.

1: The core is transmitting NAK handshakes on this endpoint.

When either the application or the core sets this bit, the core stops receiving data, even if there is space in the RxFIFO to accommodate the incoming packet. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.

Bit 16 Reserved, must be kept at reset value.

#### Bit 15 USBAEP: USB active endpoint

This bit is always set to 1, indicating that a control endpoint 0 is always active in all configurations and interfaces.

Bits 14:2 Reserved, must be kept at reset value.

#### Bits 1:0 MPSIZ: Maximum packet size

The maximum packet size for control OUT endpoint 0 is the same as what is programmed in control IN endpoint 0.

- 00: 64 bytes
- 01: 32 bytes
- 10: 16 bytes
- 11:8 bytes

# OTG\_FS device endpoint-x control register (OTG\_FS\_DOEPCTLx) (x = 1..3, where x = Endpoint\_number)

Address offset for OUT endpoints:  $0xB00 + (Endpoint_number \times 0x20)$ 

Reset value: 0x0000 0000

The application uses this register to control the behavior of each logical endpoint other than endpoint 0.

| 31    | 30    | 29             | 28             | 27   | 26   | 25 | 24   | 23    | 22 | 21        | 20   | 19    | 18 | 17     | 16         | 15     | 14 | 13   | 12    | 11 | 10 | 9  | 8  | 7  | 6  | 5    | 4  | 3  | 2  | 1  | 0  |
|-------|-------|----------------|----------------|------|------|----|------|-------|----|-----------|------|-------|----|--------|------------|--------|----|------|-------|----|----|----|----|----|----|------|----|----|----|----|----|
| EPENA | EPDIS | SODDFRM/SD1PID | SD0PID/SEVNFRM | SNAK | CNAK |    | Rese | erved | I  | Stall     | SNPM | EDTVD | _  | NAKSTS | EONUM/DPID | USBAEP |    | Rese | erved | 1  |    |    |    |    | N  | 1PSI | Z  |    |    |    |    |
| rs    | rs    | w              | w              | w    | w    |    |      |       |    | rw/<br>rs | rw   | rw    | rw | r      | r          | rw     |    |      |       |    | rw | rw | rw | rw | rw | rw   | rw | rw | rw | rw | rw |

Bit 31 **EPENA:** Endpoint enable

Applies to IN and OUT endpoints.

The application sets this bit to start transmitting data on an endpoint.

The core clears this bit before setting any of the following interrupts on this endpoint:

- SETUP phase done
- Endpoint disabled
- Transfer completed



#### Bit 30 EPDIS: Endpoint disable

The application sets this bit to stop transmitting/receiving data on an endpoint, even before the transfer for that endpoint is complete. The application must wait for the Endpoint disabled interrupt before treating the endpoint as disabled. The core clears this bit before setting the Endpoint disabled interrupt. The application must set this bit only if Endpoint enable is already set for this endpoint.

#### Bit 29 SD1PID: Set DATA1 PID

Applies to interrupt/bulk IN and OUT endpoints only. Writing to this field sets the endpoint data PID (DPID) field in this register to DATA1.

#### SODDFRM: Set odd frame

Applies to isochronous IN and OUT endpoints only. Writing to this field sets the Even/Odd frame (EONUM) field to odd frame.

#### Bit 28 SD0PID: Set DATA0 PID

Applies to interrupt/bulk OUT endpoints only. Writing to this field sets the endpoint data PID (DPID) field in this register to DATA0.

#### SEVNFRM: Set even frame

Applies to isochronous OUT endpoints only. Writing to this field sets the Even/Odd frame (EONUM) field to even frame.

#### Bit 27 SNAK: Set NAK

A write to this bit sets the NAK bit for the endpoint. Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set this bit for OUT endpoints on a Transfer Completed interrupt, or after a SETUP is received on the endpoint.

#### Bit 26 CNAK: Clear NAK

A write to this bit clears the NAK bit for the endpoint.

- Bits 25:22 Reserved, must be kept at reset value.
  - Bit 21 STALL: STALL handshake

Applies to non-control, non-isochronous OUT endpoints only (access type is rw). The application sets this bit to stall all tokens from the USB host to this endpoint. If a NAK bit, Global IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Only the application can clear this bit, never the core.

#### Applies to control endpoints only (access type is rs).

The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit, Global 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 with an ACK handshake.

#### Bit 20 SNPM: Snoop mode

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.

#### Bits 19:18 EPTYP: Endpoint type

This is the transfer type supported by this logical endpoint.

- 00: Control
- 01: Isochronous
- 10: Bulk
- 11: Interrupt



#### Bit 17 NAKSTS: NAK status

Indicates the following:

0: The core is transmitting non-NAK handshakes based on the FIFO status.

1: 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 an OUT endpoint, even if there is space in the RxFIFO to accommodate the incoming packet.

Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.

#### Bit 16 **EONUM:** Even/odd frame

Applies to isochronous IN and OUT endpoints only.

Indicates the frame number in which the core transmits/receives isochronous data for this endpoint. The application must program the even/odd frame number in which it intends to transmit/receive isochronous data for this endpoint using the SEVNFRM and SODDFRM fields in this register.

0: Even frame

1: Odd frame

DPID: Endpoint data PID

Applies to interrupt/bulk 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 application uses the SD0PID register field to program either DATA0 or DATA1 PID.

0: DATA0

1: DATA1

#### Bit 15 **USBAEP:** USB active endpoint

Indicates whether this endpoint is active in the current configuration and interface. The core clears 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.

#### Bits 14:11 Reserved, must be kept at reset value.

#### Bits 10:0 MPSIZ: Maximum packet size

The application must program this field with the maximum packet size for the current logical endpoint. This value is in bytes.



# OTG\_FS device endpoint-x interrupt register (OTG\_FS\_DIEPINTx) (x = 0..3, where $x = Endpoint_number$ )

Address offset: 0x908 + (Endpoint\_number × 0x20)

Reset value: 0x0000 0080

This register indicates the status of an endpoint with respect to USB- and AHB-related events. It is shown in *Figure 350*. The application must read this register when the IN endpoints interrupt bit of the Core interrupt register (IEPINT in OTG\_FS\_GINTSTS) is set. Before the application can read this register, it must first read the device all endpoints interrupt (OTG\_FS\_DAINT) register to get the exact endpoint number for the Device endpoint-x interrupt register. The application must clear the appropriate bit in this register to clear the corresponding bits in the OTG\_FS\_DAINT and OTG\_FS\_GINTSTS registers.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19    | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6                | 5     | 4         | 3         | 2      | 1         | 0         |
|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|---|---|------|------------------|-------|-----------|-----------|--------|-----------|-----------|
|    |    |    |    |    |    |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |    |    |   |   | TXFE | INEPNE           | erved | ITTXFE    | TOC       | erved  | EPDISD    | XFRC      |
|    |    |    |    |    |    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |    |    |   |   | r    | rc_<br>w1<br>/rw | ese   | rc_<br>w1 | rc_<br>w1 | 0<br>O | rc_<br>w1 | rc_<br>w1 |

Bits 31:8 Reserved, must be kept at reset value.

Bit 7 **TXFE:** Transmit FIFO empty

This interrupt is asserted when the TxFIFO for this endpoint is either half or completely empty. The half or completely empty status is determined by the TxFIFO Empty Level bit in the OTG\_FS\_GAHBCFG register (TXFELVL bit in OTG\_FS\_GAHBCFG).

Bit 6 INEPNE: IN endpoint NAK effective

This bit can be cleared when the application clears the IN endpoint NAK by writing to the CNAK bit in OTG\_FS\_DIEPCTLx.

This interrupt indicates that the core has sampled the NAK bit set (either by the application or by the core). The interrupt indicates that the IN endpoint NAK bit set by the application has taken effect in the core.

This interrupt does not guarantee that a NAK handshake is sent on the USB. A STALL bit takes priority over a NAK bit.

- Bit 5 Reserved, must be kept at reset value.
- Bit 4 **ITTXFE:** IN token received when TxFIFO is empty

Applies to non-periodic IN endpoints only.

Indicates that an IN token was received when the associated TxFIFO (periodic/non-periodic) was empty. This interrupt is asserted on the endpoint for which the IN token was received.

Bit 3 TOC: Timeout condition

Applies only to Control IN endpoints.

Indicates that the core has detected a timeout condition on the USB for the last IN token on this endpoint.

Bit 2 Reserved, must be kept at reset value..

#### Bit 1 EPDISD: Endpoint disabled interrupt

This bit indicates that the endpoint is disabled per the application's request.

#### Bit 0 XFRC: Transfer completed interrupt

This field indicates that the programmed transfer is complete on the AHB as well as on the USB, for this endpoint.



# OTG\_FS device endpoint-x interrupt register (OTG\_FS\_DOEPINTx) (x = 0..3, where $x = Endpoint_number$ )

Address offset: 0xB08 + (Endpoint\_number × 0x20)

Reset value: 0x0000 0080

This register indicates the status of an endpoint with respect to USB- and AHB-related events. It is shown in *Figure 350*. The application must read this register when the OUT Endpoints Interrupt bit of the OTG\_FS\_GINTSTS register (OEPINT bit in OTG\_FS\_GINTSTS) is set. Before the application can read this register, it must first read the OTG\_FS\_DAINT register to get the exact endpoint number for the OTG\_FS\_DOEPINTx register. The application must clear the appropriate bit in this register to clear the corresponding bits in the OTG\_FS\_DAINT and OTG\_FS\_GINTSTS registers.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19    | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6              | 5        | 4 | 3        | 2        | 1 | 0       |
|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|---|---|----------|----------------|----------|---|----------|----------|---|---------|
|    |    |    |    |    |    |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |    |    |   |   | Reserved | k, k J B2BSTUP | Reserved |   | ≰ a STUP | Reserved |   | LA XFRC |

Bits 31:7 Reserved, must be kept at reset value.

#### Bit 6 B2BSTUP: Back-to-back SETUP packets received

Applies to control OUT endpoint only. This bit indicates that the core has received more than three back-to-back SETUP packets for this particular endpoint.

- Bit 5 Reserved, must be kept at reset value.
- Bit 4 OTEPDIS: OUT token received when endpoint disabled

Applies only to control OUT endpoints.

Indicates that an OUT token was received when the endpoint was not yet enabled. This interrupt is asserted on the endpoint for which the OUT token was received.

#### Bit 3 STUP: SETUP phase done

Applies to control OUT endpoint only.

Indicates that the SETUP phase for the control endpoint is complete and no more back-toback SETUP packets were received for the current control transfer. On this interrupt, the application can decode the received SETUP data packet.

- Bit 2 Reserved, must be kept at reset value.
- Bit 1 **EPDISD:** Endpoint disabled interrupt

This bit indicates that the endpoint is disabled per the application's request.

Bit 0 XFRC: Transfer completed interrupt

This field indicates that the programmed transfer is complete on the AHB as well as on the USB, for this endpoint.



### OTG\_FS device IN endpoint 0 transfer size register (OTG\_FS\_DIEPTSIZ0)

Address offset: 0x910

Reset value: 0x0000 0000

The application must modify this register before enabling endpoint 0. Once endpoint 0 is enabled using the endpoint enable bit in the device control endpoint 0 control registers (EPENA in OTG\_FS\_DIEPCTL0), the core modifies this register. The application can only read this register once the core has cleared the Endpoint enable bit.

Nonzero endpoints use the registers for endpoints 1–3.

| 31 | 30 | 29 | 28 | 27 | 26    | 25   | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 | 15 | 14 | 13   | 12    | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4  | 3   | 2  | 1  | 0  |
|----|----|----|----|----|-------|------|----|----|----|----|-----|-----|----|----|----|----|----|------|-------|----|----|---|---|---|----|----|----|-----|----|----|----|
|    |    |    |    | D. |       | (a.d |    |    |    |    | PKT | CNT |    |    |    |    |    | Deer |       | J  |    |   |   |   |    |    | Х  | FRS | IZ |    |    |
|    |    |    |    | R  | eserv | /eu  |    |    |    |    | rw  | rw  |    |    |    |    |    | Rese | ervec | 1  |    |   |   |   | rw | rw | rw | rw  | rw | rw | rw |

Bits 31:21 Reserved, must be kept at reset value.

Bits 20:19 PKTCNT: Packet count

Indicates the total number of USB packets that constitute the Transfer Size amount of data for endpoint 0.

This field is decremented every time a packet (maximum size or short packet) is read from the TxFIFO.

- Bits 18:7 Reserved, must be kept at reset value.
- Bits 6:0 XFRSIZ: Transfer size

Indicates the transfer size in bytes for endpoint 0. The core interrupts the application only after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet. The core decrements this field every time a packet from the external memory is written to the TxFIFO.



#### OTG\_FS device OUT endpoint 0 transfer size register (OTG\_FS\_DOEPTSIZ0)

Address offset: 0xB10

Reset value: 0x0000 0000

The application must modify this register before enabling endpoint 0. Once endpoint 0 is enabled using the Endpoint enable bit in the OTG\_FS\_DOEPCTL0 registers (EPENA bit in OTG\_FS\_DOEPCTL0), the core modifies this register. The application can only read this register once the core has cleared the Endpoint enable bit.

Nonzero endpoints use the registers for endpoints 1–3.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 9 8 7 6 5 4 3 2 1 0 |
|---------------------------------------------------------------------|---------------------|
|---------------------------------------------------------------------|---------------------|

| eserved | NT    | Reserved | PKTCNT | Reserved |    |    | х  | FRS | IZ |    |    |
|---------|-------|----------|--------|----------|----|----|----|-----|----|----|----|
| ä       | rw rw |          | rw     |          | rw | rw | rw | rw  | rw | rw | rw |

Bit 31 Reserved, must be kept at reset value.

Bits 30:29 STUPCNT: SETUP packet count

This field specifies the number of back-to-back SETUP data packets the endpoint can receive.

- 01: 1 packet
- 10: 2 packets
- 11: 3 packets

Bits 28:20 Reserved, must be kept at reset value.

#### Bit 19 **PKTCNT:** Packet count

This field is decremented to zero after a packet is written into the RxFIFO.

- Bits 18:7 Reserved, must be kept at reset value.
- Bits 6:0 XFRSIZ: Transfer size

Indicates the transfer size in bytes for endpoint 0. The core interrupts the application only after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet. The core decrements this field every time a packet is read from the RxFIFO and written to the external memory.



# OTG\_FS device endpoint-x transfer size register (OTG\_FS\_DIEPTSIZx) $(x = 1..3, where x = Endpoint_number)$

Address offset: 0x910 + (Endpoint\_number × 0x20)

Reset value: 0x0000 0000

The application must modify this register before enabling the endpoint. Once the endpoint is enabled using the Endpoint enable bit in the OTG\_FS\_DIEPCTLx registers (EPENA bit in OTG\_FS\_DIEPCTLx), the core modifies this register. The application can only read this register once the core has cleared the Endpoint enable bit.

| 31      | 30              | 29              | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---------|-----------------|-----------------|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|
| ed      | MC              | NT              |    |    |    |    | PKT | CNT |    |    |    |    |    |    |    |    |    |    |    |    | Х  | FRSI | Z  |    |    |    |    |    |    |    |    |
| Reserve | rw/<br>r/r<br>w | rw/<br>r/r<br>w | rw | rw | rw | rw | rw  | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw   | rw | rw | rw | rw | rw | rw | rw | rw | rw |

Bit 31 Reserved, must be kept at reset value.

Bits 30:29 MCNT: Multi count

For periodic IN endpoints, this field indicates the number of packets that must be transmitted per frame on the USB. The core uses this field to calculate the data PID for isochronous IN endpoints.

- 01: 1 packet
- 10: 2 packets
- 11: 3 packets

#### Bit 28:19 PKTCNT: Packet count

Indicates the total number of USB packets that constitute the Transfer Size amount of data for this endpoint.

This field is decremented every time a packet (maximum size or short packet) is read from the TxFIFO.

#### Bits 18:0 XFRSIZ: Transfer size

This field contains the transfer size in bytes for the current endpoint. The core only interrupts the application after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.

The core decrements this field every time a packet from the external memory is written to the  $\mathsf{TxFIFO}.$ 



# OTG\_FS device IN endpoint transmit FIFO status register (OTG\_FS\_DTXFSTSx) (x = 0..3, where $x = Endpoint_number$ )

Address offset for IN endpoints:  $0x918 + (Endpoint\_number \times 0x20)$  This read-only register contains the free space information for the Device IN endpoint TxFIFO.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    | Deer |       |    |    |    |    |    |    |    |    |    |    |    |    |    | 11 | NEPT | FSA | V |   |   |   |   |   |   |
|    |    |    |    |    |    |    | Rese | ervec | 1  |    |    |    |    |    |    | r  | r  | r  | r  | r  | r  | r  | r    | r   | r | r | r | r | r | r | r |

31:16 Reserved, must be kept at reset value.

15:0 INEPTFSAV: IN endpoint TxFIFO space available
Indicates the amount of free space available in the Endpoint TxFIFO.
Values are in terms of 32-bit words:
0x0: Endpoint TxFIFO is full
0x1: 1 word available
0x2: 2 words available
0xn: n words available
Others: Reserved

# OTG\_FS device OUT endpoint-x transfer size register (OTG\_FS\_DOEPTSIZx) $(x = 1..3, where x = Endpoint_number)$

Address offset: 0xB10 + (Endpoint\_number × 0x20)

Reset value: 0x0000 0000

The application must modify this register before enabling the endpoint. Once the endpoint is enabled using Endpoint Enable bit of the OTG\_FS\_DOEPCTLx registers (EPENA bit in OTG\_FS\_DOEPCTLx), the core modifies this register. The application can only read this register once the core has cleared the Endpoint enable bit.

| 31    | 30          | 29          | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|-------------|-------------|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|
| erved | RXDF<br>TUP |             |    |    |    |    | PKT | CNT |    |    |    |    |    |    |    |    |    |    |    |    | X  | FRS | IZ |    |    |    |    |    |    |    |    |
| Rese  | rw/r/<br>rw | rw/r/<br>rw | rw | rw | rw | rw | rw  | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw |

Bit 31 Reserved, must be kept at reset value.

Bits 30:29 **RXDPID:** Received data PID

Applies to isochronous OUT endpoints only. This is the data PID received in the last packet for this endpoint. 00: DATA0 01: DATA2 10: DATA1 11: MDATA



#### STUPCNT: SETUP packet count

Applies to control OUT Endpoints only.

This field specifies the number of back-to-back SETUP data packets the endpoint can receive.

- 01: 1 packet
- 10: 2 packets
- 11: 3 packets

#### Bit 28:19 PKTCNT: Packet count

Indicates the total number of USB packets that constitute the Transfer Size amount of data for this endpoint.

This field is decremented every time a packet (maximum size or short packet) is written to the RxFIFO.

Bits 18:0 XFRSIZ: Transfer size

This field contains the transfer size in bytes for the current endpoint. The core only interrupts the application after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.

The core decrements this field every time a packet is read from the RxFIFO and written to the external memory.

# 29.16.5 OTG\_FS power and clock gating control register (OTG\_FS\_PCGCCTL)

Address offset: 0xE00

Reset value: 0x0000 0000

This register is available in host and device modes.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4       | 3 | 2        | 1        | 0       |
|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|---|---|---|---|---|---------|---|----------|----------|---------|
|    |    |    |    |    |    |    |    |    |    |    |    | Res | erve | d  |    |    |    |    |    |    |    |   |   |   |   |   | dSNSYHq |   | naviasau | GATEHCLK | STPPCLK |
|    |    |    |    |    |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |   |   |   |   |   | rw      |   | -        | rw       | rw      |

Bit 31:5 Reserved, must be kept at reset value.

#### Bit 4 PHYSUSP: PHY Suspended

Indicates that the PHY has been suspended. This bit is updated once the PHY is suspended after the application has set the STPPCLK bit (bit 0).

Bits 3:2 Reserved, must be kept at reset value.

#### Bit 1 GATEHCLK: Gate HCLK

The application sets this bit to gate HCLK to modules other than the AHB Slave and Master and wakeup logic when the USB is suspended or the session is not valid. The application clears this bit when the USB is resumed or a new session starts.

#### Bit 0 STPPCLK: Stop PHY clock

The application sets this bit to stop the PHY clock when the USB is suspended, the session is not valid, or the device is disconnected. The application clears this bit when the USB is resumed or a new session starts.



# 29.16.6 OTG\_FS register map

The table below gives the USB OTG register map and reset values.

### Table 155. OTG\_FS register map and reset values

| Offset | Register                                            | 31       | -      |          | 28       | _        | _      | 25    | 24      | 23           | 5                  | 20        | 19      | 18        | 17       | 16        | 15       | 14       | 13       | 12      | 11       | 10        | 6         | 8          | 7          | 9         | 5         | 4         | e          | 2        | -       | 0         |
|--------|-----------------------------------------------------|----------|--------|----------|----------|----------|--------|-------|---------|--------------|--------------------|-----------|---------|-----------|----------|-----------|----------|----------|----------|---------|----------|-----------|-----------|------------|------------|-----------|-----------|-----------|------------|----------|---------|-----------|
| 0x000  | OTG_FS_GOT<br>GCTL<br>Reset value                   |          | Ţ      |          |          | -        | -      | erve  |         |              |                    |           | O BSVLD |           | o DBCT . | - CIDSTS  |          | Rese     |          | -       | OHNPEN   | O HSHNPEN | o HNPRQ   | O HNGSCS   |            | F         | lese      | erve      | d          |          | o SRQ   | SRQSCS    |
| 0x004  | OTG_FS_GOT<br>GINT<br>Reset value                   |          |        |          |          | F        | Rese   | erve  | d       |              |                    |           |         |           | HNGDET   |           |          |          | Reserved |         |          |           | O HNSSCHG | O SRSSCHG  |            | Re        | serv      | ved       |            | o SEDET  | Re      | es.       |
| 0x008  | OTG_FS_GAH<br>BCFG<br>Reset value                   |          |        |          |          |          |        |       |         |              | Re                 | ser       | ved     |           | <b></b>  |           |          |          |          |         |          |           |           | O PTXFELVL | O TXFELVL  |           | F         | Rese      | erve       | d        |         | o GINTMSK |
| 0x00C  | OTG_FS_GUS<br>BCFG<br>Reset value                   | СТХРКТ   | FDMOD  | FHMOD    |          |          |        |       |         | Re           | ser                | ved       |         |           |          |           |          |          | 0        | TR<br>1 | DT       | 1         | o HNPCAP  |            | - PHYSEL   | F         | lese      | erve      | d          | т(       |         | _         |
| 0x010  | OTG_FS_GRST<br>CTL<br>Reset value                   | - AHBIDL |        | <u> </u> | <u> </u> |          |        |       |         | F            | Res                | erve      | d       |           |          |           |          |          | <u>.</u> | •       | •        | 0         | TX        | FNU<br>0   | M          | 0         | O TXFFLSH | O RXFFLSH | o Reserved | o FCRST  | o HSRST | o CSRST   |
| 0x014  | OTG_FS_GINT<br>STS                                  | WKUINT   | SRQINT | DISCINT  | CIDSCHG  | Reserved | PTXFE  | HCINT | HPRTINT | Reserved     | IPXFR/INCOMPISOOUT | IISOIXFR  | OEPINT  | IEPINT    | Beconved | 100010011 | EOPF     | ISOODRP  | ENUMDNE  | USBRST  | USBSUSP  | ESUSP     | Reserved  |            | GOUTNAKEFF | GINAKEFF  | NPTXFE    | RXFLVL    | SOF        | OTGINT   | MMIS    | CMOD      |
|        | Reset value                                         | 0        | 0      | 0        | 0        |          | 1      | 0     | 0       |              | 0                  | 0         | 0       | 0         |          | 1         | 0        | 0        | 0        | 0       | 0        | 0         |           | -          | 0          | 0         | 1         | 0         | 0          | 0        | 0       | 0         |
| 0x018  | OTG_FS_GINT<br>MSK                                  | MUIM     | SRQIM  | DISCINT  | CIDSCHGM | Reserved | PTXFEM | HCIM  | PRTIM   | Reserved     | IPXFRM/IISOOXFRM   | IISOIXFRM | OEPINT  | IEPINT    | EPMISM   | Reserved  | EOPFM    | ISOODRPM | ENUMDNEM | USBRST  | USBSUSPM | ESUSPM    | Reserved  |            | GONAKEFFM  | GINAKEFFM | NPTXFEM   | RXFLVLM   | SOFM       | OTGINT   | MMISM   | Reserved  |
|        | Reset value                                         | 0        | 0      | 0        | 0        |          | 0      | 0     | 0       |              | 0                  | 0         | 0       | 0         | 0        |           | 0        | 0        | 0        | 0       | 0        | 0         |           |            | 0          | 0         | 0         | 0         | 0          | 0        | 0       |           |
|        | OTG_FS_GRXS<br>TSR (host<br>mode)                   |          |        |          |          | Re       | ser    | ved   |         |              |                    |           |         | IST       |          | DF        | PID      |          |          |         |          |           | BCN       |            | 0          | 0         | 0         |           |            | CHN      |         | 1         |
| 0x01C  | Reset value<br>OTG_FS_GRXS<br>TSR (Device<br>mode)  |          |        | Re       | eser     | ved      |        |       |         | RMNU         |                    |           |         | 0<br>IST: |          |           | 0<br>PID | 0        | 0        | 0       | 0        |           | 0<br>BCN  |            | 0          | 0         | 0         | 0         |            | 0<br>EPN |         |           |
|        | Reset value<br>OTG_FS_GRXS                          |          |        |          |          |          |        |       | 0       | 0 0          | 0                  | 0         | 0       | 0         | 0        | 0         | 0        | 0        | 0        | 0       | 0        | 0         | 0         | 0          | 0          | 0         | 0         | 0         | 0          | 0        | 0       | 0         |
|        | TSR (host<br>mode)                                  |          |        |          |          | Re       | ser    | ved   |         |              |                    |           |         | ST        |          | DF        |          |          |          |         |          |           | BCN       |            | 0          |           | 0         |           |            | CHN      |         | 1         |
| 0x020  | Reset value<br>OTG_FS_GRXS<br>TSPR (Device<br>mode) |          |        | Re       | ser      | ved      |        |       |         | RMNU         |                    |           | РКТ     | 0<br>IST: | S        |           |          | 0        | 0        | 0       | 1        | E         | 0<br>BCN  | Т          | 0          | 0         |           | 0         |            | EPN      |         |           |
| 0x024  | Reset value<br>OTG_FS_GRXF<br>SIZ                   |          |        |          |          |          |        | F     |         | 0 0<br>erved | 0                  | 0         | 0       | 0         | 0        | 0         |          |          | 0        | 0       |          | 0         | 0         | RXI        |            |           |           | 0         | 1          | 0        | 11      | L         |
|        | Reset value                                         |          |        |          |          |          |        |       |         |              |                    |           |         |           |          |           | 0        | 0        | 0        | 0       | 0        | 0         | 1         | 0          | 0          | 0         | 0         | 0         | 0          | 0        | 0       | 0         |



| Offset | Register                                  | 31    | 30    | 29     | 28 | 27       | 26       | 25          | 23        | 22            | 33                      | 19          | 18     | 17       | 16       | 15       | 13          | 12     | 11        | 10 | 6          | 8         | 7        | 9       | 2         | 4 | <b>с</b>  | v | - 0     |
|--------|-------------------------------------------|-------|-------|--------|----|----------|----------|-------------|-----------|---------------|-------------------------|-------------|--------|----------|----------|----------|-------------|--------|-----------|----|------------|-----------|----------|---------|-----------|---|-----------|---|---------|
| 0x028  | OTG_FS_HNPT<br>XFSIZ/<br>OTG_FS_DIEP      |       |       |        |    |          |          | PTXF        |           |               |                         | <u> </u>    | -      |          |          |          | <u>·</u> [· | 1 -    | <u> </u>  |    | TXF        | -SA       | /TX      | 0FS     | A         |   |           |   |         |
|        | TXF0<br>Reset value<br>OTG_FS_HNPT        | 0     | 0     | 0      |    | 0<br>XQ  | 0<br>TOP | 0 0         | 0         | 0             |                         |             |        | 0        | 0        | 0        | 0 0         | 0      | 0         | 0  | 1<br>NF    | 0<br>ואדי | 0<br>FSA |         | 0         | 0 | 0 (       | ) | 0 0     |
| 0x02C  | XSTS<br>Reset value                       | Res.  | 0     |        |    |          |          | 0 0         | 0         | 0             | 0 (                     | 0 0         | 1      |          | 0        | 0        | 0 0         | 0      | 0         | 0  | 1          | 0         | 0        | 0       | 0         | 0 | 0 (       | ) | 0 0     |
| 0x038  | OTG_FS_<br>GCCFG                          |       |       |        | F  | lese     | erved    | I           |           |               | NOVBUSSENS<br>SOFOLITEN |             | -      | Reserved | NWDRWY.  |          |             |        |           |    | R          | ese       | rve      | b       |           |   |           |   |         |
|        | Reset value<br>OTG_FS_CID                 |       |       |        |    |          |          |             |           |               | 0 (                     | 0 0         | 0      | DD       | 0        | ЈСТ      |             |        |           |    |            |           |          |         |           |   |           |   |         |
| 0x03C  | Reset value                               |       | 0     | 0      | 0  | 0        | 0        | 0 0         |           |               | 0 (                     | 0 0         |        | 0        |          | _        | 00          | 1      | 0         | 0  |            | 1         | 0        | 0       | 0         | 0 | 0 (       | ) | 0 0     |
| 0x100  | FSIZ<br>Reset value                       | 0     | 0     | 0      | 0  | 0        | 1        | PD<br>1 1   | (FSIZ     | <u>^</u><br>1 | 1 (                     | ) 1         | 0      | 0        | 0        | 0        | 0 0         | 1      | 0         | 0  |            | РТХ<br>0  | .SA<br>0 | 0       | 1         | 0 | 0         | 1 | 0 0     |
| 0x104  | OTG_FS_DIEP<br>TXF1<br>Reset value        | 0     | 0     | 0      | 0  | 0        | 0        | INEF        | PTXF      | D             | 0 0                     | 0 0         | 0      | 0        | 0        | 0        | 0 0         | 0      | 0         | 1  |            | EPT       | rxs<br>0 | A<br>0  | 0         | 0 | 0 0       | 0 | 0 0     |
| 0x108  | OTG_FS_DIEP<br>TXF2                       | _     | <br>! |        |    |          |          |             | PTXF      |               |                         |             |        |          |          |          |             |        | <br>• - • |    |            | EPT       |          | A       |           |   |           |   |         |
| 0x10C  | Reset value<br>OTG_FS_DIEP<br>TXF3        | 0     | 0     | 0      | 0  | 0        | 0        | 1 0<br>INEF | 0<br>PTXF | 0<br>D        | 0 (                     | 0 0         | 0      | 0        | 0        | 0        | 0 0         | 0      | 0         | 1  |            | 0<br>EPT  | 0<br>TXS | 0<br>A  | 0         | 0 | 0 (       | ) | 0 0     |
|        | Reset value                               | 0     | 0     | 0      | 0  | 0        | 0        | 1 0         | 0         | 0             | 0 (                     | 0 0         | 0      | 0        | 0        | 0        | 0 0         | 0      | 0         | 1  | 0          | 0         | 0        | 0       | 0         | 0 | 0 (       | ) | 0 0     |
| 0x400  | OTG_FS_HCFG                               |       |       |        |    |          |          |             |           |               |                         |             | Re     | serv     | /ed      |          |             |        |           |    |            |           |          |         |           |   |           |   | FSLSPCS |
| 0x404  | Reset value<br>OTG_FS_HFIR<br>Reset value |       |       |        |    |          |          | Res         | erveo     | d             |                         |             |        |          |          | 1        | 111         | 0      | 111       | 0  |            | FRI<br>0  | VL<br>0  | 1       | 11        | 0 |           |   | 0 0     |
| 0x408  | OTG_FS_HFNU<br>M                          |       |       |        |    |          |          | FT          | REM       |               |                         |             |        |          |          | •        | 1 1         | 0      | <u> </u>  | U  |            | RN        |          |         | '         | 0 | 0 1       |   | 0 0     |
|        | Reset value<br>OTG_FS_HPTX                | 0     | 0     |        |    | 0<br>סדג |          | 0 0         | 0         | 0             |                         | 0 0<br>XQSA |        | 0        | 0        | 0        | 0 1         | 1      | 1         | 1  |            | 1<br>XFS  |          | 1<br>/I | 1         | 1 | 1         | 1 | 1 1     |
| 0x410  | STS<br>Reset value<br>OTG_FS_HAIN         | 0     | 0     |        | 0  | 0        |          | 0 0         | Y         | Y             | Y                       | γŢΥ         | Y      | Y        | Y        | Y        | ΥY          | Y      | Y         | Y  | Y          | Y         | Y        | Y       | Y         | Y | Y         | Y | ΥY      |
| 0x414  | T<br>Reset value                          |       |       |        |    |          |          | Res         | erveo     | d             |                         |             |        |          |          | 0        | 0 0         | 0      | 0         | 0  | 0          | HAII<br>0 | NT<br>0  | 0       | 0         | 0 | 0 0       | ) | 0 0     |
| 0x418  | OTG_FS_HAIN<br>TMSK                       |       |       |        |    |          |          | Res         | erve      | d             |                         |             |        |          |          |          |             |        |           |    |            | IAIN      |          |         |           |   |           |   |         |
| 0x440  | Reset value OTG_FS_HPRT                   |       |       |        |    |          | Res      | erved       |           |               |                         |             | PS     | PD       |          | 0<br>PTC |             | PPWR 0 | PLSTS 0   | 0  | Reserved o | PRST o    | PSUSP o  | PRES O  | POCCHNG O |   | PENCHNG 0 |   | PCSTS 0 |
|        | Reset value                               |       |       |        |    |          |          |             |           |               |                         |             | 0      | 0        | 0        | 0        | 0 0         |        |           | 0  |            | 0         | 0        |         | 000       |   | Ы         |   | 0 0     |
| 0x500  | OTG_FS_HCC<br>HAR0                        | CHENA | CHDIS | ODDFRM |    |          | D        | AD          |           |               | MCN                     | T           | ЕРТҮР  | LSDEV    | Reserved | EPDIR    | EP          | NUM    | 1         |    |            |           |          | М       | PSI       | Z |           |   |         |
|        | Reset value                               | 0     | 0     | 0      | 0  | 0        | 0        | 0 0         | 0         | 0             | 0 (                     | 0 0         | 0      | 0        | Ъ        | 0        | 0 0         | 0      | 0         | 0  | 0          | 0         | 0        | 0       | 0         | 0 | 0 (       | ) | 0 0     |
| 0x520  | OTG_FS_HCC<br>HAR1                        | CHENA | CHDIS | ODDFRM |    |          | D        | AD          |           |               | MCN                     | T           | EPIYP  | LSDEV    | Reserved | EPDIR    | EP          | NUM    | 1         |    |            |           |          | М       | PSI       | Z |           |   |         |
|        | Reset value                               | 0     | 0     | 0      | 0  | 0        | 0        | 0 0         | 0         | 0             | 0 (                     | 0           | 0      | 0        | Ć        | 0        | 0 0         | 0      | 0         | 0  | 0          | 0         | 0        | 0       | 0         | 0 | 0 (       | ) | 0 0     |
|        | 1                                         | 4     | 6     | Σ      |    |          |          |             |           |               |                         | Ģ           | ך<br>ד | >        | ba       | щ        |             |        |           |    |            |           |          |         |           |   |           |   |         |
| 0x540  | OTG_FS_HCC<br>HAR2                        | CHENA | CHDIS | ODDFRM |    |          | D        | DAD         |           |               | MCN                     | T f         | EFIYF  | LSDEV    | Reserved | EPDIR    | EP          | NUM    | 1         |    |            |           |          | Μ       | PSI       | Z |           |   |         |

### Table 155. OTG\_FS register map and reset values (continued)



|        |                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       | -      |    |    | <u> </u> |     |     | -   | t vait  |          |       |          |       |                | _       |         |         |          |          |       |       | -       | 1        | - T   |              |
|--------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|----|----|----------|-----|-----|-----|---------|----------|-------|----------|-------|----------------|---------|---------|---------|----------|----------|-------|-------|---------|----------|-------|--------------|
| Offset | Register                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        | 28 | 27 | 26       | 25  | N C | 52  | 202     | 19<br>18 | 17    | 16       | 15    | 11<br>12<br>13 | 10      | 6       | 8       | 7        | 9        | 5     | 4     | e       | 2        | -     | 0            |
| 0x560  | OTG_FS_HCC<br>HAR3               | CHENA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CHDIS | ODDFRM |    |    | C        | DAD |     |     | MCNT    | ЕРТҮР    | LSDEV | Reserved | EPDIR | EPNUM          |         |         |         |          | N        | IPSI  | Z     |         |          |       |              |
|        | Reset value                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0     | 0      | 0  | 0  | 0        | 0 0 | ) ( | 0 0 | 0 0     | 0 0      | 0     | ц        | 0     | 0 0 0 0        | 0       | 0       | 0       | 0        | 0        | 0     | 0     | 0       | 0        | 0     | 0            |
| 0x580  | OTG_FS_HCC<br>HAR4               | CHENA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CHDIS | ODDFRM |    |    | C        | DAD |     |     | MCNT    | ЕРТҮР    | LSDEV | Reserved | EPDIR | EPNUM          |         |         |         |          | N        | IPSI  | Z     |         |          |       |              |
|        | Reset value                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0     | 0      | 0  | 0  | 0        | 0 0 | ) ( | 0 0 | 0 0     | 0 0      | 0     | Ť        | 0     | 0 0 0 0        | 0       | 0       | 0       | 0        | 0        | 0     | 0     | 0       | 0        | 0     | 0            |
| 0x5A0  | OTG_FS_HCC<br>HAR5               | CHENA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       | ODDFRM |    |    | C        | DAD |     |     | MCNT    | EP       | LSDEV | Reserved | EPDIR | EPNUM          |         |         |         |          | N        | IPSI  | Z     |         |          |       |              |
|        | Reset value                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0     | 0 1    | 0  | 0  | 0        | 0 0 | ) ( | 0 0 | 0 0     | 0 0      | 0     | ш        | 0     | 0 0 0 0        | 0       | 0       | 0       | 0        | 0        | 0     | 0     | 0       | 0        | 0     | 0            |
| 0x5C0  | OTG_FS_HCC<br>HAR6               | CHENA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CHDIS | ODDFRM |    |    | C        | DAD |     |     | MCNT    | ЕРТҮР    | LSDEV | Reserved | EPDIR | EPNUM          |         |         |         |          | N        | IPSI  | Z     |         |          |       |              |
|        | Reset value                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0     | 0      | 0  | 0  | 0        | 0 0 | ) ( | 0 0 | 0 0     | 0 0      | 0     | Ē        | 0     | 0 0 0 0        | 0       | 0       | 0       | 0        | 0        | 0     | 0     | 0       | 0        | 0     | 0            |
| 0x5E0  | OTG_FS_HCC<br>HAR7               | CHENA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CHDIS | ODDFRM |    |    | C        | DAD |     |     | MCNT    | ЕРТҮР    | LSDEV | Reserved | EPDIR | EPNUM          |         |         |         |          | N        | IPSI  | Z     |         |          |       |              |
|        | Reset value                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0     | 0      | 0  | 0  | 0        | 0 0 | ) ( | 0 0 | 0 0     | 0 0      | 0     | ц        | 0     | 0 0 0 0        | 0       | 0       | 0       | 0        | 0        | 0     | 0     | 0       | 0        | 0     | 0            |
| 0x508  | OTG_FS_HCIN<br>T0                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |        |    |    |          |     |     | Re  | served  |          |       |          |       |                | DTERR   | o FRMOR |         | TXERR    | Reserved |       |       | STALL   | Reserved |       | XFRC         |
|        | Reset value                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     |     |         |          |       |          |       |                | 0<br>m  |         | 0<br>m  | 0<br>r   |          | 0     | 0     | -       |          | 0     | 0            |
| 0x528  | OTG_FS_HCIN<br>T1                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     | Re  | served  |          |       |          |       |                | o DTERR | o FRMOR |         | TXERR    | Reserved |       | NAK   | STALL   | Reserved |       | XFRC         |
|        | Reset value                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     |     |         |          |       |          |       |                |         |         | Rо      | Rо       |          | 0     | 0     | -       |          | 0     | 0            |
| 0x548  | OTG_FS_HCIN<br>T2<br>Reset value | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |        |    |    |          |     |     | Re  | served  |          |       |          |       |                | o DTERR | FRMOR   | O BBERR | o TXERR  | Reserved | o ACK | o NAK | O STALL | Reserved |       | o XFRC       |
| 0x568  | OTG_FS_HCIN<br>T3                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     | Re  | served  |          |       |          |       |                | DTERR   | FRMOR   |         | TXERR    | Reserved |       | NAK   | STALL   | Reserved | CHH   | XFRC         |
|        | Reset value                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     |     |         |          |       |          |       |                | 0       | 0       | 0       | 0        |          | 0     | 0     | -       |          | 0     | 0            |
| 0x588  | OTG_FS_HCIN<br>T4                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     | Re  | served  |          |       |          |       |                | o DTERR | FRMOR   |         | TXERR    | Reserved |       |       | STALL   | Reserved |       | XFRC         |
|        | Reset value                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     |     |         |          |       |          |       |                |         | В<br>О  | 0<br>11 | 0<br>۲   |          | 0     | 0     | -       |          |       | 0            |
| 0x5A8  | OTG_FS_HCIN<br>T5<br>Reset value |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     | Re  | served  |          |       |          |       |                | DTERR   | o FRMOR | o BBERR | o TXERR  | Reserved |       | o NAK | STALL   | ă        | o CHH | o XFRC       |
|        |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     |     |         |          |       |          |       |                |         |         |         |          | -        |       |       | Ť       | _        |       |              |
| 0x5C8  | OTG_FS_HCIN<br>T6                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     | Re  | served  |          |       |          |       |                | TER     | MC      | BBERR   | TXERR    | erve     | ACK   | NAK   | STALL   | erve     | CHH   | XFRC         |
|        | Reset value                      | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |        |    |    |          |     |     |     |         |          |       |          |       |                | o DTERR | o FRMOR | 0<br>B  | Г<br>0   | Reserved | 0     | 0     | 0       | Reserved | 0     | ^<br>0       |
| 0x5E8  | OTG_FS_HCIN<br>T7                | Reserved     Image: Application of the second |       |        |    |    |          |     |     |     |         |          | XFRC  |          |       |                |         |         |         |          |          |       |       |         |          |       |              |
|        | Reset value                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     |     |         |          |       |          |       |                | 0       | 0       | 0       | 0        | Re       | 0     | 0     | 0       | Ŗ        | 0     | 0            |
| 0x50C  | OTG_FS_HCIN<br>TMSK0             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     | Re  | eserved |          |       |          |       |                | DTERRM  | FRMORM  |         | , TXERRM | NYET     |       |       | STALLM  | Reserved |       | <b>XFRCM</b> |
|        | Reset value                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     |     |         |          |       |          |       |                | 0       | 0<br>N  | 0<br>N  | 0 N      | 0        | 0     | 0     | 0       |          |       | 0            |
| 0x52C  | OTG_FS_HCIN<br>TMSK1             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     | Re  | served  |          |       |          |       |                | DTERRM  |         |         | TXERRM   |          |       |       | STALLM  | Reserved |       | XFRCM        |
|        | Reset value                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |        |    |    |          |     |     |     |         |          |       |          |       |                | 0       | 0       | 0       | 0        | 0        | 0     | 0     | 0       | 4        | 0     | 0            |

# Table 155. OTG\_FS register map and reset values (continued)



| Offset | Register                          |          | 80   |   |   | - |   |     |     | set<br>ຊ |      |     |   | - |   |   | 15 | - | 13 | 12    | 11 | 10       | 6        | 8      | 7        | 9    | 5 | 4    | 3        | 2         | -    | 0            |
|--------|-----------------------------------|----------|------|---|---|---|---|-----|-----|----------|------|-----|---|---|---|---|----|---|----|-------|----|----------|----------|--------|----------|------|---|------|----------|-----------|------|--------------|
| 0x54C  | OTG_FS_HCIN<br>TMSK2              |          |      |   |   |   |   |     |     | Res      | serv | ved |   |   | · |   |    | · |    |       |    | DTERRM   | FRMORM   | BBERRM | TXERRM   |      |   |      | STALLM   | Reserved  |      | XFRCM        |
|        | Reset value                       |          |      |   |   |   |   |     |     |          |      |     |   |   |   |   |    |   |    |       |    |          |          | 0      | 0        | 0    | 0 | 0    | 0        |           | 0    | 0            |
| 0x56C  | OTG_FS_HCIN<br>TMSK3              |          |      |   |   |   |   |     |     | Res      | serv | ved |   |   |   |   |    |   |    |       |    | DTERRM   | o FRMORM | BBERRM | TXERRM   | NYET |   | NAKM | STALLM   | Reserved  |      | XFRCM        |
|        | Reset value                       |          |      |   |   |   |   |     |     |          |      |     |   |   |   |   |    |   |    |       |    |          |          | 0      | 0        | 0    | 0 | 0    | 0        | <u> </u>  | 0    | 0            |
| 0x58C  | OTG_FS_HCIN<br>TMSK4              |          |      |   |   |   |   |     |     | Res      | serv | ved |   |   |   |   |    |   |    |       |    | DTERRM   | FRMORM   | BBERRM | , TXERRM | NYET |   | NAKM | STALLM   | Reserved  |      | <b>XFRCM</b> |
|        | Reset value                       |          |      |   |   |   |   |     |     |          |      |     |   |   |   |   |    |   |    |       |    |          |          | 0      | 0        | 0    | 0 | 0    | 0        | $\square$ | 0    | 0            |
| 0x5AC  | OTG_FS_HCIN<br>TMSK5              |          |      |   |   |   |   |     |     | Res      | serv | ved |   |   |   |   |    |   |    |       |    | O DTERRM | FRMORM   | BBERRM | TXERRM   |      |   |      | STALLM   | Reserved  |      | XFRCM        |
|        | Reset value                       |          |      |   |   |   |   |     |     |          |      |     |   |   |   |   |    |   |    |       |    |          | 0        | 0      | 0        | 0    | 0 | 0    | 0        | <u> </u>  | 0    | 0            |
| 0x5CC  | OTG_FS_HCIN<br>TMSK6              |          |      |   |   |   |   |     |     | Res      | serv | ved |   |   |   |   |    |   |    |       |    | DTERRM   | FRMORM   | BBERRM | TXERRM   | NYET |   |      | STALLM   | Reserved  |      | XFRCM        |
|        | Reset value                       |          |      |   |   |   |   |     |     |          |      |     |   |   |   |   |    |   |    |       |    | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | Ľ         | 0    | 0            |
| 0x5EC  | OTG_FS_HCIN<br>TMSK7              |          |      |   |   |   |   |     |     | Res      | serv | ved |   |   |   |   |    |   |    |       |    | DTERRM   | FRMORM   | BBERRM | TXERRM   | NYET |   |      | STALLM   | Reserved  |      | XFRCM        |
|        | Reset value                       | 5        |      | - |   |   |   |     |     |          |      |     |   |   |   |   |    |   |    |       |    | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | <u> </u>  | 0    | 0            |
| 0x510  |                                   | rve      | DPID |   |   |   | F | РКТ | CNT |          |      |     |   |   |   |   |    |   |    |       |    | XI       | FRS      | βIZ    |          |      |   |      |          |           |      |              |
|        | OTG_FS_HCTS<br>IZ0<br>Reset value | Rese     | 0 0  | 0 | 0 | 0 | 0 | 0   | 0   | 0        | 0    | 0   | 0 | 0 | 0 | 0 | 0  | 0 | 0  | 0     | 0  | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | 0         | 0    | 0            |
| 0.500  | OTG_FS_HCTS<br>IZ1<br>Reset value | ved I    | DPID |   |   |   | F | РКТ | CNT | -        |      |     |   |   |   |   |    |   |    |       |    | X        | FRS      | βIZ    |          | 1    |   |      |          |           |      |              |
| 0x530  | Reset value                       | Resei    | 0 0  | 0 | 0 | 0 | 0 | 0   | 0   | 0        | 0    | 0   | 0 | 0 | 0 | 0 | 0  | 0 | 0  | 0     | 0  | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | 0         | 0    | 0            |
|        | OTG_FS_HCTS<br>IZ2                | l bəv    | DPID |   |   |   | F | νКТ | CNT | -        |      |     |   |   |   |   |    |   |    |       |    | XI       | FRS      | βIZ    |          | 1    |   |      |          |           |      |              |
| 0x550  | Reset value                       | Reserved | 0 0  | 0 | 0 | 0 | 0 | 0   | 0   | 0        | 0    | 0   | 0 | 0 | 0 | 0 | 0  | 0 | 0  | 0     | 0  | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | 0         | 0    | 0            |
| 0      | OTG_FS_HCTS<br>IZ3                | ved      | DPID |   |   |   | F | РКТ | CNT | -        |      |     |   |   |   |   |    |   |    |       |    | XI       | FRS      | βIZ    |          |      |   |      |          |           |      |              |
| 0x570  | Reset value                       | Resei    | 0 0  | 0 | 0 | 0 | 0 | 0   | 0   | 0        | 0    | 0   | 0 | 0 | 0 | 0 | 0  | 0 | 0  | 0     | 0  | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | 0         | 0    | 0            |
| 0.500  | OTG_FS_HCTS<br>IZ4                |          | DPID |   |   |   | F | РКТ | CNT | -        |      |     |   |   |   |   |    |   |    |       |    | XI       | FRS      | βIZ    |          |      |   |      |          |           |      |              |
| 0x590  | Reset value                       | Reserved | 0 0  | 0 | 0 | 0 | 0 | 0   | 0   | 0        | 0    | 0   | 0 | 0 | 0 | 0 | 0  | 0 | 0  | 0     | 0  | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | 0         | 0    | 0            |
|        | OTG_FS_HCTS<br>IZ5<br>Reset value | ved F    | DPID |   |   |   | F | РКТ | CNT | -        |      |     |   |   |   |   |    |   |    |       |    | XI       | FRS      | βIZ    |          |      |   |      |          |           |      |              |
| 0x5B0  | Reset value                       | Reser    | 0 0  | 0 | 0 | 0 | 0 | 0   | 0   | 0        | 0    | 0   | 0 | 0 | 0 | 0 | 0  | 0 | 0  | 0     | 0  | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | 0         | 0    | 0            |
|        | OTG_FS_HCTS<br>IZ6                | vedF     | DPID |   |   |   | F | РКТ | CNT | -        |      |     |   |   |   |   |    |   |    |       |    | XI       | FRS      | βIZ    |          |      |   |      |          |           |      |              |
| 0x5D0  | Reset value                       | Reserved | 0 0  | 0 | 0 | 0 | 0 | 0   | 0   | 0        | 0    | 0   | 0 | 0 | 0 | 0 | 0  | 0 | 0  | 0     | 0  | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | 0         | 0    | 0            |
|        | OTG_FS_HCTS<br>IZ7                |          | DPID |   |   |   | F | РКТ | CNT | -        |      |     |   |   |   |   |    |   |    |       |    | XI       | FRS      | βIZ    |          | I    |   |      |          |           |      |              |
| 0x5F0  | Reset value                       | Reserved | 0 0  | 0 | 0 | 0 | 0 | 0   | 0   | 0        | 0    | 0   | 0 | 0 | 0 | 0 | 0  | 0 | 0  | 0     | 0  | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 0        | 0         | 0    | 0            |
|        |                                   | <u>а</u> |      | - |   |   |   |     |     |          |      |     |   |   | I |   |    |   |    |       |    |          | I        | I      | I        | I    | I |      |          | Ϋ́        |      | —            |
| 0x800  | OTG_FS_DCFG                       |          |      |   |   |   |   |     | Re  | serv     | ed   |     |   |   |   |   |    |   |    | PFIVL |    |          |          |        | DAD      |      |   |      | Reserved | NZLSOHSK  | DSPD |              |
|        | Reset value                       |          |      |   |   |   |   |     |     |          |      |     |   |   |   |   |    |   |    | 0     | 0  | 0        | 0        | 0      | 0        | 0    | 0 | 0    | 4        | 0         | 0    | 0            |

## Table 155. OTG\_FS register map and reset values (continued)



| Offset | Register                   | -5 register map and rese<br>ເ_ວ໑໑໐໐໑໑໐໑໐                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                                                                     |
|--------|----------------------------|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|---------------------------------------------------------------------|
| Oliset | negistei                   | 22 23 25 26 23 28 33                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | • 0 10 11 12 13 14 15        | 0 - 1 2 3 4 5 6 7 6                                                 |
| 0x804  | OTG_FS_DCTL                | Res                                                            | erved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | POPRGDNE<br>CGONAK<br>SGONAK |                                                                     |
|        | Reset value                |                                                                | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 0 0 0                      |                                                                     |
| 0x808  | OTG_FS_DSTS                | Reserved                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | FNSOF                        | Reserved Reserved Reserved                                          |
|        | Reset value                |                                                                | 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 0 0 0 0 0 0 0              |                                                                     |
| 0x810  | OTG_FS_DIEP<br>MSK         |                                                                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                              | INEPNEM<br>INEPNEM<br>ITTXFEMSK<br>TOM<br>Reserved<br>EPDM<br>XFRCM |
|        | Reset value                |                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                                                                     |
| 0x814  | OTG_FS_DOEP<br>MSK         |                                                                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                              | o OTEPDM<br>STUPM<br>Reserved<br>FPDM                               |
|        | Reset value<br>OTG_FS_DAIN |                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                                                                     |
| 0x818  | Τ_                         | OEPINT                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              | PINT                                                                |
| -      | Reset value<br>OTG_FS_DAIN | 0 0 0 0 0 0 0 0 0 0                                            | 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                              |                                                                     |
| 0x81C  | TMSK                       | OEPM                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              | EPM                                                                 |
|        | Reset value<br>OTG_FS_DVBU | 0 0 0 0 0 0 0 0 0 0                                            | 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                              |                                                                     |
| 0x828  | SDIS                       | Reserved                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | VB                           | USDT                                                                |
|        | Reset value<br>OTG_FS_DVBU |                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0 0 0 1 0 1 1 1              |                                                                     |
| 0x82C  | SPULSE                     | Res                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DVBUSP                       |                                                                     |
|        | Reset value<br>OTG_FS_DIEP |                                                                | 0 1 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                              |                                                                     |
| 0x834  | EMPMSK                     | Reserved                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | INEF                         | PTXFEM                                                              |
| -      | Reset value                |                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              |                                                                     |
| 0x900  | OTG_FS_DIEP<br>CTL0        | MONAXT CNAK                                                    | A Stall A Stal |                              |                                                                     |
|        | Reset value<br>TG_FS_DTXFS |                                                                | 0 4 0 0 0 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                              | 0 0                                                                 |
| 0x918  | TS0                        | Reserved                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              | PTFSAV                                                              |
|        | Reset value                |                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0 0 0 0 0 1 0                |                                                                     |
| 0x920  | OTG_FS_DIEP<br>CTL1        | EPENA<br>EPDIS<br>SODDFRM/SD1PID<br>SNAK<br>SNAK<br>CNAK       | E E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reserved                     | MPSIZ                                                               |
|        | Reset value<br>TG_FS_DTXFS | 0 0 0 0 0 0 0 0 0 0 0                                          | 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 0 0                        |                                                                     |
| 0x938  | TS1                        | Reserved                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              | PTFSAV                                                              |
|        | Reset value                |                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0 0 0 0 0 1 0                | 0 0 0 0 0 0 0 0 0                                                   |
| 0x940  | OTG_FS_DIEP<br>CTL2        | EPENA<br>EPDIS<br>SODDFRIM<br>SSOOPID/SEVNFRIM<br>SNAK<br>CNAK | Beserved<br>EPTYP<br>NAKSTS<br>EONUM/DPID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reserved                     | MPSIZ                                                               |
|        | Reset value<br>TG_FS_DTXFS | 0 0 0 0 0 0 0 0 0 0                                            | 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 0 0                        |                                                                     |
| 0x958  | TS2                        | Reserved                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                              | PTFSAV                                                              |
|        | Reset value                |                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0 0 0 0 0 0 1 0              |                                                                     |

# Table 155. OTG\_FS register map and reset values (continued)

1018/1316



| Offset | Register                                         | 31          | 1       | 59        | 28                 | 27     | 26.    | 25           | 53          | Ľ.      | 0          | 19           | 17       | 16           | 15          | 1 1 2 3 4 | 8 9 10            | 7        | 9          | 5          | 4        | с<br>С            | 1 <del>-</del> | 0                        |
|--------|--------------------------------------------------|-------------|---------|-----------|--------------------|--------|--------|--------------|-------------|---------|------------|--------------|----------|--------------|-------------|-----------|-------------------|----------|------------|------------|----------|-------------------|----------------|--------------------------|
| 0x960  | OTG_FS_DIEP<br>CTL3                              | EPENA 3     | EPDIS 3 | SODDFRM 2 | SD0PID/SEVNFRM 2   | SNAK 2 | CNAK 2 | TXFN         |             | Stall 2 | Reserved 2 | EPTYP        | NAKSTS 1 | EONUM/DPID 1 | USBAEP 1    | Reserved  | <u>+ - -</u>      |          |            | IPSI       |          | <u>., ,</u>       | <u> </u>       |                          |
| 0x978  | Reset value<br>TG_FS_DTXFS<br>TS3<br>Reset value | 0           | 0       | 0         | 0 SI               | 0      | 0      | 0 0<br>Reser | 0 0<br>rved | 0       |            | 0 0          | 0        | 0            | 0           | 0101010   | 0 0 0<br>INEP     |          |            | 0          |          |                   |                | 0                        |
| 0xB00  | OTG_FS_DOEP<br>CTL0                              | EPE         | EPDIS   | por coord |                    | SNAK   | CNAK   | Reser        | rved        | Stall   | <b>NPM</b> | EPTY<br>P    | o NAKSTS | Reserved     |             |           | Reserv            | 0<br>ved | 0          | 0          | 0        | 0 0               | MP             | PSI<br>Z                 |
| 0xB20  | Reset value<br>OTG_FS_DOEP<br>CTL1               | EPENA O     | EPDIS   | SODDFRM   | SD0PID/SEVNFRM     | SNAK O | CNAK o | Reser        | rved        | Stall O | SNPM       | EPTYP o      | NAKSTS 0 | EONUM/DPID F | 1<br>NSBAEP | Reserved  |                   |          | M          | IPSI       | Z        |                   | 0              | 0                        |
| 0xB40  | Reset value<br>OTG_FS_DOEP<br>CTL2               | EPENA O     | EPDIS   | SODDFRM o | SD0PID/SEVNFRM o S | SNAK O | CNAK o | Reser        | rved        | Stall O | SNPM       | EPTYP<br>0   | NAKSTS O | EONUM/DPID O | USBAEP o    | Reserved  | 0 0 0             | 0        | 0<br>M     | 0<br>IPSI  |          | 0 0               | 0              | 0                        |
| 0xB60  | Reset value<br>OTG_FS_DOEP<br>CTL3               | EPE         | EPDIS   | SODDFRM   | SD0PID/SEVNFRM O   | SNAK O | CNAK O | Reser        | rved        | Stall O | SNPM 0     | 0<br>EPTYP   | NAKSTS O |              | USBAEP O    | Reserved  | 0 0 0             | 0        |            | 0<br>IPSI  | Z        | 0 0               |                | 0                        |
| 0x908  | Reset value OTG_FS_DIEPI NT0 Reset value         | 0           | 0       | 0         | 0                  | 0      | 0      |              |             | 0<br>F  | 0<br>Rese  | 0 0<br>erved | 0        | 0            | 0           |           | 0 0 0             | 0 JXLE 0 | o INEPNE o | Reserved o | ITTXFE   | Beserved o        | -              | o XFRC o                 |
| 0x928  | OTG_FS_DIEPI<br>NT1<br>Reset value               | -           |         |           |                    |        |        |              |             | F       | Rese       | erved        |          |              |             |           |                   | TXFE     |            | Reserved   | -        | A LUC<br>Reserved | o EPDISD       | <ul> <li>XFRC</li> </ul> |
| 0x948  | OTG_FS_DIEPI<br>NT2<br>Reset value               | PI Reserved |         |           |                    |        |        |              |             |         |            |              | TXFE     |              |             | -         | A LUC<br>Reserved | -        | o XFRC     |            |          |                   |                |                          |
| 0x968  | OTG_FS_DIEPI<br>NT3<br>Reset value               | -           |         |           |                    |        |        |              |             | F       | Rese       | erved        |          |              |             |           |                   | 1 TXFE   | -          |            | <u> </u> | COLOC<br>Reserved | o EPDISD       | <ul> <li>XFRC</li> </ul> |
| 0xB08  | OTG_FS_DOEP<br>INT0<br>Reset value               |             |         |           |                    |        |        |              |             | F       | Rese       | erved        |          |              |             |           |                   | Reserved | o B2BSTUP  | Reserved   | 0        | Reserved          | o EPDISD       | <ul> <li>XFRC</li> </ul> |
| 0xB28  | OTG_FS_DOEP<br>INT1<br>Reset value               | Reserved    |         |           |                    |        |        |              |             |         |            |              |          | Reserved     | OB2BSTUP    | Reserved  | 0                 | Reserved | o EPDISD   | o XFRC     |          |                   |                |                          |
|        | -                                                |             |         |           |                    |        |        |              |             |         |            |              | •        |              |             |           |                   |          |            |            |          |                   |                |                          |

| Table 155. | OTG_FS | register map | and reset | values | (continued) |
|------------|--------|--------------|-----------|--------|-------------|
|------------|--------|--------------|-----------|--------|-------------|



| Offset | Register                            | 31       |                    |   |    |     |      | -   | ŝ   |   |    |           | 19  | <u> </u> |    | 16 | 15 | 14 , | 13   | 12  | 11 | 10 | 6   | 8 | 7        | 9         | 5        | 4              | 3        | 2        | ۲        | 0                        |
|--------|-------------------------------------|----------|--------------------|---|----|-----|------|-----|-----|---|----|-----------|-----|----------|----|----|----|------|------|-----|----|----|-----|---|----------|-----------|----------|----------------|----------|----------|----------|--------------------------|
| 0xB48  | OTG_FS_DOEP<br>INT2<br>Reset value  |          |                    |   |    |     |      |     |     |   | Re | eser      | vec | ł        |    |    |    |      |      |     |    |    |     |   | Reserved | o B2BSTUP | Reserved |                | o STUP   | Reserved | o EPDISD | <ul> <li>XFRC</li> </ul> |
| 0xB68  | OTG_FS_DOEP<br>INT3<br>Reset value  |          |                    |   |    |     |      |     |     |   | Re | eser      | vec | ł        |    |    |    |      |      |     |    |    |     |   | Reserved | o B2BSTUP | Reserved | o OTEPDIS      | o STUP   | Reserved | o EPDISD | o XFRC                   |
| 0x910  | OTG_FS_DIEP<br>TSIZ0                |          |                    |   | Re | ser | /ed  |     |     |   |    | PKT<br>NT | -   |          |    |    |    | F    | Rese | rve | d  |    |     |   |          |           |          |                | RS       |          |          |                          |
|        | Reset value<br>OTG_FS_DIEP<br>TSIZ1 | ved      | MCNT               |   |    |     | PK   | TCI | ١T  |   |    | 0         | 0   |          |    |    |    |      |      |     |    | XF | RSI | z |          | 0         | 0        | 0              | 0        | 0        | 0        | 0                        |
| 0x930  | Reset value                         | Reserved | 0 0                | 0 | 0  | 0   | 0 0  | 0   | ) ( | ) | 0  | 0         | 0   | 0        | 0  | 0  | 0  | 0    | 0    | 0   | 0  | 0  | 0   | 0 | 0        | 0         | 0        | 0              | 0        | 0        | 0        | 0                        |
| 0x950  | OTG_FS_DIEP<br>TSIZ2                |          | MCNT               |   |    |     | PK   | TCI | NΤ  |   |    |           |     |          |    |    |    | 1    |      |     |    | XF | RSI | Z |          |           |          |                |          |          |          |                          |
| 0x950  | Reset value                         | Reserved | 0 0                | 0 | 0  | 0   | 0 0  | ) ( |     | ) | 0  | 0         | 0   | 0        | 0  | 0  | 0  | 0    | 0    | 0   | 0  | 0  | 0   | 0 | 0        | 0         | 0        | 0              | 0        | 0        | 0        | 0                        |
| 0x970  | OTG_FS_DIEP<br>TSIZ3                | Reserved | MCNT               |   |    | •   | PK   | тсі | NΤ  |   | •  | •         |     |          |    |    |    |      |      |     |    | XF | RSI | Z |          | •         |          | •              |          |          |          |                          |
| 0,370  | Reset value                         | Rese     | 0 0                | 0 | 0  | 0   | 0 0  | ) ( | ) ( | ) | 0  | 0         | 0   | 0        | 0  | 0  | 0  | 0    | 0    | 0   | 0  | 0  | 0   | 0 | 0        | 0         | 0        | 0              | 0        | 0        | 0        | 0                        |
| 0xB10  | OTG_FS_DOEP<br>TSIZ0                | Reserved | STUP<br>CNT        |   |    |     | Rese | rve | d   |   |    |           |     |          |    |    |    | F    | Rese | rve | d  |    |     |   |          |           |          | XF             | RS       | IZ       |          |                          |
|        | Reset value                         | ŭ        |                    |   |    |     |      |     |     |   |    |           | 0   |          |    |    |    |      |      |     |    |    |     |   |          | 0         | 0        | 0              | 0        | 0        | 0        | 0                        |
| 0xB30  | OTG_FS_DOEP<br>TSIZ1                | Reserved | RXDPID/<br>STUPCNT |   |    |     | PK   | TCI | NТ  |   |    |           |     |          |    |    |    |      |      |     |    | XF | RSI | Z |          |           |          |                |          |          |          |                          |
|        | Reset value                         | ш.       | 0 0<br>\ F         | 0 | 0  | 0   | 0 0  | ) ( | ) ( | ) | 0  | 0         | 0   | 0        | 0  | 0  | 0  | 0    | 0    | 0   | 0  | 0  | 0   | 0 | 0        | 0         | 0        | 0              | 0        | 0        | 0        | 0                        |
| 0xB50  | OTG_FS_DOEP<br>TSIZ2                | Reserved | RXDPID/<br>STUPCNT |   |    |     | PK   | TCI | NΤ  |   |    |           |     |          |    |    |    |      |      |     |    | XF | RSI | Z |          |           |          |                |          |          |          |                          |
|        | Reset value                         |          | 0 0<br>\ F         | 0 | 0  | 0   | 0 0  | ) ( | ) ( | ) | 0  | 0         | 0   | 0        | 0  | 0  | 0  | 0    | 0    | 0   | 0  | 0  | 0   | 0 | 0        | 0         | 0        | 0              | 0        | 0        | 0        | 0                        |
| 0xB70  | OTG_FS_DOEP<br>TSIZ3                | Reserved | RXDPID/<br>STUPCNT |   |    |     | PK   | TCI | ΝT  |   |    |           |     |          |    |    |    |      |      |     |    | XF | RSI | Z |          |           |          |                |          |          |          |                          |
|        | Reset value                         | ш.       | 0 0                | 0 | 0  | 0   | 0 0  | ) ( |     | ) | 0  | 0         | 0   | 0        | 0  | 0  | 0  | 0    | 0    | 0   | 0  | 0  | 0   | 0 | 0        | 0         | 0        | 0              | 0        | 0        | 0        | 0                        |
| 0xE00  | OTG_FS_PCG<br>CCTL                  |          |                    |   |    |     |      |     |     |   |    | I         | Res | serve    | ed |    |    |      |      |     |    |    |     |   |          |           |          | <b>JSUSYHA</b> | Recented |          | GATEHCLK | STPPCLK                  |
|        | Reset value                         |          |                    |   |    |     |      |     |     |   |    |           |     |          |    |    |    |      |      |     |    |    |     |   |          |           |          |                |          |          |          |                          |

| Table 155. | OTG_FS register map and reset values (continued) |
|------------|--------------------------------------------------|
|            |                                                  |

Refer to Table 1 on page 50 for the register boundary addresses.

# 29.17 OTG\_FS programming model

### 29.17.1 Core initialization

The application must perform the core initialization sequence. If the cable is connected during power-up, the current mode of operation bit in the OTG\_FS\_GINTSTS (CMOD bit in OTG\_FS\_GINTSTS) reflects the mode. The OTG\_FS controller enters host mode when an "A" plug is connected or device mode when a "B" plug is connected.



This section explains the initialization of the OTG\_FS controller after power-on. The application must follow the initialization sequence irrespective of host or device mode operation. All core global registers are initialized according to the core's configuration:

- 1. Program the following fields in the OTG\_FS\_GAHBCFG register:
  - Global interrupt mask bit GINTMSK = 1
  - RxFIFO non-empty (RXFLVL bit in OTG\_FS\_GINTSTS)
  - Periodic TxFIFO empty level
- 2. Program the following fields in the OTG\_FS\_GUSBCFG register:
  - HNP capable bit
  - SRP capable bit
  - FS timeout calibration field
  - USB turnaround time field
- The software must unmask the following bits in the OTG\_FS\_GINTMSK register: OTG interrupt mask

Mode mismatch interrupt mask

4. The software can read the CMOD bit in OTG\_FS\_GINTSTS to determine whether the OTG\_FS controller is operating in host or device mode.



### 29.17.2 Host initialization

To initialize the core as host, the application must perform the following steps:

- 1. Program the HPRTINT in the OTG\_FS\_GINTMSK register to unmask
- 2. Program the OTG\_FS\_HCFG register to select full-speed host
- 3. Program the PPWR bit in OTG\_FS\_HPRT to 1. This drives V<sub>BUS</sub> on the USB.
- 4. Wait for the PCDET interrupt in OTG\_FS\_HPRT0. This indicates that a device is connecting to the port.
- 5. Program the PRST bit in OTG\_FS\_HPRT to 1. This starts the reset process.
- 6. Wait at least 10 ms for the reset process to complete.
- 7. Program the PRST bit in OTG\_FS\_HPRT to 0.
- 8. Wait for the PENCHNG interrupt in OTG\_FS\_HPRT.
- 9. Read the PSPD bit in OTG\_FS\_HPRT to get the enumerated speed.
- 10. Program the HFIR register with a value corresponding to the selected PHY clock 1
- 11. Program the FSLSPCS field in the OTG\_FS\_HCFG register following the speed of the device detected in step 9. If FSLSPCS has been changed a port reset must be performed.
- 12. Program the OTG\_FS\_GRXFSIZ register to select the size of the receive FIFO.
- 13. Program the OTG\_FS\_HNPTXFSIZ register to select the size and the start address of the Non-periodic transmit FIFO for non-periodic transactions.
- 14. Program the OTG\_FS\_HPTXFSIZ register to select the size and start address of the periodic transmit FIFO for periodic transactions.

To communicate with devices, the system software must initialize and enable at least one channel.

### 29.17.3 Device initialization

The application must perform the following steps to initialize the core as a device on powerup or after a mode change from host to device.

- 1. Program the following fields in the OTG\_FS\_DCFG register:
  - Device speed
  - Non-zero-length status OUT handshake
- 2. Program the OTG\_FS\_GINTMSK register to unmask the following interrupts:
  - USB reset
  - Enumeration done
  - Early suspend
  - USB suspend
  - SOF
- 3. Program the VBUSBSEN bit in the OTG\_FS\_GCCFG register to enable V<sub>BUS</sub> sensing in "B" device mode and supply the 5 volts across the pull-up resistor on the DP line.
- 4. Wait for the USBRST interrupt in OTG\_FS\_GINTSTS. It indicates that a reset has been detected on the USB that lasts for about 10 ms on receiving this interrupt.

Wait for the ENUMDNE interrupt in OTG\_FS\_GINTSTS. This interrupt indicates the end of reset on the USB. On receiving this interrupt, the application must read the OTG\_FS\_DSTS



register to determine the enumeration speed and perform the steps listed in *Endpoint initialization on enumeration completion on page 1040*.

At this point, the device is ready to accept SOF packets and perform control transfers on control endpoint 0.

### 29.17.4 Host programming model

#### **Channel initialization**

The application must initialize one or more channels before it can communicate with connected devices. To initialize and enable a channel, the application must perform the following steps:

- 1. Program the OTG\_FS\_GINTMSK register to unmask the following:
- 2. Channel interrupt
  - Non-periodic transmit FIFO empty for OUT transactions (applicable when operating in pipelined transaction-level with the packet count field programmed with more than one).
  - Non-periodic transmit FIFO half-empty for OUT transactions (applicable when operating in pipelined transaction-level with the packet count field programmed with more than one).
- 3. Program the OTG\_FS\_HAINTMSK register to unmask the selected channels' interrupts.
- 4. Program the OTG\_FS\_HCINTMSK register to unmask the transaction-related interrupts of interest given in the host channel interrupt register.
- 5. Program the selected channel's OTG\_FS\_HCTSIZx register with the total transfer size, in bytes, and the expected number of packets, including short packets. The application must program the PID field with the initial data PID (to be used on the first OUT transaction or to be expected from the first IN transaction).
- 6. Program the OTG\_FS\_HCCHARx register of the selected channel with the device's endpoint characteristics, such as type, speed, direction, and so forth. (The channel can be enabled by setting the channel enable bit to 1 only when the application is ready to transmit or receive any packet).

#### Halting a channel

The application can disable any channel by programming the OTG\_FS\_HCCHARx register with the CHDIS and CHENA bits set to 1. This enables the OTG\_FS host to flush the posted requests (if any) and generates a channel halted interrupt. The application must wait for the CHH interrupt in OTG\_FS\_HCINTx before reallocating the channel for other transactions. The OTG\_FS host does not interrupt the transaction that has already been started on the USB.

Before disabling a channel, the application must ensure that there is at least one free space available in the non-periodic request queue (when disabling a non-periodic channel) or the periodic request queue (when disabling a periodic channel). The application can simply flush the posted requests when the Request queue is full (before disabling the channel), by programming the OTG\_FS\_HCCHARx register with the CHDIS bit set to 1, and the CHENA bit cleared to 0.

The application is expected to disable a channel on any of the following conditions:



- 1. When an STALL, TXERR, BBERR or DTERR interrupt in OTG\_FS\_HCINTx is received for an IN or OUT channel. The application must be able to receive other interrupts (DTERR, Nak, Data, TXERR) for the same channel before receiving the halt.
- 2. When a DISCINT (Disconnect Device) interrupt in OTG\_FS\_GINTSTS is received. (The application is expected to disable all enabled channels).
- 3. When the application aborts a transfer before normal completion.

### **Operational model**

The application must initialize a channel before communicating to the connected device. This section explains the sequence of operation to be performed for different types of USB transactions.

#### • Writing the transmit FIFO

The OTG\_FS host automatically writes an entry (OUT request) to the periodic/nonperiodic request queue, along with the last DWORD write of a packet. The application must ensure that at least one free space is available in the periodic/non-periodic request queue before starting to write to the transmit FIFO. The application must always write to the transmit FIFO in DWORDs. If the packet size is non-DWORD aligned, the application must use padding. The OTG\_FS host determines the actual packet size based on the programmed maximum packet size and transfer size.

#### Figure 352. Transmit FIFO write task





### • Reading the receive FIFO

The application must ignore all packet statuses other than IN data packet (bx0010).

#### Figure 353. Receive FIFO read task



# Bulk and control OUT/SETUP transactions A typical bulk or control OUT/SETUP pipelined transaction-level operation is shown in *Figure 354*. See channel 1 (ch\_1). Two bulk OUT packets are transmitted. A control



SETUP transaction operates in the same way but has only one packet. The assumptions are:

- The application is attempting to send two maximum-packet-size packets (transfer size = 1, 024 bytes).
- The non-periodic transmit FIFO can hold two packets (128 bytes for FS).
- The non-periodic request queue depth = 4.

#### • Normal bulk and control OUT/SETUP operations

The sequence of operations in (channel 1) is as follows:

- a) Initialize channel 1
- b) Write the first packet for channel 1
- c) Along with the last Word write, the core writes an entry to the non-periodic request queue
- d) As soon as the non-periodic queue becomes non-empty, the core attempts to send an OUT token in the current frame
- e) Write the second (last) packet for channel 1
- f) The core generates the XFRC interrupt as soon as the last transaction is completed successfully
- g) In response to the XFRC interrupt, de-allocate the channel for other transfers
- h) Handling non-ACK responses





Figure 354. Normal bulk/control OUT/SETUP and bulk/control IN transactions

The channel-specific interrupt service routine for bulk and control OUT/SETUP transactions is shown in the following code samples.

- Interrupt service routine for bulk/control OUT/SETUP and bulk/control IN transactions
  - a) Bulk/Control OUT/SETUP

```
Unmask (NAK/TXERR/STALL/XFRC)
if (XFRC)
    {
    Reset Error Count
    Mask ACK
```



```
De-allocate Channel
  }
else if (STALL)
  {
  Transfer Done = 1
  Unmask CHH
  Disable Channel
  }
else if (NAK or TXERR )
  {
  Rewind Buffer Pointers
  Unmask CHH
  Disable Channel
  if (TXERR)
     ł
     Increment Error Count
     Unmask ACK
     }
  else
     Reset Error Count
else if (CHH)
  {
  Mask CHH
  if (Transfer Done or (Error_count == 3))
     {
     De-allocate Channel
     }
  else
     {
     Re-initialize Channel
     }
  }
  else if (ACK)
     {
     Reset Error Count
     Mask ACK
     }
   The application is expected to write the data packets into the transmit FIFO as and
    when the space is available in the transmit FIFO and the Request queue. The
    application can make use of the NPTXFE interrupt in OTG_FS_GINTSTS to find the
   transmit FIFO space.
   b)
       Bulk/Control IN
Unmask (TXERR/XFRC/BBERR/STALL/DTERR)
if (XFRC)
  {
  Reset Error Count
  Unmask CHH
  Disable Channel
```



```
Reset Error Count
  Mask ACK
  }
else if (TXERR or BBERR or STALL)
  {
  Unmask CHH
  Disable Channel
  if (TXERR)
     ł
    Increment Error Count
    Unmask ACK
     }
  }
else if (CHH)
  {
  Mask CHH
  if (Transfer Done or (Error count == 3))
     {
    De-allocate Channel
     }
  else
    Re-initialize Channel
     }
  }
else if (ACK)
  {
  Reset Error Count
  Mask ACK
  }
else if (DTERR)
  {
  Reset Error Count
  }
```

The application is expected to write the requests as and when the Request queue space is available and until the XFRC interrupt is received.

#### • Bulk and control IN transactions

A typical bulk or control IN pipelined transaction-level operation is shown in *Figure 355*. See channel 2 (ch\_2). The assumptions are:

- The application is attempting to receive two maximum-packet-size packets (transfer size = 1 024 bytes).
- The receive FIFO can contain at least one maximum-packet-size packet and two status Words per packet (72 bytes for FS).
- The non-periodic request queue depth = 4.





Figure 355. Bulk/control IN transactions

The sequence of operations is as follows:

- a) Initialize channel 2.
- b) Set the CHENA bit in HCCHAR2 to write an IN request to the non-periodic request queue.
- c) The core attempts to send an IN token after completing the current OUT transaction.
- d) The core generates an RXFLVL interrupt as soon as the received packet is written to the receive FIFO.
- e) In response to the RXFLVL interrupt, mask the RXFLVL interrupt and read the received packet status to determine the number of bytes received, then read the receive FIFO accordingly. Following this, unmask the RXFLVL interrupt.



- f) The core generates the RXFLVL interrupt for the transfer completion status entry in the receive FIFO.
- g) The application must read and ignore the receive packet status when the receive packet status is not an IN data packet (PKTSTS in GRXSTSR  $\neq$  0b0010).
- h) The core generates the XFRC interrupt as soon as the receive packet status is read.
- In response to the XFRC interrupt, disable the channel and stop writing the OTG\_FS\_HCCHAR2 register for further requests. The core writes a channel disable request to the non-periodic request queue as soon as the OTG\_FS\_HCCHAR2 register is written.
- j) The core generates the RXFLVL interrupt as soon as the halt status is written to the receive FIFO.
- k) Read and ignore the receive packet status.
- I) The core generates a CHH interrupt as soon as the halt status is popped from the receive FIFO.
- m) In response to the CHH interrupt, de-allocate the channel for other transfers.
- n) Handling non-ACK responses

#### Control transactions

Setup, Data, and Status stages of a control transfer must be performed as three separate transfers. Setup-, Data- or Status-stage OUT transactions are performed similarly to the bulk OUT transactions explained previously. Data- or Status-stage IN transactions are performed similarly to the bulk IN transactions explained previously. For all three stages, the application is expected to set the EPTYP field in OTG\_FS\_HCCHAR1 to Control. During the Setup stage, the application is expected to set the PID field in OTG\_FS\_HCTSIZ1 to SETUP.

#### • Interrupt OUT transactions

A typical interrupt OUT operation is shown in *Figure 356*. The assumptions are:

- The application is attempting to send one packet in every frame (up to 1 maximum packet size), starting with the odd frame (transfer size = 1 024 bytes)
- The periodic transmit FIFO can hold one packet (1 KB)
- Periodic request queue depth = 4

The sequence of operations is as follows:

- a) Initialize and enable channel 1. The application must set the ODDFRM bit in OTG\_FS\_HCCHAR1.
- b) Write the first packet for channel 1.
- c) Along with the last Word write of each packet, the OTG\_FS host writes an entry to the periodic request queue.
- d) The OTG\_FS host attempts to send an OUT token in the next (odd) frame.
- e) The OTG\_FS host generates an XFRC interrupt as soon as the last packet is transmitted successfully.
- f) In response to the XFRC interrupt, reinitialize the channel for the next transfer.





Figure 356. Normal interrupt OUT/IN transactions



```
Disable Channel
     if (STALL)
       {
       Transfer Done = 1
       }
     }
  else
     if (NAK or TXERR)
       {
       Rewind Buffer Pointers
       Reset Error Count
       Mask ACK
       Unmask CHH
       Disable Channel
       }
     else
       if (CHH)
       {
       Mask CHH
       if (Transfer Done or (Error count == 3))
          {
         De-allocate Channel
          }
       else
         {
         Re-initialize Channel (in next b_interval - 1 Frame)
          }
       }
     else
       if (ACK)
       {
       Reset Error Count
       Mask ACK
       }
   The application uses the NPTXFE interrupt in OTG_FS_GINTSTS to find the transmit
   FIFO space.
   b) Interrupt IN
Unmask (NAK/TXERR/XFRC/BBERR/STALL/FRMOR/DTERR)
if (XFRC)
  {
  Reset Error Count
  Mask ACK
  if (OTG_FS_HCTSIZx.PKTCNT == 0)
    {
    De-allocate Channel
    }
  else
     {
    Transfer Done = 1
    Unmask CHH
    Disable Channel
```



```
}
  }
else
  if (STALL or FRMOR or NAK or DTERR or BBERR)
    {
    Mask ACK
    Unmask CHH
    Disable Channel
    if (STALL or BBERR)
       {
       Reset Error Count
       Transfer Done = 1
       }
     else
       if (!FRMOR)
       {
       Reset Error Count
       }
     }
else
  if (TXERR)
     {
    Increment Error Count
    Unmask ACK
    Unmask CHH
    Disable Channel
     }
else
  if (CHH)
     {
    Mask CHH
     if (Transfer Done or (Error count == 3))
       {
      De-allocate Channel
       }
     else
      Re-initialize Channel (in next b_interval - 1 /Frame)
     }
  }
else
  if (ACK)
    {
    Reset Error Count
    Mask ACK
     }
```



#### RM0090

### • Interrupt IN transactions

The assumptions are:

- The application is attempting to receive one packet (up to 1 maximum packet size) in every frame, starting with odd (transfer size = 1 024 bytes).
- The receive FIFO can hold at least one maximum-packet-size packet and two status Words per packet (1 031 bytes).
- Periodic request queue depth = 4.
- Normal interrupt IN operation

The sequence of operations is as follows:

- a) Initialize channel 2. The application must set the ODDFRM bit in OTG\_FS\_HCCHAR2.
- b) Set the CHENA bit in OTG\_FS\_HCCHAR2 to write an IN request to the periodic request queue.
- c) The OTG\_FS host writes an IN request to the periodic request queue for each OTG\_FS\_HCCHAR2 register write with the CHENA bit set.
- d) The OTG\_FS host attempts to send an IN token in the next (odd) frame.
- e) As soon as the IN packet is received and written to the receive FIFO, the OTG\_FS host generates an RXFLVL interrupt.
- f) In response to the RXFLVL interrupt, read the received packet status to determine the number of bytes received, then read the receive FIFO accordingly. The application must mask the RXFLVL interrupt before reading the receive FIFO, and unmask after reading the entire packet.
- g) The core generates the RXFLVL interrupt for the transfer completion status entry in the receive FIFO. The application must read and ignore the receive packet status when the receive packet status is not an IN data packet (PKTSTS in GRXSTSR ≠ 0b0010).
- h) The core generates an XFRC interrupt as soon as the receive packet status is read.
- i) In response to the XFRC interrupt, read the PKTCNT field in OTG\_FS\_HCTSIZ2. If the PKTCNT bit in OTG\_FS\_HCTSIZ2 is not equal to 0, disable the channel before re-initializing the channel for the next transfer, if any). If PKTCNT bit in OTG\_FS\_HCTSIZ2 = 0, reinitialize the channel for the next transfer. This time, the application must reset the ODDFRM bit in OTG\_FS\_HCCHAR2.



A typical isochronous OUT operation is shown in *Figure 357*. The assumptions are:

- The application is attempting to send one packet every frame (up to 1 maximum packet size), starting with an odd frame. (transfer size = 1 024 bytes).
- The periodic transmit FIFO can hold one packet (1 KB).
- Periodic request queue depth = 4.

**Isochronous OUT transactions** 

The sequence of operations is as follows:

- a) Initialize and enable channel 1. The application must set the ODDFRM bit in OTG\_FS\_HCCHAR1.
- b) Write the first packet for channel 1.
- c) Along with the last Word write of each packet, the OTG\_FS host writes an entry to the periodic request queue.
- d) The OTG\_FS host attempts to send the OUT token in the next frame (odd).
- e) The OTG\_FS host generates the XFRC interrupt as soon as the last packet is transmitted successfully.
- f) In response to the XFRC interrupt, reinitialize the channel for the next transfer.
- g) Handling non-ACK responses





Figure 357. Normal isochronous OUT/IN transactions

Interrupt service routine for isochronous OUT/IN transactions
 Code sample: Isochronous OUT

```
Unmask (FRMOR/XFRC)
if (XFRC)
   {
    De-allocate Channel
    }
else
    if (FRMOR)
     {
        Unmask CHH
        Disable Channel
    }
```



```
else
  if (CHH)
    {
    Mask CHH
    De-allocate Channel
    }
   Code sample: Isochronous IN
Unmask (TXERR/XFRC/FRMOR/BBERR)
if (XFRC or FRMOR)
  {
  if (XFRC and (OTG_FS_HCTSIZx.PKTCNT == 0))
   {
    Reset Error Count
    De-allocate Channel
    }
  else
    {
    Unmask CHH
    Disable Channel
    }
  }
  else
    if (TXERR or BBERR)
       {
       Increment Error Count
       Unmask CHH
       Disable Channel
       }
    else
       if (CHH)
         {
         Mask CHH
         if (Transfer Done or (Error_count == 3))
            {
            De-allocate Channel
            }
         else
            {
            Re-initialize Channel
            }
          }
```





#### • Isochronous IN transactions

The assumptions are:

- The application is attempting to receive one packet (up to 1 maximum packet size) in every frame starting with the next odd frame (transfer size = 1 024 bytes).
- The receive FIFO can hold at least one maximum-packet-size packet and two status Word per packet (1 031 bytes).
- Periodic request queue depth = 4.

The sequence of operations is as follows:

- a) Initialize channel 2. The application must set the ODDFRM bit in OTG\_FS\_HCCHAR2.
- b) Set the CHENA bit in OTG\_FS\_HCCHAR2 to write an IN request to the periodic request queue.
- c) The OTG\_FS host writes an IN request to the periodic request queue for each OTG\_FS\_HCCHAR2 register write with the CHENA bit set.
- d) The OTG\_FS host attempts to send an IN token in the next odd frame.
- e) As soon as the IN packet is received and written to the receive FIFO, the OTG\_FS host generates an RXFLVL interrupt.
- f) In response to the RXFLVL interrupt, read the received packet status to determine the number of bytes received, then read the receive FIFO accordingly. The application must mask the RXFLVL interrupt before reading the receive FIFO, and unmask it after reading the entire packet.
- g) The core generates an RXFLVL interrupt for the transfer completion status entry in the receive FIFO. This time, the application must read and ignore the receive packet status when the receive packet status is not an IN data packet (PKTSTS bit in OTG\_FS\_GRXSTSR ≠ 0b0010).
- h) The core generates an XFRC interrupt as soon as the receive packet status is read.
- i) In response to the XFRC interrupt, read the PKTCNT field in OTG\_FS\_HCTSIZ2. If PKTCNT≠ 0 in OTG\_FS\_HCTSIZ2, disable the channel before re-initializing the channel for the next transfer, if any. If PKTCNT = 0 in OTG\_FS\_HCTSIZ2, reinitialize the channel for the next transfer. This time, the application must reset the ODDFRM bit in OTG\_FS\_HCCHAR2.

#### • Selecting the queue depth

Choose the periodic and non-periodic request queue depths carefully to match the number of periodic/non-periodic endpoints accessed.

The non-periodic request queue depth affects the performance of non-periodic transfers. The deeper the queue (along with sufficient FIFO size), the more often the core is able to pipeline non-periodic transfers. If the queue size is small, the core is able to put in new requests only when the queue space is freed up.

The core's periodic request queue depth is critical to perform periodic transfers as scheduled. Select the periodic queue depth, based on the number of periodic transfers scheduled in a microframe. If the periodic request queue depth is smaller than the periodic transfers scheduled in a microframe, a frame overrun condition occurs.

#### Handling babble conditions

OTG\_FS controller handles two cases of babble: packet babble and port babble. Packet babble occurs if the device sends more data than the maximum packet size for





the channel. Port babble occurs if the core continues to receive data from the device at EOF2 (the end of frame 2, which is very close to SOF).

When OTG\_FS controller detects a packet babble, it stops writing data into the Rx buffer and waits for the end of packet (EOP). When it detects an EOP, it flushes already written data in the Rx buffer and generates a Babble interrupt to the application.

When OTG\_FS controller detects a port babble, it flushes the RxFIFO and disables the port. The core then generates a Port disabled interrupt (HPRTINT in OTG\_FS\_GINTSTS, PENCHNG in OTG\_FS\_HPRT). On receiving this interrupt, the application must determine that this is not due to an overcurrent condition (another cause of the Port Disabled interrupt) by checking POCA in OTG\_FS\_HPRT, then perform a soft reset. The core does not send any more tokens after it has detected a port babble condition.

# 29.17.5 Device programming model

### Endpoint initialization on USB reset

- 1. Set the NAK bit for all OUT endpoints
  - SNAK = 1 in OTG\_FS\_DOEPCTLx (for all OUT endpoints)
- 2. Unmask the following interrupt bits
  - INEP0 = 1 in OTG\_FS\_DAINTMSK (control 0 IN endpoint)
  - OUTEP0 = 1 in OTG\_FS\_DAINTMSK (control 0 OUT endpoint)
  - STUP = 1 in DOEPMSK
  - XFRC = 1 in DOEPMSK
  - XFRC = 1 in DIEPMSK
  - TOC = 1 in DIEPMSK
- 3. Set up the Data FIFO RAM for each of the FIFOs
  - Program the OTG\_FS\_GRXFSIZ register, to be able to receive control OUT data and setup data. If thresholding is not enabled, at a minimum, this must be equal to 1 max packet size of control endpoint 0 + 2 Words (for the status of the control OUT data packet) + 10 Words (for setup packets).
  - Program the OTG\_FS\_TX0FSIZ register (depending on the FIFO number chosen) to be able to transmit control IN data. At a minimum, this must be equal to 1 max packet size of control endpoint 0.
- 4. Program the following fields in the endpoint-specific registers for control OUT endpoint 0 to receive a SETUP packet
  - STUPCNT = 3 in OTG\_FS\_DOEPTSIZ0 (to receive up to 3 back-to-back SETUP packets)

At this point, all initialization required to receive SETUP packets is done.

#### Endpoint initialization on enumeration completion

- 1. On the Enumeration Done interrupt (ENUMDNE in OTG\_FS\_GINTSTS), read the OTG\_FS\_DSTS register to determine the enumeration speed.
- 2. Program the MPSIZ field in OTG\_FS\_DIEPCTL0 to set the maximum packet size. This step configures control endpoint 0. The maximum packet size for a control endpoint depends on the enumeration speed.



At this point, the device is ready to receive SOF packets and is configured to perform control transfers on control endpoint 0.

#### Endpoint initialization on SetAddress command

This section describes what the application must do when it receives a SetAddress command in a SETUP packet.

- 1. Program the OTG\_FS\_DCFG register with the device address received in the SetAddress command
- 1. Program the core to send out a status IN packet

#### Endpoint initialization on SetConfiguration/SetInterface command

This section describes what the application must do when it receives a SetConfiguration or SetInterface command in a SETUP packet.

- 1. When a SetConfiguration command is received, the application must program the endpoint registers to configure them with the characteristics of the valid endpoints in the new configuration.
- 2. When a SetInterface command is received, the application must program the endpoint registers of the endpoints affected by this command.
- 3. Some endpoints that were active in the prior configuration or alternate setting are not valid in the new configuration or alternate setting. These invalid endpoints must be deactivated.
- 4. Unmask the interrupt for each active endpoint and mask the interrupts for all inactive endpoints in the OTG\_FS\_DAINTMSK register.
- 5. Set up the Data FIFO RAM for each FIFO.
- 6. After all required endpoints are configured; the application must program the core to send a status IN packet.

At this point, the device core is configured to receive and transmit any type of data packet.

#### **Endpoint activation**

This section describes the steps required to activate a device endpoint or to configure an existing device endpoint to a new type.

- 1. Program the characteristics of the required endpoint into the following fields of the OTG\_FS\_DIEPCTLx register (for IN or bidirectional endpoints) or the OTG\_FS\_DOEPCTLx register (for OUT or bidirectional endpoints).
  - Maximum packet size
  - USB active endpoint = 1
  - Endpoint start data toggle (for interrupt and bulk endpoints)
  - Endpoint type
  - TxFIFO number
- 2. Once the endpoint is activated, the core starts decoding the tokens addressed to that endpoint and sends out a valid handshake for each valid token received for the endpoint.

#### Endpoint deactivation

This section describes the steps required to deactivate an existing endpoint.



Doc ID 018909 Rev 1

- 1. In the endpoint to be deactivated, clear the USB active endpoint bit in the OTG\_FS\_DIEPCTLx register (for IN or bidirectional endpoints) or the OTG\_FS\_DOEPCTLx register (for OUT or bidirectional endpoints).
- 2. Once the endpoint is deactivated, the core ignores tokens addressed to that endpoint, which results in a timeout on the USB.

Note: 1 The application must meet the following conditions to set up the device core to handle traffic: NPTXFEM and RXFLVLM in the OTG\_FS\_GINTMSK register must be cleared.

### 29.17.6 Operational model

#### **SETUP and OUT data transfers**

This section describes the internal data flow and application-level operations during data OUT transfers and SETUP transactions.

#### Packet read

This section describes how to read packets (OUT data and SETUP packets) from the receive FIFO.

- 1. On catching an RXFLVL interrupt (OTG\_FS\_GINTSTS register), the application must read the Receive status pop register (OTG\_FS\_GRXSTSP).
- 2. The application can mask the RXFLVL interrupt (in OTG\_FS\_GINTSTS) by writing to RXFLVL = 0 (in OTG\_FS\_GINTMSK), until it has read the packet from the receive FIFO.
- 3. If the received packet's byte count is not 0, the byte count amount of data is popped from the receive Data FIFO and stored in memory. If the received packet byte count is 0, no data is popped from the receive data FIFO.
- 4. The receive FIFO's packet status readout indicates one of the following:
  - a) Global OUT NAK pattern:
     PKTSTS = Global OUT NAK, BCNT = 0x000, EPNUM = Don't Care (0x0),
     DPID = Don't Care (0b00).
     These data indicate that the global OUT NAK bit has taken effect.
  - b) SETUP packet pattern: PKTSTS = SETUP, BCNT = 0x008, EPNUM = Control EP Num, DPID = D0. These data indicate that a SETUP packet for the specified endpoint is now available for reading from the receive FIFO.
  - c) Setup stage done pattern: PKTSTS = Setup Stage Done, BCNT = 0x0, EPNUM = Control EP Num, DPID = Don't Care (0b00). These data indicate that the Setup stage for the specified endpoint has completed and the Data stage has started. After this entry is popped from the receive FIFO, the core asserts a Setup interrupt on the specified control OUT endpoint.
    d) Data OUT packet pattern:
    - PKTSTS = DataOUT, BCNT = size of the received data OUT packet ( $0 \le BCNT \le 1.024$ ), EPNUM = EPNUM on which the packet was received, DPID = Actual Data PID.
  - e) Data transfer completed pattern:
     PKTSTS = Data OUT Transfer Done, BCNT = 0x0, EPNUM = OUT EP Num on which the data transfer is complete, DPID = Don't Care (0b00).
     These data indicate that an OUT data transfer for the specified OUT endpoint has



completed. After this entry is popped from the receive FIFO, the core asserts a Transfer Completed interrupt on the specified OUT endpoint.

- 5. After the data payload is popped from the receive FIFO, the RXFLVL interrupt (OTG\_FS\_GINTSTS) must be unmasked.
- 6. Steps 1–5 are repeated every time the application detects assertion of the interrupt line due to RXFLVL in OTG\_FS\_GINTSTS. Reading an empty receive FIFO can result in undefined core behavior.

*Figure 358* provides a flowchart of the above procedure.

#### Figure 358. Receive FIFO packet read



#### • SETUP transactions

This section describes how the core handles SETUP packets and the application's sequence for handling SETUP transactions.

#### • Application requirements

1. To receive a SETUP packet, the STUPCNT field (OTG\_FS\_DOEPTSIZx) in a control OUT endpoint must be programmed to a non-zero value. When the application programs the STUPCNT field to a non-zero value, the core receives SETUP packets and writes them to the receive FIFO, irrespective of the NAK status and EPENA bit setting in OTG\_FS\_DOEPCTLx. The STUPCNT field is decremented every time the control endpoint receives a SETUP packet. If the STUPCNT field is not programmed to a proper value before receiving a SETUP packet, the core still receives the SETUP packet and decrements the STUPCNT field, but the application may not be able to



determine the correct number of SETUP packets received in the Setup stage of a control transfer.

- STUPCNT = 3 in OTG\_FS\_DOEPTSIZx
- 2. The application must always allocate some extra space in the Receive data FIFO, to be able to receive up to three SETUP packets on a control endpoint.
  - The space to be reserved is 10 Words. Three Words are required for the first SETUP packet, 1 Word is required for the Setup stage done Word and 6 Words are required to store two extra SETUP packets among all control endpoints.
  - 3 Words per SETUP packet are required to store 8 bytes of SETUP data and 4 bytes of SETUP status (Setup packet pattern). The core reserves this space in the receive data.
  - FIFO to write SETUP data only, and never uses this space for data packets.
- 3. The application must read the 2 Words of the SETUP packet from the receive FIFO.
- 4. The application must read and discard the Setup stage done Word from the receive FIFO.
- Internal data flow
- 5. When a SETUP packet is received, the core writes the received data to the receive FIFO, without checking for available space in the receive FIFO and irrespective of the endpoint's NAK and STALL bit settings.
  - The core internally sets the IN NAK and OUT NAK bits for the control IN/OUT endpoints on which the SETUP packet was received.
- 6. For every SETUP packet received on the USB, 3 Words of data are written to the receive FIFO, and the STUPCNT field is decremented by 1.
  - The first Word contains control information used internally by the core
  - The second Word contains the first 4 bytes of the SETUP command
  - The third Word contains the last 4 bytes of the SETUP command
- 7. When the Setup stage changes to a Data IN/OUT stage, the core writes an entry (Setup stage done Word) to the receive FIFO, indicating the completion of the Setup stage.
- 8. On the AHB side, SETUP packets are emptied by the application.
- 9. When the application pops the Setup stage done Word from the receive FIFO, the core interrupts the application with an STUP interrupt (OTG\_FS\_DOEPINTx), indicating it can process the received SETUP packet.
  - The core clears the endpoint enable bit for control OUT endpoints.
- Application programming sequence
- Program the OTG\_FS\_DOEPTSIZx register.
   STUPCNT = 3
- 2. Wait for the RXFLVL interrupt (OTG\_FS\_GINTSTS) and empty the data packets from the receive FIFO.
- 3. Assertion of the STUP interrupt (OTG\_FS\_DOEPINTx) marks a successful completion of the SETUP Data Transfer.
  - On this interrupt, the application must read the OTG\_FS\_DOEPTSIZx register to determine the number of SETUP packets received and process the last received SETUP packet.





#### Figure 359. Processing a SETUP packet

#### • Handling more than three back-to-back SETUP packets

Per the USB 2.0 specification, normally, during a SETUP packet error, a host does not send more than three back-to-back SETUP packets to the same endpoint. However, the USB 2.0 specification does not limit the number of back-to-back SETUP packets a host can send to the same endpoint. When this condition occurs, the OTG\_FS controller generates an interrupt (B2BSTUP in OTG\_FS\_DOEPINTx).

#### • Setting the global OUT NAK

Internal data flow:

- 1. When the application sets the Global OUT NAK (SGONAK bit in OTG\_FS\_DCTL), the core stops writing data, except SETUP packets, to the receive FIFO. Irrespective of the space availability in the receive FIFO, non-isochronous OUT tokens receive a NAK handshake response, and the core ignores isochronous OUT data packets
- 2. The core writes the Global OUT NAK pattern to the receive FIFO. The application must reserve enough receive FIFO space to write this data pattern.
- 3. When the application pops the Global OUT NAK pattern Word from the receive FIFO, the core sets the GONAKEFF interrupt (OTG\_FS\_GINTSTS).
- 4. Once the application detects this interrupt, it can assume that the core is in Global OUT NAK mode. The application can clear this interrupt by clearing the SGONAK bit in OTG\_FS\_DCTL.

Application programming sequence



- 1. To stop receiving any kind of data in the receive FIFO, the application must set the Global OUT NAK bit by programming the following field:
  - SGONAK = 1 in OTG\_FS\_DCTL
- 2. Wait for the assertion of the GONAKEFF interrupt in OTG\_FS\_GINTSTS. When asserted, this interrupt indicates that the core has stopped receiving any type of data except SETUP packets.
- 3. The application can receive valid OUT packets after it has set SGONAK in OTG\_FS\_DCTL and before the core asserts the GONAKEFF interrupt (OTG\_FS\_GINTSTS).
- 4. The application can temporarily mask this interrupt by writing to the GINAKEFFM bit in the OTG\_FS\_GINTMSK register.
  - GINAKEFFM = 0 in the OTG\_FS\_GINTMSK register
- 5. Whenever the application is ready to exit the Global OUT NAK mode, it must clear the SGONAK bit in OTG\_FS\_DCTL. This also clears the GONAKEFF interrupt (OTG\_FS\_GINTSTS).
  - OTG\_FS\_DCTL = 1 in CGONAK
- 6. If the application has masked this interrupt earlier, it must be unmasked as follows:
  - GINAKEFFM = 1 in GINTMSK
- Disabling an OUT endpoint

The application must use this sequence to disable an OUT endpoint that it has enabled.

Application programming sequence:

- 1. Before disabling any OUT endpoint, the application must enable Global OUT NAK mode in the core.
  - SGONAK = 1 in OTG\_FS\_DCTL
- 2. Wait for the GONAKEFF interrupt (OTG\_FS\_GINTSTS)
- 3. Disable the required OUT endpoint by programming the following fields:
  - EPDIS = 1 in OTG\_FS\_DOEPCTLx
  - SNAK = 1 in OTG\_FS\_DOEPCTLx
- 4. Wait for the EPDISD interrupt (OTG\_FS\_DOEPINTx), which indicates that the OUT endpoint is completely disabled. When the EPDISD interrupt is asserted, the core also clears the following bits:
  - EPDIS = 0 in OTG\_FS\_DOEPCTLx
  - EPENA = 0 in OTG\_FS\_DOEPCTLx
- 5. The application must clear the Global OUT NAK bit to start receiving data from other non-disabled OUT endpoints.
  - SGONAK = 0 in OTG\_FS\_DCTL
- Generic non-isochronous OUT data transfers

This section describes a regular non-isochronous OUT data transfer (control, bulk, or interrupt).

Application requirements:



- 1. Before setting up an OUT transfer, the application must allocate a buffer in the memory to accommodate all data to be received as part of the OUT transfer.
- 2. For OUT transfers, the transfer size field in the endpoint's transfer size register must be a multiple of the maximum packet size of the endpoint, adjusted to the Word boundary.
  - transfer size[EPNUM] =  $n \times (MPSIZ[EPNUM] + 4 (MPSIZ[EPNUM] mod 4))$
  - packet count[EPNUM] = n
  - *n* > 0
- 3. On any OUT endpoint interrupt, the application must read the endpoint's transfer size register to calculate the size of the payload in the memory. The received payload size can be less than the programmed transfer size.
  - Payload size in memory = application programmed initial transfer size core updated final transfer size
  - Number of USB packets in which this payload was received = application programmed initial packet count – core updated final packet count

- 1. The application must set the transfer size and packet count fields in the endpointspecific registers, clear the NAK bit, and enable the endpoint to receive the data.
- 2. Once the NAK bit is cleared, the core starts receiving data and writes it to the receive FIFO, as long as there is space in the receive FIFO. For every data packet received on the USB, the data packet and its status are written to the receive FIFO. Every packet (maximum packet size or short packet) written to the receive FIFO decrements the packet count field for that endpoint by 1.
  - OUT data packets received with bad data CRC are flushed from the receive FIFO automatically.
  - After sending an ACK for the packet on the USB, the core discards nonisochronous OUT data packets that the host, which cannot detect the ACK, resends. The application does not detect multiple back-to-back data OUT packets on the same endpoint with the same data PID. In this case the packet count is not decremented.
  - If there is no space in the receive FIFO, isochronous or non-isochronous data packets are ignored and not written to the receive FIFO. Additionally, nonisochronous OUT tokens receive a NAK handshake reply.
  - In all the above three cases, the packet count is not decremented because no data are written to the receive FIFO.
- 3. When the packet count becomes 0 or when a short packet is received on the endpoint, the NAK bit for that endpoint is set. Once the NAK bit is set, the isochronous or non-isochronous data packets are ignored and not written to the receive FIFO, and non-isochronous OUT tokens receive a NAK handshake reply.
- 4. After the data are written to the receive FIFO, the application reads the data from the receive FIFO and writes it to external memory, one packet at a time per endpoint.
- 5. At the end of every packet write on the AHB to external memory, the transfer size for the endpoint is decremented by the size of the written packet.



- 6. The OUT data transfer completed pattern for an OUT endpoint is written to the receive FIFO on one of the following conditions:
  - The transfer size is 0 and the packet count is 0
  - The last OUT data packet written to the receive FIFO is a short packet (0 ≤ packet size < maximum packet size)</li>
- 7. When either the application pops this entry (OUT data transfer completed), a transfer completed interrupt is generated for the endpoint and the endpoint enable is cleared.

Application programming sequence:

- 1. Program the OTG\_FS\_DOEPTSIZx register for the transfer size and the corresponding packet count.
- 2. Program the OTG\_FS\_DOEPCTLx register with the endpoint characteristics, and set the EPENA and CNAK bits.
  - EPENA = 1 in OTG\_FS\_DOEPCTLx
  - CNAK = 1 in OTG\_FS\_DOEPCTLx
- 3. Wait for the RXFLVL interrupt (in OTG\_FS\_GINTSTS) and empty the data packets from the receive FIFO.
  - This step can be repeated many times, depending on the transfer size.
- 4. Asserting the XFRC interrupt (OTG\_FS\_DOEPINTx) marks a successful completion of the non-isochronous OUT data transfer.
- 5. Read the OTG\_FS\_DOEPTSIZx register to determine the size of the received data payload.
- Generic isochronous OUT data transfer

This section describes a regular isochronous OUT data transfer.

Application requirements:

- 1. All the application requirements for non-isochronous OUT data transfers also apply to isochronous OUT data transfers.
- 2. For isochronous OUT data transfers, the transfer size and packet count fields must always be set to the number of maximum-packet-size packets that can be received in a single frame and no more. Isochronous OUT data transfers cannot span more than 1 frame.
- The application must read all isochronous OUT data packets from the receive FIFO (data and status) before the end of the periodic frame (EOPF interrupt in OTG\_FS\_GINTSTS).
- 4. To receive data in the following frame, an isochronous OUT endpoint must be enabled after the EOPF (OTG\_FS\_GINTSTS) and before the SOF (OTG\_FS\_GINTSTS).

- 1. The internal data flow for isochronous OUT endpoints is the same as that for nonisochronous OUT endpoints, but for a few differences.
- 2. When an isochronous OUT endpoint is enabled by setting the Endpoint Enable and clearing the NAK bits, the Even/Odd frame bit must also be set appropriately. The core receives data on an isochronous OUT endpoint in a particular frame only if the following condition is met:
  - EONUM (in OTG\_FS\_DOEPCTLx) = SOFFN[0] (in OTG\_FS\_DSTS)
- 3. When the application completely reads an isochronous OUT data packet (data and status) from the receive FIFO, the core updates the RXDPID field in



OTG\_FS\_DOEPTSIZx with the data PID of the last isochronous OUT data packet read from the receive FIFO.

Application programming sequence:

- 1. Program the OTG\_FS\_DOEPTSIZx register for the transfer size and the corresponding packet count
- 2. Program the OTG\_FS\_DOEPCTLx register with the endpoint characteristics and set the Endpoint Enable, ClearNAK, and Even/Odd frame bits.
  - EPENA = 1
  - CNAK = 1
  - EONUM = (0: Even/1: Odd)
- 3. Wait for the RXFLVL interrupt (in OTG\_FS\_GINTSTS) and empty the data packets from the receive FIFO
  - This step can be repeated many times, depending on the transfer size.
- 4. The assertion of the XFRC interrupt (in OTG\_FS\_DOEPINTx) marks the completion of the isochronous OUT data transfer. This interrupt does not necessarily mean that the data in memory are good.
- 5. This interrupt cannot always be detected for isochronous OUT transfers. Instead, the application can detect the IISOOXFRM interrupt in OTG\_FS\_GINTSTS.
- 6. Read the OTG\_FS\_DOEPTSIZx register to determine the size of the received transfer and to determine the validity of the data received in the frame. The application must treat the data received in memory as valid only if one of the following conditions is met:
  - RXDPID = D0 (in OTG\_FS\_DOEPTSIZx) and the number of USB packets in which this payload was received = 1
  - RXDPID = D1 (in OTG\_FS\_DOEPTSIZx) and the number of USB packets in which this payload was received = 2
  - RXDPID = D2 (in OTG\_FS\_DOEPTSIZx) and the number of USB packets in which this payload was received = 3

The number of USB packets in which this payload was received = Application programmed initial packet count – Core updated final packet count

The application can discard invalid data packets.

#### • Incomplete isochronous OUT data transfers

This section describes the application programming sequence when isochronous OUT data packets are dropped inside the core.

- 1. For isochronous OUT endpoints, the XFRC interrupt (in OTG\_FS\_DOEPINTx) may not always be asserted. If the core drops isochronous OUT data packets, the application could fail to detect the XFRC interrupt (OTG\_FS\_DOEPINTx) under the following circumstances:
  - When the receive FIFO cannot accommodate the complete ISO OUT data packet, the core drops the received ISO OUT data
  - When the isochronous OUT data packet is received with CRC errors
  - When the isochronous OUT token received by the core is corrupted
  - When the application is very slow in reading the data from the receive FIFO
- 2. When the core detects an end of periodic frame before transfer completion to all isochronous OUT endpoints, it asserts the incomplete Isochronous OUT data interrupt



(IISOOXFRM in OTG\_FS\_GINTSTS), indicating that an XFRC interrupt (in OTG\_FS\_DOEPINTx) is not asserted on at least one of the isochronous OUT endpoints. At this point, the endpoint with the incomplete transfer remains enabled, but no active transfers remain in progress on this endpoint on the USB.

Application programming sequence:

- 1. Asserting the IISOOXFRM interrupt (OTG\_FS\_GINTSTS) indicates that in the current frame, at least one isochronous OUT endpoint has an incomplete transfer.
- 2. If this occurs because isochronous OUT data is not completely emptied from the endpoint, the application must ensure that the application empties all isochronous OUT data (data and status) from the receive FIFO before proceeding.
  - When all data are emptied from the receive FIFO, the application can detect the XFRC interrupt (OTG\_FS\_DOEPINTx). In this case, the application must reenable the endpoint to receive isochronous OUT data in the next frame.
- 3. When it receives an IISOOXFRM interrupt (in OTG\_FS\_GINTSTS), the application must read the control registers of all isochronous OUT endpoints (OTG\_FS\_DOEPCTLx) to determine which endpoints had an incomplete transfer in the current microframe. An endpoint transfer is incomplete if both the following conditions are met:
  - EONUM bit (in OTG\_FS\_DOEPCTLx) = SOFFN[0] (in OTG\_FS\_DSTS)
  - EPENA = 1 (in OTG\_FS\_DOEPCTLx)
- 4. The previous step must be performed before the SOF interrupt (in OTG\_FS\_GINTSTS) is detected, to ensure that the current frame number is not changed.
- 5. For isochronous OUT endpoints with incomplete transfers, the application must discard the data in the memory and disable the endpoint by setting the EPDIS bit in OTG\_FS\_DOEPCTLx.
- 6. Wait for the EPDIS interrupt (in OTG\_FS\_DOEPINTx) and enable the endpoint to receive new data in the next frame.
  - Because the core can take some time to disable the endpoint, the application may not be able to receive the data in the next frame after receiving bad isochronous data.

#### • Stalling a non-isochronous OUT endpoint

This section describes how the application can stall a non-isochronous endpoint.

- 1. Put the core in the Global OUT NAK mode.
- 2. Disable the required endpoint
  - When disabling the endpoint, instead of setting the SNAK bit in OTG\_FS\_DOEPCTL, set STALL = 1 (in OTG\_FS\_DOEPCTL).

The STALL bit always takes precedence over the NAK bit.

- 3. When the application is ready to end the STALL handshake for the endpoint, the STALL bit (in OTG\_FS\_DOEPCTLx) must be cleared.
- 4. If the application is setting or clearing a STALL for an endpoint due to a SetFeature.Endpoint Halt or ClearFeature.Endpoint Halt command, the STALL bit must be set or cleared before the application sets up the Status stage transfer on the control endpoint.



#### Examples

This section describes and depicts some fundamental transfer types and scenarios.

Bulk OUT transaction

*Figure 360* depicts the reception of a single Bulk OUT Data packet from the USB to the AHB and describes the events involved in the process.





After a SetConfiguration/SetInterface command, the application initializes all OUT endpoints by setting CNAK = 1 and EPENA = 1 (in OTG\_FS\_DOEPCTLx), and setting a suitable XFRSIZ and PKTCNT in the OTG\_FS\_DOEPTSIZx register.

- 1. host attempts to send data (OUT token) to an endpoint.
- 2. When the core receives the OUT token on the USB, it stores the packet in the RxFIFO because space is available there.
- 3. After writing the complete packet in the RxFIFO, the core then asserts the RXFLVL interrupt (in OTG\_FS\_GINTSTS).
- 4. On receiving the PKTCNT number of USB packets, the core internally sets the NAK bit for this endpoint to prevent it from receiving any more packets.
- 5. The application processes the interrupt and reads the data from the RxFIFO.
- 6. When the application has read all the data (equivalent to XFRSIZ), the core generates an XFRC interrupt (in OTG\_FS\_DOEPINTx).
- 7. The application processes the interrupt and uses the setting of the XFRC interrupt bit (in OTG\_FS\_DOEPINTx) to determine that the intended transfer is complete.



#### IN data transfers

#### • Packet write

This section describes how the application writes data packets to the endpoint FIFO when dedicated transmit FIFOs are enabled.

- 1. The application can either choose the polling or the interrupt mode.
  - In polling mode, the application monitors the status of the endpoint transmit data FIFO by reading the OTG\_FS\_DTXFSTSx register, to determine if there is enough space in the data FIFO.
  - In interrupt mode, the application waits for the TXFE interrupt (in OTG\_FS\_DIEPINTx) and then reads the OTG\_FS\_DTXFSTSx register, to determine if there is enough space in the data FIFO.
  - To write a single non-zero length data packet, there must be space to write the entire packet in the data FIFO.
  - To write zero length packet, the application must not look at the FIFO space.
- 2. Using one of the above mentioned methods, when the application determines that there is enough space to write a transmit packet, the application must first write into the endpoint control register, before writing the data into the data FIFO. Typically, the application, must do a read modify write on the OTG\_FS\_DIEPCTLx register to avoid modifying the contents of the register, except for setting the Endpoint Enable bit.

The application can write multiple packets for the same endpoint into the transmit FIFO, if space is available. For periodic IN endpoints, the application must write packets only for one microframe. It can write packets for the next periodic transaction only after getting transfer complete for the previous transaction.

#### • Setting IN endpoint NAK

Internal data flow:

- 1. When the application sets the IN NAK for a particular endpoint, the core stops transmitting data on the endpoint, irrespective of data availability in the endpoint's transmit FIFO.
- 2. Non-isochronous IN tokens receive a NAK handshake reply
  - Isochronous IN tokens receive a zero-data-length packet reply
- 3. The core asserts the INEPNE (IN endpoint NAK effective) interrupt in OTG\_FS\_DIEPINTx in response to the SNAK bit in OTG\_FS\_DIEPCTLx.
- 4. Once this interrupt is seen by the application, the application can assume that the endpoint is in IN NAK mode. This interrupt can be cleared by the application by setting the CNAK bit in OTG\_FS\_DIEPCTLx.

Application programming sequence:



1. To stop transmitting any data on a particular IN endpoint, the application must set the IN NAK bit. To set this bit, the following field must be programmed.

– SNAK = 1 in OTG\_FS\_DIEPCTLx

- 2. Wait for assertion of the INEPNE interrupt in OTG\_FS\_DIEPINTx. This interrupt indicates that the core has stopped transmitting data on the endpoint.
- 3. The core can transmit valid IN data on the endpoint after the application has set the NAK bit, but before the assertion of the NAK Effective interrupt.
- 4. The application can mask this interrupt temporarily by writing to the INEPNEM bit in DIEPMSK.
  - INEPNEM = 0 in DIEPMSK
- To exit Endpoint NAK mode, the application must clear the NAK status bit (NAKSTS) in OTG\_FS\_DIEPCTLx. This also clears the INEPNE interrupt (in OTG\_FS\_DIEPINTx).
   CNAK = 1 in OTG\_FS\_DIEPCTLx
- 6. If the application masked this interrupt earlier, it must be unmasked as follows:
  - INEPNEM = 1 in DIEPMSK

#### • IN endpoint disable

Use the following sequence to disable a specific IN endpoint that has been previously enabled.

Application programming sequence:

- 1. The application must stop writing data on the AHB for the IN endpoint to be disabled.
- 2. The application must set the endpoint in NAK mode.
  - SNAK = 1 in OTG\_FS\_DIEPCTLx
- 3. Wait for the INEPNE interrupt in OTG\_FS\_DIEPINTx.
- 4. Set the following bits in the OTG\_FS\_DIEPCTLx register for the endpoint that must be disabled.
  - EPDIS = 1 in OTG\_FS\_DIEPCTLx
  - SNAK = 1 in OTG\_FS\_DIEPCTLx
- 5. Assertion of the EPDISD interrupt in OTG\_FS\_DIEPINTx indicates that the core has completely disabled the specified endpoint. Along with the assertion of the interrupt, the core also clears the following bits:
  - EPENA = 0 in OTG\_FS\_DIEPCTLx
  - EPDIS = 0 in OTG\_FS\_DIEPCTLx
- 6. The application must read the OTG\_FS\_DIEPTSIZx register for the periodic IN EP, to calculate how much data on the endpoint were transmitted on the USB.
- 7. The application must flush the data in the Endpoint transmit FIFO, by setting the following fields in the OTG\_FS\_GRSTCTL register:
  - TXFNUM (in OTG\_FS\_GRSTCTL) = Endpoint transmit FIFO number
  - TXFFLSH in (OTG\_FS\_GRSTCTL) = 1

The application must poll the OTG\_FS\_GRSTCTL register, until the TXFFLSH bit is cleared by the core, which indicates the end of flush operation. To transmit new data on this endpoint, the application can re-enable the endpoint at a later point.



#### • Generic non-periodic IN data transfers

Application requirements:

- 1. Before setting up an IN transfer, the application must ensure that all data to be transmitted as part of the IN transfer are part of a single buffer.
- 2. For IN transfers, the Transfer Size field in the Endpoint Transfer Size register denotes a payload that constitutes multiple maximum-packet-size packets and a single short packet. This short packet is transmitted at the end of the transfer.
  - To transmit a few maximum-packet-size packets and a short packet at the end of the transfer:

Transfer size[EPNUM] =  $x \times MPSIZ[EPNUM] + sp$ 

If (sp > 0), then packet count[EPNUM] = x + 1.

Otherwise, packet count[EPNUM] = x

– To transmit a single zero-length data packet:

Transfer size[EPNUM] = 0

Packet count[EPNUM] = 1

 To transmit a few maximum-packet-size packets and a zero-length data packet at the end of the transfer, the application must split the transfer into two parts. The first sends maximum-packet-size data packets and the second sends the zerolength data packet alone.

First transfer: transfer size[EPNUM] =  $x \times MPSIZ[epnum]$ ; packet count = n; Second transfer: transfer size[EPNUM] = 0; packet count = 1;

- 3. Once an endpoint is enabled for data transfers, the core updates the Transfer size register. At the end of the IN transfer, the application must read the Transfer size register to determine how much data posted in the transmit FIFO have already been sent on the USB.
- 4. Data fetched into transmit FIFO = Application-programmed initial transfer size coreupdated final transfer size
  - Data transmitted on USB = (application-programmed initial packet count Core updated final packet count) × MPSIZ[EPNUM]
  - Data yet to be transmitted on USB = (Application-programmed initial transfer size – data transmitted on USB)

- 1. The application must set the transfer size and packet count fields in the endpointspecific registers and enable the endpoint to transmit the data.
- 2. The application must also write the required data to the transmit FIFO for the endpoint.
- 3. Every time a packet is written into the transmit FIFO by the application, the transfer size for that endpoint is decremented by the packet size. The data is fetched from the memory by the application, until the transfer size for the endpoint becomes 0. After writing the data into the FIFO, the "number of packets in FIFO" count is incremented (this is a 3-bit count, internally maintained by the core for each IN endpoint transmit FIFO. The maximum number of packets maintained by the core at any time in an IN endpoint FIFO is eight). For zero-length packets, a separate flag is set for each FIFO, without any data in the FIFO.
- 4. Once the data are written to the transmit FIFO, the core reads them out upon receiving an IN token. For every non-isochronous IN data packet transmitted with an ACK



handshake, the packet count for the endpoint is decremented by one, until the packet count is zero. The packet count is not decremented on a timeout.

- 5. For zero length packets (indicated by an internal zero length flag), the core sends out a zero-length packet for the IN token and decrements the packet count field.
- 6. If there are no data in the FIFO for a received IN token and the packet count field for that endpoint is zero, the core generates an "IN token received when TxFIFO is empty" (ITTXFE) Interrupt for the endpoint, provided that the endpoint NAK bit is not set. The core responds with a NAK handshake for non-isochronous endpoints on the USB.
- 7. The core internally rewinds the FIFO pointers and no timeout interrupt is generated.
- 8. When the transfer size is 0 and the packet count is 0, the transfer complete (XFRC) interrupt for the endpoint is generated and the endpoint enable is cleared.

Application programming sequence:

- 1. Program the OTG\_FS\_DIEPTSIZx register with the transfer size and corresponding packet count.
- 2. Program the OTG\_FS\_DIEPCTLx register with the endpoint characteristics and set the CNAK and EPENA (Endpoint Enable) bits.
- 3. When transmitting non-zero length data packet, the application must poll the OTG\_FS\_DTXFSTSx register (where x is the FIFO number associated with that endpoint) to determine whether there is enough space in the data FIFO. The application can optionally use TXFE (in OTG\_FS\_DIEPINTx) before writing the data.

#### Generic periodic IN data transfers

This section describes a typical periodic IN data transfer.

Application requirements:

- 1. Application requirements 1, 2, 3, and 4 of *Generic non-periodic IN data transfers on page 1054* also apply to periodic IN data transfers, except for a slight modification of requirement 2.
  - The application can only transmit multiples of maximum-packet-size data packets or multiples of maximum-packet-size packets, plus a short packet at the end. To transmit a few maximum-packet-size packets and a short packet at the end of the transfer, the following conditions must be met:

transfer size[EPNUM] =  $x \times MPSIZ[EPNUM] + sp$ (where x is an integer  $\ge 0$ , and  $0 \le sp < MPSIZ[EPNUM]$ )

If (sp > 0), packet count[EPNUM] = x + 1

Otherwise, packet count[EPNUM] = x;

MCNT[EPNUM] = packet count[EPNUM]

- The application cannot transmit a zero-length data packet at the end of a transfer.
   It can transmit a single zero-length data packet by itself. To transmit a single zero-length data packet:
- transfer size[EPNUM] = 0

packet count[EPNUM] = 1 MCNT[EPNUM] = packet count[EPNUM]



- 2. The application can only schedule data transfers one frame at a time.
  - $\quad (\mathsf{MCNT}-1) \times \mathsf{MPSIZ} \leq \; \mathsf{XFERSIZ} \leq \; \mathsf{MCNT} \times \mathsf{MPSIZ}$
  - PKTCNT = MCNT (in OTG\_FS\_DIEPTSIZx)
  - If XFERSIZ < MCNT × MPSIZ, the last data packet of the transfer is a short packet.
  - Note that: MCNT is in OTG\_FS\_DIEPTSIZx, MPSIZ is in OTG\_FS\_DIEPCTLx, PKTCNT is in OTG\_FS\_DIEPTSIZx and XFERSIZ is in OTG\_FS\_DIEPTSIZx
- 3. The complete data to be transmitted in the frame must be written into the transmit FIFO by the application, before the IN token is received. Even when 1 Word of the data to be transmitted per frame is missing in the transmit FIFO when the IN token is received, the core behaves as when the FIFO is empty. When the transmit FIFO is empty:
  - A zero data length packet would be transmitted on the USB for isochronous IN endpoints
  - A NAK handshake would be transmitted on the USB for interrupt IN endpoints

- 1. The application must set the transfer size and packet count fields in the endpointspecific registers and enable the endpoint to transmit the data.
- 2. The application must also write the required data to the associated transmit FIFO for the endpoint.
- 3. Every time the application writes a packet to the transmit FIFO, the transfer size for that endpoint is decremented by the packet size. The data are fetched from application memory until the transfer size for the endpoint becomes 0.
- 4. When an IN token is received for a periodic endpoint, the core transmits the data in the FIFO, if available. If the complete data payload (complete packet, in dedicated FIFO mode) for the frame is not present in the FIFO, then the core generates an IN token received when TxFIFO empty interrupt for the endpoint.
  - A zero-length data packet is transmitted on the USB for isochronous IN endpoints
  - A NAK handshake is transmitted on the USB for interrupt IN endpoints
- 5. The packet count for the endpoint is decremented by 1 under the following conditions:
  - For isochronous endpoints, when a zero- or non-zero-length data packet is transmitted
  - For interrupt endpoints, when an ACK handshake is transmitted
  - When the transfer size and packet count are both 0, the transfer completed interrupt for the endpoint is generated and the endpoint enable is cleared.
- 6. At the "Periodic frame Interval" (controlled by PFIVL in OTG\_FS\_DCFG), when the core finds non-empty any of the isochronous IN endpoint FIFOs scheduled for the current frame non-empty, the core generates an IISOIXFR interrupt in OTG\_FS\_GINTSTS.



Application programming sequence:

- 1. Program the OTG\_FS\_DIEPCTLx register with the endpoint characteristics and set the CNAK and EPENA bits.
- 2. Write the data to be transmitted in the next frame to the transmit FIFO.
- 3. Asserting the ITTXFE interrupt (in OTG\_FS\_DIEPINTx) indicates that the application has not yet written all data to be transmitted to the transmit FIFO.
- 4. If the interrupt endpoint is already enabled when this interrupt is detected, ignore the interrupt. If it is not enabled, enable the endpoint so that the data can be transmitted on the next IN token attempt.
- Asserting the XFRC interrupt (in OTG\_FS\_DIEPINTx) with no ITTXFE interrupt in OTG\_FS\_DIEPINTx indicates the successful completion of an isochronous IN transfer. A read to the OTG\_FS\_DIEPTSIZx register must give transfer size = 0 and packet count = 0, indicating all data were transmitted on the USB.
- 6. Asserting the XFRC interrupt (in OTG\_FS\_DIEPINTx), with or without the ITTXFE interrupt (in OTG\_FS\_DIEPINTx), indicates the successful completion of an interrupt IN transfer. A read to the OTG\_FS\_DIEPTSIZx register must give transfer size = 0 and packet count = 0, indicating all data were transmitted on the USB.
- Asserting the incomplete isochronous IN transfer (IISOIXFR) interrupt in OTG\_FS\_GINTSTS with none of the aforementioned interrupts indicates the core did not receive at least 1 periodic IN token in the current frame.
- Incomplete isochronous IN data transfers

This section describes what the application must do on an incomplete isochronous IN data transfer.

Internal data flow:

- 1. An isochronous IN transfer is treated as incomplete in one of the following conditions:
  - a) The core receives a corrupted isochronous IN token on at least one isochronous IN endpoint. In this case, the application detects an incomplete isochronous IN transfer interrupt (IISOIXFR in OTG\_FS\_GINTSTS).
  - b) The application is slow to write the complete data payload to the transmit FIFO and an IN token is received before the complete data payload is written to the FIFO. In this case, the application detects an IN token received when TxFIFO empty interrupt in OTG\_FS\_DIEPINTx. The application can ignore this interrupt, as it eventually results in an incomplete isochronous IN transfer interrupt (IISOIXFR in OTG\_FS\_GINTSTS) at the end of periodic frame.

The core transmits a zero-length data packet on the USB in response to the received IN token.

- 2. The application must stop writing the data payload to the transmit FIFO as soon as possible.
- 3. The application must set the NAK bit and the disable bit for the endpoint.
- 4. The core disables the endpoint, clears the disable bit, and asserts the Endpoint Disable interrupt for the endpoint.



Application programming sequence:

- 1. The application can ignore the IN token received when TxFIFO empty interrupt in OTG\_FS\_DIEPINTx on any isochronous IN endpoint, as it eventually results in an incomplete isochronous IN transfer interrupt (in OTG\_FS\_GINTSTS).
- 2. Assertion of the incomplete isochronous IN transfer interrupt (in OTG\_FS\_GINTSTS) indicates an incomplete isochronous IN transfer on at least one of the isochronous IN endpoints.
- 3. The application must read the Endpoint Control register for all isochronous IN endpoints to detect endpoints with incomplete IN data transfers.
- 4. The application must stop writing data to the Periodic Transmit FIFOs associated with these endpoints on the AHB.
- 5. Program the following fields in the OTG\_FS\_DIEPCTLx register to disable the endpoint:
  - SNAK = 1 in OTG\_FS\_DIEPCTLx
  - EPDIS = 1 in OTG\_FS\_DIEPCTLx
- 6. The assertion of the Endpoint Disabled interrupt in OTG\_FS\_DIEPINTx indicates that the core has disabled the endpoint.
  - At this point, the application must flush the data in the associated transmit FIFO or overwrite the existing data in the FIFO by enabling the endpoint for a new transfer in the next microframe. To flush the data, the application must use the OTG\_FS\_GRSTCTL register.

#### • Stalling non-isochronous IN endpoints

This section describes how the application can stall a non-isochronous endpoint.

Application programming sequence:

- 1. Disable the IN endpoint to be stalled. Set the STALL bit as well.
- 2. EPDIS = 1 in OTG\_FS\_DIEPCTLx, when the endpoint is already enabled
  - STALL = 1 in OTG\_FS\_DIEPCTLx
  - The STALL bit always takes precedence over the NAK bit
- 3. Assertion of the Endpoint Disabled interrupt (in OTG\_FS\_DIEPINTx) indicates to the application that the core has disabled the specified endpoint.
- 4. The application must flush the non-periodic or periodic transmit FIFO, depending on the endpoint type. In case of a non-periodic endpoint, the application must re-enable the other non-periodic endpoints that do not need to be stalled, to transmit data.
- 5. Whenever the application is ready to end the STALL handshake for the endpoint, the STALL bit must be cleared in OTG\_FS\_DIEPCTLx.
- 6. If the application sets or clears a STALL bit for an endpoint due to a SetFeature.Endpoint Halt command or ClearFeature.Endpoint Halt command, the STALL bit must be set or cleared before the application sets up the Status stage transfer on the control endpoint.

Special case: stalling the control OUT endpoint

The core must stall IN/OUT tokens if, during the data stage of a control transfer, the host sends more IN/OUT tokens than are specified in the SETUP packet. In this case, the application must enable the ITTXFE interrupt in OTG\_FS\_DIEPINTx and the OTEPDIS interrupt in OTG\_FS\_DOEPINTx during the data stage of the control transfer, after the core has transferred the amount of data specified in the SETUP packet. Then, when the



application receives this interrupt, it must set the STALL bit in the corresponding endpoint control register, and clear this interrupt.

#### 29.17.7 Worst case response time

When the OTG\_FS controller acts as a device, there is a worst case response time for any tokens that follow an isochronous OUT. This worst case response time depends on the AHB clock frequency.

The core registers are in the AHB domain, and the core does not accept another token before updating these register values. The worst case is for any token following an isochronous OUT, because for an isochronous transaction, there is no handshake and the next token could come sooner. This worst case value is 7 PHY clocks when the AHB clock is the same as the PHY clock. When the AHB clock is faster, this value is smaller.

If this worst case condition occurs, the core responds to bulk/interrupt tokens with a NAK and drops isochronous and SETUP tokens. The host interprets this as a timeout condition for SETUP and retries the SETUP packet. For isochronous transfers, the Incomplete isochronous IN transfer interrupt (IISOIXFR) and Incomplete isochronous OUT transfer interrupt (IISOOXFR) inform the application that isochronous IN/OUT packets were dropped.

#### Choosing the value of TRDT in OTG\_FS\_GUSBCFG

The value in TRDT (OTG\_FS\_GUSBCFG) is the time it takes for the MAC, in terms of PHY clocks after it has received an IN token, to get the FIFO status, and thus the first data from the PFC block. This time involves the synchronization delay between the PHY and AHB clocks. The worst case delay for this is when the AHB clock is the same as the PHY clock. In this case, the delay is 5 clocks.

Once the MAC receives an IN token, this information (token received) is synchronized to the AHB clock by the PFC (the PFC runs on the AHB clock). The PFC then reads the data from the SPRAM and writes them into the dual clock source buffer. The MAC then reads the data out of the source buffer (4 deep).

If the AHB is running at a higher frequency than the PHY, the application can use a smaller value for TRDT (in OTG\_FS\_GUSBCFG).

Figure 361 has the following signals:

- tkn\_rcvd: Token received information from MAC to PFC
- dynced\_tkn\_rcvd: Doubled sync tkn\_rcvd, from PCLK to HCLK domain
- spr\_read: Read to SPRAM
- spr\_addr: Address to SPRAM
- spr\_rdata: Read data from SPRAM
- srcbuf\_push: Push to the source buffer
- srcbuf\_rdata: Read data from the source buffer. Data seen by MAC

The application can use the following formula to calculate the value of TRDT:

 $4 \times AHB \operatorname{clock} + 1 \operatorname{PHY} \operatorname{clock} = (2 \operatorname{clock} \operatorname{sync} + 1 \operatorname{clock} \operatorname{memory} \operatorname{address} + 1 \operatorname{clock} \operatorname{memory} \operatorname{data} \operatorname{from} \operatorname{sync} \operatorname{RAM}) + (1 \operatorname{PHY} \operatorname{clock} (\operatorname{next} \operatorname{PHY} \operatorname{clock} \operatorname{MAC} \operatorname{can} \operatorname{sample} \operatorname{the} 2 \operatorname{clock} \operatorname{FIFO} \operatorname{outputs})$ 





#### Figure 361. TRDT max timing case

# 29.17.8 OTG programming model

The OTG\_FS controller is an OTG device supporting HNP and SRP. When the core is connected to an "A" plug, it is referred to as an A-device. When the core is connected to a "B" plug it is referred to as a B-device. In host mode, the OTG\_FS controller turns off V<sub>BUS</sub> to conserve power. SRP is a method by which the B-device signals the A-device to turn on V<sub>BUS</sub> power. A device must perform both data-line pulsing and V<sub>BUS</sub> pulsing, but a host can detect either data-line pulsing or V<sub>BUS</sub> pulsing for SRP. HNP is a method by which the B-device negotiates and switches to host role. In Negotiated mode after HNP, the B-device suspends the bus and reverts to the device role.

#### A-device session request protocol

The application must set the SRP-capable bit in the Core USB configuration register. This enables the OTG\_FS controller to detect SRP as an A-device.







1. DRV\_VBUS =  $V_{BUS}$  drive signal to the PHY VBUS\_VALID =  $V_{BUS}$  valid signal from PHY A\_VALID = A-peripheral  $V_{BUS}$  level signal to PHY D+ = Data plus line D- = Data minus line

- 1. To save power, the application suspends and turns off port power when the bus is idle by writing the port suspend and port power bits in the host port control and status register.
- 2. PHY indicates port power off by deasserting the VBUS\_VALID signal.
- 3. The device must detect SE0 for at least 2 ms to start SRP when V<sub>BUS</sub> power is off.
- 4. To initiate SRP, the device turns on its data line pull-up resistor for 5 to 10 ms. The OTG\_FS controller detects data-line pulsing.
- 5. The device drives  $\rm V_{BUS}$  above the A-device session valid (2.0 V minimum) for  $\rm V_{BUS}$  pulsing.

The OTG\_FS controller interrupts the application on detecting SRP. The Session request detected bit is set in Global interrupt status register (SRQINT set in OTG\_FS\_GINTSTS).

- 6. The application must service the Session request detected interrupt and turn on the port power bit by writing the port power bit in the host port control and status register. The PHY indicates port power-on by asserting the VBUS\_VALID signal.
- 7. When the USB is powered, the device connects, completing the SRP process.



#### **B-device session request protocol**

The application must set the SRP-capable bit in the Core USB configuration register. This enables the OTG\_FS controller to initiate SRP as a B-device. SRP is a means by which the OTG\_FS controller can request a new session from the host.

| VBUS_VALI   | ID 6                          |         |  |
|-------------|-------------------------------|---------|--|
| B_VALID     | 2                             |         |  |
| DISCHRG_VBU |                               |         |  |
| SESS_END    | 4                             |         |  |
| DP          | 5 Data line pulsing Connect   |         |  |
| DM          | Low                           |         |  |
| CHRG_VBUS   | 7<br>V <sub>BUS</sub> pulsing | ai15682 |  |

#### Figure 363. B-device SRP

 VBUS\_VALID = V<sub>BUS</sub> valid signal from PHY B\_VALID = B-peripheral valid session to PHY DISCHRG\_VBUS = discharge signal to PHY SESS\_END = session end signal to PHY CHRG\_VBUS = charge V<sub>BUS</sub> signal to PHY DP = Data plus line DM = Data minus line

1. To save power, the host suspends and turns off port power when the bus is idle.

The OTG\_FS controller sets the early suspend bit in the Core interrupt register after 3 ms of bus idleness. Following this, the OTG\_FS controller sets the USB suspend bit in the Core interrupt register.

The OTG\_FS controller informs the PHY to discharge V<sub>BUS</sub>.

2. The PHY indicates the session's end to the device. This is the initial condition for SRP. The OTG\_FS controller requires 2 ms of SE0 before initiating SRP.

For a USB 1.1 full-speed serial transceiver, the application must wait until  $V_{BUS}$  discharges to 0.2 V after BSVLD (in OTG\_FS\_GOTGCTL) is deasserted. This



discharge time can be obtained from the transceiver vendor and varies from one transceiver to another.

- 3. The USB OTG core informs the PHY to speed up V<sub>BUS</sub> discharge.
- The application initiates SRP by writing the session request bit in the OTG Control and status register. The OTG\_FS controller perform data-line pulsing followed by V<sub>BUS</sub> pulsing.
- 5. The host detects SRP from either the data-line or  $V_{BUS}$  pulsing, and turns on  $V_{BUS}$ . The PHY indicates  $V_{BUS}$  power-on to the device.
- 6. The OTG\_FS controller performs V<sub>BUS</sub> pulsing.

The host starts a new session by turning on  $V_{BUS}$ , indicating SRP success. The OTG\_FS controller interrupts the application by setting the session request success status change bit in the OTG interrupt status register. The application reads the session request success bit in the OTG control and status register.

7. When the USB is powered, the OTG\_FS controller connects, completing the SRP process.

#### A-device host negotiation protocol

HNP switches the USB host role from the A-device to the B-device. The application must set the HNP-capable bit in the Core USB configuration register to enable the OTG\_FS controller to perform HNP as an A-device.



#### Figure 364. A-device HNP

1. DPPULLDOWN = signal from core to PHY to enable/disable the pull-down on the DP line inside the PHY. DMPULLDOWN = signal from core to PHY to enable/disable the pull-down on the DM line inside the PHY.

1. The OTG\_FS controller sends the B-device a SetFeature b\_hnp\_enable descriptor to enable HNP support. The B-device's ACK response indicates that the B-device supports HNP. The application must set host Set HNP Enable bit in the OTG Control



and status register to indicate to the OTG\_FS controller that the B-device supports HNP.

- 2. When it has finished using the bus, the application suspends by writing the Port suspend bit in the host port control and status register.
- 3. When the B-device observes a USB suspend, it disconnects, indicating the initial condition for HNP. The B-device initiates HNP only when it must switch to the host role; otherwise, the bus continues to be suspended.

The OTG\_FS controller sets the host negotiation detected interrupt in the OTG interrupt status register, indicating the start of HNP.

The OTG\_FS controller deasserts the DM pull down and DM pull down in the PHY to indicate a device role. The PHY enables the OTG\_FS\_DP pull-up resistor to indicate a connect for B-device.

The application must read the current mode bit in the OTG Control and status register to determine device mode operation.

- 4. The B-device detects the connection, issues a USB reset, and enumerates the OTG\_FS controller for data traffic.
- 5. The B-device continues the host role, initiating traffic, and suspends the bus when done.

The OTG\_FS controller sets the early suspend bit in the Core interrupt register after 3 ms of bus idleness. Following this, the OTG\_FS controller sets the USB Suspend bit in the Core interrupt register.

- 6. In Negotiated mode, the OTG\_FS controller detects the suspend, disconnects, and switches back to the host role. The OTG\_FS controller asserts the DM pull down and DM pull down in the PHY to indicate its assumption of the host role.
- 7. The OTG\_FS controller sets the Connector ID status change interrupt in the OTG Interrupt Status register. The application must read the connector ID status in the OTG Control and Status register to determine the OTG\_FS controller operation as an Adevice. This indicates the completion of HNP to the application. The application must read the Current mode bit in the OTG control and status register to determine host mode operation.
- 8. The B-device connects, completing the HNP process.

#### **B-device host negotiation protocol**

HNP switches the USB host role from B-device to A-device. The application must set the HNP-capable bit in the Core USB configuration register to enable the OTG\_FS controller to perform HNP as a B-device.





#### Figure 365. B-device HNP

- DPPULLDOWN = signal from core to PHY to enable/disable the pull-down on the DP line inside the PHY. DMPULLDOWN = signal from core to PHY to enable/disable the pull-down on the DM line inside the PHY.
- The A-device sends the SetFeature b\_hnp\_enable descriptor to enable HNP support. The OTG\_FS controller's ACK response indicates that it supports HNP. The application must set the device HNP enable bit in the OTG Control and status register to indicate HNP support.

The application sets the HNP request bit in the OTG Control and status register to indicate to the OTG\_FS controller to initiate HNP.

2. When it has finished using the bus, the A-device suspends by writing the Port suspend bit in the host port control and status register.

The OTG\_FS controller sets the Early suspend bit in the Core interrupt register after 3 ms of bus idleness. Following this, the OTG\_FS controller sets the USB suspend bit in the Core interrupt register.

The OTG\_FS controller disconnects and the A-device detects SE0 on the bus, indicating HNP. The OTG\_FS controller asserts the DP pull down and DM pull down in the PHY to indicate its assumption of the host role.

The A-device responds by activating its OTG\_FS\_DP pull-up resistor within 3 ms of detecting SE0. The OTG\_FS controller detects this as a connect.

The OTG\_FS controller sets the host negotiation success status change interrupt in the OTG Interrupt status register, indicating the HNP status. The application must read the host negotiation success bit in the OTG Control and status register to determine host



negotiation success. The application must read the current Mode bit in the Core interrupt register (OTG\_FS\_GINTSTS) to determine host mode operation.

- 3. The application sets the reset bit (PRST in OTG\_FS\_HPRT) and the OTG\_FS controller issues a USB reset and enumerates the A-device for data traffic.
- 4. The OTG\_FS controller continues the host role of initiating traffic, and when done, suspends the bus by writing the Port suspend bit in the host port control and status register.
- 5. In Negotiated mode, when the A-device detects a suspend, it disconnects and switches back to the host role. The OTG\_FS controller deasserts the DP pull down and DM pull down in the PHY to indicate the assumption of the device role.
- 6. The application must read the current mode bit in the Core interrupt (OTG\_FS\_GINTSTS) register to determine the host mode operation.
- 7. The OTG\_FS controller connects, completing the HNP process.



# 30 USB on-the-go high-speed (OTG\_HS)

# 30.1 OTG\_HS introduction

Portions Copyright (c) 2004, 2005 Synopsys, Inc. All rights reserved. Used with permission.

This section presents the architecture and the programming model of the OTG\_HS controller.

The following acronyms are used throughout the section:

| FS   | full-speed                          |
|------|-------------------------------------|
| HS   | High-speed                          |
| LS   | Low-speed                           |
| USB  | Universal serial bus                |
| OTG  | On-the-go                           |
| PHY  | Physical layer                      |
| MAC  | Media access controller             |
| PFC  | Packet FIFO controller              |
| UTMI | USB Transceiver Macrocell Interface |
| ULPI | UTMI+ Low Pin Interface             |
|      |                                     |

References are made to the following documents:

- USB On-The-Go Supplement, Revision 1.3
- Universal Serial Bus Revision 2.0 Specification

The OTG\_HS is a dual-role device (DRD) controller that supports both peripheral and host functions and is fully compliant with the *On-The-Go Supplement to the USB 2.0 Specification.* It can also be configured as a host-only or peripheral-only controller, fully compliant with the *USB 2.0 Specification.* In host mode, the OTG\_HS supports high-speed (HS, 480 Mbits/s), full-speed (FS, 12 Mbits/s) and low-speed (LS, 1.5 Mbits/s) transfers whereas in peripheral mode, it only supports high-speed (HS, 480Mbits/s) and full-speed (FS, 12 Mbits/s) transfers. The OTG\_HS supports both HNP and SRP. The only external device required is a charge pump for VBUS in OTG mode.

# **30.2 OTG\_HS main features**

The main features can be divided into three categories: general, host-mode and peripheralmode features.

### 30.2.1 General features

The OTG\_HS interface main features are the following:

- It is USB-IF certified in compliance with the Universal Serial Bus Revision 2.0 Specification
- It supports 3 PHY interfaces
  - An on-chip full-speed PHY
  - An I<sup>2</sup>C Interface for external full-speed I<sup>2</sup>C PHY
  - An ULPI interface for external high-speed PHY.
- It supports the host negotiation protocol (HNP) and the session request protocol (SRP)
- It allows the host to turn V<sub>BUS</sub> off to save power in OTG applications, with no need for external components
- It allows to monitor V<sub>BUS</sub> levels using internal comparators
- It supports dynamic host-peripheral role switching
- It is software-configurable to operate as:
  - An SRP-capable USB HS/FS peripheral (B-device)
  - An SRP-capable USB HS/FS/low-speed host (A-device)
  - An USB OTG FS dual-role device
- It supports HS/FS SOFs as well as low-speed (LS) keep-alive tokens with:
  - SOF pulse PAD output capability
  - SOF pulse internal connection to timer 2 (TIM2)
  - Configurable framing period
  - Configurable end-of-frame interrupt
- It embeds an internal DMA with shareholding support and software selectable AHB burst type in DMA mode
- It has power saving features such as system clock stop during USB suspend, switching off of the digital core internal clock domains, PHY and DFIFO power management
- It features a dedicated 4-Kbyte data RAM with advanced FIFO management:
  - The memory partition can be configured into different FIFOs to allow flexible and efficient use of RAM
  - Each FIFO can contain multiple packets
  - Memory allocation is performed dynamically
  - The FIFO size can be configured to values that are not powers of 2 to allow the use of contiguous memory locations
- It ensures a maximum USB bandwidth of up to one frame without application intervention



# 30.2.2 Host-mode features

The OTG\_HS interface features in host mode are the following:

- It requires an external charge pump to generate V<sub>BUS</sub>
- It has up to 12 host channels (pipes), each channel being dynamically reconfigurable to support any kind of USB transfer
- It features a built-in hardware scheduler holding:
  - Up to 8 interrupt plus isochronous transfer requests in the periodic hardware queue
  - Up to 8 control plus bulk transfer requests in the nonperiodic hardware queue
- It manages a shared RX FIFO, a periodic TX FIFO, and a nonperiodic TX FIFO for efficient usage of the USB data RAM
- It features dynamic trimming capability of SOF framing period in host mode.

### **30.2.3** Peripheral-mode features

The OTG\_HS interface main features in peripheral mode are the following:

- It has 1 bidirectional control endpoint 0
- It has 5 IN endpoints (EP) configurable to support bulk, interrupt or isochronous transfers
- It has 5 OUT endpoints configurable to support bulk, interrupt or isochronous transfers
- It manages a shared Rx FIFO and a Tx-OUT FIFO for efficient usage of the USB data RAM
- It manages up to 6 dedicated Tx-IN FIFOs (one for each IN-configured EP) to reduce the application load
- It features soft disconnect capability



# **30.3 OTG\_HS** functional description

*Figure 366* shows the OTG\_HS interface block diagram.





1. The USB DMA cannot directly address the internal Flash memory.

# 30.3.1 High-speed OTG PHY

The USB OTG HS core embeds an ULPI interface to connect an external HS phy.

# 30.3.2 External Full-speed OTG PHY using the I2C interface

The USB OTG HS core embeds an I<sup>2</sup>C interface allowing to connect an external FS phy.

# 30.3.3 Embedded Full-speed OTG PHY

The full-speed OTG PHY includes the following components:

- FS/LS transceiver module used by both host and Device. It directly drives transmission and reception on the single-ended USB lines.
- Integrated ID pull-up resistor used to sample the ID line for A/B Device identification.
- DP/DM integrated pull-up and pull-down resistors controlled by the OTG\_HS core depending on the current role of the device. As a peripheral, it enables the DP pull-up resistor to signal full-speed peripheral connections as soon as V<sub>BUS</sub> is sensed to be at a valid level (B-session valid). In host mode, pull-down resistors are enabled on both



DP/DM. Pull-up and pull-down resistors are dynamically switched when the peripheral role is changed via the host negotiation protocol (HNP).

Pull-up/pull-down resistor ECN circuit

The DP pull-up consists of 2 resistors controlled separately from the OTG\_HS as per the resistor Engineering Change Notice applied to USB Rev2.0. The dynamic trimming of the DP pull-up strength allows to achieve a better noise rejection and Tx/Rx signal quality.

- V<sub>BUS</sub> sensing comparators with hysteresis used to detect VBUS\_VALID, A-B Session Valid and session-end voltage thresholds. They are used to drive the session request protocol (SRP), detect valid startup and end-of-session conditions, and constantly monitor the V<sub>BUS</sub> supply during USB operations.
- V<sub>BUS</sub> pulsing method circuit used to charge/discharge V<sub>BUS</sub> through resistors during the SRP (weak drive).
- **Caution:** To guarantee a correct operation for the USB OTG HS peripheral, the AHB frequency should be higher than 30 MHz.

# 30.4 OTG dual-role device

#### 30.4.1 ID line detection

The host or peripheral (the default) role depends on the level of the ID input line. It is determined when the USB cable is plugged in and depends on which side of the USB cable is connected to the micro-AB receptacle:

- If the B-side of the USB cable is connected with a floating ID wire, the integrated pull-up resistor detects a high ID level and the default peripheral role is confirmed. In this configuration the OTG\_HS conforms to the FSM standard described in section 6.8.2. On-The-Go B-device of the USB On-The-Go Supplement, Revision 1.3.
- If the A-side of the USB cable is connected with a grounded ID, the OTG\_HS issues an ID line status change interrupt (CIDSCHG bit in the OTG\_HS\_GINTSTS register) for host software initialization, and automatically switches to host role. In this configuration the OTG\_HS conforms to the FSM standard described by section 6.8.1: On-The-Go A-Device of the USB On-The-Go Supplement, Revision 1.3.

#### 30.4.2 HNP dual role device

The HNP capable bit in the Global USB configuration register (HNPCAP bit in the OTG\_HS\_ GUSBCFG register) configures the OTG\_HS core to dynamically change from A-host to Adevice role and vice-versa, or from B-device to B-host role and vice-versa, according to the host negotiation protocol (HNP). The current device status is defined by the combination of the Connector ID Status bit in the Global OTG control and status register (CIDSTS bit in OTG\_HS\_GOTGCTL) and the current mode of operation bit in the global interrupt and status register (CMOD bit in OTG\_HS\_GINTSTS).

The HNP programming model is described in detail in *Section 30.13: OTG\_HS programming model*.

#### 30.4.3 SRP dual-role device

The SRP capable bit in the global USB configuration register (SRPCAP bit in OTG\_HS\_GUSBCFG) configures the OTG\_HS core to switch V<sub>BUS</sub> off for the A-device in



order to save power. The A-device is always in charge of driving V<sub>BUS</sub> regardless of the OTG\_HS role (host or peripheral). The SRP A/B-device program model is described in detail in *Section 30.13: OTG\_HS programming model*.

# 30.5 USB functional description in peripheral mode

The OTG\_HS operates as an USB peripheral in the following circumstances:

- OTG B-device
  - OTG B-device default state if the B-side of USB cable is plugged in
- OTG A-device
   OTG A-device state after the HNP switches the OTG\_HS to peripheral role
- B-Device
   If the ID line is present, functional and connected to the B-side of the USB cable, and the HNP-capable bit in the Global USB Configuration register (HNPCAP bit in OTG\_HS\_GUSBCFG) is cleared (see On-The-Go specification Revision 1.3 section 6.8.3).
- Peripheral only (see Figure 344: USB peripheral-only connection) The force peripheral mode bit in the Global USB configuration register (FDMOD in OTG\_HS\_GUSBCFG) is set to 1, forcing the OTG\_HS core to operate in USB peripheral-only mode (see On-The-Go specification Revision 1.3 section 6.8.3). In this case, the ID line is ignored even if it is available on the USB connector.

Note: To build a bus-powered device architecture in the B-Device or peripheral-only configuration, an external regulator must be added to generate the V<sub>DD</sub> supply voltage from V<sub>BUS</sub>.

### **30.5.1** SRP-capable peripheral

The SRP capable bit in the Global USB configuration register (SRPCAP bit in OTG\_HS\_GUSBCFG) configures the OTG\_HS to support the session request protocol (SRP). As a result, it allows the remote A-device to save power by switching  $V_{BUS}$  off when the USB session is suspended.

The SRP peripheral mode program model is described in detail in *Section : B-device session request protocol.* 

#### 30.5.2 Peripheral states

#### **Powered state**

The V<sub>BUS</sub> input detects the B-session valid voltage used to put the USB peripheral in the Powered state (see USB2.0 specification section 9.1). The OTG\_HS then automatically connects the DP pull-up resistor to signal full-speed device connection to the host, and generates the session request interrupt (SRQINT bit in OTG\_HS\_GINTSTS) to notify the Powered state. The V<sub>BUS</sub> input also ensures that valid V<sub>BUS</sub> levels are supplied by the host during USB operations. If V<sub>BUS</sub> drops below the B-session valid voltage (for example because power disturbances occurred or the host port has been switched off), the OTG\_HS automatically disconnects and the session end detected (SEDET bit in OTG\_HS\_GOTGINT) interrupt is generated to notify that the OTG\_HS has exited the Powered state.



In Powered state, the OTG\_HS expects a reset from the host. No other USB operations are possible. When a reset is received, the reset detected interrupt (USBRST in OTG\_HS\_GINTSTS) is generated. When the reset is complete, the enumeration done interrupt (ENUMDNE bit in OTG\_HS\_GINTSTS) is generated and the OTG\_HS enters the Default state.

#### Soft disconnect

The Powered state can be exited by software by using the soft disconnect feature. The DP pull-up resistor is removed by setting the Soft disconnect bit in the device control register (SDIS bit in OTG\_HS\_DCTL), thus generating a device disconnect detection interrupt on the host side even though the USB cable was not really unplugged from the host port.

#### **Default state**

In Default state the OTG\_HS expects to receive a SET\_ADDRESS command from the host. No other USB operations are possible. When a valid SET\_ADDRESS command is decoded on the USB, the application writes the corresponding number into the device address field in the device configuration register (DAD bit in OTG\_HS\_DCFG). The OTG\_HS then enters the address state and is ready to answer host transactions at the configured USB address.

#### Suspended state

The OTG\_HS peripheral constantly monitors the USB activity. When the USB remains idle for 3 ms, the early suspend interrupt (ESUSP bit in OTG\_HS\_GINTSTS) is issued. It is confirmed 3 ms later, if appropriate, by generating a suspend interrupt (USBSUSP bit in OTG\_HS\_GINTSTS). The device suspend bit is then automatically set in the device status register (SUSPSTS bit in OTG\_HS\_DSTS) and the OTG\_HS enters the Suspended state.

The device can also exit from the Suspended state by itself. In this case the application sets the remote wakeup signaling bit in the device control register (WKUPINT bit in OTG\_HS\_DCTL) and clears it after 1 to 15 ms.

When a resume signaling is detected from the host, the resume interrupt (RWUSIG bit in OTG\_HS\_GINTSTS) is generated and the device suspend bit is automatically cleared.

# 30.5.3 Peripheral endpoints

The OTG\_HS core instantiates the following USB endpoints:

• Control endpoint 0

This endpoint is bidirectional and handles control messages only.

It has a separate set of registers to handle IN and OUT transactions, as well as dedicated control (OTG\_HS\_DIEPCTL0/OTG\_HS\_DOEPCTL0), transfer configuration (OTG\_HS\_DIEPTSIZ0/OTG\_HS\_DIEPTSIZ0), and status-interrupt



(OTG\_HS\_DIEPINTx/)OTG\_HS\_DOEPINT0) registers. The bits available inside the control and transfer size registers slightly differ from other endpoints.

- 5 IN endpoints
  - They can be configured to support the isochronous, bulk or interrupt transfer type.
  - They feature dedicated control (OTG\_HS\_DIEPCTLx), transfer configuration (OTG\_HS\_DIEPTSIZx), and status-interrupt (OTG\_HS\_DIEPINTx) registers.
  - The Device IN endpoints common interrupt mask register (OTG\_HS\_DIEPMSK) allows to enable/disable a single endpoint interrupt source on all of the IN endpoints (EP0 included).
  - They support incomplete isochronous IN transfer interrupt (IISOIXFR bit in OTG\_HS\_GINTSTS). This interrupt is asserted when there is at least one isochronous IN endpoint for which the transfer is not completed in the current frame. This interrupt is asserted along with the end of periodic frame interrupt (OTG\_HS\_GINTSTS/EOPF).
- 5 OUT endpoints
  - They can be configured to support the isochronous, bulk or interrupt transfer type.
  - They feature dedicated control (OTG\_HS\_DOEPCTLx), transfer configuration (OTG\_HS\_DOEPTSIZx) and status-interrupt (OTG\_HS\_DOEPINTx) registers.
  - The Device Out endpoints common interrupt mask register (OTG\_HS\_DOEPMSK) allows to enable/disable a single endpoint interrupt source on all OUT endpoints (EP0 included).
  - They support incomplete isochronous OUT transfer interrupt (INCOMPISOOUT bit in OTG\_HS\_GINTSTS). This interrupt is asserted when there is at least one isochronous OUT endpoint on which the transfer is not completed in the current frame. This interrupt is asserted along with the end of periodic frame interrupt (OTG\_HS\_GINTSTS/EOPF).

### Endpoint controls

The following endpoint controls are available through the device endpoint-x IN/OUT control register (DIEPCTLx/DOEPCTLx):

- Endpoint enable/disable
- Endpoint activation in current configuration
- Program the USB transfer type (isochronous, bulk, interrupt)
- Program the supported packet size
- Program the Tx-FIFO number associated with the IN endpoint
- Program the expected or transmitted data0/data1 PID (bulk/interrupt only)
- Program the even/odd frame during which the transaction is received or transmitted (isochronous only)
- Optionally program the NAK bit to always send a negative acknowledge to the host regardless of the FIFO status
- Optionally program the STALL bit to always stall host tokens to that endpoint
- Optionally program the Snoop mode for OUT endpoint where the received data CRC is not checked



### **Endpoint transfer**

The device endpoint-x transfer size registers (DIEPTSIZx/DOEPTSIZx) allow the application to program the transfer size parameters and read the transfer status.

The programming operation must be performed before setting the endpoint enable bit in the endpoint control register.

Once the endpoint is enabled, these fields are read-only as the OTG FS core updates them with the current transfer status.

The following transfer parameters can be programmed:

- Transfer size in bytes
- Number of packets constituting the overall transfer size.

### Endpoint status/interrupt

The device endpoint-x interrupt registers (DIEPINTx/DOPEPINTx) indicate the status of an endpoint with respect to USB- and AHB-related events. The application must read these registers when the OUT endpoint interrupt bit or the IN endpoint interrupt bit in the core interrupt register (OEPINT bit in OTG\_HS\_GINTSTS or IEPINT bit in OTG\_HS\_GINTSTS, respectively) is set. Before the application can read these registers, it must first read the device all endpoints interrupt register (OTG\_HS\_DAINT) to get the exact endpoint number for the device endpoint-x interrupt register. The application must clear the appropriate bit in this register to clear the corresponding bits in the DAINT and GINTSTS registers.

The peripheral core provides the following status checks and interrupt generation:

- Transfer completed interrupt, indicating that data transfer has completed on both the application (AHB) and USB sides
- Setup stage done (control-out only)
- Associated transmit FIFO is half or completely empty (in endpoints)
- NAK acknowledge transmitted to the host (isochronous-in only)
- IN token received when Tx-FIFO was empty (bulk-in/interrupt-in only)
- OUT token received when endpoint was not yet enabled
- Babble error condition detected
- Endpoint disable by application is effective
- Endpoint NAK by application is effective (isochronous-in only)
- More than 3 back-to-back setup packets received (control-out only)
- Timeout condition detected (control-in only)
- Isochronous out packet dropped without generating an interrupt



# **30.6 USB functional description on host mode**

This section gives the functional description of the OTG\_HS in the USB host mode. The OTG\_HS works as a USB host in the following circumstances:

• OTG A-host

OTG A-device default state when the A-side of the USB cable is plugged in

OTG B-host

OTG B-device after HNP switching to the host role

A-device

If the ID line is present, functional and connected to the A-side of the USB cable, and the HNP-capable bit is cleared in the Global USB Configuration register (HNPCAP bit in OTG\_HS\_GUSBCFG). Integrated pull-down resistors are automatically set on the DP/DM lines.

• Host only (Figure 345: USB host-only connection).

The force host mode bit in the global USB configuration register (FHMOD bit in OTG\_HS\_GUSBCFG) forces the OTG\_HS core to operate in USB host-only mode. In this case, the ID line is ignored even if it is available on the USB connector. Integrated pull-down resistors are automatically set on the OTG\_HS\_FS\_DP/OTG\_HS\_FS\_DM lines.

- Note: 1 On-chip 5 V V<sub>BUS</sub> generation is not supported. As a result, a charge pump or a basic power switch (if a 5 V supply is available on the application board) must be added externally to drive the 5 V V<sub>BUS</sub> line. The external charge pump can be driven by any GPIO output. This is required for the OTG A-host, A-device and host-only configurations.
  - 2 The  $V_{BUS}$  input ensures that valid  $V_{BUS}$  levels are supplied by the charge pump during USB operations while the charge pump overcurrent output can be input to any GPIO pin configured to generate port interrupts. The overcurrent ISR must promptly disable the  $V_{BUS}$  generation.

### 30.6.1 SRP-capable host

SRP support is available through the SRP capable bit in the global USB configuration register (SRPCAP bit in OTG\_HS\_GUSBCFG). When the SRP feature is enabled, the host can save power by switching off the V<sub>BUS</sub> power while the USB session is suspended. The SRP host mode program model is described in detail in *Section : A-device session request protocol*.

### 30.6.2 USB host states

### Host port power

On-chip 5 V V<sub>BUS</sub> generation is not supported. As a result, a charge pump or a basic power switch (if a 5 V supply voltage is available on the application board) must be added externally to drive the 5 V V<sub>BUS</sub> line. The external charge pump can be driven by any GPIO output. When the application powers on V<sub>BUS</sub> through the selected GPIO, it must also set the port power bit in the host port control and status register (PPWR bit in OTG\_HS\_HPRT).



### V<sub>BUS</sub> valid

The  $V_{\text{BUS}}$  input ensures that valid  $V_{\text{BUS}}$  levels are supplied by the charge pump during USB operations.

Any unforeseen V<sub>BUS</sub> voltage drop below the V<sub>BUS</sub> valid threshold (4.25 V) generates an OTG interrupt triggered by the session end detected bit (SEDET bit in OTG\_HS\_GOTGINT). The application must then switch the V<sub>BUS</sub> power off and clear the port power bit. The charge pump overcurrent flag can also be used to prevent electrical damage. Connect the overcurrent flag output from the charge pump to any GPIO input, and configure it to generate a port interrupt on the active level. The overcurrent ISR must promptly disable the V<sub>BUS</sub> generation and clear the port power bit.

### Detection of peripheral connection by the host

Even if USB peripherals or B-devices can be attached at any time, the OTG\_HS does not detect a bus connection until the end of the  $V_{BUS}$  sensing ( $V_{BUS}$  over 4.75 V).

When  $V_{BUS}$  is at a valid level and a remote B-device is attached, the OTG\_HS core issues a host port interrupt triggered by the device connected bit in the host port control and status register (PCDET bit in OTG\_HS\_HPRT).

### Detection of peripheral disconnection by the host

The peripheral disconnection event triggers the disconnect detected interrupt (DISCINT bit in OTG\_HS\_GINTSTS).

### Host enumeration

After detecting a peripheral connection, the host must start the enumeration process by issuing an USB reset and configuration commands to the new peripheral.

Before sending an USB reset, the application waits for the OTG interrupt triggered by the debounce done bit (DBCDNE bit in OTG\_HS\_GOTGINT), which indicates that the bus is stable again after the electrical debounce caused by the attachment of a pull-up resistor on OTG\_HS\_FS\_DP (full speed) or OTG\_HS\_FS\_DM (low speed).

The application issues an USB reset (single-ended zero) via the USB by keeping the port reset bit set in the Host port control and status register (PRST bit in OTG\_HS\_HPRT) for a minimum of 10 ms and a maximum of 20 ms. The application monitors the time and then clears the port reset bit.

Once the USB reset sequence has completed, the host port interrupt is triggered by the port enable/disable change bit (PENCHNG bit in OTG\_HS\_HPRT) to inform the application that the speed of the enumerated peripheral can be read from the port speed field in the host port control and status register (PSPD bit in OTG\_HS\_HPRT), and that the host is starting to drive SOFs (full speed) or keep-alive tokens (low speed). The host is then ready to complete the peripheral enumeration by sending peripheral configuration commands.

### Host suspend

The application can decide to suspend the USB activity by setting the port suspend bit in the host port control and status register (PSUSP bit in OTG\_HS\_HPRT). The OTG\_HS core stops sending SOFs and enters the Suspended state.

The Suspended state can be exited on the remote device initiative (remote wakeup). In this case the remote wakeup interrupt (WKUPINT bit in OTG\_HS\_GINTSTS) is generated upon detection of a remote wakeup event, the port resume bit in the host port control and status





register (PRES bit in OTG\_HS\_HPRT) is set, and a resume signaling is automatically issued on the USB. The application must monitor the resume window duration, and then clear the port resume bit to exit the Suspended state and restart the SOF.

If the Suspended state is exited on the host initiative, the application must set the port resume bit to start resume signaling on the host port, monitor the resume window duration and then clear the port resume bit.

### 30.6.3 Host channels

The OTG\_HS core instantiates 12 host channels. Each host channel supports an USB host transfer (USB pipe). The host is not able to support more than 8 transfer requests simultaneously. If more than 8 transfer requests are pending from the application, the host controller driver (HCD) must re-allocate channels when they become available, that is, after receiving the transfer completed and channel halted interrupts.

Each host channel can be configured to support IN/OUT and any type of periodic/nonperiodic transaction. Each host channel has dedicated control (HCCHARx), transfer configuration (HCTSIZx) and status/interrupt (HCINTx) registers with associated mask (HCINTMSKx) registers.

### Host channel controls

The following host channel controls are available through the host channel-x characteristics register (HCCHARx):

- Channel enable/disable
- Program the HS/FS/LS speed of target USB peripheral
- Program the address of target USB peripheral
- Program the endpoint number of target USB peripheral
- Program the transfer IN/OUT direction
- Program the USB transfer type (control, bulk, interrupt, isochronous)
- Program the maximum packet size (MPS)
- Program the periodic transfer to be executed during odd/even frames

### Host channel transfer

The host channel transfer size registers (HCTSIZx) allow the application to program the transfer size parameters, and read the transfer status.

The programming operation must be performed before setting the channel enable bit in the host channel characteristics register. Once the endpoint is enabled, the packet count field is read-only as the OTG HS core updates it according to the current transfer status.

The following transfer parameters can be programmed:

- Transfer size in bytes
- Number of packets constituting the overall transfer size
- Initial data PID

### Host channel status/interrupt

The host channel-x interrupt register (HCINTx) indicates the status of an endpoint with respect to USB- and AHB-related events. The application must read these register when the host channels interrupt bit in the core interrupt register (HCINT bit in OTG\_HS\_GINTSTS) is



set. Before the application can read these registers, it must first read the host all channels interrupt (HCAINT) register to get the exact channel number for the host channel-x interrupt register. The application must clear the appropriate bit in this register to clear the corresponding bits in the HAINT and GINTSTS registers. The mask bits for each interrupt source of each channel are also available in the OTG\_HS\_HCINTMSK-x register.

The host core provides the following status checks and interrupt generation:

- Transfer completed interrupt, indicating that the data transfer is complete on both the application (AHB) and USB sides
- Channel stopped due to transfer completed, USB transaction error or disable command from the application
- Associated transmit FIFO half or completely empty (IN endpoints)
- ACK response received
- NAK response received
- STALL response received
- USB transaction error due to CRC failure, timeout, bit stuff error, false EOP
- Babble error
- Frame overrun
- Data toggle error

### 30.6.4 Host scheduler

The host core features a built-in hardware scheduler which is able to autonomously re-order and manage the USB the transaction requests posted by the application. At the beginning of each frame the host executes the periodic (isochronous and interrupt) transactions first, followed by the nonperiodic (control and bulk) transactions to achieve the higher level of priority granted to the isochronous and interrupt transfer types by the USB specification.

The host processes the USB transactions through request queues (one for periodic and one for nonperiodic). Each request queue can hold up to 8 entries. Each entry represents a pending transaction request from the application, and 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 to the queue determines the sequence of the transactions on the USB interface.

At the beginning of each frame, the host processes the periodic request queue first, followed by the nonperiodic request queue. The host issues an incomplete periodic transfer interrupt (IPXFR bit in OTG\_HS\_GINTSTS) if an isochronous or interrupt transaction scheduled for the current frame is still pending at the end of the current frame. The OTG HS core is fully responsible for the management of the periodic and nonperiodic request queues. The periodic transmit FIFO and queue status register (HPTXSTS) and nonperiodic transmit FIFO and queue status register (HNPTXSTS) are read-only registers which can be used by the application to read the status of each request queue. They contain:

- The number of free entries currently available in the periodic (nonperiodic) request queue (8 max)
- Free space currently available in the periodic (nonperiodic) Tx-FIFO (out-transactions)
- IN/OUT token, host channel number and other status information.

As request queues can hold a maximum of 8 entries each, the application can push to schedule host transactions in advance with respect to the moment they physically reach the



USB for a maximum of 8 pending periodic transactions plus 8 pending nonperiodic transactions.

To post a transaction request to the host scheduler (queue) the application must check that there is at least 1 entry available in the periodic (nonperiodic) request queue by reading the PTXQSAV bits in the OTG\_HS\_HNPTXSTS register or NPTQXSAV bits in the OTG\_HS\_HNPTXSTS register.

# 30.7 SOF trigger

The OTG FS core allows to monitor, track and configure SOF framing in the host and peripheral. It also features an SOF pulse output connectivity.

These capabilities are particularly useful to implement adaptive audio clock generation techniques, where the audio peripheral needs to synchronize to the isochronous stream provided by the PC, or the host needs trimming its framing rate according to the requirements of the audio peripheral.

### 30.7.1 Host SOFs

In host mode the number of PHY clocks occurring between the generation of two consecutive SOF (FS) or keep-alive (LS) tokens is programmable in the host frame interval register (OTG\_HS\_HFIR), thus providing application control over the SOF framing period. An interrupt is generated at any start of frame (SOF bit in OTG\_HS\_GINTSTS). The current frame number and the time remaining until the next SOF are tracked in the host frame number register (OTG\_HS\_HFINUM).

An SOF pulse signal is generated at any SOF starting token and with a width of 12 system clock cycles. It can be made available externally on the SOF pin using the SOFOUTEN bit in the global control and configuration register. The SOF pulse is also internally connected to the input trigger of timer 2 (TIM2), so that the input capture feature, the output compare feature and the timer can be triggered by the SOF pulse. The TIM2 connection is enabled through ITR1\_RMP bits of TIM2\_OR register.

 OTG\_HS\_Core

 For the second second

SOF trigger output to TIM2 ITR1 connection

### 30.7.2 Peripheral SOFs

In peripheral mode, the start of frame interrupt is generated each time an SOF token is received on the USB (SOF bit in OTG\_HS\_GINTSTS). The corresponding frame number

Doc ID 018909 Rev 1



can be read from the device status register (FNSOF bit in OTG\_HS\_DSTS). An SOF pulse signal with a width of 12 system clock cycles is also generated and can be made available externally on the SOF pin by using the SOF output enable bit in the global control and configuration register (SOFOUTEN bit in OTG\_HS\_GCCFG). The SOF pulse signal is also internally connected to the TIM2 input trigger, so that the input capture feature, the output compare feature and the timer can be triggered by the SOF pulse (see *Figure*). The TIM2 connection is enabled through ITR1\_RMP bits of TIM2\_OR register.

The end of periodic frame interrupt (GINTSTS/EOPF) is used to notify the application when 80%, 85%, 90% or 95% of the time frame interval elapsed depending on the periodic frame interval field in the device configuration register (PFIVL bit in OTG\_HS\_DCFG).

This feature can be used to determine if all of the isochronous traffic for that frame is complete.

### 30.8 USB\_HS power modes

The power consumption of the OTG PHY is controlled by three bits in the general core configuration register:

• PHY power down (GCCFG/PWRDWN)

This bit switches on/off the PHY full-speed transceiver module. It must be preliminarily set to allow any USB operation.

- A-VBUS sensing enable (GCCFG/VBUSASEN)
   This bit switches on/off the V<sub>BUS</sub> comparators associated with A-device operations. It must be set when in A-device (USB host) mode and during HNP.
- B-VBUS sensing enable (GCCFG/VBUSASEN)

This bit switches on/off the V<sub>BUS</sub> comparators associated with B-device operations. It must be set when in B-device (USB peripheral) mode and during HNP.

Power reduction techniques are available in the USB suspended state, when the USB session is not yet valid or the device is disconnected.

- Stop PHY clock (STPPCLK bit in OTG\_HS\_PCGCCTL)
  - When setting the stop PHY clock bit in the clock gating control register, most of the clock domain internal to the OTG high-speed core is switched off by clock gating. The dynamic power consumption due to the USB clock switching activity is cut even if the clock input is kept running by the application
  - Most of the transceiver is also disabled, and only the part in charge of detecting the asynchronous resume or remote wakeup event is kept alive.
- Gate HCLK (GATEHCLK bit in OTG\_HS\_PCGCCTL)

When setting the Gate HCLK bit in the clock gating control register, most of the system clock domain internal to the OTG\_HS core is switched off by clock gating. Only the register read and write interface is kept alive. The dynamic power consumption due to the USB clock switching activity is cut even if the system clock is kept running by the application for other purposes.

- USB system stop
  - When the OTG\_HS is in USB suspended state, the application can decide to drastically reduce the overall power consumption by shutting down all the clock sources in the system. USB System Stop is activated by first setting the Stop PHY



clock bit and then configuring the system deep sleep mode in the powercontrol system module (PWR).

 The OTG\_HS core automatically reactivates both system and USB clocks by asynchronous detection of remote wakeup (as an host) or resume (as a Device) signaling on the USB.

# 30.9 Dynamic update of the OTG\_HS\_HFIR register

The USB core embeds a dynamic trimming capability of micro-SOF framing period in host mode allowing to synchronize an external device with the micro-SOF frames.

When the OTG\_HS\_HFIR register is changed within a current micro-SOF frame, the SOF period correction is applied in the next frame as described in *Figure 367*.





# **30.10** FIFO RAM allocation

### 30.10.1 Peripheral mode

### **Receive FIFO RAM**

For Receive FIFO RAM, the application should allocate RAM for SETUP packets: 10 locations must be reserved in the receive FIFO to receive SETUP packets on control endpoints. These locations are reserved for SETUP packets and are not used by the core to write any other data.

One location must be allocated for Global OUT NAK. Status information are also written to the FIFO along with each received packet. Therefore, a minimum space of (Largest Packet Size / 4) + 1 must be allocated to receive packets. If a high-bandwidth endpoint or multiple isochronous endpoints are enabled, at least two spaces of (Largest Packet Size / 4) + 1 must be allotted to receive back-to-back packets. Typically, two (Largest Packet Size / 4) + 1 spaces are recommended so that when the previous packet is being transferred to AHB, the USB can receive the subsequent packet.

Along with each endpoints last packet, transfer complete status information are also pushed to the FIFO. Typically, one location for each OUT endpoint is recommended.



### **Transmit FIFO RAM**

For Transmit FIFO RAM, the minimum RAM space required for each IN Endpoint Transmit FIFO is the maximum packet size for this IN endpoint.

Note: More space allocated in the transmit IN Endpoint FIFO results in a better performance on the USB.

### 30.10.2 Host mode

### **Receive FIFO RAM**

For Receive FIFO RAM allocation, Status information are written to the FIFO along with each received packet. Therefore, a minimum space of (Largest Packet Size / 4) + 1 must be allocated to receive packets. If a high-bandwidth channel or multiple isochronous channels are enabled, at least two spaces of (Largest Packet Size / 4) + 1 must be allocated to receive back-to-back packets. Typically, two (Largest Packet Size / 4) + 1 spaces are recommended so that when the previous packet is being transferred to AHB, the USB can receive the subsequent packet.

Along with each host channels last packet, transfer complete status information are also pushed to the FIFO. As a consequence, one location must be allocated to store this data.

### **Transmit FIFO RAM**

For Transmit FIFO RAM allocation, the minimum amount of RAM required for the host nonperiodic Transmit FIFO is the largest maximum packet size for all supported nonperiodic OUT channels. Typically, a space corresponding to two Largest Packet Size is recommended, so that when the current packet is being transferred to the USB, the AHB can transmit the subsequent packet.

The minimum amount of RAM required for Host periodic Transmit FIFO is the largest maximum packet size for all supported periodic OUT channels. If there is at least one High Bandwidth Isochronous OUT endpoint, then the space must be at least two times the maximum packet size for that channel.

- Note: 1 More space allocated in the Transmit nonperiodic FIFO results in better performance on the USB.
  - 2 When operating in DMA mode, the DMA address register for each host channel (HCDMAn) is stored in the SPRAM (FIFO). One location for each channel must be reserved for this.

# **30.11 OTG\_HS interrupts**

When the OTG\_HS controller is operating in one mode, either peripheral or host, the application must not access registers from the other mode. If an illegal access occurs, a mode mismatch interrupt is generated and reflected in the Core interrupt register (MMIS bit in the OTG\_HS\_GINTSTS register). When the core switches from one mode to the other, the registers in the new mode of operation must be reprogrammed as they would be after a power-on reset.

Figure 368 shows the interrupt hierarchy.



### Figure 368. Interrupt hierarchy



1. The core interrupt register bits are shown in OTG\_HS core interrupt register (OTG\_HS\_GINTSTS) on page 1101.



#### RM0090

# **30.12** OTG\_HS control and status registers

By reading from and writing to the control and status registers (CSRs) through the AHB slave interface, the application controls the OTG\_HS controller. These registers are 32 bits wide, and the addresses are 32-bit block aligned. CSRs are classified as follows:

- Core global registers
- Host-mode registers
- Host global registers
- Host port CSRs
- Host channel-specific registers
- Device-mode registers
- Device global registers
- Device endpoint-specific registers
- Power and clock-gating registers
- Data FIFO (DFIFO) access registers

Only the Core global, Power and clock-gating, Data FIFO access, and host port control and status registers can be accessed in both host and peripheral modes. When the OTG\_HS controller is operating in one mode, either peripheral or host, the application must not access registers from the other mode. If an illegal access occurs, a mode mismatch interrupt is generated and reflected in the Core interrupt register (MMIS bit in the OTG\_HS\_GINTSTS register). When the core switches from one mode to the other, the registers in the new mode of operation must be reprogrammed as they would be after a power-on reset.



### 30.12.1 CSR memory map

The host and peripheral mode registers occupy different addresses. All registers are implemented in the AHB clock domain.





1. x = 5 in peripheral mode and x = 11 in host mode.

### **Global CSR map**

These registers are available in both host and peripheral modes.

| Table 130. Cole global control and status registers (CSRS) | Table 156. | Core global control and status registers (CSRs) |
|------------------------------------------------------------|------------|-------------------------------------------------|
|------------------------------------------------------------|------------|-------------------------------------------------|

| Acronym        | Address<br>offset | Register name                                                    |  |
|----------------|-------------------|------------------------------------------------------------------|--|
| OTG_HS_GOTGCTL | 0x000             | OTG_HS control and status register (OTG_HS_GOTGCTL) on page 1091 |  |
| OTG_HS_GOTGINT | 0x004             | OTG_HS interrupt register (OTG_HS_GOTGINT) on page 1093          |  |
| OTG_HS_GAHBCFG | 0x008             | OTG_HS AHB configuration register (OTG_HS_GAHBCFG) on page 1094  |  |
| OTG_HS_GUSBCFG | 0x00C             | OTG_HS USB configuration register (OTG_HS_GUSBCFG) on page 1095  |  |
| OTG_HS_GRSTCTL | 0x010             | OTG_HS reset register (OTG_HS_GRSTCTL) on page 1098              |  |

Doc ID 018909 Rev 1



| Acronym                                     | Address<br>offset                                                                      | Register name                                                                                                                |  |
|---------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|
| OTG_HS_GINTSTS                              | 0x014                                                                                  | OTG_HS core interrupt register (OTG_HS_GINTSTS) on page 1101                                                                 |  |
| OTG_HS_GINTMSK                              | 0x018                                                                                  | OTG_HS interrupt mask register (OTG_HS_GINTMSK) on page 1105                                                                 |  |
| OTG_HS_GRXSTSR                              | 0x01C                                                                                  | OTG_HS Receive status debug read/OTG status read and pop registers                                                           |  |
| OTG_HS_GRXSTSP                              | 0x020                                                                                  | (OTG_HS_GRXSTSR/OTG_HS_GRXSTSP) on page 1108                                                                                 |  |
| OTG_HS_GRXFSIZ                              | 0x024                                                                                  | DTG_HS Receive FIFO size register (OTG_HS_GRXFSIZ) on page 110                                                               |  |
| OTG_HS_GNPTXFSIZ/<br>OTG_HS_TX0FSIZ         | 0x028                                                                                  | OTG_HS nonperiodic transmit FIFO size/Endpoint 0 transmit FIFO size register (OTG_HS_GNPTXFSIZ/OTG_HS_TX0FSIZ) on page 1110  |  |
| OTG_HS_GNPTXSTS                             | 0x02C                                                                                  | OTG_HS nonperiodic transmit FIFO/queue status register<br>(OTG_HS_GNPTXSTS) on page 1110                                     |  |
| OTG_HS_GCCFG                                | 0x038                                                                                  | OTG_HS general core configuration register (OTG_HS_GCCFG) on page 1113                                                       |  |
| OTG_HS_CID                                  | 0x03C                                                                                  | OTG_HS core ID register (OTG_HS_CID) on page 1114                                                                            |  |
| OTG_HS_HPTXFSIZ                             | PTXFSIZ 0x100 OTG_HS Host periodic transmit FIFO size register (OTG_HS_Hi<br>page 1114 |                                                                                                                              |  |
| OTG_HS_DIEPTXFx 0x104<br>0x124<br><br>0x13C |                                                                                        | OTG_HS device IN endpoint transmit FIFO size register<br>(OTG_HS_DIEPTXFx) (x = 17, where x is the FIFO_number) on page 1114 |  |

| Table 156. | Core global control and s | status registers ( | (CSRs) | (continued) |
|------------|---------------------------|--------------------|--------|-------------|
|            | oole global control and a | status registers ( | 00113  | (continucu) |

## Host-mode CSR map

These registers must be programmed every time the core changes to host mode.

| Table 157. Host-mode control and status registers (CSRs) | Table 157. | s registers (CSRs) |
|----------------------------------------------------------|------------|--------------------|
|----------------------------------------------------------|------------|--------------------|

| Acronym         | Offset<br>address | Register name                                                                             |  |
|-----------------|-------------------|-------------------------------------------------------------------------------------------|--|
| OTG_HS_HCFG     | 0x400             | OTG_HS host configuration register (OTG_HS_HCFG) on page 1115                             |  |
| OTG_HS_HFIR     | 0x404             | OTG_HS Host frame interval register (OTG_HS_HFIR) on page 1116                            |  |
| OTG_HS_HFNUM    | 0x408             | OTG_HS host frame number/frame time remaining register<br>(OTG_HS_HFNUM) on page 1116     |  |
| OTG_HS_HPTXSTS  | 0x410             | OTG_HS_Host periodic transmit FIFO/queue status register<br>(OTG_HS_HPTXSTS) on page 1117 |  |
| OTG_HS_HAINT    | 0x414             | OTG_HS Host all channels interrupt register (OTG_HS_HAINT) on page 1118                   |  |
| OTG_HS_HAINTMSK | 0x418             | OTG_HS host all channels interrupt mask register (OTG_HS_HAINTMSK) on page 1118           |  |



| Acronym          | Offset<br>address                                                                                                                                                                       | Register name                                                                                                       |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--|
| OTG_HS_HPRT      | 0x440                                                                                                                                                                                   | OTG_HS host port control and status register (OTG_HS_HPRT) on page 1119                                             |  |
| OTG_HS_HCCHARx   | Ox500       Ox520       OTG_HS host channel-x characteristics register (OTG_HS_HCCHA.          (x = 011, where x = Channel_number) on page 1121         0x6E0       Otext               |                                                                                                                     |  |
| OTG_HS_HCSPLTx   | $0x504 \qquad \begin{array}{l} OTG_HS \text{ host channel-x split control register (OTG_HS_HCSPLTx)} \\ (x = 011, \text{ where } x = Channel_number) \text{ on page } 1123 \end{array}$ |                                                                                                                     |  |
| OTG_HS_HCINTx    | 0x508                                                                                                                                                                                   | $OTG_HS$ host channel-x interrupt register ( $OTG_HS_HCINTx$ ) (x = 011, where x = Channel_number) on page 1124     |  |
| OTG_HS_HCINTMSKx | 0x50C                                                                                                                                                                                   | OTG_HS host channel-x interrupt mask register (OTG_HS_HCINTMSKx) $(x = 011, where x = Channel_number)$ on page 1125 |  |
| OTG_HS_HCTSIZx   | 0x510                                                                                                                                                                                   | OTG_HS host channel-x transfer size register (OTG_HS_HCTSIZx) $(x = 011, where x = Channel_number)$ on page 1126    |  |
| OTG_HS_HCDMAx    | 0x514                                                                                                                                                                                   | OTG_HS host channel-x DMA address register (OTG_HS_HCDMAx) $(x = 011, where x = Channel_number)$ on page 1127       |  |

Table 157. Host-mode control and status registers (CSRs) (continued)

### Device-mode CSR map

These registers must be programmed every time the core changes to peripheral mode.

| Table 158. | Device-mode control and status registers |
|------------|------------------------------------------|
|------------|------------------------------------------|

| Acronym Offset address |       | Register name                                                                              |  |
|------------------------|-------|--------------------------------------------------------------------------------------------|--|
| OTG_HS_DCFG            | 0x800 | OTG_HS device configuration register (OTG_HS_DCFG) on page 1127                            |  |
| OTG_HS_DCTL            | 0x804 | OTG_HS device control register (OTG_HS_DCTL) on page 1129                                  |  |
| OTG_HS_DSTS            | 0x808 | OTG_HS device status register (OTG_HS_DSTS) on page 1131                                   |  |
| OTG_HS_DIEPMSK         | 0x810 | OTG_HS device IN endpoint common interrupt mask register<br>(OTG_HS_DIEPMSK) on page 1132  |  |
| OTG_HS_DOEPMSK         | 0x814 | OTG_HS device OUT endpoint common interrupt mask register<br>(OTG_HS_DOEPMSK) on page 1133 |  |
| OTG_HS_DAINT 0x818     |       | OTG_HS device all endpoints interrupt register (OTG_HS_DAINT) on page 1134                 |  |
| OTG_HS_DAINTMSK        | 0x81C | OTG_HS all endpoints interrupt mask register<br>(OTG_HS_DAINTMSK) on page 1134             |  |
| OTG_HS_DVBUSDIS        | 0x828 | OTG_HS device V <sub>BUS</sub> discharge time register<br>(OTG_HS_DVBUSDIS) on page 1135   |  |
| OTG_HS_DVBUSPULSE      | 0x82C | OTG_HS device V <sub>BUS</sub> pulsing time register<br>(OTG_HS_DVBUSPULSE) on page 1135   |  |



| Acronym                                                                          | Offset<br>address           | Register name                                                                                                                            |  |
|----------------------------------------------------------------------------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|
| OTG_HS_DIEPEMPMSK                                                                | 0x834                       | OTG_HS device IN endpoint FIFO empty interrupt mask register:<br>(OTG_HS_DIEPEMPMSK) on page 1137                                        |  |
| OTG_HS_EACHHINT                                                                  | 0x838                       | OTG_HS device each endpoint interrupt register<br>(OTG_HS_DEACHINT) on page 1137                                                         |  |
| OTG_HS_EACHHINTMSK                                                               | 0x83C                       | OTG_HS device each endpoint interrupt register mask<br>(OTG_HS_DEACHINTMSK) on page 1138                                                 |  |
| OTG_HS_DIEPEACHMSK1                                                              | 0x840                       | OTG_HS device each in endpoint-1 interrupt register<br>(OTG_HS_DIEPEACHMSK1) on page 1138                                                |  |
| OTG_HS_DOEPEACHMSK1                                                              | 0x880                       | OTG_HS device each OUT endpoint-1 interrupt register<br>(OTG_HS_DOEPEACHMSK1) on page 1139                                               |  |
| OTG_HS_DIEPCTLx                                                                  | 0x920<br>0x940<br><br>0xAE0 | OTG device endpoint-x control register (OTG_HS_DIEPCTLx) ( $x = 07$ , where $x = Endpoint_number$ ) on page 1140                         |  |
| OTG_HS_DIEPINTx 0x908                                                            |                             | OTG_HS device endpoint-x interrupt register<br>(OTG_HS_DIEPINTx) (x = 07, where x = Endpoint_number) on<br>page 1147                     |  |
| OTG_HS_DIEPTSIZ0                                                                 | 0x910                       | OTG_HS device IN endpoint 0 transfer size register<br>(OTG_HS_DIEPTSIZ0) on page 1150                                                    |  |
| OTG_HS_DIEPDMAx 0x914                                                            |                             | OTG_HS device endpoint-x DMA address register<br>(OTG_HS_DIEPDMAx / OTG_HS_DOEPDMAx) (x = 15, where<br>x = Endpoint_number) on page 1154 |  |
| OTG_HS_DTXFSTSx                                                                  | 0x918                       | OTG_HS device IN endpoint transmit FIFO status register<br>(OTG_HS_DTXFSTSx) ( $x = 05$ , where $x = Endpoint_number$ ) on<br>page 1153  |  |
| OTG_HS_DIEPTSIZx                                                                 | 0x930<br>0x950<br><br>0xAF0 | OTG_HS device endpoint-x transfer size register<br>(OTG_HS_DOEPTSIZx) ( $x = 15$ , where $x = Endpoint_number$ )<br>on page 1153         |  |
| OTG_HS_DOEPCTL0                                                                  | 0xB00                       | OTG_HS device control OUT endpoint 0 control register<br>(OTG_HS_DOEPCTL0) on page 1143                                                  |  |
| OTG_HS_DOEPCTLx<br>OTG_HS_DOEPCTLx<br>OTG_HS_DOEPCTLx<br>OXCC0<br>OXCE0<br>OXCFD |                             | OTG device endpoint-x control register (OTG_HS_DIEPCTLx) (x = 07, where x = Endpoint_number) on page 1140                                |  |

Table 158. Device-mode control and status registers (continued)



| Acronym          | Offset<br>address | Register name                                                                                                                    |
|------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------|
| OTG_HS_DOEPINTx  | 0xB08             | OTG_HS device endpoint-x interrupt register<br>(OTG_HS_DIEPINTx) ( $x = 07$ , where $x = Endpoint_number$ ) on<br>page 1147      |
| OTG_HS_DOEPTSIZx | 0xB10             | OTG_HS device endpoint-x transfer size register<br>(OTG_HS_DOEPTSIZx) ( $x = 15$ , where $x = Endpoint_number$ )<br>on page 1153 |

Table 158. Device-mode control and status registers (continued)

### Data FIFO (DFIFO) access register map

These registers, available in both host and peripheral modes, are used to read or write the FIFO space for a specific endpoint or a channel, in a given direction. If a host channel is of type IN, the FIFO can only be read on the channel. Similarly, if a host channel is of type OUT, the FIFO can only be written on the channel.

Table 159. Data FIFO (DFIFO) access register map

| FIFO access register section                                                                                                                               | Address range   | Access |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|
| Device IN Endpoint 0/Host OUT Channel 0: DFIFO Write Access<br>Device OUT Endpoint 0/Host IN Channel 0: DFIFO Read Access                                  | 0x1000-0x1FFC   | w<br>r |
| Device IN Endpoint 1/Host OUT Channel 1: DFIFO Write Access<br>Device OUT Endpoint 1/Host IN Channel 1: DFIFO Read Access                                  | 0x2000-0x2FFC   | w<br>r |
|                                                                                                                                                            |                 |        |
| Device IN Endpoint $x^{(1)}$ /Host OUT Channel $x^{(1)}$ : DFIFO Write Access Device OUT Endpoint $x^{(1)}$ /Host IN Channel $x^{(1)}$ : DFIFO Read Access | 0xX000h-0xXFFCh | w<br>r |

1. Where x is 5 in peripheral mode and 11 in host mode.

### Power and clock gating CSR map

There is a single register for power and clock gating. It is available in both host and peripheral modes.

### Table 160. Power and clock gating control and status registers

| Register name                           | Acronym | Offset address: 0xE00-0xFFF |
|-----------------------------------------|---------|-----------------------------|
| Power and clock gating control register | PCGCR   | 0xE00-0xE04                 |
| Reserved                                |         | 0xE05–0xFFF                 |



### 30.12.2 OTG\_HS global registers

These registers are available in both host and peripheral modes, and do not need to be reprogrammed when switching between these modes.

Bit values in the register descriptions are expressed in binary unless otherwise specified.

### OTG\_HS control and status register (OTG\_HS\_GOTGCTL)

Address offset: 0x000

Reset value: 0x0000 0800

The OTG control and status register controls the behavior and reflects the status of the OTG function of the core.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 |  |  |  |  |  |  |  |  |  |  |   |
|----|----|----|----|----|----|----|----|----|----|----|--|--|--|--|--|--|--|--|--|--|---|
|    |    |    |    |    |    |    |    |    |    |    |  |  |  |  |  |  |  |  |  |  | 1 |

| Reserved | BSVLD | ASVLD | DBCT | CIDSTS | Reserved | DHNPEN | HSHNPEN | HNPRQ | SOSONH | Reserved | SRQ | SRQSCS |
|----------|-------|-------|------|--------|----------|--------|---------|-------|--------|----------|-----|--------|
|          | r     | r     | r    | r      |          | rw     | rw      | rw    | r      |          | rw  | r      |

Bits 31:20 Reserved, must be kept at reset value.

#### Bit 19 BSVLD: B-session valid

Indicates the peripheral mode transceiver status.

- 0: B-session is not valid.
- 1: B-session is valid.

In OTG mode, you can use this bit to determine if the device is connected or disconnected. *Note: Only accessible in peripheral mode.* 

#### Bit 18 ASVLD: A-session valid

Indicates the host mode transceiver status.

- 0: A-session is not valid
- 1: A-session is valid
- Note: Only accessible in host mode.

#### Bit 17 DBCT: Long/short debounce time

Indicates the debounce time of a detected connection.

- 0: Long debounce time, used for physical connections (100 ms + 2.5 µs)
- 1: Short debounce time, used for soft connections (2.5  $\mu$ s)

Note: Only accessible in host mode.

#### Bit 16 CIDSTS: Connector ID status

Indicates the connector ID status on a connect event.

0: The OTG\_HS controller is in A-device mode

1: The OTG\_HS controller is in B-device mode

Note: Accessible in both peripheral and host modes.

#### Bits 15:12 Reserved, must be kept at reset value.

#### Bit 11 DHNPEN: Device HNP enabled

The application sets this bit when it successfully receives a SetFeature.SetHNPEnable command from the connected USB host.

- 0: HNP is not enabled in the application
- 1: HNP is enabled in the application

Note: Only accessible in peripheral mode.



Doc ID 018909 Rev 1

#### Bit 10 HSHNPEN: Host set HNP enable

The application sets this bit when it has successfully enabled HNP (using the SetFeature.SetHNPEnable command) on the connected device.

0: Host Set HNP is not enabled

1: Host Set HNP is enabled

Note: Only accessible in host mode.

#### Bit 9 HNPRQ: 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 when the host negotiation success status change bit in the OTG interrupt register (HNSSCHG bit in OTG\_HS\_GOTGINT) is set. The core clears this bit when the HNSSCHG bit is cleared.

0: No HNP request

1: HNP request

Note: Only accessible in peripheral mode.

#### Bit 8 HNGSCS: Host negotiation success

The core sets this bit when host negotiation is successful. The core clears this bit when the HNP Request (HNPRQ) bit in this register is set.

0: Host negotiation failure

1: Host negotiation success

Note: Only accessible in peripheral mode.

Bits 7:2 Reserved, must be kept at reset value.

#### Bit 1 SRQ: 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 OTG Interrupt register (HNSSCHG bit in OTG\_HS\_GOTGINT) is set. The core clears this bit when the HNSSCHG bit is cleared.

If you use the USB 1.1 full-speed serial transceiver interface to initiate the session request, the application must wait until  $V_{BUS}$  discharges to 0.2 V, after the B-Session Valid bit in this register (BSVLD bit in OTG\_HS\_GOTGCTL) is cleared. This discharge time varies between different PHYs and can be obtained from the PHY vendor.

0: No session request

1: Session request

Note: Only accessible in peripheral mode.

#### Bit 0 SRQSCS: Session request success

The core sets this bit when a session request initiation is successful.

- 0: Session request failure
- 1: Session request success

Note: Only accessible in peripheral mode.





### OTG\_HS interrupt register (OTG\_HS\_GOTGINT)

Address offset: 0x04

Reset value: 0x0000 0000

The application reads this register whenever there is an OTG interrupt and clears the bits in this register to clear the OTG interrupt.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|

| Reserved | DBCDNE    | ADTOCHG   | HNGDET    | Reserved | <b>DHOSSNH</b> | SRSSCHG   | Reserved | SEDET     | Res. |
|----------|-----------|-----------|-----------|----------|----------------|-----------|----------|-----------|------|
|          | rc_<br>w1 | rc_<br>w1 | rc_<br>w1 |          |                | rc_<br>w1 |          | rc_<br>w1 |      |

Bits 31:20 Reserved, must be kept at reset value.

#### Bit 19 DBCDNE: Debounce done

The core sets this bit when the debounce is completed after the device connect. The application can start driving USB reset after seeing this interrupt. This bit is only valid when the HNP Capable or SRP Capable bit is set in the Core USB Configuration register (HNPCAP bit or SRPCAP bit in OTG\_HS\_GUSBCFG, respectively).

Note: Only accessible in host mode.

#### Bit 18 ADTOCHG: A-device timeout change

The core sets this bit to indicate that the A-device has timed out while waiting for the B-device to connect.

Note: Accessible in both peripheral and host modes.

Bit 17 HNGDET: Host negotiation detected

The core sets this bit when it detects a host negotiation request on the USB.

Note: Accessible in both peripheral and host modes.

- Bits 16:10 Reserved, must be kept at reset value..
  - Bit 9 HNSSCHG: Host negotiation success status change

The core sets this bit on the success or failure of a USB host negotiation request. The application must read the host negotiation success bit of the OTG Control and Status register (HNGSCS in OTG\_HS\_GOTGCTL) to check for success or failure.

Note: Accessible in both peripheral and host modes.

Bits 7:3 Reserved, must be kept at reset value..

#### Bit 8 SRSSCHG: Session request success status change

The core sets this bit on the success or failure of a session request. The application must read the session request success bit in the OTG Control and status register (SRQSCS bit in OTG\_HS\_GOTGCTL) to check for success or failure.

Note: Accessible in both peripheral and host modes.

#### Bit 2 SEDET: Session end detected

The core sets this bit to indicate that the level of the voltage on  $V_{BUS}$  is no longer valid for a B-device session when  $V_{BUS}$  < 0.8 V.

Bits 1:0 Reserved, must be kept at reset value..

### OTG\_HS AHB configuration register (OTG\_HS\_GAHBCFG)

Address offset: 0x008

Reset value: 0x0000 0000

This register can be used to configure the core after power-on or a change in mode. This register mainly contains AHB system-related configuration parameters. Do not change this register after the initial programming. The application must program this register before starting any transactions on either the AHB or the USB.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8        | 7       | 6        | 5     | 4 | 3    | 2    | 1 | 0    |
|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|----|----|----|---|----------|---------|----------|-------|---|------|------|---|------|
|    |    |    |    |    |    |    |    |    |    | Re | eserv | ed |    |    |    |    |    |    |    |    |    |   | PTXFELVL | TXFELVL | Reserved | DMAEN |   | HBS' | TLEN | 1 | GINT |
|    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |    |    |   | rw       | rw      |          | rw    |   |      |      |   | rw   |

Bits 31:20 Reserved, must be kept at reset value..

Bit 8 **PTXFELVL:** Periodic TxFIFO empty level

Indicates when the periodic TxFIFO empty interrupt bit in the Core interrupt register (PTXFE bit in OTG\_HS\_GINTSTS) is triggered.

0: PTXFE (in OTG\_HS\_GINTSTS) interrupt indicates that the Periodic TxFIFO is half empty 1: PTXFE (in OTG\_HS\_GINTSTS) interrupt indicates that the Periodic TxFIFO is completely empty

Note: Only accessible in host mode.

Bit 7 **TXFELVL:** TxFIFO empty level

In peripheral mode, this bit indicates when the IN endpoint Transmit FIFO empty interrupt (TXFE in OTG\_HS\_DIEPINTx.) is triggered.

0: TXFE (in OTG\_HS\_DIEPINTx) interrupt indicates that the IN Endpoint TxFIFO is half empty

1: TXFE (in OTG\_HS\_DIEPINTx) interrupt indicates that the IN Endpoint TxFIFO is completely empty

Note: Only accessible in peripheral mode.

- Bit 6 Reserved, must be kept at reset value.
- Bits5 **DMAEN:** DMA enable
  - 0: The core operates in slave mode
  - 1: The core operates in DMA mode

#### Bits 4:1 HBSTLEN: Burst length/type

0000 Single 0001 INCR 0011 INCR4 0101 INCR8 0111 INCR16 Others: Reserved

Bit 0 GINT: Global interrupt mask

This bit is used to mask or unmask the interrupt line assertion to the application. Irrespective of this bit setting, the interrupt status registers are updated by the core.

0: Mask the interrupt assertion to the application.

1: Unmask the interrupt assertion to the application

Note: Accessible in both peripheral and host modes.

Doc ID 018909 Rev 1



### OTG\_HS USB configuration register (OTG\_HS\_GUSBCFG)

Address offset: 0x00C

Reset value: 0x0000 0A00

This register can be used to configure the core after power-on or a changing to host mode or peripheral mode. It contains USB and USB-PHY related configuration parameters. The application must program this register before starting any transactions on either the AHB or the USB. Do not make changes to this register after the initial programming.

| 31     | 30    | 29    | 28 | 27    | 26 | 25      | 24   | 23   | 22    | 21         | 20         | 19      | 18     | 17       | 16       | 15      | 14       | 13 | 12 | 11 | 10 | 9      | 8      | 7 | 6  | 5     | 4   | 3 | 2 | 1   | 0 |
|--------|-------|-------|----|-------|----|---------|------|------|-------|------------|------------|---------|--------|----------|----------|---------|----------|----|----|----|----|--------|--------|---|----|-------|-----|---|---|-----|---|
| СТХРКТ | FDMOD | FHMOD | Re | eserv | ed | ULPIIPD | PTCI | PCCI | TSDPS | ULPIEVBUSI | ULPIEVBUSD | NLPICSM | ULPIAR | ULPIFSLS | Reserved | PHYLPCS | Reserved |    | TR | DT |    | HNPCAP | SRPCAP |   | Re | eserv | red |   | т | OCA | L |
| rw     | rw    | rw    |    |       |    | rw      | rw   | rw   | rw    | rw         | rw         | rw      | rw     | rw       | rw       | rw      |          |    | r  | N  |    | r/rw   | r/rw   |   |    |       |     |   |   | rw  |   |

#### Bit 31 CTXPKT: Corrupt Tx packet

This bit is for debug purposes only. Never set this bit to 1. *Note: Accessible in both peripheral and host modes.* 

#### Bit 30 **FDMOD:** Forced peripheral mode

Writing a 1 to this bit forces the core to peripheral mode irrespective of the OTG\_HS\_ID input pin.

- 0: Normal mode
- 1: Forced peripheral mode

After setting the force bit, the application must wait at least 25 ms before the change takes effect.

Note: Accessible in both peripheral and host modes.

Bit 29 FHMOD: Forced host mode

Writing a 1 to this bit forces the core to host mode irrespective of the OTG\_HS\_ID input pin.

- 0: Normal mode
- 1: Forced host mode

After setting the force bit, the application must wait at least 25 ms before the change takes effect.

Note: Accessible in both peripheral and host modes.

Bits 28:26 Reserved, must be kept at reset value.

#### Bit 25 ULPI Interface protect disable

This bit controls the circuitry built in the PHY to protect the ULPI interface when the link tristates stp and data. Any pull-up or pull-down resistors employed by this feature can be disabled. Please refer to the ULPI specification for more details.

- 0: Enables the interface protection circuit
- 1: Disables the interface protection circuit

#### Bit 24 PTCI: Indicator pass through

This bit controls whether the complement output is qualified with the internal  $V_{BUS}$  valid comparator before being used in the  $V_{BUS}$  state in the RX CMD. Please refer to the ULPI specification for more details.

- 0: Complement Output signal is qualified with the Internal  $V_{\text{BUS}}$  valid comparator
- 1: Complement Output signal is not qualified with the Internal V<sub>BUS</sub> valid comparator



#### Bit 23 PCCI: Indicator complement

This bit controls the PHY to invert the ExternalVbusIndicator input signal, and generate the complement output. Please refer to the ULPI specification for more details. 0: PHY does not invert the ExternalVbusIndicator signal

1: PHY inverts ExternalVbusIndicator signal

#### Bit 22 TSDPS: TermSel DLine pulsing selection

This bit selects utmi\_termselect to drive the data line pulse during SRP (session request protocol).

0: Data line pulsing using utmi\_txvalid (default)

1: Data line pulsing using utmi\_termsel

#### Bit 21 ULPIEVBUSI: ULPI external V<sub>BUS</sub> indicator

This bit indicates to the ULPI PHY to use an external  $V_{\text{BUS}}$  overcurrent indicator.

0: PHY uses an internal V<sub>BUS</sub> valid comparator

1: PHY uses an external V<sub>BUS</sub> valid comparator

### Bit 20 ULPIEVBUSD: ULPI External V<sub>BUS</sub> Drive

This bit selects between internal or external supply to drive 5 V on  $V_{BUS}$ , in the ULPI PHY.

0: PHY drives V<sub>BUS</sub> using internal charge pump (default)

1: PHY drives V<sub>BUS</sub> using external supply.

#### Bit 19 ULPICSM: ULPI Clock SuspendM

This bit sets the ClockSuspendM bit in the interface control register on the ULPI PHY. This bit applies only in the serial and carkit modes.

- 0: PHY powers down the internal clock during suspend
- 1: PHY does not power down the internal clock

#### Bit 18 ULPIAR: ULPI Auto-resume

This bit sets the AutoResume bit in the interface control register on the ULPI PHY.

- 0: PHY does not use AutoResume feature
- 1: PHY uses AutoResume feature

#### Bit 17 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 is selected on the ULPI PHY. 0: ULPI interface

- 1: ULPI FS/LS serial interface
- Bit 16 Reserved, must be kept at reset value.

#### Bit 15 PHYLPCS: PHY Low-power clock select

This bit selects either 480 MHz or 48 MHz (low-power) PHY mode. In FS and LS modes, the PHY can usually operate on a 48 MHz clock to save power.

0: 480 MHz internal PLL clock

1: 48 MHz external clock

In 480 MHz mode, the UTMI interface operates at either 60 or 30 MHz, depending on whether the 8- or 16-bit data width is selected. In 48 MHz mode, the UTMI interface operates at 48 MHz in FS and LS modes.

#### Bit 14 Reserved, must be kept at reset value.



Bits 13:10 TRDT: USB turnaround time

Sets the turnaround time in PHY clocks.

The formula below gives the value of TRDT:

TRDT =  $4 \times AHB$  clock frequency+ 1 PHY clock frequency.

For example:

If AHB clock frequency = 72 MHz (PHY Clock frequency = 48 MHz), the TRDT must be set to 9.

If AHB clock frequency = 48 Mhz (PHY Clock frequency = 48 MHz), the TRDT must be set to 5.

Note: Only accessible in peripheral mode.

- Bit 9 HNPCAP: HNP-capable
  - The application uses this bit to control the OTG\_HS controller's HNP capabilities.
  - 0: HNP capability is not enabled
  - 1: HNP capability is enabled

Note: Accessible in both peripheral and host modes.

Bit 8 **SRPCAP:** SRP-capable

The application uses this bit to control the OTG\_HS controller's SRP capabilities. If the core operates as a nonSRP-capable B-device, it cannot request the connected A-device (host) to activate  $V_{BUS}$  and start a session.

- 0: SRP capability is not enabled
- 1: SRP capability is enabled

Note: Accessible in both peripheral and host modes.

Bits 7:3 Reserved, must be kept at reset value.

#### Bits 2:0 TOCAL: FS timeout calibration

The number of PHY clocks that the application programs in this field is added to the fullspeed interpacket 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 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 is 0.25 bit times.



### OTG\_HS reset register (OTG\_HS\_GRSTCTL)

Address offset: 0x010

Reset value: 0x2000 0000

The application uses this register to reset various hardware features inside the core.

| 31  | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7    | 6 | 5   | 4    | 3  | 2  | 1   | 0  |
|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------|---|-----|------|----|----|-----|----|
| lDL | REQ |    |    |    |    |    |    |    |    |    | ed |    |    |    |    |    |    |    |    |    |    | ту |   | 1. 1 |   | LSH | :LSH | ed | ßT | RST | ßT |

| AHBIDI | DMARE | deserved | TXFNUM | TXFFLS | RXFFLS | leserved | FCRST | TSRSH | CSRST |  |
|--------|-------|----------|--------|--------|--------|----------|-------|-------|-------|--|
| r      | r     | Ш        | rw     | rs     | rs     | 4        | rs    | rs    | rs    |  |

#### Bit 31 AHBIDL: AHB master idle

Indicates that the AHB master state machine is in the Idle condition.

Note: Accessible in both peripheral and host modes.

#### Bit 30 DMAREQ: DMA request signal

This bit indicates that the DMA request is in progress. Used for debug.

Bits 29:11 Reserved, must be kept at reset value.

#### Bits 10:6 **TXFNUM:** TxFIFO number

This is the FIFO number that must be flushed using the TxFIFO Flush bit. This field must not be changed until the core clears the TxFIFO Flush bit.

- 00000:
  - Nonperiodic TxFIFO flush in host mode
  - Tx FIFO 0 flush in peripheral mode
- 00001:
  - Periodic TxFIFO flush in host mode
  - TXFIFO 1 flush in peripheral mode
- 00010: TXFIFO 2 flush in peripheral mode
- ...
- 00101: TXFIFO 15 flush in peripheral mode
- 10000: Flush all the transmit FIFOs in peripheral or host mode.

Note: Accessible in both peripheral and host modes.

Bit 5 TXFFLSH: TxFIFO flush

This bit selectively flushes a single or all transmit FIFOs, but cannot do so if the core is in the midst of a transaction.

The application must write this bit only after checking that the core is neither writing to the TxFIFO nor reading from the TxFIFO. Verify using these registers:

- Read: the NAK effective interrupt ensures the core is not reading from the FIFO
- Write: the AHBIDL bit in OTG\_HS\_GRSTCTL ensures that the core is not writing anything to the FIFO

Note: Accessible in both peripheral and host modes.



#### Bit 4 **RXFFLSH:** RxFIFO flush

The application can flush the entire RxFIFO using this bit, but must first ensure that the core is not in the middle of a transaction.

The application must only write to this bit after checking that the core is neither reading from the RxFIFO nor writing to the RxFIFO.

The application must wait until the bit is cleared before performing any other operation. This bit requires 8 clocks (slowest of PHY or AHB clock) to be cleared.

Note: Accessible in both peripheral and host modes.

#### Bit 3 Reserved, must be kept at reset value.

#### Bit 2 FCRST: Host frame counter reset

The application writes this bit to reset the frame number counter inside the core. When the frame counter is reset, the subsequent SOF sent out by the core has a frame number of 0. *Note: Only accessible in host mode.* 

#### Bit 1 HSRST: HCLK soft reset

The application uses this bit to flush the control logic in the AHB Clock domain. Only AHB Clock Domain pipelines are reset.

FIFOs are not flushed with this bit.

All state machines in the AHB clock domain are reset to the Idle state after terminating the transactions on the AHB, following the protocol.

CSR control bits used by the AHB clock domain state machines are cleared.

To clear this interrupt, status mask bits that control the interrupt status and are generated by the AHB clock domain state machine are cleared.

Because interrupt status bits are not cleared, the application can get the status of any core events that occurred after it set this bit.

This is a self-clearing bit that the core clears after all necessary logic is reset in the core. This can take several clocks, depending on the core's current state.

Note: Accessible in both peripheral and host modes.



#### Bit 0 **CSRST:** Core soft reset

Resets the HCLK and PCLK domains as follows:

Clears the interrupts and all the CSR register bits except for the following bits:

- RSTPDMODL bit in OTG\_HS\_PCGCCTL
- GAYEHCLK bit in OTG\_HS\_PCGCCTL
- PWRCLMP bit in OTG\_HS\_PCGCCTL
- STPPCLK bit in OTG\_HS\_PCGCCTL
- FSLSPCS bit in OTG\_HS\_HCFG
- DSPD bit in OTG\_HS\_DCFG

All module state machines (except for 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 are terminated as soon as possible, after completing the last data phase of an AHB transfer. Any transactions on the USB are terminated immediately.

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 after all the necessary logic is reset in the core, which can take several clocks, depending on the current state of the core. Once this bit has been cleared, the software must wait at least 3 PHY clocks before accessing the PHY domain (synchronization delay). The software must also check that bit 31 in this register is set to 1 (AHB Master is Idle) before starting any operation.

Typically, the software reset is used during software development and also when you dynamically change the PHY selection bits in the above listed USB configuration registers. 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 be reset for proper operation.

Note: Accessible in both peripheral and host modes.



### OTG\_HS core interrupt register (OTG\_HS\_GINTSTS)

Address offset: 0x014

Reset value: 0x0400 0020

This register interrupts the application for system-level events in the current mode (peripheral mode or host mode).

Some of the bits in this register are valid only in host mode, while others are valid in peripheral mode only. This register also indicates the current mode. To clear the interrupt status bits of the rc\_w1 type, the application must write 1 into the bit.

The FIFO status interrupts are read-only; once software reads from or writes to the FIFO while servicing these interrupts, FIFO interrupt conditions are cleared automatically.

The application must clear the OTG\_HS\_GINTSTS register at initialization before unmasking the interrupt bit to avoid any interrupts generated prior to initialization.

|       | WKUINT             | 31 |
|-------|--------------------|----|
| rc_   | SRQINT             | 30 |
| _w1   | DISCINT            | 29 |
|       | CIDSCHG            | 28 |
|       | Reserved           | 27 |
| r     | PTXFE              | 26 |
| r     | HCINT              | 25 |
| r     | HPRTINT            | 24 |
|       | Reserved           | 23 |
|       | DATAFSUSP          | 22 |
| rc_   | IPXFR/INCOMPISOOUT | 21 |
| w1    | IISOIXFR           | 20 |
| r     | OEPINT             | 19 |
| r     | IEPINT             | 18 |
|       | Reserved           | 17 |
|       |                    | 16 |
|       | EOPF               | 15 |
|       | ISOODRP            | 14 |
| rc_   | ENUMDNE            | 13 |
| _w1   | USBRST             | 12 |
|       | ASUSASU            | 11 |
|       | ESUSP              | 10 |
|       | Beserved           | 9  |
|       |                    | 8  |
| r     | BOUTNAKEFF         | 1  |
| r     | GINAKEFF           | 6  |
| r     | NPTXFE             | 5  |
| r     | RXFLVL             | 4  |
| rc_w1 | SOF                | 3  |
| r     | OTGINT             | 2  |
| rc_w1 | MMIS               | 1  |
| r     | CMOD               | 0  |
|       |                    |    |

#### Bit 31 **WKUPINT:** Resume/remote wakeup detected interrupt

In peripheral mode, this interrupt is asserted when a resume is detected on the USB. In host mode, this interrupt is asserted when a remote wakeup is detected on the USB. *Note: Accessible in both peripheral and host modes.* 

Bit 30 SRQINT: Session request/new session detected interrupt

In host mode, this interrupt is asserted when a session request is detected from the device. In peripheral mode, this interrupt is asserted when  $V_{BUS}$  is in the valid range for a B-device device. Accessible in both peripheral and host modes.

Bit 29 **DISCINT:** Disconnect detected interrupt

Asserted when a device disconnect is detected.

Note: Only accessible in host mode.

Bit 28 CIDSCHG: Connector ID status change

The core sets this bit when there is a change in connector ID status.

Note: Accessible in both peripheral and host modes.

- Bit 27 Reserved, must be kept at reset value.
- Bit 26 PTXFE: Periodic TxFIFO empty

Asserted when the periodic transmit FIFO is either half or completely empty and there is space for at least one entry to be written in the periodic request queue. The half or completely empty status is determined by the periodic TxFIFO empty level bit in the Core AHB configuration register (PTXFELVL bit in OTG\_HS\_GAHBCFG).

Note: Only accessible in host mode.



Doc ID 018909 Rev 1

#### Bit 25 HCINT: 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 read the host all channels interrupt (OTG\_HS\_HAINT) register to determine the exact number of the channel on which the interrupt occurred, and then read the corresponding host channel-x interrupt (OTG\_HS\_HCINTx) register to determine the exact cause of the interrupt. The application must clear the appropriate status bit in the OTG\_HS\_HCINTx register to clear this bit. *Note: Only accessible in host mode.* 

#### Bit 24 HPRTINT: Host port interrupt

The core sets this bit to indicate a change in port status of one of the OTG\_HS controller ports in host mode. The application must read the host port control and status (OTG\_HS\_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.

#### Note: Only accessible in host mode.

#### Bits 23 Reserved, must be kept at reset value.

#### Bit 22 DATAFSUSP: 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. For example, after detecting an endpoint mismatch, the application:

- Sets a global nonperiodic IN NAK handshake
- Disables IN endpoints
- Flushes the FIFO
- Determines the token sequence from the IN token sequence learning queue
- Re-enables the endpoints
- Clears the global nonperiodic IN NAK handshake If the global nonperiodic IN NAK is cleared, the core has not yet fetched data for the IN endpoint, and the IN token is received: the core generates an "IN token received when FIFO empty" interrupt. The OTG then sends a NAK response to the host. To avoid this scenario, the application can check the FetSusp interrupt in OTG\_FS\_GINTSTS, which ensures that the FIFO is full before clearing a global NAK handshake. Alternatively, the application can mask the "IN token received when FIFO empty" interrupt when clearing a global IN NAK handshake.

#### Bit 21 IPXFR: Incomplete periodic transfer

In host mode, the core sets this interrupt bit when there are incomplete periodic transactions still pending, which are scheduled for the current frame.

#### Note: Only accessible in host mode.

#### INCOMPISOOUT: Incomplete isochronous OUT transfer

In peripheral mode, the core sets this interrupt to indicate that there is at least one isochronous OUT endpoint on which the transfer is not completed in the current frame. This interrupt is asserted along with the End of periodic frame interrupt (EOPF) bit in this register.

Note: Only accessible in peripheral mode.

#### Bit 20 IISOIXFR: Incomplete isochronous IN transfer

The core sets this interrupt to indicate that there is at least one isochronous IN endpoint on which the transfer is not completed in the current frame. This interrupt is asserted along with the End of periodic frame interrupt (EOPF) bit in this register.

Note: Only accessible in peripheral mode.



#### Bit 19 OEPINT: OUT endpoint interrupt

The core sets this bit to indicate that an interrupt is pending on one of the OUT endpoints of the core (in peripheral mode). The application must read the device all endpoints interrupt (OTG\_HS\_DAINT) register to determine the exact number of the OUT endpoint on which the interrupt occurred, and then read the corresponding device OUT Endpoint-x Interrupt (OTG\_HS\_DOEPINTx) register to determine the exact cause of the interrupt. The application must clear the appropriate status bit in the corresponding OTG\_HS\_DOEPINTx register to clear this bit.

Note: Only accessible in peripheral mode.

#### Bit 18 IEPINT: IN endpoint interrupt

The core sets this bit to indicate that an interrupt is pending on one of the IN endpoints of the core (in peripheral mode). The application must read the device All Endpoints Interrupt (OTG\_HS\_DAINT) register to determine the exact number of the IN endpoint on which the interrupt occurred, and then read the corresponding device IN Endpoint-x interrupt (OTG\_HS\_DIEPINTx) register to determine the exact cause of the interrupt. The application must clear the appropriate status bit in the corresponding OTG\_HS\_DIEPINTx register to clear this bit.

Note: Only accessible in peripheral mode.

- Bits 17:16 Reserved, must be kept at reset value.
  - Bit 15 EOPF: End of periodic frame interrupt

Indicates that the period specified in the periodic frame interval field of the device configuration register (PFIVL bit in OTG\_HS\_DCFG) has been reached in the current frame. *Note: Only accessible in peripheral mode.* 

#### Bit 14 ISOODRP: Isochronous OUT packet dropped interrupt

The core sets this bit when it fails to write an isochronous OUT packet into the RxFIFO because the RxFIFO does not have enough space to accommodate a maximum size packet for the isochronous OUT endpoint.

Note: Only accessible in peripheral mode.

#### Bit 13 ENUMDNE: Enumeration done

The core sets this bit to indicate that speed enumeration is complete. The application must read the device Status (OTG\_HS\_DSTS) register to obtain the enumerated speed. *Note: Only accessible in peripheral mode.* 

#### Bit 12 USBRST: USB reset

The core sets this bit to indicate that a reset is detected on the USB. *Note: Only accessible in peripheral mode.* 

#### Bit 11 USBSUSP: USB suspend

The core sets this bit to indicate that a suspend was detected on the USB. The core enters the Suspended state when there is no activity on the data lines for a period of 3 ms. *Note: Only accessible in peripheral mode.* 

#### Bit 10 ESUSP: Early suspend

The core sets this bit to indicate that an Idle state has been detected on the USB for 3 ms. *Note: Only accessible in peripheral mode.* 

Bits 9:8 Reserved, must be kept at reset value.



#### Bit 7 GONAKEFF: Global OUT NAK effective

Indicates that the Set global OUT NAK bit in the Device control register (SGONAK bit in OTG\_HS\_DCTL), set by the application, has taken effect in the core. This bit can be cleared by writing the Clear global OUT NAK bit in the Device control register (CGONAK bit in OTG\_HS\_DCTL).

Note: Only accessible in peripheral mode.

#### Bit 6 GINAKEFF: Global IN nonperiodic NAK effective

Indicates that the Set global nonperiodic IN NAK bit in the Device control register (SGINAK bit in OTG\_HS\_DCTL), set by the application, has taken effect in the core. That is, the core has sampled the Global IN NAK bit set by the application. This bit can be cleared by clearing the Clear global nonperiodic IN NAK bit in the Device control register (CGINAK bit in OTG\_HS\_DCTL).

This interrupt does not necessarily mean that a NAK handshake is sent out on the USB. The STALL bit takes precedence over the NAK bit.

Note: Only accessible in peripheral mode.

#### Bit 5 NPTXFE: Nonperiodic TxFIFO empty

This interrupt is asserted when the nonperiodic TxFIFO is either half or completely empty, and there is space in at least one entry to be written to the nonperiodic transmit request queue. The half or completely empty status is determined by the nonperiodic TxFIFO empty level bit in the OTG\_HS\_GAHBCFG register (TXFELVL bit in OTG\_HS\_GAHBCFG).

Note: Only accessible in host mode.

#### Bit 4 RXFLVL: RxFIFO nonempty

Indicates that there is at least one packet pending to be read from the RxFIFO. *Note:* Accessible in both host and peripheral modes.

#### Bit 3 SOF: Start of frame

In host mode, the core sets this bit to indicate that an SOF (FS), or Keep-Alive (LS) is transmitted on the USB. The application must write a 1 to this bit to clear the interrupt. In peripheral mode, in the core sets this bit to indicate that an SOF token has been received on the USB. The application can read the Device Status register to get the current frame number. This interrupt is seen only when the core is operating in FS.

Note: Accessible in both host and peripheral modes.

#### Bit 2 OTGINT: OTG interrupt

The core sets this bit to indicate an OTG protocol event. The application must read the OTG Interrupt Status (OTG\_HS\_GOTGINT) register to determine the exact event that caused this interrupt. The application must clear the appropriate status bit in the OTG\_HS\_GOTGINT register to clear this bit.

Note: Accessible in both host and peripheral modes.

#### Bit 1 MMIS: Mode mismatch interrupt

The core sets this bit when the application is trying to access:

A host mode register, when the core is operating in peripheral mode

A peripheral mode register, when the core is operating in host mode

The register access is completed on the AHB with an OKAY response, but is ignored by the core internally and does not affect the operation of the core.

Note: Accessible in both host and peripheral modes.

#### Bit 0 CMOD: Current mode of operation

Indicates the current mode.

- 0: Peripheral mode
- 1: Host mode

Note: Accessible in both host and peripheral modes.



### OTG\_HS interrupt mask register (OTG\_HS\_GINTMSK)

Address offset: 0x018

Reset value: 0x0000 0000

This register works with the Core interrupt register to interrupt the application. When an interrupt bit is masked, the interrupt associated with that bit is not generated. However, the Core Interrupt (OTG\_HS\_GINTSTS) register bit corresponding to that interrupt is still set.

| 31  | 30    | 29      | 28       | 27       | 26      | 25   | 24    | 23       | 22     | 21               | 20        | 19     | 18     | 17     | 16       | 15    | 14       | 13       | 12     | 11       | 10     | 9        | 8 | 7         | 6         | 5       | 4      | 3    | 2      | 1     | 0        |
|-----|-------|---------|----------|----------|---------|------|-------|----------|--------|------------------|-----------|--------|--------|--------|----------|-------|----------|----------|--------|----------|--------|----------|---|-----------|-----------|---------|--------|------|--------|-------|----------|
| MUM | SRQIM | DISCINT | CIDSCHGM | Reserved | MEHXFEM | HCIM | PRTIM | Reserved | FSUSPM | MARXENNIISOOXFRM | IISOIXFRM | OEPINT | IEPINT | EPMISM | Reserved | EOPFM | ISOODRPM | ENUMDNEM | USBRST | MASUSASU | ESUSPM | Reserved |   | GONAKEFFM | GINAKEFFM | NPTXFEM | MTATER | NHOS | OTGINT | WSIMM | Reserved |
| rw  | rw    | rw      | rw       |          | rw      | rw   | r     |          | rw     | rw               | rw        | rw     | rw     | rw     |          | rw    | rw       | rw       | rw     | rw       | rw     |          |   | rw        | rw        | rw      | rw     | rw   | rw     | rw    |          |

Bit 31 WUIM: Resume/remote wakeup detected interrupt mask

0: Masked interrupt

1: Unmasked interrupt

Note: Accessible in both host and peripheral modes.

#### Bit 30 **SRQIM:** Session request/new session detected interrupt mask

- 0: Masked interrupt
- 1: Unmasked interrupt

Note: Accessible in both host and peripheral modes.

#### Bit 29 **DISCINT:** Disconnect detected interrupt mask

- 0: Masked interrupt
- 1: Unmasked interrupt

Note: Accessible in both host and peripheral modes.

#### Bit 28 CIDSCHGM: Connector ID status change mask

- 0: Masked interrupt
- 1: Unmasked interrupt

Note: Accessible in both host and peripheral modes.

Bit 27 Reserved, must be kept at reset value.

#### Bit 26 PTXFEM: Periodic TxFIFO empty mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Only accessible in host mode.

#### Bit 25 HCIM: Host channels interrupt mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Only accessible in host mode.

#### Bit 24 PRTIM: Host port interrupt mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Only accessible in host mode.
- Bit 23 Reserved, must be kept at reset value.



| Bit 22 FSUSPM: Data fetch suspended ma | s | k |
|----------------------------------------|---|---|
|----------------------------------------|---|---|

0: Masked interrupt

- 1: Unmasked interrupt
- Note: Only accessible in peripheral mode.
- Bit 21 IPXFRM: Incomplete periodic transfer mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
  - Note: Only accessible in host mode.
  - **IISOOXFRM:** Incomplete isochronous OUT transfer mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt
  - Note: Only accessible in peripheral mode.
- Bit 20 IISOIXFRM: Incomplete isochronous IN transfer mask
  - 0: Masked interrupt 1: Unmasked interrupt
  - Note: Only accessible in peripheral mode.
- Bit 19 OEPINT: OUT endpoints interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
  - Note: Only accessible in peripheral mode.
- Bit 18 IEPINT: IN endpoints interrupt mask
  - 0: Masked interrupt 1: Unmasked interrupt *Note: Only accessible in peripheral mode.*
- Bit 17 EPMISM: Endpoint mismatch interrupt mask
  - 0: Masked interrupt 1: Unmasked interrupt Note: Only accessible in peripheral mode.
- Bit 16 Reserved, must be kept at reset value.
- Bit 15 **EOPFM:** End of periodic frame interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
  - Note: Only accessible in peripheral mode.
- Bit 14 ISOODRPM: Isochronous OUT packet dropped interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
  - Note: Only accessible in peripheral mode.
- Bit 13 **ENUMDNEM:** Enumeration done mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
  - Note: Only accessible in peripheral mode.
- Bit 12 USBRST: USB reset mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
  - Note: Only accessible in peripheral mode.



#### Bit 11 USBSUSPM: USB suspend mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Only accessible in peripheral mode.

### Bit 10 ESUSPM: Early suspend mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Only accessible in peripheral mode.

#### Bits 9:8 Reserved, must be kept at reset value..

#### Bit 7 GONAKEFFM: Global OUT NAK effective mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Only accessible in peripheral mode.

#### Bit 6 **GINAKEFFM:** Global nonperiodic IN NAK effective mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Only accessible in peripheral mode.

#### Bit 5 NPTXFEM: Nonperiodic TxFIFO empty mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Accessible in both peripheral and host modes.

#### Bit 4 RXFLVLM: Receive FIFO nonempty mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Accessible in both peripheral and host modes.

#### Bit 3 **SOFM:** Start of frame mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Accessible in both peripheral and host modes.

#### Bit 2 **OTGINT:** OTG interrupt mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Note: Accessible in both peripheral and host modes.

#### Bit 1 MMISM: Mode mismatch interrupt mask

#### 0: Masked interrupt

- 1: Unmasked interrupt
- Note: Accessible in both peripheral and host modes.
- Bit 0 Reserved, must be kept at reset value.



# OTG\_HS Receive status debug read/OTG status read and pop registers (OTG\_HS\_GRXSTSR/OTG\_HS\_GRXSTSP)

Address offset for Read: 0x01C

Address offset for Pop: 0x020

Reset value: 0x0000 0000

A read to the Receive status debug read register returns the contents of the top of the Receive FIFO. A read to the Receive status read and pop register additionally pops the top data entry out of the RxFIFO.

The receive status contents must be interpreted differently in host and peripheral modes. The core ignores the receive status pop/read when the receive FIFO is empty and returns a value of 0x0000 0000. The application must only pop the Receive Status FIFO when the Receive FIFO nonempty bit of the Core interrupt register (RXFLVL bit in OTG\_HS\_GINTSTS) is asserted.

### Host mode:

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8 7 6 5 4 3 2 1 0 |
|---------------------------------------------------------------------|-------------------|
|---------------------------------------------------------------------|-------------------|

| Reserved | PKTSTS | DPID | BCNT | CHNUM |
|----------|--------|------|------|-------|
| neserveu | r      | r    | r    | r     |

Bits 31:21 Reserved, must be kept at reset value.

Bits 20:17 PKTSTS: Packet status

Indicates the status of the received packet 0010: IN data packet received 0011: IN transfer completed (triggers an interrupt) 0101: Data toggle error (triggers an interrupt) 0111: Channel halted (triggers an interrupt) Others: Reserved

Bits 16:15 **DPID:** Data PID

Indicates the Data PID of the received packet 00: DATA0 10: DATA1 01: DATA2 11: MDATA

Bits 14:4 BCNT: Byte count

Indicates the byte count of the received IN data packet.

#### Bits 3:0 CHNUM: Channel number

Indicates the channel number to which the current received packet belongs.



### Peripheral mode:

| 31 | 30 29 | 28 27 | 26 25 | 24 2 | 3 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|-------|-------|-------|------|------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |       |       |       |      |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|         | Reserved | FRMNUM | PKTSTS | DPID | BCNT | EPNUM |
|---------|----------|--------|--------|------|------|-------|
| r r r r | neserveu | r      | r      | r    | r    | r     |

Bits 31:25 Reserved, must be kept at reset value.

Bits 24:21 FRMNUM: Frame number

This is the least significant 4 bits of the frame number in which the packet is received on the USB. This field is supported only when isochronous OUT endpoints are supported.

Bits 20:17 PKTSTS: Packet status

Indicates the status of the received packet 0001: Global OUT NAK (triggers an interrupt) 0010: OUT data packet received 0011: OUT transfer completed (triggers an interrupt) 0100: SETUP transaction completed (triggers an interrupt) 0110: SETUP data packet received Others: Reserved

Bits 16:15 **DPID:** Data PID

Indicates the Data PID of the received OUT data packet 00: DATA0 10: DATA1 01: DATA2 11: MDATA

Bits 14:4 BCNT: Byte count

Indicates the byte count of the received data packet.

Bits 3:0 **EPNUM:** Endpoint number Indicates the endpoint number to which the current received packet belongs.

### OTG\_HS Receive FIFO size register (OTG\_HS\_GRXFSIZ)

Address offset: 0x024

Reset value: 0x0000 0200

The application can program the RAM size that must be allocated to the RxFIFO.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Reserved    | RXFD |
|-------------|------|
| i lesci veu | r/rw |

Bits 31:16 Reserved, must be kept at reset value.

Bits 15:0 **RXFD:** RxFIFO depth This value is in terms of 32-bit words. Minimum value is 16 Maximum value is 1024 The power-on reset value of this register is specified as the largest Rx data FIFO depth.



Doc ID 018909 Rev 1

# OTG HS nonperiodic transmit FIFO size/Endpoint 0 transmit FIFO size register (OTG\_HS\_GNPTXFSIZ/OTG\_HS\_TX0FSIZ)

Address offset: 0x028

Reset value: 0x0000 0200

# Host mode:

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

| NPTXFD | NPTXFSA |
|--------|---------|
| r/rw   | r/rw    |

Bits 31:16 NPTXFD: Nonperiodic TxFIFO depth

This value is in terms of 32-bit words. Minimum value is 16 Maximum value is 1024

Bits 15:0 NPTXFSA: Nonperiodic transmit RAM start address

This field contains the memory start address for nonperiodic transmit FIFO RAM.

## Peripheral mode:

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

| TX0FD | TX0FSA |
|-------|--------|
| r/rw  | r/rw   |

#### Bits 31:16 TOXFD: Endpoint 0 TxFIFO depth

This value is in terms of 32-bit words. Minimum value is 16 Maximum value is 256

Bits 15:0 TX0FSA: Endpoint 0 transmit RAM start address

This field contains the memory start address for Endpoint 0 transmit FIFO RAM.

# OTG\_HS nonperiodic transmit FIFO/queue status register (OTG\_HS\_GNPTXSTS)

Address offset: 0x02C

Reset value: 0x0008 0200

Note: In peripheral mode, this register is not valid.

> This read-only register contains the free space information for the nonperiodic TxFIFO and the nonperiodic transmit request queue.

| 31    | 30 | 29 | 28 | 27  | 26  | 25 | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 1   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|-----|-----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|---|------|-----|---|---|---|---|---|---|---|
| ved   |    |    | NP | rxq | TOP |    |    |    |    | N  | PTQ | XSA | V  |    |    |    |    |    |    |    |    | Ν | IPTX | FSA | V |   |   |   |   |   |   |
| Reser |    |    |    | r   |     |    |    |    |    |    | r   |     |    |    |    |    |    |    |    |    |    |   | I    | r   |   |   |   |   |   |   |   |

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|



- Bit 31 Reserved, must be kept at reset value.
- Bits 30:24 NPTXQTOP: Top of the nonperiodic transmit request queue

Entry in the nonperiodic Tx request queue that is currently being processed by the MAC. Bits [30:27]: Channel/endpoint number

Bits [26:25]:

- 00: IN/OUT token
- 01: Zero-length transmit packet (device IN/host OUT)
- 10: PING/CSPLIT token
- 11: Channel halt command
- Bit [24]: Terminate (last entry for selected channel/endpoint)

#### Bits 23:16 NPTQXSAV: Nonperiodic transmit request queue space available

Indicates the amount of free space available in the nonperiodic transmit request queue. This queue holds both IN and OUT requests in host mode. Peripheral mode has only IN requests.

00: Nonperiodic transmit request queue is full

01: dx1 location available

10: dx2 locations available

*bxn*: dx*n* locations available ( $0 \le n \le dx8$ ) Others: Reserved

#### Bits 15:0 NPTXFSAV: Nonperiodic TxFIFO space available

Indicates the amount of free space available in the nonperiodic TxFIFO. Values are in terms of 32-bit words. 00: Nonperiodic TxFIFO is full 01: dx1 word available 10: dx2 words available 0xn: dx*n* words available (where  $0 \le n \le dx1024$ ) Others: Reserved

# OTG\_HS I<sup>2</sup>C access register (OTG\_HS\_GI2CCTL)

Address offset: 0x030

Reset value: 0x0000 0000

| 31     | 30 | 29       | 28        | 27 | 26        | 25       | 24  | 23    | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3    | 2  | 1  | 0  |
|--------|----|----------|-----------|----|-----------|----------|-----|-------|----|----|----|------|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|-----|------|----|----|----|
| BSYDNE | RW | Reserved | I2CDATSE0 | -  | DEV<br>DR | Reserved | ACK | IZCEN |    |    | А  | .DDF | 7  |    |    |    |    | R  | EG | ٩DD | R  |    |    |    |    | I  | RWI | DATA | Ą  |    |    |
| rw     | rw |          | rw        | rw | rw        |          | rw  | rw    | rw | rw | rw | rw   | rw | rw | rw | rw | rw | rw | rw | rw  | rw | rw | rw | rw | rw | rw | rw  | rw   | rw | rw | rw |



#### Bit 31 BSYDNE: I2C Busy/Done

The application sets this bit to 1 to start a request on the  $I^2C$  interface. When the transfer is complete, the core deasserts this bit to 0. As long as the bit is set indicating that the  $I^2C$  interface is busy, the application cannot start another request on the interface.

Bit 30 RW: Read/Write Indicator

This bit indicates whether a read or write register transfer must be performed on the interface.

0: Write

1: Read

Note: Read/write bursting is not supported for registers.

Bit 29 Reserved, must be kept at reset value.

## Bit 28 I2CDATSE0: I<sup>2</sup>C DatSe0 USB mode

This bit is used to select the full-speed interface USB mode.

- 0: VP\_VM USB mode
- 1: DAT\_SE0 USB mode

## Bits 27:26 **I2CDEVADR**: I<sup>2</sup>C Device Address

This bit selects the address of the  $I^2C$  slave on the USB 1.1 full-speed serial transceiver corresponding to the one used by the core for OTG signalling.

- Bit 25 Reserved, must be kept at reset value.
- Bit 24 ACK: I<sup>2</sup>C ACK

This bit indicates whether an ACK response was received from the  $I^2C$  slave. It is valid when BSYDNE is cleared by the core, after the application has initiated an  $I^2C$  access. 0: NAK

1: ACK

Bit 23 **I2CEN**: I<sup>2</sup>C Enable

This bit enables the  $I^2C$  master to initiate transactions on the  $I^2C$  interface.

Bits 22:16 **ADDR**: I<sup>2</sup>C Address

This is the 7-bit I<sup>2</sup>C device address used by the application to access any external I<sup>2</sup>C slave, including the I<sup>2</sup>C slave on a USB 1.1 OTG full-speed serial transceiver.

## Bits 15:8 **REGADDR**: I<sup>2</sup>C Register Address

These bits allow to program the address of the register to be read from or written to.

#### Bits 7:0 **RWDATA**: I<sup>2</sup>C Read/Write Data

After a register read operation, these bits hold the read data for the application. During a write operation, the application can use this register to program the data to be written to a register.





# OTG\_HS general core configuration register (OTG\_HS\_GCCFG)

Address offset: 0x038

Reset value: 0x0000 0000

| 31 30 29 2 | 28 27 26 25 24 23 | 3 22 21 20 19 18 17 | 16 15 14 13 12 11 10 9 | 8 7 6 5 4 3 2 1 0 |
|------------|-------------------|---------------------|------------------------|-------------------|
|------------|-------------------|---------------------|------------------------|-------------------|

| Reserved | NOVBUSSENS | SOFOUTEN | NBUSBSEN | VBUSASEN | <b>I2CPADEN</b> | PWRDWN. | Reserved |
|----------|------------|----------|----------|----------|-----------------|---------|----------|
|          | rw         | rw       | rw       | rw       | rw              | rw      |          |

Bits 31:22 Reserved, must be kept at reset value.

Bit 21 NOVBUSSENS: V<sub>BUS</sub> sensing disable option

When this bit is set,  $V_{BUS}$  is considered internally to be always at  $V_{BUS}$  valid level (5 V). This option removes the need for a dedicated  $V_{BUS}$  pad, and leave this pad free to be used for other purposes such as a shared functionality.  $V_{BUS}$  connection can be remapped on another general purpose input pad and monitored by software.

This option is only suitable for host-only or device-only applications.

- 0: V<sub>BUS</sub> sensing available by hardware
- 1:  $V_{BUS}$  sensing not available by hardware.

#### Bit 20 SOFOUTEN: SOF output enable

- 0: SOF pulse not available on PAD
- 1: SOF pulse available on PAD
- Bit 19 VBUSBSEN: Enable the V<sub>BUS</sub> sensing "B" device
  - 0: V<sub>BUS</sub> sensing "B" disabled
  - 1: V<sub>BUS</sub> sensing "B" enabled
- Bit 18 VBUSASEN: Enable the V<sub>BUS</sub> sensing "A" device
  - 0: V<sub>BUS</sub> sensing "A" disabled
  - 1:  $V_{BUS}$  sensing "A" enabled
- Bit 17 **I2CPADEN**: Enable I<sup>2</sup>C bus connection for the external I<sup>2</sup>C PHY interface.
  - 0: I<sup>2</sup>C bus disabled
  - 1: I<sup>2</sup>C bus enabled

#### Bit 16 PWRDWN: Power down

Used to activate the transceiver in transmission/reception

- 0: Power down active
- 1: Power down deactivated ("Transceiver active")
- Bits 15:0 Reserved, must be kept at reset value..

# OTG\_HS core ID register (OTG\_HS\_CID)

Address offset: 0x03C

Reset value:0x0000 1200

This is a read only register containing the Product ID.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15   | 14  | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | PF | RODI | JCT_ | _ID |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw   | rw   | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw |

### Bits 31:0 PRODUCT\_ID: Product ID field

Application-programmable ID field.

# OTG\_HS Host periodic transmit FIFO size register (OTG\_HS\_HPTXFSIZ)

Address offset: 0x100

Reset value: 0x0200 0600

| PTXFD PTXSA | n |       |       |
|-------------|---|-------|-------|
|             | D | PTXFD | PTXSA |
|             |   |       |       |

Bits 31:16 PTXFD: Host periodic TxFIFO depth

This value is in terms of 32-bit words. Minimum value is 16 Maximum value is 512

Bits 15:0 PTXSA: Host periodic TxFIFO start address

The power-on reset value of this register is the sum of the largest Rx data FIFO depth and largest nonperiodic Tx data FIFO depth.

# OTG\_HS device IN endpoint transmit FIFO size register (OTG\_HS\_DIEPTXFx) (x = 1..7, where x is the FIFO\_number)

Address offset:  $0x104 + (FIFO_number - 1) \times 0x04$ 

Reset value: 0x02000400

| 3   | 1 | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|---|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
|     |   |      |      |      |      |      | I    | NEP  | TXF  | 2    |      |      |      |      |      |      |      |      |      |      |      |      | П    | NEP. | TXS  | 4    |      |      |      |      |      |      |
| r/r | w | r/rw |

#### Bits 31:16 INEPTXFD: IN endpoint TxFIFO depth

This value is in terms of 32-bit words. Minimum value is 16 Maximum value is 512 The power-on reset value of this register is specified as the largest IN endpoint FIFO number depth.



Bits 15:0 **INEPTXSA:** IN endpoint FIFOx transmit RAM start address

This field contains the memory start address for IN endpoint transmit FIFOx.

# 30.12.3 Host-mode registers

Bit values in the register descriptions are expressed in binary unless otherwise specified.

Host-mode registers affect the operation of the core in the host mode. Host mode registers must not be accessed in peripheral mode, as the results are undefined. Host mode registers can be categorized as follows:

# OTG\_HS host configuration register (OTG\_HS\_HCFG)

Address offset: 0x400

Reset value: 0x0000 0000

This register configures the core after power-on. Do not change to this register after initializing the host.

| 0  |          | rw |
|----|----------|----|
| 1  |          | rw |
| 2  | FSLSS    | r  |
| 3  |          |    |
| 4  |          |    |
| 5  |          |    |
| 6  |          |    |
| 7  |          |    |
| 8  |          |    |
| 9  |          |    |
| 10 |          |    |
| 11 |          |    |
| 12 |          |    |
| 13 |          |    |
| 14 |          |    |
| 15 |          |    |
| 16 |          |    |
| 17 | leserved | ш. |
| 18 |          |    |
| 19 |          |    |
| 20 |          |    |
| 21 |          |    |
| 22 |          |    |
| 23 |          |    |
| 24 |          |    |
| 25 |          |    |
| 26 |          |    |
| 27 |          |    |
| 28 |          |    |
| 29 |          |    |
| 30 |          |    |
| 31 |          |    |

Bits 31:3 Reserved, must be kept at reset value.

Bit 2 FSLSS: FS- and LS-only support

The application uses this bit to control the core's enumeration speed. Using this bit, the application can make the core enumerate as an FS host, even if the connected device supports HS traffic. Do not make changes to this field after initial programming. 0: HS/FS/LS, based on the maximum speed supported by the connected device 1: FS/LS-only, even if the connected device can support HS (read-only)

## Bits 1:0 FSLSPCS: FS/LS PHY clock select

When the core is in FS host mode 01: PHY clock is running at 48 MHz Others: Reserved When the core is in LS host mode 01: PHY clock is running at 48 MHz. Others: Reserved



# OTG\_HS Host frame interval register (OTG\_HS\_HFIR)

Address offset: 0x404

Reset value: 0x0000 EA60

This register stores the frame interval information for the current speed to which the OTG\_HS controller has enumerated.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | Poor |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FR | IVL |    |    |    |    |    |    |    |
|    |    |    |    |    |    |    | nese | ervec | 1  |    |    |    |    |    |    | rw  | rw | rw | rw | rw | rw | rw | rw |

Bits 31:16 Reserved, must be kept at reset value.

Bits 15:0 FRIVL: Frame interval

The value that the application programs to this field specifies the interval between two consecutive SOFs (FS), micro-SOFs (HS) or Keep-Alive tokens (LS). This field contains the number of PHY clocks that constitute the required frame interval. The application can write a value to this register only after the Port enable bit of the host port control and status register (PENA bit in OTG\_HS\_HPRT) has been set. If no value is programmed, the core calculates the value based on the PHY clock specified in the FS/LS PHY Clock Select field of the Host configuration register (FSLSPCS in OTG\_HS\_HCFG):

frame duration × PHY clock frequency

Note: The FRIVL bit can be modified whenever the application needs to change the Frame interval time.

# OTG\_HS host frame number/frame time remaining register (OTG\_HS\_HFNUM)

Address offset: 0x408

#### Reset value: 0x0000 3FFF

This register indicates the current frame number. It also indicates the time remaining (in terms of the number of PHY clocks) in the current frame.

| 31 | 30    | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|---|---|---|---|---|---|
|    | FTREM |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FRN | NUN |   |   |   | _ |   |   |   |   |   |
| r  |       |    |    |    |    |    |    |    |    |    |    | r  | r  | r  | r  | r  | r  | r  | r  | r  | r   | r   | r | r | r | r | r |   |   |   |   |

#### Bits 31:16 FTREM: Frame time remaining

Indicates the amount of time remaining in the current frame, in terms of PHY clocks. This field decrements on each PHY clock. When it reaches zero, this field is reloaded with the value in the Frame interval register and a new SOF is transmitted on the USB.

### Bits 15:0 **FRNUM:** Frame number

This field increments when a new SOF is transmitted on the USB, and is cleared to 0 when it reaches 0x3FFF.



# OTG\_HS\_Host periodic transmit FIFO/queue status register (OTG\_HS\_HPTXSTS)

Address offset: 0x410

Reset value: 0x0008 0100

This read-only register contains the free space information for the periodic TxFIFO and the periodic transmit request queue.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|   |   | F | РТХС | OLC | 2 |   |   |   |   | F | РТХС | 2SA\ | / |   |   |    |    |    |    |    |    | F  | PTXF | SAV | L  |    |    |    |    |    |    |
|---|---|---|------|-----|---|---|---|---|---|---|------|------|---|---|---|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|
| r | r | r | r    | r   | r | r | r | r | r | r | r    | r    | r | r | r | rw   | rw  | rw | rw | rw | rw | rw | rw | rw |

## Bits 31:24 PTXQTOP: Top of the periodic transmit request queue

This indicates the entry in the periodic Tx request queue that is currently being processed by the MAC.

This register is used for debugging.

Bit [31]: Odd/Even frame

- 0: send in even (micro) frame
- 1: send in odd (micro) frame

Bits [30:27]: Channel/endpoint number

Bits [26:25]: Type

- 00: IN/OUT
- 01: Zero-length packet
- 11: Disable channel command

Bit [24]: Terminate (last entry for the selected channel/endpoint)

## Bits 23:16 **PTXQSAV:** Periodic transmit request queue space available

Indicates the number of free locations available to be written in the periodic transmit request queue. This queue holds both IN and OUT requests.

- 00: Periodic transmit request queue is full
- 01: dx1 location available
- 10: dx2 locations available
- bxn: dxn locations available ( $0 \le dxn \le PTXFD$ ) Others: Reserved

#### Bits 15:0 **PTXFSAVL:** Periodic transmit data FIFO space available

Indicates the number of free locations available to be written to in the periodic TxFIFO. Values are in terms of 32-bit words 0000: Periodic TxFIFO is full 0001: dx1 word available 0010: dx2 words available

bxn: dxn words available (where 0  $\leq~dxn\leq~dx512)$  Others: Reserved



# OTG\_HS Host all channels interrupt register (OTG\_HS\_HAINT)

Address offset: 0x414

Reset value: 0x0000 000

When a significant event occurs on a channel, the host all channels interrupt register interrupts the application using the host channels interrupt bit of the Core interrupt register (HCINT bit in OTG\_HS\_GINTSTS). This is shown in *Figure 368*. There is one interrupt bit per channel, up to a maximum of 16 bits. Bits in this register are set and cleared when the application sets and clears bits in the corresponding host channel-x interrupt register.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|-----|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    | Deer |       | J  |    |    |    |    |    |    |    |    |    |    |    |    |   | HA | INT |   |   |   |   |   |   |   |
|    |    |    |    |    |    |    | Rese | ervec | 1  |    |    |    |    |    |    | r  | r  | r  | r  | r  | r  | r | r  | r   | r | r | r | r | r | r | r |

Bits 31:16 Reserved, must be kept at reset value.

Bits 15:0 HAINT: Channel interrupts

One bit per channel: Bit 0 for Channel 0, bit 15 for Channel 15

# OTG\_HS host all channels interrupt mask register (OTG\_HS\_HAINTMSK)

Address offset: 0x418

Reset value: 0x0000 0000

The host all channel interrupt mask register works with the host all channel interrupt register to interrupt the application when an event occurs on a channel. There is one interrupt mask bit per channel, up to a maximum of 16 bits.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 | 10 9 8 7 6 5 4 3 2 1 0 |
|----------------------------------------------------------------|------------------------|
|----------------------------------------------------------------|------------------------|

| Reserved |    |    |    |    |    |    |    | HAI | NTM |    |    |    |    | _  | _  |    |
|----------|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|
|          | rw  | rw  | rw | rw | rw | rw | rw | rw | rw |

Bits 31:16 Reserved, must be kept at reset value.

Bits 15:0 HAINTM: Channel interrupt mask

0: Masked interrupt

1: Unmasked interrupt

One bit per channel: Bit 0 for channel 0, bit 15 for channel 15  $\,$ 



# OTG\_HS host port control and status register (OTG\_HS\_HPRT)

Address offset: 0x440

Reset value: 0x0000 0000

This register is available only in host mode. Currently, the OTG host supports only one port.

A single register holds USB port-related information such as USB reset, enable, suspend, resume, connect status, and test mode for each port. It is shown in *Figure 368*. The rc\_w1 bits in this register can trigger an interrupt to the application through the host port interrupt bit of the core interrupt register (HPRTINT bit in OTG\_HS\_GINTSTS). On a Port Interrupt, the application must read this register and clear the bit that caused the interrupt. For the rc\_w1 bits, the application must write a 1 to the bit to clear the interrupt.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|

| Reserved | PS | PD |    | PTC | CTL |    | AWAA | ά | - | eserved | PRST | dSNSd | PRES | POCCHNG   | POCA | PENCHNG   | PENA | PCDET     | PCSTS |
|----------|----|----|----|-----|-----|----|------|---|---|---------|------|-------|------|-----------|------|-----------|------|-----------|-------|
|          | r  | r  | rw | rw  | rw  | rw | rw   | r | r | Ē       | rw   | rs    | rw   | rc_<br>w1 |      | rc_<br>w1 |      | rc_<br>w1 | r     |

Bits 31:19 Reserved, must be kept at reset value.

#### Bits 18:17 **PSPD:** Port speed

Indicates the speed of the device attached to this port.

- 00: High speed
- 01: Full speed
- 10: Low speed
- 11: Reserved

Bits 16:13 PTCTL: Port test control

The application writes a nonzero value to this field to put the port into a Test mode, and the corresponding pattern is signaled on the port.

- 0000: Test mode disabled
- 0001: Test\_J mode
- 0010: Test\_K mode
- 0011: Test\_SE0\_NAK mode
- 0100: Test\_Packet mode
- 0101: Test\_Force\_Enable
- Others: Reserved

Bit 12 PPWR: Port power

The application uses this field to control power to this port, and the core clears this bit on an overcurrent condition.

- 0: Power off
- 1: Power on

# Bits 11:10 **PLSTS:** Port line status

Indicates the current logic level USB data lines Bit [10]: Logic level of OTG\_HS\_FS\_DP Bit [11]: Logic level of OTG\_HS\_FS\_DM

Bit 9 Reserved, must be kept at reset value.



### Bit 8 PRST: Port reset

When the application sets this bit, a reset sequence is started on this port. The application must time the reset period and clear this bit after the reset sequence is complete. 0: Port not in reset

1: Port in reset

The application must leave this bit set for a minimum duration of at least 10 ms to start a reset on the port. The application can leave it set for another 10 ms in addition to the required minimum duration, before clearing the bit, even though there is no maximum limit set by the USB standard.

High speed: 50 ms

Full speed/Low speed: 10 ms

#### Bit 7 PSUSP: Port suspend

The application sets this bit to put this port in Suspend mode. The core only stops sending SOFs when this is set. To stop the PHY clock, the application must set the Port clock stop bit, which asserts the suspend input pin of the PHY.

The read value of this bit reflects the current suspend status of the port. This bit is cleared by the core after a remote wakeup signal is detected or the application sets the Port reset bit or Port resume bit in this register or the Resume/remote wakeup detected interrupt bit or Disconnect detected interrupt bit in the Core interrupt register (WKUINT or DISCINT in OTG\_HS\_GINTSTS, respectively).

0: Port not in Suspend mode

1: Port in Suspend mode

### Bit 6 PRES: 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 (WKUINT bit in OTG\_HS\_GINTSTS), 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.

- 0: No resume driven
- 1: Resume driven

## Bit 5 POCCHNG: Port overcurrent change

The core sets this bit when the status of the Port overcurrent active bit (bit 4) in this register changes.

### Bit 4 POCA: Port overcurrent active

Indicates the overcurrent condition of the port.

- 0: No overcurrent condition
- 1: Overcurrent condition

### Bit 3 **PENCHNG:** Port enable/disable change

The core sets this bit when the status of the Port enable bit [2] in this register changes.



### Bit 2 PENA: Port enable

A port is enabled only by the core after a reset sequence, and is disabled by an overcurrent condition, a disconnect condition, or by the application clearing this bit. The application cannot set this bit by a register write. It can only clear it to disable the port. This bit does not trigger any interrupt to the application.

- 0: Port disabled
- 1: Port enabled
- Bit 1 PCDET: Port connect detected

The core sets this bit when a device connection is detected to trigger an interrupt to the application using the host port interrupt bit in the Core interrupt register (HPRTINT bit in OTG\_HS\_GINTSTS). The application must write a 1 to this bit to clear the interrupt.

- Bit 0 PCSTS: Port connect status
  - 0: No device is attached to the port
  - 1: A device is attached to the port

# OTG\_HS host channel-x characteristics register (OTG\_HS\_HCCHARx) (x = 0..11, where x = Channel\_number)

Address offset: 0x500 + (Channel\_number × 0x20)

Reset value: 0x0000 0000

| 31    | 30    | 29     | 28 | 27 | 26 | 25  | 24 | 23 | 22 | 21 | 20 | 19    | 18 | 17    | 16       | 15    | 14 | 13  | 12  | 11 | 10 | 9  | 8  | 7  | 6  | 5    | 4  | 3  | 2  | 1  | 0  |
|-------|-------|--------|----|----|----|-----|----|----|----|----|----|-------|----|-------|----------|-------|----|-----|-----|----|----|----|----|----|----|------|----|----|----|----|----|
| CHENA | CHDIS | ODDFRM |    |    |    | DAD |    |    |    | М  | IC | EPTVD | _  | LSDEV | leserved | EPDIR |    | EPN | IUM |    |    |    |    |    | N  | IPSI | Z  |    |    |    |    |
| rs    | rs    | rw     | rw | rw | rw | rw  | rw | rw | rw | rw | rw | rw    | rw | rw    | ш        | rw    | rw | rw  | rw  | rw | rw | rw | rw | rw | rw | rw   | rw | rw | rw | rw | rw |

#### Bit 31 CHENA: Channel enable

This field is set by the application and cleared by the OTG host.

- 0: Channel disabled
- 1: Channel enabled
- Bit 30 CHDIS: Channel disable

The application sets this bit to stop transmitting/receiving data on a channel, even before the transfer for that channel is complete. The application must wait for the Channel disabled interrupt before treating the channel as disabled.

#### Bit 29 ODDFRM: Odd frame

This field is set (reset) by the application to indicate that the OTG host must perform a transfer in an odd frame. This field is applicable for only periodic (isochronous and interrupt) transactions.

- 0: Even (micro) frame
- 1: Odd (micro) frame

## Bits 28:22 DAD: Device address

This field selects the specific device serving as the data source or sink.



Bits 21:20 MC: Multi Count (MC) / Error Count (EC)

- When the split enable bit (SPLITEN) in the host channel-x split control register (OTG\_HS\_HCSPLTx) is reset (0), this field indicates to the host the number of transactions that must be executed per micro-frame for this periodic endpoint. For nonperiodic transfers, this field specifies the number of packets to be fetched for this channel before the internal DMA engine changes arbitration.
  - 00: Reserved This field yields undefined results
  - 01: 1 transaction
  - b10: 2 transactions to be issued for this endpoint per micro-frame
- 11: 3 transactions to be issued for this endpoint per micro-frame.
- When the SPLITEN bit is set (1) in OTG\_HS\_HCSPLTx, this field indicates the number of immediate retries to be performed for a periodic split transaction on transaction errors. This field must be set to at least 01.
- Bits 19:18 EPTYP: Endpoint type
  - Indicates the transfer type selected.
  - 00: Control
  - 01: Isochronous
  - 10: Bulk
  - 11: Interrupt
  - Bit 17 LSDEV: Low-speed device

This field is set by the application to indicate that this channel is communicating to a low-speed device.

- Bit 16 Reserved, must be kept at reset value.
- Bit 15 **EPDIR:** Endpoint direction

Indicates whether the transaction is IN or OUT. 0: OUT 1: IN

Bits 14:11 **EPNUM:** Endpoint number

Indicates the endpoint number on the device serving as the data source or sink.

Bits 10:0 MPSIZ: Maximum packet size

Indicates the maximum packet size of the associated endpoint.



# OTG\_HS host channel-x split control register (OTG\_HS\_HCSPLTx) (x = 0..11, where x = Channel\_number)

Address offset:  $0x504 + (Channel_number \times 0x20)$ 

Reset value: 0x0000 0000

| 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16        | 15      | 14 | 13 | 12 | 11 | 10      | 9  | 8  | 7  | 6  | 5  | 4  | 3       | 2  | 1  | 0  |
|---------|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|-----------|---------|----|----|----|----|---------|----|----|----|----|----|----|---------|----|----|----|
| SPLITEN |    |    |    |    |    |    |    | Heserved |    |    |    |    |    |    | COMPLSPLT | JUDIUVA |    |    |    |    | HUBADDR |    |    |    |    |    |    | PRTADDR |    |    |    |
| rw      |    |    |    |    |    |    |    |          |    |    |    |    |    |    | rw        | rw      | rw | rw | rw | rw | rw      | rw | rw | rw | rw | rw | rw | rw      | rw | rw | rw |

### Bit 31 SPLITEN: Split enable

The application sets this bit to indicate that this channel is enabled to perform split transactions.

Bits 30:17 Reserved, must be kept at reset value.

# Bit 16 COMPLSPLT: Do complete split

The application sets this bit to request the OTG host to perform a complete split transaction.

# Bits 15:14 XACTPOS: Transaction position

This field is used to determine whether to send all, first, middle, or last payloads with each OUT transaction.

11: All. This is the entire data payload of this transaction (which is less than or equal to 188 bytes)

10: Begin. This is the first data payload of this transaction (which is larger than 188 bytes)00: Mid. This is the middle payload of this transaction (which is larger than 188 bytes)01: End. This is the last payload of this transaction (which is larger than 188 bytes)

## Bits 13:7 HUBADDR: Hub address

This field holds the device address of the transaction translator's hub.

## Bits 6:0 PRTADDR: Port address

This field is the port number of the recipient transaction translator.



# OTG\_HS host channel-x interrupt register (OTG\_HS\_HCINTx) (x = 0..11, where $x = Channel_number$ )

Address offset:  $0x508 + (Channel_number \times 0x20)$ 

Reset value: 0x0000 0000

This register indicates the status of a channel with respect to USB- and AHB-related events. It is shown in *Figure 368*. The application must read this register when the host channels interrupt bit in the Core interrupt register (HCINT bit in OTG\_HS\_GINTSTS) is set. Before the application can read this register, it must first read the host all channels interrupt (OTG\_HS\_HAINT) register to get the exact channel number for the host channel-x interrupt register. The application must clear the appropriate bit in this register to clear the corresponding bits in the OTG\_HS\_HAINT and OTG\_HS\_GINTSTS registers.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21    | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10        | 9         | 8     | 7         | 6         | 5         | 4   | 3     | 2         | 1         | 0         |
|----|----|----|----|----|----|----|----|----|----|-------|-----|----|----|----|----|----|----|----|----|----|-----------|-----------|-------|-----------|-----------|-----------|-----|-------|-----------|-----------|-----------|
|    |    |    |    |    |    |    |    |    | Re | eserv | red |    |    |    |    |    |    |    |    |    | DTERR     | FRMOR     | BBERR | TXERR     | NYET      | ACK       | NAK | STALL | AHBERR    | СНН       | XFRC      |
|    |    |    |    |    |    |    |    |    |    |       |     |    |    |    |    |    |    |    |    |    | rc_<br>w1 | rc_<br>w1 |       | rc_<br>w1 | rc_<br>w1 | rc_<br>w1 |     |       | rc_<br>w1 | rc_<br>w1 | rc_<br>w1 |

Bits 31:11 Reserved, must be kept at reset value.

- Bit 10 DTERR: Data toggle error
- Bit 9 **FRMOR:** Frame overrun
- Bit 8 BBERR: Babble error
- Bit 7 TXERR: Transaction error

Indicates one of the following errors occurred on the USB. CRC check failure Timeout Bit stuff error False EOP

- Bit 6 NYET: Response received interrupt
- Bit 5 ACK: ACK response received/transmitted interrupt
- Bit 4 NAK: NAK response received interrupt
- Bit 3 STALL: STALL response received interrupt
- Bit 2 AHBERR: AHB error

This error is generated only in Internal DMA mode when an AHB error occurs during an AHB read/write operation. The application can read the corresponding DMA channel address register to get the error address.

Bit 1 CHH: Channel halted

Indicates the transfer completed abnormally either because of any USB transaction error or in response to disable request by the application.

Bit 0 XFRC: Transfer completed

Transfer completed normally without any errors.



# OTG\_HS host channel-x interrupt mask register (OTG\_HS\_HCINTMSKx) (x = 0..11, where x = Channel\_number)

Address offset: 0x50C + (Channel\_number × 0x20)

Reset value: 0x0000 0000

This register reflects the mask for each channel status described in the previous section.

| 31 30 2 | 9 28 2 | 27 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|--------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|---------|--------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

| Reserved | DTERRM | RMORM | MARAB | тхевям | NYET | ACKM | NAKM | STALLM | AHBERR | СННМ | XFRCM |
|----------|--------|-------|-------|--------|------|------|------|--------|--------|------|-------|
|          | rw     | rw    | rw    | rw     | rw   | rw   | rw   | rw     | rw     | rw   | rw    |

- Bits 31:11 Reserved, must be kept at reset value.
  - Bit 10 **DTERRM:** Data toggle error mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt
  - Bit 9 FRMORM: Frame overrun mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt
  - Bit 8 BBERRM: Babble error mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt
  - Bit 7 TXERRM: Transaction error mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt
  - Bit 6 NYET: response received interrupt mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt
  - Bit 5 ACKM: ACK response received/transmitted interrupt mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt
  - Bit 4 NAKM: NAK response received interrupt mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt
  - Bit 3 STALLM: STALL response received interrupt mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt



#### Bit 2 AHBERR: AHB error

This is generated only in Internal DMA mode when 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.

- Bit 1 CHHM: Channel halted mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 0 XFRCM: Transfer completed mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt

# OTG\_HS host channel-x transfer size register (OTG\_HS\_HCTSIZx) (x = 0..11, where $x = Channel_number$ )

Address offset:  $0x510 + (Channel_number \times 0x20)$ 

Reset value: 0x0000 0000

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|   | Heserved | DF | DI |    |    |    |    | PKT | CNT |    |    |    |    |    |    |    |    |    |    |    |    | х  | FRS | IZ |    |    |    |    |    |    |    |    |   |
|---|----------|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|---|
| r | w        | rw  | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw | l |

#### Bit 31 DOPING: Do ping

This bit is used only for OUT transfers. Setting this field to 1 directs the host to do PING protocol.

Note: Do not set this bit for IN transfers. If this bit is set for IN transfers it disables the channel.

Bits 30:29 **DPID:** Data PID

The application programs this field with the type of PID to use for the initial transaction. The host maintains this field for the rest of the transfer.

- 00: DATA0
- 01: DATA2
- 10: DATA1

11: MDATA (noncontrol)/SETUP (control)

#### Bits 28:19 PKTCNT: Packet count

This field is programmed by the application with the expected number of packets to be transmitted (OUT) or received (IN).

The host decrements this count on every successful transmission or reception of an OUT/IN packet. Once this count reaches zero, the application is interrupted to indicate normal completion.

## Bits 18:0 XFRSIZ: Transfer size

For an OUT, this field is the number of data bytes the host sends during the transfer. For an IN, this field is the buffer size that the application has reserved for the transfer. The application is expected to program this field as an integer multiple of the maximum packet size for IN transactions (periodic and nonperiodic).



# OTG\_HS host channel-x DMA address register (OTG\_HS\_HCDMAx) (x = 0..11, where x = Channel\_number)

Address offset:  $0x514 + (Channel_number \times 0x20)$ 

Reset value: 0x0000 0000

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  | DMA | ADDF | ٦  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw  | rw   | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw |

Bits 31:0 **DMAADDR:** DMA address

This field holds the start address in the external memory from which the data for the endpoint must be fetched or to which it must be stored. This register is incremented on every AHB transaction.

# 30.12.4 Device-mode registers

# OTG\_HS device configuration register (OTG\_HS\_DCFG)

Address offset: 0x800

Reset value: 0x0220 0000

This register configures the core in peripheral mode after power-on or after certain control commands or enumeration. Do not make changes to this register after initial programming.

| 31 30 29 28 27 26 3 | 25 24 23 22 21 | 20 19 18 17 16 15 | 14 13 12 11 10 9 8 | 8 7 6 5 4 3 2 1 0 |
|---------------------|----------------|-------------------|--------------------|-------------------|
| 01 00 20 20 21 20 1 |                |                   |                    |                   |

| Reserved | PERSCHIVL | Reserved | Reserved | PFIVL |    |    |    | DAD |    |    |    | Reserved | NZHOSTZN |    | പഹ |
|----------|-----------|----------|----------|-------|----|----|----|-----|----|----|----|----------|----------|----|----|
|          | rw rw     |          |          | rw    | rw | rw | rw | rw  | rw | rw | rw |          | rw       | rw | rw |

Bits 31:26 Reserved, must be kept at reset value.

#### Bits 25:24 PERSCHIVL: Periodic scheduling interval

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 the (micro)frame.

- When any periodic endpoints are active, the internal DMA engine allocates the specified amount of time in fetching periodic IN endpoint data
- When no periodic endpoint is 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 nonperiodic endpoints
- 00: 25% of (micro)frame
- 01: 50% of (micro)frame
- 10: 75% of (micro)frame
- 11: Reserved

Bits 23:13 Reserved, must be kept at reset value.



### Bits 12:11 PFIVL: Periodic (micro)frame interval

Indicates the time within a (micro) frame at which the application must be notified using the end of periodic (micro) frame interrupt. This can be used to determine if all the isochronous traffic for that frame is complete.

- 00: 80% of the frame interval
- 01: 85% of the frame interval
- 10: 90% of the frame interval
- 11: 95% of the frame interval

### Bits 10:4 **DAD:** Device address

The application must program this field after every SetAddress control command.

Bit 3 Reserved, must be kept at reset value.

### Bit 2 NZLSOHSK: Nonzero-length status OUT handshake

The application can use this field to select the handshake the core sends on receiving a nonzero-length data packet during the OUT transaction of a control transfer's Status stage. 1: Send a STALL handshake on a nonzero-length status OUT transaction and do not send the received OUT packet to the application.

0: Send the received OUT packet to the application (zero-length or nonzero-length) and send a handshake based on the NAK and STALL bits for the endpoint in the device endpoint control register.

## Bits 1:0 **DSPD:** Device speed

Indicates the speed at which the application requires the core to enumerate, or the maximum speed the application can support. However, the actual bus speed is determined only after the chirp sequence is completed, and is based on the speed of the USB host to which the core is connected.

- 00: High speed
- 01: Reserved
- 10: Reserved
- 11: Full speed (USB 1.1 transceiver clock is 48 MHz)



# OTG\_HS device control register (OTG\_HS\_DCTL)

Address offset: 0x804

Reset value: 0x0000 0000

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21    | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11       | 10     | 9      | 8      | 7      | 6  | 5    | 4  | 3      | 2      | 1    | 0      |
|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|----------|--------|--------|--------|--------|----|------|----|--------|--------|------|--------|
|    |    |    |    |    |    |    |    |    | Rese | erved | I  |    |    |    |    |    |    |    |    | POPRGDNE | CGONAK | SGONAK | CGINAK | SGINAK |    | тстг |    | GONSTS | GINSTS | SIDS | RWUSIG |
|    |    |    |    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |    |    | rw       | w      | w      | w      | w      | rw | rw   | rw | r      | r      | rw   | rw     |

Bits 31:12 Reserved, must be kept at reset value.

#### Bit 11 **POPRGDNE:** Power-on programming done

The application uses this bit to indicate that register programming is completed after a wakeup from power down mode.

## Bit 10 CGONAK: Clear global OUT NAK

A write to this field clears the Global OUT NAK.

#### Bit 9 SGONAK: Set global OUT NAK

A write to this field sets the Global OUT NAK. The application uses this bit to send a NAK handshake on all OUT endpoints. The application must set the this bit only after making sure that the Global OUT NAK effective bit in the Core interrupt register (GONAKEFF bit in OTG\_HS\_GINTSTS) is cleared.

#### Bit 8 CGINAK: Clear global IN NAK

A write to this field clears the Global IN NAK.

#### Bit 7 SGINAK: Set global IN NAK

A write to this field sets the Global nonperiodic IN NAK. The application uses this bit to send a NAK handshake on all nonperiodic IN endpoints.

The application must set this bit only after making sure that the Global IN NAK effective bit in the Core interrupt register (GINAKEFF bit in OTG\_HS\_GINTSTS) is cleared.

## Bits 6:4 **TCTL:** Test control

- 000: Test mode disabled
- 001: Test\_J mode
- 010: Test\_K mode
- 011: Test\_SE0\_NAK mode
- 100: Test\_Packet mode
- 101: Test\_Force\_Enable
- Others: Reserved
- Bit 3 GONSTS: Global OUT NAK status

0: A handshake is sent based on the FIFO Status and the NAK and STALL bit settings. 1: 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.



#### Bit 2 GINSTS: Global IN NAK status

0: A handshake is sent out based on the data availability in the transmit FIFO. 1: A NAK handshake is sent out on all nonperiodic IN endpoints, irrespective of the data availability in the transmit FIFO.

#### Bit 1 **SDIS:** Soft disconnect

The application uses this bit to signal the USB OTG core to perform a soft disconnect. As long as this bit is set, the host does not see that the device is connected, and the device does not receive signals on the USB. The core stays in the disconnected state until the application clears this bit.

0: Normal operation. When this bit is cleared after a soft disconnect, the core generates a device connect event to the USB host. When the device is reconnected, the USB host restarts device enumeration.

1: The core generates a device disconnect event to the USB host.

## Bit 0 RWUSIG: Remote wakeup signaling

When the application sets this bit, the core initiates remote signaling to wake up the USB host. The application must set this bit to instruct the core to exit the Suspend state. As specified in the USB 2.0 specification, the application must clear this bit 1 ms to 15 ms after setting it.

*Table 161* contains the minimum duration (according to device state) for which the Soft disconnect (SDIS) bit must be set for the USB host to detect a device disconnect. To accommodate clock jitter, it is recommended that the application add some extra delay to the specified minimum duration.

| Operating speed | Device state                                    | Minimum duration |
|-----------------|-------------------------------------------------|------------------|
| High speed      | Not Idle or Suspended (Performing transactions) | 125 µs           |
| Full speed      | Suspended                                       | 1 ms + 2.5 µs    |
| Full speed      | Idle                                            | 2.5 µs           |
| Full speed      | Not Idle or Suspended (Performing transactions) | 2.5 µs           |

Table 161. Minimum duration for soft disconnect



# OTG\_HS device status register (OTG\_HS\_DSTS)

Address offset: 0x808

Reset value: 0x0000 0010

This register indicates the status of the core with respect to USB-related events. It must be read on interrupts from the device all interrupts (OTG\_HS\_DAINT) register.

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

| Reserved |   |   |   |   |   |   | FN | SOF |   |   |   |   |   |   | Reserved | EERR |   |   | SUSPSTS |
|----------|---|---|---|---|---|---|----|-----|---|---|---|---|---|---|----------|------|---|---|---------|
|          | r | r | r | r | r | r | r  | r   | r | r | r | r | r | r |          | r    | r | r | r       |

Bits 31:22 Reserved, must be kept at reset value.

Bits 21:8 FNSOF: Frame number of the received SOF

Bits 7:4 Reserved, must be kept at reset value.

Bit 3 **EERR:** Erratic error

The core sets this bit to report any erratic errors.

Due to erratic errors, the OTG\_HS controller goes into Suspended state and an interrupt is generated to the application with Early suspend bit of the Core interrupt register (ESUSP bit in OTG\_HS\_GINTSTS). If the early suspend is asserted due to an erratic error, the application can only perform a soft disconnect recover.

#### Bits 2:1 ENUMSPD: Enumerated speed

Indicates the speed at which the OTG\_HS controller has come up after speed detection through a chirp sequence.

- 00: High speed
- 01: Reserved
- 10: Reserved
- 11: Full speed (PHY clock is running at 48 MHz)

Others: reserved

## Bit 0 SUSPSTS: Suspend status

In peripheral mode, this bit is set as long as a Suspend condition is detected on the USB. The core enters the Suspended state when there is no activity on the USB data lines for a period of 3 ms. The core comes out of the suspend:

- When there is an activity on the USB data lines
- When the application writes to the Remote wakeup signaling bit in the Device control register (RWUSIG bit in OTG\_HS\_DCTL).



# OTG\_HS device IN endpoint common interrupt mask register (OTG\_HS\_DIEPMSK)

Address offset: 0x810

Reset value: 0x0000 0000

This register works with each of the Device IN endpoint interrupt (OTG\_HS\_DIEPINTx) registers for all endpoints to generate an interrupt per IN endpoint. The IN endpoint interrupt for a specific status in the OTG\_HS\_DIEPINTx register can be masked by writing to the corresponding bit in this register. Status bits are masked by default.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21   | 20    | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8      | 7        | 6       | 5       | 4         | 3   | 2        | 1    | 0     |
|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|----|-----|--------|----------|---------|---------|-----------|-----|----------|------|-------|
|    |    |    |    |    |    |    |    |    |    | Rese | erved | I  |    |    |    |    |    |    |    |    |    | BIM | TXFURM | Reserved | INEPNEM | INEPNMM | ITTXFEMSK | TOM | Reserved | EPDM | XFRCM |
|    |    |    |    |    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |    |    |    | rw  | rw     |          | rw      | rw      | rw        | rw  |          | rw   | rw    |

Bits 31:10 Reserved, must be kept at reset value.

- Bit 9 BIM: BNA interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 8 TXFURM: FIFO underrun mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 7 Reserved, must be kept at reset value.
- Bit 6 INEPNEM: IN endpoint NAK effective mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 5 INEPNMM: IN token received with EP mismatch mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 4 **ITTXFEMSK:** IN token received when TxFIFO empty mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 3 **TOM:** Timeout condition mask (nonisochronous endpoints)
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 2 Reserved, must be kept at reset value.
- Bit 1 EPDM: Endpoint disabled interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 0 XFRCM: Transfer completed interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt



# OTG\_HS device OUT endpoint common interrupt mask register (OTG\_HS\_DOEPMSK)

Address offset: 0x814

Reset value: 0x0000 0000

This register works with each of the Device OUT endpoint interrupt (OTG\_HS\_DOEPINTx) registers for all endpoints to generate an interrupt per OUT endpoint. The OUT endpoint interrupt for a specific status in the OTG\_HS\_DOEPINTx register can be masked by writing into the corresponding bit in this register. Status bits are masked by default.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21   | 20    | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    | 7        | 6       | 5        | 4      | 3     | 2        | 1    | 0     |
|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|----|----|------|------|----------|---------|----------|--------|-------|----------|------|-------|
|    |    |    |    |    |    |    |    |    |    | Rese | erved | I  |    |    |    |    |    |    |    |    |    | BOIM | OPEM | Reserved | B2BSTUP | Reserved | OTEPDM | STUPM | Reserved | EPDM | XFRCM |
|    |    |    |    |    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |    |    |    | rw   | rw   | ш        | rw      | ш        | rw     | rw    | ш        | rw   | rw    |

Bits 31:10 Reserved, must be kept at reset value.

- Bit 9 BOIM: BNA interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 8 OPEM: OUT packet error mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 7 Reserved, must be kept at reset value.
- Bit 6 **B2BSTUP:** Back-to-back SETUP packets received mask Applies to control OUT endpoints only.
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 5 Reserved, must be kept at reset value.
- Bit 4 **OTEPDM:** OUT token received when endpoint disabled mask
  - Applies to control OUT endpoints only.

0: Masked interrupt

- 1: Unmasked interrupt
- Bit 3 STUPM: SETUP phase done mask

Applies to control endpoints only.

- 0: Masked interrupt
- 1: Unmasked interrupt
- Bit 2 Reserved, must be kept at reset value.
- Bit 1 EPDM: Endpoint disabled interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 0 XFRCM: Transfer completed interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt



# OTG\_HS device all endpoints interrupt register (OTG\_HS\_DAINT)

Address offset: 0x818

Reset value: 0x0000 0000

When a significant event occurs on an endpoint, a device all endpoints interrupt register interrupts the application using the Device OUT endpoints interrupt bit or Device IN endpoints interrupt bit of the Core interrupt register (OEPINT or IEPINT in OTG\_HS\_GINTSTS, respectively). There is one interrupt bit per endpoint, up to a maximum of 16 bits for OUT endpoints and 16 bits for IN endpoints. For a bidirectional endpoint, the corresponding IN and OUT interrupt bits are used. Bits in this register are set and cleared when the application sets and clears bits in the corresponding Device Endpoint-x interrupt register (OTG\_HS\_DIEPINTx/OTG\_HS\_DOEPINTx).

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|-----|---|---|---|---|---|---|---|
| ſ |    |    |    |    |    |    |    | OEF | PINT |    |    |    |    |    |    |    |    |    |    |    |    |    |   | IEP | INT |   |   |   |   |   |   |   |
|   | r  | r  | r  | r  | r  | r  | r  | r   | r    | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r | r   | r   | r | r | r | r | r | r | r |

Bits 31:16 **OEPINT:** OUT endpoint interrupt bits

One bit per OUT endpoint:

Bit 16 for OUT endpoint 0, bit 31 for OUT endpoint 15

Bits 15:0 **IEPINT:** IN endpoint interrupt bits

One bit per IN endpoint: Bit 0 for IN endpoint 0, bit 15 for endpoint 15

# OTG\_HS all endpoints interrupt mask register (OTG\_HS\_DAINTMSK)

Address offset: 0x81C

Reset value: 0x0000 0000

The device endpoint interrupt mask register works with the device endpoint interrupt register to interrupt the application when an event occurs on a device endpoint. However, the device all endpoints interrupt (OTG\_HS\_DAINT) register bit corresponding to that interrupt is still set.

|--|

|    |    |    |    |    |    |    | OE | РМ |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IEF | РМ |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|
| rw  | rw | rw | rw | rw | rw | rw | rw | rw |

## Bits 31:16 **OEPM:** OUT EP interrupt mask bits

One per OUT endpoint: Bit 16 for OUT EP 0, bit 18 for OUT EP 3 0: Masked interrupt 1: Unmasked interrupt

Bits 15:0 **IEPM:** IN EP interrupt mask bits

One bit per IN endpoint: Bit 0 for IN EP 0, bit 3 for IN EP 3

- 0: Masked interrupt
- 1: Unmasked interrupt



# OTG\_HS device V<sub>BUS</sub> discharge time register (OTG\_HS\_DVBUSDIS)

Address offset: 0x0828

Reset value: 0x0000 17D7

This register specifies the  $V_{BUS}$  discharge time after  $V_{BUS}$  pulsing during SRP.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 |
|-----------------------------------------------------------------------|-----------------|
|-----------------------------------------------------------------------|-----------------|

| Reserved |    |    |    |    |    |    | ,  | VBU | SDT |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|
|          | rw  | rw  | rw | rw | rw | rw | rw | rw | rw |

Bits 31:16 Reserved, must be kept at reset value.

Bits 15:0 **VBUSDT:** Device  $V_{BUS}$  discharge time

Specifies the  $V_{BUS}$  discharge time after  $V_{BUS}$  pulsing during SRP. This value equals:  $V_{BUS}$  discharge time in PHY clocks / 1 024

Depending on your  $V_{BUS}$  load, this value may need adjusting.

# OTG\_HS device V<sub>BUS</sub> pulsing time register (OTG\_HS\_DVBUSPULSE)

Address offset: 0x082C

Reset value: 0x0000 05B8

This register specifies the  $V_{\text{BUS}}$  pulsing time during SRP.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21     | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6   | 5   | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|
|    |    |    |    |    |    |    |    |    | Door | erveo  | 4  |    |    |    |    |    |    |    |    |    |    |    |    |    | DVB | USP |    |    |    |    |    |
|    |    |    |    |    |    |    |    |    | nese | ei veu |    |    |    |    |    |    |    |    |    | rw | rw | rw | rw | rw | rw  | rw  | rw | rw | rw | rw | rw |

Bits 31:12 Reserved, must be kept at reset value.

Bits 11:0 **DVBUSP:** Device V<sub>BUS</sub> pulsing time

Specifies the  $V_{BUS}$  pulsing time during SRP. This value equals:  $V_{BUS}$  pulsing time in PHY clocks / 1 024



# OTG\_HS Device threshold control register (OTG\_HS\_DTHRCTL)

Address offset: 0x0830

Reset value: 0x0000 0000

| 3 | 1 | 30   | 29    | 28 | 27    | 26       | 25 | 24 | 23 | 22 | 21   | 20  | 19 | 18 | 17 | 16      | 15 | 14 | 13   | 12  | 11 | 10 | 9  | 8  | 7   | 6    | 5   | 4  | 3  | 2  | 1        | 0           |
|---|---|------|-------|----|-------|----------|----|----|----|----|------|-----|----|----|----|---------|----|----|------|-----|----|----|----|----|-----|------|-----|----|----|----|----------|-------------|
|   | F | Rese | erved | I  | ARPEN | Reserved |    |    |    | RX | THRI | LEN |    |    |    | RXTHREN |    | Re | serv | red |    |    |    |    | TXT | THRL | .EN |    |    |    | ISOTHREN | NONISOTHREN |
|   |   |      |       |    | rw    |          | rw | rw | rw | rw | rw   | rw  | rw | rw | rw | rw      |    |    |      |     |    | rw | rw | rw | rw  | rw   | rw  | rw | rw | rw | rw       | rw          |

Bits 31:28 Reserved, must be kept at reset value.

#### Bit 27 ARPEN: Arbiter parking enable

This bit controls internal DMA arbiter parking for IN endpoints. When thresholding is enabled and this bit is set to one, then the arbiter parks on the IN endpoint for which there is a token received on the USB. This is done to avoid getting into underrun conditions. By default parking is enabled.

Bit 26 Reserved, must be kept at reset value.

#### Bits 25: 17 RXTHRLEN: Receive threshold length

This field specifies the receive thresholding size in DWORDS. This field also specifies the amount of data received on the USB before the core can start transmitting on the AHB. The threshold length has to be at least eight DWORDS. The recommended value for RXTHRLEN is to be the same as the programmed AHB burst length (HBSTLEN bit in OTG\_HS\_GAHBCFG).

## Bit 16 RXTHREN: Receive threshold enable

When this bit is set, the core enables thresholding in the receive direction.

- Bits 15: 11 Reserved, must be kept at reset value.
  - Bits 10:2 **TXTHRLEN:** Transmit threshold length

This field specifies the transmit thresholding size in DWORDS. This field specifies the amount of data in bytes to be in the corresponding endpoint transmit FIFO, before the core can start transmitting on the USB. The threshold length has to be at least eight DWORDS. This field controls both isochronous and nonisochronous IN endpoint thresholds. The recommended value for TXTHRLEN is to be the same as the programmed AHB burst length (HBSTLEN bit in OTG\_HS\_GAHBCFG).

Bit 1 **ISOTHREN:** ISO IN endpoint threshold enable

When this bit is set, the core enables thresholding for isochronous IN endpoints.

Bit 0 **NONISOTHREN:** Nonisochronous IN endpoints threshold enable When this bit is set, the core enables thresholding for nonisochronous IN endpoints.



# OTG\_HS device IN endpoint FIFO empty interrupt mask register: (OTG\_HS\_DIEPEMPMSK)

Address offset: 0x834

Reset value: 0x0000 0000

This register is used to control the IN endpoint FIFO empty interrupt generation (TXFE\_OTG\_HS\_DIEPINTx).

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
|-----------------------------------------------------------------------------------|-----|
|-----------------------------------------------------------------------------------|-----|

| Reserved |    |    |    |    |    |    | IN | IEPT | XFE | M  |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|
| neseiveu | rw   | rw  | rw | rw | rw | rw | rw | rw | rw |

Bits 31:16 Reserved, must be kept at reset value.

Bits 15:0 INEPTXFEM: IN EP Tx FIFO empty interrupt mask bits

These bits act as mask bits for OTG\_HS\_DIEPINTx.

TXFE interrupt one bit per IN endpoint:

Bit 0 for IN endpoint 0, bit 15 for IN endpoint 15

0: Masked interrupt

1: Unmasked interrupt

# OTG\_HS device each endpoint interrupt register (OTG\_HS\_DEACHINT)

Address offset: 0x0838

Reset value: 0x0000 0000

There is one interrupt bit for endpoint 1 IN and one interrupt bit for endpoint 1 OUT.

| 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24    | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0      |
|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|------|----|----|----|----|----|----|----|-------|-----|---|---|---|---|---|---|------|--------|
|    |    |    |    |    |    |      |       |    |    |    |    |    |    | IINT |    |    |    |    |    |    |    |       |     |   |   |   |   |   |   | INT  | pe     |
|    |    |    |    |    |    | Rese | erveo | ł  |    |    |    |    |    | OEP1 |    |    |    |    |    |    | Re | eserv | red |   |   |   |   |   |   | IEP1 | eserve |

Bits 31:18 Reserved, must be kept at reset value.

Bit 17 **OEP1INT:** OUT endpoint 1 interrupt bit

Bits 16:2 Reserved, must be kept at reset value.

Bit 1 IEP1INT: IN endpoint 1 interrupt bit

Bit 0 Reserved, must be kept at reset value.



Res

# OTG\_HS device each endpoint interrupt register mask (OTG\_HS\_DEACHINTMSK)

Address offset: 0x083C

Reset value: 0x0000 0000

There is one interrupt bit for endpoint 1 IN and one interrupt bit for endpoint 1 OUT.

| 31 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

| Reserved Reserved Reserved |  | Reserved |
|----------------------------|--|----------|
|----------------------------|--|----------|

Bits 31:18 Reserved, must be kept at reset value.

Bit 17 **OEP1INTM:** OUT Endpoint 1 interrupt mask bit

- Bits 16:2 Reserved, must be kept at reset value.
  - Bit 1 IEP1INTM: IN Endpoint 1 interrupt mask bit
  - Bit 0 Reserved, must be kept at reset value.

# OTG\_HS device each in endpoint-1 interrupt register (OTG\_HS\_DIEPEACHMSK1)

Address offset: 0x840

Reset value: 0x0000 0000

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22    | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13   | 12 | 11       | 10 | 9   | 8      | 7        | 6       | 5       | 4         | 3   | 2        | 1    | 0     |
|----|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|----|------|----|----------|----|-----|--------|----------|---------|---------|-----------|-----|----------|------|-------|
|    |    |    |    |    |    |    |    | Rese | erved | 1  |    |    |    |    |    |    |    | NAKM |    | Reserved |    | BIM | TXFURM | Reserved | INEPNEM | INEPNMM | ITTXFEMSK | TOM | Reserved | RPDM | XFRCM |
|    |    |    |    |    |    |    |    |      |       |    |    |    |    |    |    |    |    | rw   |    |          |    | rw  | rw     |          | rw      | rw      | rw        | rw  |          | rw   | rw    |

Bits 31:14 Reserved, must be kept at reset value.

#### Bit 13 NAKM: NAK interrupt mask

- 0: Masked interrupt
- 1: unmasked interrupt
- Bit 12:10 Reserved, must be kept at reset value.
  - Bit 9 BIM: BNA interrupt mask
    - 0: Masked interrupt
    - 1: Unmasked interrupt
    - Bit 8 TXFURM: FIFO underrun mask
      - 0: Masked interrupt
      - 1: Unmasked interrupt
    - Bit 7 Reserved, must be kept at reset value.



- Bit 6 INEPNEM: IN endpoint NAK effective mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 5 **INEPNMM:** IN token received with EP mismatch mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 4 ITTXFEMSK: IN token received when TxFIFO empty mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 3 TOM: Timeout condition mask (nonisochronous endpoints)
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 2 Reserved, must be kept at reset value.
- Bit 1 EPDM: Endpoint disabled interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 0 XFRCM: Transfer completed interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt

# OTG\_HS device each OUT endpoint-1 interrupt register (OTG\_HS\_DOEPEACHMSK1)

Address offset: 0x880

Reset value: 0x0000 0000

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14    | 13   | 12    | 11 | 10       | 9   | 8      | 7        | 6       | 5       | 4         | 3   | 2        | 1    | 0     |
|----|----|----|----|----|----|----|----|-------|-----|----|----|----|----|----|----|----|-------|------|-------|----|----------|-----|--------|----------|---------|---------|-----------|-----|----------|------|-------|
|    |    |    |    |    |    |    | Re | eserv | red |    |    |    |    |    |    |    | NYETM | NAKM | BERRM |    | heserved | BIM | TXFURM | Reserved | INEPNEM | INEPNMM | ITTXFEMSK | MOT | Reserved | EPDM | XFRCM |
|    |    |    |    |    |    |    |    |       |     |    |    |    |    |    |    |    | rw    | rw   | rw    |    |          | rw  | rw     |          | rw      | rw      | rw        | rw  |          | rw   | rw    |

Bits 31:15 Reserved, must be kept at reset value.

#### Bit 14 NYETM: NYET interrupt mask

- 0: Masked interrupt
  - 1: unmasked interrupt
- Bit 13 NAKM: NAK interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt
- Bit 12 BERRM: Bubble error interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt

Bit 11:10 Reserved, must be kept at reset value.



- Bit 9 **BIM:** BNA interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt

#### Bit 8 **OPEM:** OUT packet error mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Bits 7:3 Reserved, must be kept at reset value.

#### Bit 2 AHBERRM: AHB error mask

- 0: Masked interrupt
- 1: Unmasked interrupt
- Bit 1 EPDM: Endpoint disabled interrupt mask
  - 0: Masked interrupt
  - 1: Unmasked interrupt

#### Bit 0 XFRCM: Transfer completed interrupt mask

- 0: Masked interrupt
- 1: Unmasked interrupt

# OTG device endpoint-x control register (OTG\_HS\_DIEPCTLx) (x = 0..7, where x = Endpoint\_number)

Address offset: 0x900 + (Endpoint\_number × 0x20)

. .

Reset value: 0x0000 0000

The application uses this register to control the behavior of each logical endpoint other than endpoint 0.

| 31    | 30    | 29      | 28             | 27   | 26   | 25 | 24  | 23  | 22 | 21        | 20       | 19    | 18 | 17     | 16         | 15     | 14 | 13   | 12    | 11 | 10 | 9  | 8  | 7  | 6  | 5    | 4  | 3  | 2  | 1  | 0  |
|-------|-------|---------|----------------|------|------|----|-----|-----|----|-----------|----------|-------|----|--------|------------|--------|----|------|-------|----|----|----|----|----|----|------|----|----|----|----|----|
| EPENA | EPDIS | SODDFRM | SD0PID/SEVNFRM | SNAK | CNAK |    | TXF | NUM | 1  | Stall     | Reserved | EPTVD | -  | NAKSTS | EONUM/DPID | USBAEP |    | Rese | erved | 1  |    |    |    |    | N  | IPSI | Z  |    |    |    |    |
| rs    | rs    | w       | w              | w    | w    | rw | rw  | rw  | rw | rw/<br>rs |          | rw    | rw | r      | r          | rw     |    |      |       |    | rw | rw | rw | rw | rw | rw   | rw | rw | rw | rw | rw |

. -

Bit 31 EPENA: Endpoint enable

The application sets this bit to start transmitting data on an endpoint.

The core clears this bit before setting any of the following interrupts on this endpoint: – SETUP phase done

- Endpoint disabled
- Transferresserverleted
- Transfer completed
- Bit 30 EPDIS: Endpoint disable

The application sets this bit to stop transmitting/receiving data on an endpoint, even before the transfer for that endpoint is complete. The application must wait for the Endpoint disabled interrupt before treating the endpoint as disabled. The core clears this bit before setting the Endpoint disabled interrupt. The application must set this bit only if Endpoint enable is already set for this endpoint.



### Bit 29 SODDFRM: Set odd frame

Applies to isochronous IN and OUT endpoints only.

Writing to this field sets the Even/Odd frame (EONUM) field to odd frame.

## Bit 28 SD0PID: Set DATA0 PID

Applies to interrupt/bulk IN endpoints only. Writing to this field sets the endpoint data PID (DPID) field in this register to DATA0.

## SEVNFRM: Set even frame

Applies to isochronous IN endpoints only. Writing to this field sets the Even/Odd frame (EONUM) field to even frame.

### Bit 27 SNAK: Set NAK

A write to this bit sets the NAK bit for the endpoint.

Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set this bit for OUT endpoints on a Transfer completed interrupt, or after a SETUP is received on the endpoint.

## Bit 26 CNAK: Clear NAK

A write to this bit clears the NAK bit for the endpoint.

### Bits 25:22 TXFNUM: TxFIFO number

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.

## Bit 21 STALL: STALL handshake

Applies to noncontrol, nonisochronous IN endpoints only (access type is rw).

The application sets this bit to stall all tokens from the USB host to this endpoint. If a NAK bit, Global IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Only the application can clear this bit, never the core.

#### Applies to control endpoints only (access type is rs).

The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit, Global 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 with an ACK handshake.

#### Bit 20 Reserved, must be kept at reset value.

#### Bits 19:18 **EPTYP:** Endpoint type

This is the transfer type supported by this logical endpoint.

- 00: Control
- 01: Isochronous
- 10: Bulk
- 11: Interrupt



## Bit 17 NAKSTS: NAK status

It indicates the following:

0: The core is transmitting nonNAK handshakes based on the FIFO status.

1: The core is transmitting NAK handshakes on this endpoint.

When either the application or the core sets this bit:

For nonisochronous IN endpoints: The core stops transmitting any data on an IN endpoint, even if there are data available in the TxFIFO.

For isochronous IN endpoints: The core sends out a zero-length data packet, even if there are data available in the TxFIFO.

Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.

## Bit 16 EONUM: Even/odd frame

Applies to isochronous IN endpoints only.

Indicates the frame number in which the core transmits/receives isochronous data for this endpoint. The application must program the even/odd frame number in which it intends to transmit/receive isochronous data for this endpoint using the SEVNFRM and SODDFRM fields in this register.

- 0: Even frame
- 1: Odd frame

## DPID: Endpoint data PID

Applies to interrupt/bulk IN 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 application uses the SD0PID register field to program either DATA0 or DATA1 PID.

- 0: DATA0
- 1: DATA1

## Bit 15 USBAEP: USB active endpoint

Indicates whether this endpoint is active in the current configuration and interface. The core clears 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.

Bits 14:11 Reserved, must be kept at reset value.

#### Bits 10:0 MPSIZ: Maximum packet size

The application must program this field with the maximum packet size for the current logical endpoint. This value is in bytes.



# OTG\_HS device control OUT endpoint 0 control register (OTG\_HS\_DOEPCTL0)

Address offset: 0xB00

Reset value: 0x0000 8000

This section describes the device control OUT endpoint 0 control register. Nonzero control endpoints use registers for endpoints 1–15.

| 31    | 30    | 29 | 28      | 27   | 26   | 25 | 24   | 23    | 22 | 21    | 20   | 19 | 18  | 17     | 16      | 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7  | 6 | 5 | 4 | 3 | 2 | 1  | 0   |
|-------|-------|----|---------|------|------|----|------|-------|----|-------|------|----|-----|--------|---------|--------|----|----|----|----|----|----|-------|----|---|---|---|---|---|----|-----|
| EPENA | EPDIS |    | esei ve | SNAK | CNAK |    | Rese | erved | I  | Stall | MANS | EP | TYP | NAKSTS | eserved | USBAEP |    |    |    |    |    | Re | eserv | ed |   |   |   |   |   | MP | SIZ |
| w     | r     |    | C       | w    | w    |    |      |       |    | rs    | rw   | r  | r   | r      | щ       | r      |    |    |    |    |    |    |       |    |   |   |   |   |   | r  | r   |

#### Bit 31 EPENA: Endpoint enable

The application sets this bit to start transmitting data on endpoint 0.

The core clears this bit before setting any of the following interrupts on this endpoint:

- SETUP phase done
- Endpoint disabled
- Transfer completed

## Bit 30 EPDIS: Endpoint disable

The application cannot disable control OUT endpoint 0.

Bits 29:28 Reserved, must be kept at reset value.

Bit 27 SNAK: Set NAK

A write to this bit sets the NAK bit for the endpoint.

Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set this bit on a Transfer completed interrupt, or after a SETUP is received on the endpoint.

Bit 26 CNAK: Clear NAK

A write to this bit clears the NAK bit for the endpoint.

- Bits 25:22 Reserved, must be kept at reset value.
  - Bit 21 STALL: STALL handshake

The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit 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 with an ACK handshake.

Bit 20 SNPM: Snoop mode

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.

Bits 19:18 EPTYP: Endpoint type

Hardcoded to 2'b00 for control.



### Bit 17 NAKSTS: NAK status

Indicates the following:

0: The core is transmitting nonNAK handshakes based on the FIFO status.

1: The core is transmitting NAK handshakes on this endpoint.

When either the application or the core sets this bit, the core stops receiving data, even if there is space in the RxFIFO to accommodate the incoming packet. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.

Bit 16 Reserved, must be kept at reset value.

#### Bit 15 USBAEP: USB active endpoint

This bit is always set to 1, indicating that a control endpoint 0 is always active in all configurations and interfaces.

Bits 14:2 Reserved, must be kept at reset value.

#### Bits 1:0 MPSIZ: Maximum packet size

The maximum packet size for control OUT endpoint 0 is the same as what is programmed in control IN endpoint 0.

- 00: 64 bytes
- 01: 32 bytes
- 10: 16 bytes
- 11: 8 bytes

# OTG\_HS device endpoint-x control register (OTG\_HS\_DOEPCTLx) (x = 1..3, where x = Endpoint\_number)

Address offset for OUT endpoints:  $0xB00 + (Endpoint_number \times 0x20)$ 

Reset value: 0x0000 0000

The application uses this register to control the behavior of each logical endpoint other than endpoint 0.

|       |       | 5       | IFRM        |      |      |       |      |           |      |       |    |        | PID      |        |         |    |    |    |    |    |    |      |    |    |    |    |    |
|-------|-------|---------|-------------|------|------|-------|------|-----------|------|-------|----|--------|----------|--------|---------|----|----|----|----|----|----|------|----|----|----|----|----|
| EPENA | EPDIS | SODDFRM | SD0PID/SEVN | SNAK | CNAK | Resei | rved | Stall     | SNPM | EDTVD | -  | NAKSTS | EONUM/DF | USBAEP | Reserve | ed |    |    |    |    | N  | IPSI | Z  |    |    |    |    |
| rs    | rs    | w       | w           | w    | w    |       |      | rw/<br>rs | rw   | rw    | rw | r      | r        | rw     |         |    | rw | rw | rw | rw | rw | rw   | rw | rw | rw | rw | rw |

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

Bit 31 EPENA: Endpoint enable

Applies to IN and OUT endpoints.

The application sets this bit to start transmitting data on an endpoint.

The core clears this bit before setting any of the following interrupts on this endpoint:

- SETUP phase done
- Endpoint disabled
- Transfer completed



## Bit 30 EPDIS: Endpoint disable

The application sets this bit to stop transmitting/receiving data on an endpoint, even before the transfer for that endpoint is complete. The application must wait for the Endpoint disabled interrupt before treating the endpoint as disabled. The core clears this bit before setting the Endpoint disabled interrupt. The application must set this bit only if Endpoint enable is already set for this endpoint.

## Bit 29 SODDFRM: Set odd frame

Applies to isochronous OUT endpoints only. Writing to this field sets the Even/Odd frame (EONUM) field to odd frame.

#### Bit 28 SDOPID: Set DATA0 PID

Applies to interrupt/bulk OUT endpoints only. Writing to this field sets the endpoint data PID (DPID) field in this register to DATA0.

#### SEVNFRM: Set even frame

Applies to isochronous OUT endpoints only. Writing to this field sets the Even/Odd frame (EONUM) field to even frame.

## Bit 27 SNAK: Set NAK

A write to this bit sets the NAK bit for the endpoint.

Using this bit, the application can control the transmission of NAK handshakes on an endpoint. The core can also set this bit for OUT endpoints on a Transfer Completed interrupt, or after a SETUP is received on the endpoint.

### Bit 26 CNAK: Clear NAK

A write to this bit clears the NAK bit for the endpoint.

#### Bits 25:22 Reserved, must be kept at reset value.

#### Bit 21 STALL: STALL handshake

Applies to noncontrol, nonisochronous OUT endpoints only (access type is rw).

The application sets this bit to stall all tokens from the USB host to this endpoint. If a NAK bit, Global IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Only the application can clear this bit, never the core.

#### Applies to control endpoints only (access type is rs).

The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit, Global 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 with an ACK handshake.

#### Bit 20 SNPM: Snoop mode

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.

#### Bits 19:18 EPTYP: Endpoint type

This is the transfer type supported by this logical endpoint.

- 00: Control
- 01: Isochronous
- 10: Bulk
- 11: Interrupt



#### Bit 17 NAKSTS: NAK status

Indicates the following:

0: The core is transmitting nonNAK handshakes based on the FIFO status.

1: 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 an OUT endpoint, even if there is space in the RxFIFO to accommodate the incoming packet.

Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.

### Bit 16 **EONUM:** Even/odd frame

Applies to isochronous IN and OUT endpoints only.

Indicates the frame number in which the core transmits/receives isochronous data for this endpoint. The application must program the even/odd frame number in which it intends to transmit/receive isochronous data for this endpoint using the SEVNFRM and SODDFRM fields in this register.

0: Even frame

1: Odd frame

**DPID:** Endpoint data PID

Applies to interrupt/bulk 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 application uses the SD0PID register field to program either DATA0 or DATA1 PID.

0: DATA0

1: DATA1

### Bit 15 **USBAEP:** USB active endpoint

Indicates whether this endpoint is active in the current configuration and interface. The core clears 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.

- Bits 14:11 Reserved, must be kept at reset value.
- Bits 10:0 MPSIZ: Maximum packet size

The application must program this field with the maximum packet size for the current logical endpoint. This value is in bytes.





rc\_ w1

rc\_

w1

rc\_ rc\_

w1 w1

# OTG\_HS device endpoint-x interrupt register (OTG\_HS\_DIEPINTx) (x = 0..7, where x = Endpoint\_number)

Address offset: 0x908 + (Endpoint\_number × 0x20)

Reset value: 0x0000 0080

This register indicates the status of an endpoint with respect to USB- and AHB-related events. It is shown in *Figure 368*. The application must read this register when the IN endpoints interrupt bit of the Core interrupt register (IEPINT in OTG\_HS\_GINTSTS) is set. Before the application can read this register, it must first read the device all endpoints interrupt (OTG\_HS\_DAINT) register to get the exact endpoint number for the device endpoint-x interrupt register. The application must clear the appropriate bit in this register to clear the corresponding bits in the OTG\_HS\_DAINT and OTG\_HS\_GINTSTS registers.

| NAK | BERR | (TDRPSTS | erved<br>BNA | KFIFOUDRN | TXFE | INEPNE | erved | ITTXFE | TOC | erved | EPDISD | XFRC |
|-----|------|----------|--------------|-----------|------|--------|-------|--------|-----|-------|--------|------|

Bits 31:14 Reserved, must be kept at reset value.

Bit 13 NAK: NAK interrupt

The core generates this interrupt when a NAK 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 unavailability of data in the Tx FIFO.

- Bit 12 BERR: Babble error interrupt
- Bit 11 **PKTDRPSTS:** Packet dropped status

This bit indicates to the application that an ISOC OUT packet has been dropped. This bit does not have an associated mask bit and does not generate an interrupt.

Bit10 Reserved, must be kept at reset value.

#### Bit 9 BNA: Buffer not available interrupt

The core generates this interrupt when the descriptor accessed is not ready for the Core to process, such as host busy or DMA done.

Bit 8 **TXFIFOUDRN**: Transmit Fifo Underrun (TxfifoUndrn) The core generates this interrupt when it detects a transmit FIFO underrun condition for this endpoint.

Dependency: This interrupt is valid only when Thresholding is enabled

Bit 7 TXFE: Transmit FIFO empty

This interrupt is asserted when the TxFIFO for this endpoint is either half or completely empty. The half or completely empty status is determined by the TxFIFO empty level bit in the Core AHB configuration register (TXFELVL bit in OTG\_HS\_GAHBCFG).



Bit 6 INEPNE: IN endpoint NAK effective

This bit can be cleared when the application clears the IN endpoint NAK by writing to the CNAK bit in OTG\_HS\_DIEPCTLx.

This interrupt indicates that the core has sampled the NAK bit set (either by the application or by the core). The interrupt indicates that the IN endpoint NAK bit set by the application has taken effect in the core.

This interrupt does not guarantee that a NAK handshake is sent on the USB. A STALL bit takes priority over a NAK bit.

- Bit 5 Reserved, must be kept at reset value.
- Bit 4 ITTXFE: IN token received when TxFIFO is empty

Applies to nonperiodic IN endpoints only.

Indicates that an IN token was received when the associated TxFIFO (periodic/nonperiodic) was empty. This interrupt is asserted on the endpoint for which the IN token was received.

#### Bit 3 **TOC:** Timeout condition

Applies only to Control IN endpoints. Indicates that the core has detected a timeout condition on the USB for the last IN token on this endpoint.

Bit 2 Reserved, must be kept at reset value.

#### Bit 1 EPDISD: Endpoint disabled interrupt

This bit indicates that the endpoint is disabled per the application's request.

#### Bit 0 XFRC: Transfer completed interrupt

This field indicates that the programmed transfer is complete on the AHB as well as on the USB, for this endpoint.



# OTG\_HS device endpoint-x interrupt register (OTG\_HS\_DOEPINTx) (x = 0..7, where x = Endpoint\_number)

Address offset: 0xB08 + (Endpoint\_number × 0x20)

Reset value: 0x0000 0080

This register indicates the status of an endpoint with respect to USB- and AHB-related events. It is shown in *Figure 368*. The application must read this register when the OUT Endpoints Interrupt bit of the Core interrupt register (OEPINT bit in OTG\_HS\_GINTSTS) is set. Before the application can read this register, it must first read the device all endpoints interrupt (OTG\_HS\_DAINT) register to get the exact endpoint number for the device Endpoint-x interrupt register. The application must clear the appropriate bit in this register to clear the corresponding bits in the OTG\_HS\_DAINT and OTG\_HS\_GINTSTS registers.

| 31 | 3 | 80 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11 | 10    | 9  | 8 | 7 | 6              | 5        | 4 | 3         | 2        | 1      | 0              |
|----|---|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|----|------|----|----|----|-------|----|---|---|----------------|----------|---|-----------|----------|--------|----------------|
|    |   |    |    |    |    |    |    | Re | eserv | ed |    |    |    |    |    |    |    | NYET |    |    | Re | eserv | ed |   |   | ≩_ຊີລີ B2BSTUP | Reserved |   | sTUP STUP | Reserved | EPDISD | ts J<br>L SFRC |

Bits 31:15 Reserved, must be kept at reset value.

Bit 14 NYET: NYET interrupt

The core generates this interrupt when a NYET response is transmitted for a nonisochronous OUT endpoint.

- Bits 13:7 Reserved, must be kept at reset value.
  - Bit 6 **B2BSTUP:** Back-to-back SETUP packets received

Applies to Control OUT endpoint only. This bit indicates that the core has received more than three back-to-back SETUP packets for this particular endpoint.

- Bit 5 Reserved, must be kept at reset value.
- Bit 4 OTEPDIS: OUT token received when endpoint disabled

Applies only to control OUT endpoint.

Indicates that an OUT token was received when the endpoint was not yet enabled. This interrupt is asserted on the endpoint for which the OUT token was received.

### Bit 3 STUP: SETUP phase done

Applies to control OUT endpoints only.

Indicates that the SETUP phase for the control endpoint is complete and no more back-toback SETUP packets were received for the current control transfer. On this interrupt, the application can decode the received SETUP data packet.

- Bit 2 Reserved, must be kept at reset value.
- Bit 1 EPDISD: Endpoint disabled interrupt

This bit indicates that the endpoint is disabled per the application's request.

Bit 0 XFRC: Transfer completed interrupt

This field indicates that the programmed transfer is complete on the AHB as well as on the USB, for this endpoint.



## OTG\_HS device IN endpoint 0 transfer size register (OTG\_HS\_DIEPTSIZ0)

Address offset: 0x910

Reset value: 0x0000 0000

The application must modify this register before enabling endpoint 0. Once endpoint 0 is enabled using the endpoint enable bit in the device control endpoint 0 control registers (EPENA in OTG\_HS\_DIEPCTL0), the core modifies this register. The application can only read this register once the core has cleared the Endpoint enable bit.

Nonzero endpoints use the registers for endpoints 1–15.

| 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reserved PKTCNT Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    | Х  | FRS | IZ |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                          |    |    |    |    |    |    |    |    |    |    |    |    | rw | rw | rw  | rw | rw | rw | rw |    |    |   |   |   |   |   |   |   |   |   |   |

Bits 31:21 Reserved, must be kept at reset value.

Bits 20:19 **PKTCNT:** Packet count

Indicates the total number of USB packets that constitute the Transfer Size amount of data for endpoint 0.

This field is decremented every time a packet (maximum size or short packet) is read from the TxFIFO.

- Bits 18:7 Reserved, must be kept at reset value.
- Bits 6:0 XFRSIZ: Transfer size

Indicates the transfer size in bytes for endpoint 0. The core interrupts the application only after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet. The core decrements this field every time a packet from the external memory is written to the TxFIFO.



## OTG\_HS device OUT endpoint 0 transfer size register (OTG\_HS\_DOEPTSIZ0)

Address offset: 0xB10

Reset value: 0x0000 0000

The application must modify this register before enabling endpoint 0. Once endpoint 0 is enabled using the Endpoint enable bit in the device control endpoint 0 control registers (EPENA bit in OTG\_HS\_DOEPCTL0), the core modifies this register. The application can only read this register once the core has cleared the Endpoint enable bit.

Nonzero endpoints use the registers for endpoints 1–15.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 | 2 1 | 0 |  |
|---------------------------------------------------------------------------------|-----|---|--|
|---------------------------------------------------------------------------------|-----|---|--|

| eserved | NT    | Reserved | KICN | Reserved |    |    | х  | FRS | IZ |    |    |
|---------|-------|----------|------|----------|----|----|----|-----|----|----|----|
| č       | rw rw | rw       | w    |          | rw | rw | rw | rw  | rw | rw | rw |

Bit 31 Reserved, must be kept at reset value.

Bits 30:29 STUPCNT: SETUP packet count

This field specifies the number of back-to-back SETUP data packets the endpoint can receive.

- 01: 1 packet
- 10: 2 packets
- 11: 3 packets

Bits 28:20 Reserved, must be kept at reset value.

#### Bit 19 **PKTCNT:** Packet count

This field is decremented to zero after a packet is written into the RxFIFO.

- Bits 18:7 Reserved, must be kept at reset value.
- Bits 6:0 XFRSIZ: Transfer size

Indicates the transfer size in bytes for endpoint 0. The core interrupts the application only after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet. The core decrements this field every time a packet is read from the RxFIFO and written to the external memory.



# OTG\_HS device endpoint-x transfer size register (OTG\_HS\_DIEPTSIZx) $(x = 1..3, where x = Endpoint_number)$

Address offset:  $0x910 + (Endpoint\_number \times 0x20)$ 

Reset value: 0x0000 0000

The application must modify this register before enabling the endpoint. Once the endpoint is enabled using the Endpoint enable bit in the device endpoint-x control registers (EPENA bit in OTG\_HS\_DIEPCTLx), the core modifies this register. The application can only read this register once the core has cleared the Endpoint enable bit.

| 31      | 30              | 29              | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---------|-----------------|-----------------|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|
| ed      | MC              | NT              |    |    |    |    | PKT | CNT |    |    |    |    |    |    |    |    |    |    |    |    | Х  | FRS | IZ |    |    |    |    |    |    |    |    |
| Reserve | rw/<br>r/r<br>w | rw/<br>r/r<br>w | rw | rw | rw | rw | rw  | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw |

Bit 31 Reserved, must be kept at reset value.

Bits 30:29 MCNT: Multi count

For periodic IN endpoints, this field indicates the number of packets that must be transmitted per frame on the USB. The core uses this field to calculate the data PID for isochronous IN endpoints.

- 01: 1 packet
- 10: 2 packets
- 11: 3 packets
- Bit 28:19 **PKTCNT:** Packet count

Indicates the total number of USB packets that constitute the Transfer Size amount of data for this endpoint.

This field is decremented every time a packet (maximum size or short packet) is read from the TxFIFO.

### Bits 18:0 XFRSIZ: Transfer size

This field contains the transfer size in bytes for the current endpoint. The core only interrupts the application after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.

The core decrements this field every time a packet from the external memory is written to the  $\mathsf{TxFIFO}.$ 



### OTG\_HS device IN endpoint transmit FIFO status register (OTG\_HS\_DTXFSTSx) (x = 0..5, where x = Endpoint\_number)

Address offset for IN endpoints:  $0x918 + (Endpoint\_number \times 0x20)$  This read-only register contains the free space information for the Device IN endpoint TxFIFO.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 | 9 8 7 6 5 4 3 2 1 0 |
|-------------------------------------------------------------------|---------------------|
|-------------------------------------------------------------------|---------------------|

| Reserved |   |   |   |   |   |   | ١N | NEPT | FSA | V |   |   |   |   |   |   |
|----------|---|---|---|---|---|---|----|------|-----|---|---|---|---|---|---|---|
| neserved | r | r | r | r | r | r | r  | r    | r   | r | r | r | r | r | r | r |

31:16 Reserved, must be kept at reset value.

15:0 INEPTFSAV: IN endpoint TxFIFO space avail ()
Indicates the amount of free space available in the Endpoint TxFIFO.
Values are in terms of 32-bit words:
0x0: Endpoint TxFIFO is full
0x1: 1 word available
0x2: 2 words available
0xn: n words available (0 < n < 512)</li>
Others: Reserved

# OTG\_HS device endpoint-x transfer size register (OTG\_HS\_DOEPTSIZx) (x = 1..5, where x = Endpoint\_number)

Address offset: 0xB10 + (Endpoint\_number × 0x20)

Reset value: 0x0000 0000

The application must modify this register before enabling the endpoint. Once the endpoint is enabled using Endpoint Enable bit of the device endpoint-x control registers (EPENA bit in OTG\_HS\_DOEPCTLx), the core modifies this register. The application can only read this register once the core has cleared the Endpoint enable bit.

| 31    | 30                        | 29          | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|---------------------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|
| erved | RXDPID/S<br>TUPCNT PKTCNT |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | х  | FRS | IZ |    |    |    |    |    |    |    |    |
| Rese  | rw/r/<br>rw               | rw/r/<br>rw | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw |

Bit 31 Reserved, must be kept at reset value.

Bits 30:29 **RXDPID:** Received data PID

Applies to isochronous OUT endpoints only. This is the data PID received in the last packet for this endpoint. 00: DATA0 01: DATA2 10: DATA1 11: MDATA



STUPCNT: SETUP packet count

Applies to control OUT Endpoints only.

This field specifies the number of back-to-back SETUP data packets the endpoint can receive.

- 01: 1 packet
- 10: 2 packets
- 11: 3 packets

#### Bit 28:19 PKTCNT: Packet count

Indicates the total number of USB packets that constitute the Transfer Size amount of data for this endpoint.

This field is decremented every time a packet (maximum size or short packet) is written to the RxFIFO.

Bits 18:0 XFRSIZ: Transfer size

This field contains the transfer size in bytes for the current endpoint. The core only interrupts the application after it has exhausted the transfer size amount of data. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.

The core decrements this field every time a packet is read from the RxFIFO and written to the external memory.

# OTG\_HS device endpoint-*x* DMA address register (OTG\_HS\_DIEPDMAx / OTG\_HS\_DOEPDMAx) (x = 1..5, where x = Endpoint\_number)

Address offset for IN endpoints: 0x914 + (Endpoint\_number × 0x20)

Reset value: 0xXXXX XXXX

Address offset for OUT endpoints: 0xB14 + (Endpoint\_number × 0x20)

Reset value: 0xXXXX XXXX

| 31 | 30      | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    | DMAADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Bits 31:0 DMAADDR: DMA address

This bit holds the start address of the external memory for storing or fetching endpoint data.

Note: For control endpoints, this field stores control OUT data packets as well as SETUP transaction data packets. When more than three SETUP packets are received back-to-back, the SETUP data packet in the memory is overwritten. This register is incremented on every AHB transaction. The application can give only a DWORD-aligned address.

# 30.12.5 OTG\_HS power and clock gating control register (OTG\_HS\_PCGCCTL)

Address offset: 0xE00

Reset value: 0x0000 0000

This register is available in host and peripheral modes.



| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4       | 3 | 2        | 1        | 0       |
|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|---|---|---|---|---|---------|---|----------|----------|---------|
|    |    |    |    |    |    |    |    |    |    |    |    | Res | erve | d  |    |    |    |    |    |    |    |   |   |   |   |   | dSNSYHq |   | naviasau | GATEHCLK | STPPCLK |
|    |    |    |    |    |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |   |   |   |   |   | rw      | _ | -        | rw       | rw      |

- Bit 31:5 Reserved, must be kept at reset value.
  - Bit 4 PHYSUSP: PHY suspended

Indicates that the PHY has been suspended. This bit is updated once the PHY is suspended after the application has set the STPPCLK bit (bit 0).

- Bits 3:2 Reserved, must be kept at reset value.
  - Bit 1 GATEHCLK: Gate HCLK

The application sets this bit to gate HCLK to modules other than the AHB Slave and Master and wakeup logic when the USB is suspended or the session is not valid. The application clears this bit when the USB is resumed or a new session starts.

Bit 0 STPPCLK: Stop PHY clock

The application sets this bit to stop the PHY clock when the USB is suspended, the session is not valid, or the device is disconnected. The application clears this bit when the USB is resumed or a new session starts.

## 30.12.6 OTG\_HS register map

The table below gives the USB OTG register map and reset values.

| Offset | Register                          | 31     | 30     | 29    | 28 | 27  | 26   | 25      | 24   | 23   | 22    | 21         | 20         | 19       | 18     | 17       | 16       | 15      | 14       | 13       | 12 | 11 | 10      | 6       | 8         | 7       | 9  | 5       | 4       | 3    | 2       | 1     | 0      |
|--------|-----------------------------------|--------|--------|-------|----|-----|------|---------|------|------|-------|------------|------------|----------|--------|----------|----------|---------|----------|----------|----|----|---------|---------|-----------|---------|----|---------|---------|------|---------|-------|--------|
| 0x000  | OTG_HS_GOT<br>GCTL                |        |        |       |    | F   | Rese | erve    | ed   |      |       |            |            | BSVLD    | ASVLD  | DBCT     | CIDSTS   | F       | Rese     | erve     |    |    | HSHNPEN | HNPRQ   | HNGSCS    |         | F  | Rese    | erve    | d    |         |       | SRQSCS |
|        | Reset value                       |        |        |       |    |     |      |         |      |      |       |            |            | 0        | 0      | 0        | 1        |         |          |          |    | 0  | 0       | 0       | 0         |         |    |         |         |      |         | 0     | 0      |
| 0x004  | OTG_HS_GOT<br>GINT<br>Reset value |        |        |       |    | F   | Rese | erve    | ed   |      |       |            |            |          |        | HNGDET   |          |         |          | Reserved |    |    |         | HNSSCHG | o SRSSCHG |         | Re | ser     | ved     |      | O SEDET | Re    | es.    |
|        | OTG_HS_GAH                        |        |        |       |    |     |      |         |      |      |       |            |            | <u> </u> |        |          | <u> </u> |         |          |          |    |    |         | -       | -         | LVL     |    |         |         |      | •       |       | L,     |
| 0x008  | BCFG                              |        |        |       |    |     |      |         |      |      |       | Re         | eser       | ved      |        |          |          |         |          |          |    |    |         |         | PTXFELVL  | TXFELVL |    | F       | Rese    | erve | d       |       | GINT   |
|        | Reset value                       | 1      |        |       |    |     |      |         |      |      |       |            |            |          |        |          |          |         |          |          |    |    |         |         | 0         | 0       |    |         |         |      |         |       | 0      |
| 0x00C  | OTG_HS_GUS<br>BCFG                | СТХРКТ | FDMOD  | FHMOD | Re | ser | ved  | ULPIIPD | PTCI | PCCI | TSDPS | ULPIEVBUSI | ULPIEVBUSD | ULPICSM  | ULPIAR | NLPIFSLS | Reserved | PHYLPCS | Reserved |          | TR | DT |         | HNPCAP  | SRPCAP    |         | Re | ser     | ved     |      | тс      | OCA   | Ĺ      |
|        | Reset value                       | 0      | 0      | 0     |    |     |      | 0       | 0    | 0    | 0     | 0          | 0          | 0        | 0      | 0        |          | 0       |          | 0        | 0  | 1  | 0       | 1       | 0         |         |    |         |         |      | 0       | 0     | 0      |
| 0x010  |                                   | AHBIDL | DMAREQ |       |    |     |      |         |      |      |       | Re         | eser       | ved      |        |          |          |         |          |          |    |    |         | тх      | (FNI      | UM      |    | TXFFLSH | RXFFLSH | ш    | FCRST   | HSRST | CSRST  |
|        | Reset value                       | 1      | 0      |       |    |     |      |         |      |      |       |            |            |          |        |          |          |         |          |          |    |    | 0       | 0       | 0         | 0       | 0  | 0       | 0       | 0    | 0       | 0     | 0      |



| Offset | Register                                         | 31     | 30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 29       | 28       | 27       | 26     | 25       | 24        | 23        | 22        | 21                | 20       | 19     | 18         | 17       | 16       | 15    | 14       | 13       | 12     | 11       | 10     | 6 8         | 7          | 9         | 5       | 4       | e        | 2      | -     | 0        |
|--------|--------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|--------|----------|-----------|-----------|-----------|-------------------|----------|--------|------------|----------|----------|-------|----------|----------|--------|----------|--------|-------------|------------|-----------|---------|---------|----------|--------|-------|----------|
| 0x014  | OTG_HS_GINT<br>STS                               | WKUINT | SRQINT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | DISCINT  | CIDSCHG  | Reserved | PTXFE  | HCINT    | HPRTINT   | Reserved  | DATAFSUSP | PXFR/INCOMPISOOUT | IISOIXFR | OEPINT | IEPINT     | Reserved |          | EOPF  | ISOODRP  | ENUMDNE  | USBRST | USBSUSP  | ESUSP  | Reserved    | BOUTNAKEFF | GINAKEFF  | NPTXFE  | RXFLVL  | SOF      | OTGINT | SIMM  | CMOD     |
|        | Reset value                                      | 0      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0        | 0        |          | 1      | 0        | 0         |           | 0         | 0                 | 0        | 0      | 0          |          |          | 0     | 0        | 0        | 0      | 0        | 0      |             | 0          | 0         | 1       | 0       | 0        | 0      | 0     | 0        |
| 0x018  |                                                  |        | SRQIM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DISCINT  | CIDSCHGM | Reserved | PTXFEM |          | PRTIM     | Reserved  | FSUSPM    | IPXF              | =        | OEPINT | IEPINT     | EPMISM   | Reserved | EOPFM |          | Ш        |        | MASUSASU | ESUSPM | Reserved    | GONAKEFFM  | GINAKEFFM | NPTXFEM | RXFLVLM | SOFM     |        | WSIMW | Reserved |
|        | Reset value                                      | 0      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0        | 0        |          | 0      | 0        | 0         |           | 0         | 0                 | 0        | 0      | 0          | 0        |          | 0     | 0        | 0        | 0      | 0        | 0      |             | 0          | 0         | 0       | 0       | 0        | 0      | 0     |          |
|        | OTG_HS_GRX<br>STSR (Host<br>mode)                |        | Reserved         PKTSTS         DPID         BCNT           0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         |          |          |          |        |          |           |           |           |                   |          |        |            |          |          |       | CHN      |          | I      |          |        |             |            |           |         |         |          |        |       |          |
| 0x01C  | Reset value<br>OTG_HS_GRX                        |        | EBMNUM PKTSTS DPID BCNT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |          |          |        |          |           |           |           |                   |          |        |            |          |          | 0     | 0        | 0        |        |          |        |             |            |           |         |         |          |        |       |          |
|        | STSR<br>(peripheral<br>mode)                     |        | O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         |          |          |          |        |          |           |           |           |                   |          |        |            |          |          |       | EPN      |          |        |          |        |             |            |           |         |         |          |        |       |          |
|        | Reset value<br>OTG_HS_GRX<br>STSP (Host<br>mode) |        | Heserved         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0< |          |          |          |        |          |           |           |           |                   |          |        |            |          |          | 0     | 0        | 0<br>CHN |        | <u> </u> |        |             |            |           |         |         |          |        |       |          |
| 0x020  | Reset value<br>OTG_HS_GRX                        |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |          |          |        |          | 1         |           |           |                   | 0        | 0      | 0          | 0        |          | 0     | 0        | 0        | 0      | 0        | 0      | 0 0         | 0          | 0         | 0       | 0       | 0        | 0      | 0     |          |
| 0.020  | STSP<br>(peripheral<br>mode)                     |        | Heserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |          |          |        |          |           |           |           |                   |          |        |            |          |          |       |          | EPN      | IUN    | I        |        |             |            |           |         |         |          |        |       |          |
| 0x024  | Reset value<br>OTG_HS_GRX<br>FSIZ                |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |          |          |        | F        | 0<br>Rese | 0<br>erve | 0<br>d    | 0                 | 0        | 0      | 0          | 0        | 0        | 0     | 0        | 0        | 0      | 0        | 0      | 0 0<br>RX   | 0<br>FD    | 0         | 0       | 0       | 0        | 0      | 0     | 0        |
|        | Reset value<br>OTG_HS_GNP<br>TXFSIZ              |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |          |          |        | 1        | NPT       | XFI       | )         |                   |          |        |            |          |          | 0     | 0        | 0        | 0      | 0        | 0      | 1 0<br>NPTX | 0<br>(FS   | 0<br>SA   | 0       | 0       | 0        | 0      | 0     | 0        |
|        | (Host mode)<br>Reset value                       | 0      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0        | 0        | 0        | 0      | 0        | 0         | 0         | 0         | 0                 | 0        | 0      | 0          | 0        | 0        | 0     | 0        | 0        | 0      | 0        | 0      | 1 0         | 0          | 0         | 0       | 0       | 0        | 0      | 0     | 0        |
| 0x028  | OTG_HS_GNP<br>TXFSIZ<br>(peripheral              |        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1        | 1        | 1        |        | 1        | тхо       | )FD       |           | 1                 |          |        |            |          |          |       |          |          |        |          | 1      | ТХО         | FSA        | 4         |         |         | 1        |        |       |          |
|        | mode)<br>Reset value                             | 0      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0        | 0        | 0        | 0      | 0        | 0         | 0         | 0         | 0                 | 0        | 0      | 0          | 0        | 0        | 0     | 0        | 0        | 0      | 0        | 0      | 1 0         | 0          | 0         | 0       | 0       | 0        | 0      | 0     | 0        |
|        | OTG_HS_GNP                                       |        | Ē                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          | TXQ      |        |          | <u> </u>  | <u> </u>  | Ŭ         |                   | о<br>РТQ |        |            | Ŭ        | -        | -     | <u> </u> | Ľ,       | Ľ,     | Ľ,       | , J    | NPTX        |            |           | 1       | 1       | Ŭ        | Ľ      | Ľ     | <u> </u> |
| 0x02C  | TXSTS<br>Reset value                             | Res.   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0        |          |          | 0      | 0        | 0         | 0         | 0         | 0                 | 0        | 0      | ۰v<br>1    | 0        | 0        | 0     | 0        | 0        | 0      | 0        | 0      | 1 0         | 0          | 0         | 0       | 0       | 0        | 0      | 0     | 0        |
| 0x030  |                                                  | BSYDNE | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reserved | 2CDATSE0 |          |        | Reserved | -         | I2CEN o   |           |                   | 1        | .DD    |            |          | 0        | 0     |          | 1        | EG/    | 1        | 1      | <u></u>     | 0          | 10        | -       | RWI     |          |        |       | 0        |
|        | Reset value                                      | 0      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          | 0        | 0        | 0      |          | 0         | 0         | 0         | 0                 | 0        | 0      | 0          | 0        | 0        |       |          |          |        |          |        |             |            |           |         |         |          |        |       |          |
| 0x038  | OTG_HS_GCC<br>FG<br>Reset value                  |        | <u>I</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          | F        | Rese     |        | d        |           |           |           |                   |          |        | O VBUSASEN |          | O PWRDWN |       |          |          |        |          |        | Rese        | erve       | ed        |         |         | <u>I</u> |        |       |          |
| 02020  | OTG_HS_CID                                       |        | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | _        | _        |          |        |          | _         | _         | _         | L Y               |          | 5      |            | PR       |          | ЈСТ   | _ID      | _        | _      | _        | _      |             |            | _         |         |         | _        | _      | _     |          |
| 0x03C  | Reset value                                      | 0      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0        | 0        | 0        | 0      | 0        | 0         | 0         | 0         | 0                 | 0        | 0      | 0          | 0        | 0        |       | 0        | 0        | 1      | 0        | 0      | 1 0         | 0          | 0         | 0       | 0       | 0        | 0      | 0     | 0        |
|        |                                                  |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |          |          |        |          |           |           |           |                   |          |        |            |          |          |       |          |          |        |          |        |             |            |           |         |         |          |        |       |          |

Table 162. OTG\_HS register map and reset values (continued)



| Offset | 62. OTG_F<br>Register          |       |       |          |          |     | -        |      |          |      | 1000<br>1000<br>1000 |          |          | 15       |            | <u> 7 8 9</u>                   | 2 0                 | <b>.</b>  | ო ი              | 1             |
|--------|--------------------------------|-------|-------|----------|----------|-----|----------|------|----------|------|----------------------|----------|----------|----------|------------|---------------------------------|---------------------|-----------|------------------|---------------|
| Suger  | OTG HS HPTX                    |       | ñ     | Ñ        | N        | ิง  |          |      |          | 0    | I <del>F</del> F     | -        | Ē        | Ť        | +          |                                 |                     | 4         |                  | - 0           |
| 0x100  | FSIZ<br>Reset value            |       | 0     | 0        |          | 0 1 |          | TXF  |          | 1110 | 110                  | 0        | 0        | 0        | 0 0 1 0    | PTXSA                           |                     | 0         | 011              | 00            |
|        | OTG_HS_DIEP                    | 0     | 0     | 0        | 0        | 0 1 | 1 1      |      |          |      |                      | 0        | 0        | 0        |            |                                 |                     | 0         |                  | 0 0           |
| 0x104  | TXF1<br>Reset value            | 0     | 0     | 0        | 0        | 0 0 |          |      |          | 1010 | 00                   | 0        | 0        | 0        | 0 0 0 0    | INEPTXS                         |                     | 0         | 0 0              | 00            |
|        | OTG_HS_DIEP                    | 0     | 0     | 0        | 0        | 0 0 | 1 1      | PTX  |          |      |                      | 0        | 0        | 0        |            | INEPTXS                         |                     | U         | 0 0              |               |
| 0x108  | TXF2<br>Reset value            | 0     | 0     | 0        | 0        | 0 0 |          |      |          | 000  | 00                   | 0        | 0        | 0        | 0 0 0 0    | 1 0 0 0                         |                     | 0         | 0 0              | 0 0           |
|        | OTG_HS_DIEP                    | 0     | 0     | U        | 0        | 0 0 |          | PTX  |          |      | 0 0                  | 0        | 0        | 0        |            | INEPTXS                         |                     | U         | 0 0              |               |
| 0x10C  | TXF3<br>Reset value            | 0     | 0     | 0        | 0        | 0 0 |          |      |          | 00   | 0 0                  | 0        | 0        | 0        | 0 0 0 0    | 1 0 0 0                         |                     | 0         | 0 0              | 0 0           |
|        | OTG_HS_DIEP                    | Ū     | U     | Ŭ        |          | 0   | 1 1      | PTX  |          |      |                      | Ū        | Ů        |          |            | INEPTXS                         |                     | <b>_</b>  | 0 0              |               |
| 0x110  | TXF4<br>Reset value            | 0     | 0     | 0        | 0        | 0 0 | 1        | 0 0  | 0        | 0 0  | 0 0                  | 0        | 0        | 0        | 0 0 0 0    | 1 0 0 0                         | 0 0                 | 0         | 0 0              | 0 0           |
| 0x400  | OTG_HS_HCF<br>G<br>Reset value |       |       | <u> </u> |          |     | <u> </u> |      |          |      | R                    | eser     | ved      | <u> </u> |            |                                 | <u> </u>            | <u> </u>  | o FSLSS          | o<br>ESLSPCS- |
| 0x404  | OTG_HS_HFIR                    |       |       |          |          |     | Re       | serv | red      |      |                      |          |          | L        |            | FRIVL                           |                     |           | _                |               |
|        | Reset value<br>OTG_HS_HFN      |       |       |          |          |     |          |      |          |      |                      |          |          | 1        | 1 1 0 1    | 0 1 0 0                         | 11                  | 0         | 0 0              | 0 0           |
| 0x408  | UM                             |       |       | •        |          |     |          | TRE  |          |      |                      |          |          |          |            | FRNUM                           |                     |           |                  |               |
|        | Reset value<br>OTG_HS_HPTX     | 0     | 0     |          |          |     | 0        | 0 0  | 0 0      |      |                      | 0        | 0        | 0        | 0 1 1 1    | 1 1 1 1<br>PTXFSA               | 1 1                 | 1         | 1 1              | 1 1           |
| 0x410  | STS<br>Reset value             | 0     | 0     |          | TXQ<br>0 |     | 0        | 0 Y  |          |      | QSAV                 | ΤY       | ΙY       | Y        |            | YYYYY                           | VL<br>IYIY          | IYI       | YIY              | IYIY          |
|        | OTG_HS_HAIN                    | -     | 0     | 0        |          | 0 0 |          |      | <u> </u> | 1.1. | 1 '   '              | <u> </u> | <u> </u> | Ľ        | 1,1,1,1,1, | HAINT                           |                     | <u>''</u> | ·   ·            |               |
| 0x414  | T<br>Reset value               |       |       |          |          |     | Re       | serv | ed       |      |                      |          |          | 0        | 0 0 0 0 0  | 0 0 0 0 0                       | 0 0                 | 0         | 0 0              | 0 0           |
|        | OTG_HS_HAIN                    |       |       |          |          |     |          |      |          |      |                      |          |          | Ť        |            | HAINTN                          |                     | <b>•</b>  |                  |               |
| 0x418  | TMSK<br>Reset value            |       |       |          |          |     | Re       | serv | ed       |      |                      |          |          | 0        | 0 0 0 0    | 0 0 0 0                         | 0 0                 | 0         | 0 0              | 0 0           |
| 0x440  | OTG_HS_HPRT                    | -     |       |          |          | R   | eserve   | d    |          |      | P                    | SPD      | 0        | PT       |            | o Reserved<br>o PRST<br>o PSUSP | o PRES<br>o POCCHNG |           | o PENA<br>o PENA |               |
|        | OTG_HS_HCC                     | CHENA | CHDIS | ODDFRM   |          |     | DAD      |      |          | мс   | ЕРТҮР                | LSDEV    | ved      | EPDIR    | EPNUM      |                                 | MPS                 | SIZ       |                  | <u> </u>      |
| 0x500  | HAR0                           | CHE   | Ч     | aac      |          |     | 0,10     |      |          | mo   | EPI                  | LSD      | Reserved | EPI      | Lintom     |                                 |                     |           |                  |               |
|        | Reset value                    | 0     | 0     | 0        | 0        | 0 0 | 0        | 0 0  | 0 0      | 0 0  | 0 0                  | 0        | æ        | 0        | 0 0 0 0    | 0 0 0 0                         | 0 0                 | 0         | 0 0              | 0 0           |
| 0x520  | OTG_HS_HCC<br>HAR1             | CHENA | CHDIS | ODDFRM   |          |     | DAD      |      |          | мс   | ЕРТҮР                | LSDEV    | Reserved | EPDIR    | EPNUM      |                                 | MPS                 | SIZ       |                  |               |
|        | Reset value                    | 0     | 0     | 0        | 0        | 0 0 | 0        | 0 0  | 0        | 0 0  |                      |          | Be       | 0        | 0 0 0 0    | 0 0 0 0                         | 0 0                 | 0         | 0 0              | 0 0           |
| 0x540  | OTG_HS_HCC<br>HAR2             | CHENA | CHDIS | ODDFRM   |          |     | DAD      |      |          | мс   | ЕРТҮР                | LSDEV    | Reserved | EPDIR    | EPNUM      |                                 | MPS                 | SIZ       |                  |               |
|        | Reset value                    | 0     | 0     | 0        | 0        | 0 0 | 0        | 0 0  | 0        | 0 0  | 0 0                  |          | Å        | 0        | 0 0 0 0    | 0 0 0 0                         | 0 0                 | 0         | 0 0              | 0 0           |
| 0x560  | OTG_HS_HCC<br>HAR3             | CHENA | CHDIS | ODDFRM   |          |     | DAD      |      |          | мс   | ЕРТҮР                | LSDEV    | Reserved | EPDIR    | EPNUM      |                                 | MPS                 | SIZ       |                  |               |
|        | Reset value                    | 0     | 0     | 0        | 0        | 0 0 | 0        | 0 0  | 0        | 0 0  | 0 0                  | 0        | Ť        | 0        | 0 0 0 0    | 0 0 0 0                         | 0 0                 | 0         | 0 0              | 0 0           |
| 0x580  | OTG_HS_HCC<br>HAR4             | CHENA |       | ODDFRM   |          |     | DAD      |      |          | МС   | ЕРТҮР                | LSDEV    | Reserved | EPDIR    | EPNUM      |                                 | MPS                 |           |                  |               |
|        | Reset value                    | 0     | 0     | 0        | 0        | 0 0 | 0        | 0 0  | ) 0      | 0 0  | 0 0                  | 0        | LT.      | 0        | 0 0 0 0    | 0 0 0 0                         | 0 0                 | 0         | 0 0              | 0 0           |
| 0x5A0  | OTG_HS_HCC<br>HAR5             | CHENA |       | ODDFRM   |          |     | DAD      |      |          | МС   | ЕРТҮР                | LSDEV    | Reserved | EPDIR    | EPNUM      |                                 | MPS                 |           |                  |               |
|        | Reset value                    | 0     | 0     | 0        | 0        | 0 0 | 0        | 0 0  | 0 0      | 0 0  | 0 0                  | 0        | 4        | 0        | 0 0 0 0    | 0 0 0 0                         | 0 0                 | 0         | 0 0              | 0 0           |



| Ox5C0         OTG_HS_HCC         Stress<br>HAR6         Stress<br>HAR6         DAD         MC         L<br>L<br>L<br>L<br>L<br>L<br>H<br>HAR6         EPNUM         MPSIZ           Dx5C0         OTG_HS_HCC         Str<br>HAR6         Str<br>HAR6         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Table 1 |                    | 1       |       |        |     |    |     |       |    |          |          |       |           |         | -  |                |       |       | -              | -    |     |     |       |     |          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------|---------|-------|--------|-----|----|-----|-------|----|----------|----------|-------|-----------|---------|----|----------------|-------|-------|----------------|------|-----|-----|-------|-----|----------|
| Ox5E0         OTG_HS_HCC         M         M         MC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Offset  | Register           | 31      | 30    |        | 28  | 26 | 25  | 53    | 2  | 21<br>20 | 19<br>18 | 17    | 16        | 15      | 14 | 13<br>11<br>11 | 10    | 6     | 8              | 9    | 2   | 4   | e     | - N | - 0      |
| Ox5E0         OTG_HS_HCC<br>HAR7         G<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B<br>B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x5C0   | OTG_HS_HCC<br>HAR6 | CHENA   | CHDIS | DDDFRM |     |    | DAD |       |    | МС       | ЕРТҮР    | LSDEV | eserved   | EPDIR   |    | EPNUM          |       |       |                | N    | IPS | IZ  |       |     |          |
| Ox600         OTG_HS_HCC<br>HAR8         M<br>HO<br>HO         DAD<br>HO         MC         L<br>HA<br>HAR         MC<br>HO         L<br>HAR         MC<br>HO         MC<br>HO         L<br>HAR         MC<br>HO         MC<br>HO         L<br>HAR         MC<br>HO         MC<br>HO         L<br>HAR         MC<br>HO         MPSIZ         MPSIZ           0x600         OTG_HS_HOC<br>HARTIO         M<br>HO         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O <t< td=""><td></td><td>Reset value</td><td>0</td><td>0</td><td></td><td>0 0</td><td>0</td><td>0 0</td><td>0</td><td>0</td><td>0 0</td><td>0 0</td><td>0</td><td>щ</td><td>0</td><td>0</td><td>0 0 0</td><td>0</td><td>0</td><td>0 0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0 0</td><td>0</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                     |         | Reset value        | 0       | 0     |        | 0 0 | 0  | 0 0 | 0     | 0  | 0 0      | 0 0      | 0     | щ         | 0       | 0  | 0 0 0          | 0     | 0     | 0 0            | 0    | 0   | 0   | 0     | 0 0 | 0        |
| Order         OTG_HS_HCC<br>HAR8         M<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x5E0   |                    | CHENA   | CHDIS | DDDFRM |     |    | DAD |       |    | мс       | ЕРТҮР    | LSDEV | eserved   | EPDIR   |    | EPNUM          |       |       |                | N    | IPS | IZ  |       |     |          |
| Ox620         OTG_HS_HCC         X         Y         H         DAD         MC         A         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         | Reset value        | 0       | 0     |        | 0 0 | 0  | 0 0 | 0     | 0  | 0 0      | 0 0      | 0     | æ         | 0       | 0  | 0 0 0          | 0     | 0     | 0 0            | 0    | 0   | 0   | 0     | 0 0 | 0        |
| Ox620         OTG_HS_HCC         ARP         Othor         DAD         MC         A         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x600   | HAR8               |         |       | ODDFRM |     |    |     |       |    |          |          |       | Reserved  |         |    |                |       |       |                |      |     |     |       |     |          |
| Ox640         OTG_HS_HCC         Solution         Market of the second                 |         | Reset value        | 1       |       |        | 0 0 | 0  | 0 0 | 0     | 0  | 0 0      |          |       |           | -       | 0  | 0 0 0          | 0     | 0     | 0 0            | 0    | 0   | 0   | 0     | 0 0 | 0        |
| Ox640         OTG_HS_HCC         Solution         Market of the second                 | 0x620   | HAR9               |         |       | ODDFR  |     |    |     |       |    |          |          |       | Reserved  |         |    |                |       |       |                |      |     | IZ  |       |     |          |
| Ox660         OTG_HS_HCC<br>HAR11         H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         | Reset value        | 1       |       |        | 0 0 | 0  | 0 0 | 0     | 0  | 0 0      |          |       |           | -       | 0  | 0 0 0          | 0     | 0     | 0 0            | 0    | 0   | 0   | 0     | 0 0 | 0        |
| Ox660         OTG_HS_HCC<br>HAR11         H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x640   |                    | CHENA   | CHDIS | ODDFRN |     |    | DAD |       |    | мс       | ЕРТҮР    | LSDEV | leserved  | EPDIR   |    | EPNUM          |       |       |                | N    | IPS | IZ  |       |     |          |
| Reset value       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 <th< td=""><td></td><td>Reset value</td><td>0</td><td></td><td></td><td>0 0</td><td>0</td><td>0 0</td><td>0</td><td>0</td><td>0 0</td><td>0 0</td><td></td><td>Œ</td><td>-</td><td>0</td><td>0 0 0</td><td>0</td><td>0</td><td>0 0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0 0</td><td>0</td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         | Reset value        | 0       |       |        | 0 0 | 0  | 0 0 | 0     | 0  | 0 0      | 0 0      |       | Œ         | -       | 0  | 0 0 0          | 0     | 0     | 0 0            | 0    | 0   | 0   | 0     | 0 0 | 0        |
| Reset value       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 <th< td=""><td>0x660</td><td></td><td>CHENA</td><td>CHDIS</td><td>ODDFRV</td><td></td><td></td><td>DAD</td><td></td><td></td><td>мс</td><td>ЕРТҮР</td><td>LSDEV</td><td>eserved</td><td>EPDIR</td><td>   </td><td>EPNUM</td><td></td><td></td><td></td><td>N</td><td>IPS</td><td>IZ</td><td></td><td></td><td></td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x660   |                    | CHENA   | CHDIS | ODDFRV |     |    | DAD |       |    | мс       | ЕРТҮР    | LSDEV | eserved   | EPDIR   |    | EPNUM          |       |       |                | N    | IPS | IZ  |       |     |          |
| Reset value         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 <th< td=""><td></td><td>Reset value</td><td>0</td><td>0</td><td>0</td><td>0 0</td><td>0</td><td>0 0</td><td>0</td><td>0</td><td>0 0</td><td>0 0</td><td>0</td><td></td><td>0</td><td>0</td><td>0 0 0</td><td>0</td><td>0</td><td>0 0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0 0</td><td>0</td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         | Reset value        | 0       | 0     | 0      | 0 0 | 0  | 0 0 | 0     | 0  | 0 0      | 0 0      | 0     |           | 0       | 0  | 0 0 0          | 0     | 0     | 0 0            | 0    | 0   | 0   | 0     | 0 0 | 0        |
| Reset value         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 <th< td=""><td>0x504</td><td></td><td>SPLITEN</td><td></td><td></td><td></td><td></td><td>Res</td><td>serve</td><td>ed</td><td></td><td></td><td></td><td>COMPLSPLT</td><td>VALTOOS</td><td></td><td>HUI</td><td>BAD</td><td>DR</td><td></td><td></td><td></td><td>PR</td><td>FADE</td><td>R</td><td></td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x504   |                    | SPLITEN |       |        |     |    | Res | serve | ed |          |          |       | COMPLSPLT | VALTOOS |    | HUI            | BAD   | DR    |                |      |     | PR  | FADE  | R   |          |
| Reset value         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O <th< td=""><td></td><td>Reset value</td><td>0</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>0</td><td>0</td><td>0 0 0</td><td>0</td><td>0</td><td>0 0</td><td>0</td><td>0</td><td>0</td><td></td><td></td><td>0</td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         | Reset value        | 0       |       |        |     |    |     |       |    |          |          |       |           | 0       | 0  | 0 0 0          | 0     | 0     | 0 0            | 0    | 0   | 0   |       |     | 0        |
| Reset value         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O <th< td=""><td>0x508</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>Re</td><td>served</td><td></td><td></td><td></td><td></td><td></td><td></td><td>DTERR</td><td>FRMOR</td><td>BBERR<br/>TXERR</td><td>NYET</td><td>ACK</td><td>NAK</td><td>STALL</td><td></td><td>XFRC</td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x508   |                    |         |       |        |     |    |     |       | Re | served   |          |       |           |         |    |                | DTERR | FRMOR | BBERR<br>TXERR | NYET | ACK | NAK | STALL |     | XFRC     |
| Ox528         OTG_HS_HCIN<br>T1         Reserved         Reserved         HUBADR         HUBADR         HUBADR         PRTADR           0x544         OTG_HS_HCIN<br>Feset value         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         | Reset value        |         | 1     |        |     |    |     |       |    |          |          |       |           | 1       |    | 1              |       |       | 0 0            | 0    | 0   | 0   |       |     | 0        |
| Ox528         OTG_HS_HCIN<br>T1         Reserved         Reserved         HUBADR         HUBADR         HUBADR         PRTADR           0x544         OTG_HS_HCIN<br>Feset value         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N         N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x524   |                    | SPLITEN |       |        |     |    | Res | serve | ed |          |          |       | COMPLSPLT | XACTDOS |    | HUI            | BAD   | DR    |                |      |     | PR  | FADE  | R   |          |
| Reset value         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I         I <th< td=""><td></td><td>Reset value</td><td>0</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>0</td><td>0</td><td>0</td><td></td><td></td><td></td><td></td><td>_</td><td>0</td><td>0</td><td></td><td></td><td>0</td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         | Reset value        | 0       |       |        |     |    |     |       |    |          |          |       | 0         | 0       | 0  |                |       |       |                | _    | 0   | 0   |       |     | 0        |
| 0x544     OTG_HS_HCS<br>PLT2     NUTRADDR       0x544     Reset value     0       0x548     Reset value     0       0x548     OTG_HS_HCIN<br>T2       Reset value     0       0x564     OTG_HS_HCS<br>PLT3       Nutration     Reserved       Image: Nutration     Image: Nutration of the state o                                                                                                                                                                                                                                   | 0x528   | T1                 |         |       |        |     |    |     |       | Re | served   |          |       |           |         |    |                | _     |       |                |      |     |     | <     | ۲.  |          |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         | nesel value        |         | 1     |        |     |    |     |       |    |          |          |       | Б         |         |    |                | 0     | 0     | 0 0            |      | 0   | 0   | 0     |     | 0        |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x544   |                    | SPLITEN |       |        |     |    | Res | serve | ed |          |          |       | COMPLSP   |         |    | HUI            | BAD   | DR    |                |      |     | PR  | rade  | R   |          |
| Reset value       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 <th< td=""><td></td><td>Reset value</td><td>0</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>0</td><td>0</td><td>0</td><td>0 0 0</td><td></td><td>-</td><td></td><td>_</td><td>0</td><td>0</td><td></td><td></td><td>0</td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         | Reset value        | 0       |       |        |     |    |     |       |    |          |          |       | 0         | 0       | 0  | 0 0 0          |       | -     |                | _    | 0   | 0   |       |     | 0        |
| 0x564     OTG_HS_HCS     Image: Comparison of the second descent fraction of the second descent desce | 0x548   | T2                 | _       |       |        |     |    |     |       | Re | served   |          |       |           |         |    |                |       |       |                |      |     |     |       |     |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x564   | OTG_HS_HCS         | SPLITEN |       |        |     |    | Res | serve | ed |          |          |       | COMPLSPLT | XACTDOC |    | HUI            |       |       | <u> </u>       |      |     |     |       |     | <u> </u> |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         | Reset value        | 0       |       |        |     |    |     |       |    |          |          |       | 0         | 0       | 0  | 0 0 0          | 0     | 0     | 0 0            | 0    | 0   | 0   | 0     | 0 0 | 0        |

# Table 162. OTG\_HS register map and reset values (continued)



| Offset | Register                               | 5 register map and reset values (cc |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|----------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x568  | OTG_HS_HCIN<br>T3<br>Reset value       | Reserved                            | o DTERR<br>o BBERR<br>o BBERR<br>o TXERR<br>o NYET<br>o AHBERR<br>o CHH<br>o CHH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0x584  | OTG_HS_HCS<br>PLT4                     | Reserved                            | HUBADDR PRTADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x588  | Reset value OTG_HS_HCIN T4 Reset value | 0<br>Reserved                       | o         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 |
| 0x5A4  | OTG_HS_HCS<br>PLT5                     | Reserved                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x5A8  | Reset value OTG_HS_HCIN T5 Reset value | 0 Reserved                          | 0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 |
| 0x5C4  | OTG_HS_HCS<br>PLT6                     | Reserved                            | HUBADDR PRTADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x5C8  | Reset value OTG_HS_HCIN T6 Reset value | 0<br>Reserved                       | 0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 |
| 0x5E4  | OTG_HS_HCS<br>PLT7                     | Reserved                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x5E8  | Reset value OTG_HS_HCIN T7 Reset value | 0<br>Reserved                       | 0     0     0     0     0     0       0     0     0     0     0     0     0       0     0     0     0     0     0     0       0     0     0     0     0     0     0       0     0     0     0     0     0     0       0     0     0     0     0     0     0       0     0     0     0     0     0     0       0     0     0     0     0     0     0       0     0     0     0     0     0     0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x604  | OTG_HS_HCS<br>PLT8                     | Reserved                            | HUBADDR PRTADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x608  | Reset value OTG_HS_HCIN T8 Reset value | 0<br>Reserved                       | o         o         DTERR         o         o         o           o         o         DTERR         o         o         o         o         o           o         o         TXERR         o         o         O         O         O         O         O           o         o         NVET         o         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O                    |
| 0x624  | OTG_HS_HCS<br>PLT9<br>Reset value      | Reserved                            | HUBADDR PRTADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|        | 1000t value                            | •                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# Table 162. OTG\_HS register map and reset values (continued)



| Offset | Register                                | 5 register map and reset values (continued) | <b>7 8 9 1 1 1 1 2</b>                                                                                                                                                                                                    | 0 - 1 5 3 7 20                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-----------------------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x628  | OTG_HS_HCIN<br>T9                       | Reserved                                    | DTERR<br>FRMOR<br>BBERR<br>TXERR                                                                                                                                                                                          | NYET<br>ACK<br>NAK<br>STALL<br>AHBERR<br>CHH<br>XFRC                                                                                                                                                                                                                                                                                                                                             |
| 0x644  | Reset value OTG_HS_HCS PLT10            | Reserved Reserved                           | 0 0 0 0                                                                                                                                                                                                                   | 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                  |
| 0x648  | Reset value OTG_HS_HCIN T10 Reset value | Reserved                                    | o         DTERR         o         o           o         FRMOR         o         o         o           o         BBERR         o         TXERR         o                                                                   | O         NYET         O           O         ACK         O           O         NAK         O           O         STALL         O           O         STALL         O           O         O         OHBERR         O           O         OHBERR         O         OHBERR         O           O         CHH         O         OFH         O           O         XFRC         O         O         O |
| 0x664  | OTG_HS_HCS<br>PLT11                     | Reserved Reserved                           | HUBADDR                                                                                                                                                                                                                   | PRTADDR                                                                                                                                                                                                                                                                                                                                                                                          |
| 0x668  | Reset value OTG_HS_HCIN T11 Reset value | 0 0 0 0 0                                   | 0         0         0         0         0         0           0         0         FRMOR         0         0         0         0           0         0         BBERR         0         0         TXERR         0         0 | O         NYET         O           O         ACK         O           O         NAK         O           O         STALL         O           O         AHBERR         O           O         CHH         O           O         CHH         O                                                                                                                                                        |
| 0x50C  | OTG_HS_HCIN<br>TMSK0<br>Reset value     | Reserved                                    | o DTERRM<br>o FRMORM<br>o BBERRM<br>o TXERRM                                                                                                                                                                              | o NYET<br>O ACKM<br>O NAKM<br>O STALLM<br>O CHHM<br>O CHHM                                                                                                                                                                                                                                                                                                                                       |
| 0x52C  | OTG_HS_HCIN<br>TMSK1<br>Reset value     | Reserved                                    | <ul> <li>DTERRM</li> <li>FRMORM</li> <li>BBERRM</li> <li>TXERRM</li> </ul>                                                                                                                                                | o     NYET       o     ACKM       o     NAKM       o     STALLM       o     AHBERR       o     AHBERR       o     CHHM       o     CHHM       o     CHHM                                                                                                                                                                                                                                         |
| 0x54C  | OTG_HS_HCIN<br>TMSK2<br>Reset value     | Reserved                                    | <ul> <li>DTERRM</li> <li>FRMORM</li> <li>BBERRM</li> <li>TXERRM</li> </ul>                                                                                                                                                | <ul> <li>NYET</li> <li>ACKM</li> <li>ACKM</li> <li>ACKM</li> <li>ALBER</li> <li>AHBERR</li> <li>CHHM</li> <li>CHHM</li> <li>XFRCM</li> </ul>                                                                                                                                                                                                                                                     |
| 0x56C  | OTG_HS_HCIN<br>TMSK3<br>Reset value     | Reserved                                    | <ul> <li>DTERRM</li> <li>FRMORM</li> <li>BBERRM</li> <li>TXERRM</li> </ul>                                                                                                                                                | o NYET<br>ACKM<br>ACKM<br>NAKM<br>STALLM<br>AHBERR<br>AHBERR<br>CHHM<br>CHHM                                                                                                                                                                                                                                                                                                                     |
| 0x58C  | OTG_HS_HCIN<br>TMSK4<br>Reset value     | Reserved                                    | o DTERRM<br>o FRMORM<br>o BBERRM<br>o TXERRM                                                                                                                                                                              | o NYET<br>o ACKM<br>o NAKM<br>o STALLM<br>o AHBERR<br>o CHHM<br>o CHHM                                                                                                                                                                                                                                                                                                                           |
| 0x5AC  | OTG_HS_HCIN<br>TMSK5<br>Reset value     | Reserved                                    | o DTERRM<br>o FRMORM<br>o BBERRM<br>o TXERRM                                                                                                                                                                              | o NYET<br>o ACKM<br>o NAKM<br>o STALLM<br>o AHBERR<br>o CHHM<br>o CHHM                                                                                                                                                                                                                                                                                                                           |
| 0x5CC  | OTG_HS_HCIN<br>TMSK6<br>Reset value     | Reserved                                    | o DTERRM<br>o FRMORM<br>o BBERRM<br>o TXERRM                                                                                                                                                                              | o NYET<br>o ACKM<br>o NAKM<br>o STALLM<br>o AHBERR<br>o CHHM<br>o XFRCM                                                                                                                                                                                                                                                                                                                          |
| 0x5EC  | OTG_HS_HCIN<br>TMSK7<br>Reset value     | Reserved                                    | o DTERRM<br>o BBERRM<br>o DBERRM<br>o TXERRM                                                                                                                                                                              | o NYET<br>O ACKM<br>O NAKM<br>O STALLM<br>O AHBERR<br>O AHBERR                                                                                                                                                                                                                                                                                                                                   |

## Table 162. OTG\_HS register map and reset values (continued)



| Offset   | Register                             |          |          | -   |     |     | 20<br>20<br>20 | -   | -   | 1  | 1     |          |   | <u> </u> | 17 |     | 15 |          | 13 | 12 | 11  | 10     | 6        | δ       | 7          | 6      | ß      | 4    | e        | 2        | -        | 0       |
|----------|--------------------------------------|----------|----------|-----|-----|-----|----------------|-----|-----|----|-------|----------|---|----------|----|-----|----|----------|----|----|-----|--------|----------|---------|------------|--------|--------|------|----------|----------|----------|---------|
| 0x60C    | OTG_HS_HCIN<br>TMSK8<br>Reset value  |          |          |     |     |     |                |     |     |    | serv  |          |   |          |    | 1   | 1  | <u> </u> |    |    |     | DTERRM |          |         | o TXERRM   | o NYET | o ACKM |      | o STALLM | o AHBERR |          | o XFRCM |
| 0x62C    | OTG_HS_HCIN<br>TMSK9                 |          |          |     |     |     |                |     |     | Re | ser   | ved      |   |          |    |     |    |          |    |    |     |        |          | _       | o TXERRM ( |        |        |      |          | ~        | СННМ     | o XFRCM |
| 0x64C    | OTG_HS_HCIN<br>TMSK10                |          |          |     |     |     |                |     |     | Re | eserv | ved      |   |          |    |     |    |          |    |    |     |        |          | BBEHHIN | TXERRM     | NYET   | ACKM   | NAKM | STALLM   | AHBERR   | СННМ     | XFRCM   |
| 0x66C    | Reset value<br>OTG_HS_HCIN<br>TMSK11 |          |          |     |     |     |                |     |     | Re | ser   | ved      |   |          |    |     |    |          |    |    | _   | DTERRM |          | _       | Τ          |        |        |      |          | 4        | СННМ     | XFRCM o |
|          | Reset value<br>OTG_HS_HCTS           | /ed      | DPI      | ID  |     |     |                | PK  | TCN | т  |       |          |   |          |    |     |    |          |    |    |     |        | 0<br>RSI | 0<br>Z  | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x510    | IZ0<br>Reset value                   | Reserved | <u> </u> |     | 0   | 0   | 0 0            | -   | -   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   |        |          | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
|          | OTG_HS_HCTS                          |          | DPI      |     |     |     |                |     |     |    |       |          |   |          |    |     |    |          |    |    |     | XF     | RSI      | z       |            |        |        |      |          |          |          |         |
| 0x530    | Reset value                          | Reserved | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0        | OTG_HS_HCTS<br>IZ2                   | ved      | DPI      | ID  |     |     |                | PK. | TCN | Т  | 1     |          |   |          |    |     |    | 1        |    |    |     | XF     | RSI      | Z       |            |        |        | ł    |          |          |          |         |
| 0x550    | Reset value                          | Reser    | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x570    | OTG_HS_HCTS<br>IZ3                   |          | DPI      | ID  |     |     |                | PK  | TCN | Т  |       | <u> </u> |   |          |    |     |    |          |    |    |     | XF     | RSI      | Z       |            |        |        | 4    |          |          |          |         |
| 0,570    | Reset value                          | Reserved | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x590    | OTG_HS_HCTS<br>IZ4                   | Reserved | DPI      | ID  |     |     |                | PK  | TCN | Т  |       |          |   |          |    |     |    |          |    |    |     | XF     | RSI      | Z       |            |        |        |      |          |          |          |         |
| - Choose | Reset value                          |          | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x5B0    | OTG_HS_HCTS<br>IZ5                   | Š        | DPI      | ID  |     |     |                | PK  | TCN | Т  |       |          |   |          |    |     |    |          |    |    |     | XF     | RSI      | Z       |            |        |        |      |          |          |          |         |
|          | Reset value                          | Reser    | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x5D0    | OTG_HS_HCTS<br>IZ6                   | Reserved | DPI      | ID  |     |     |                | PK  | TCN | Т  |       |          |   |          |    |     |    |          |    |    |     | XF     | RSI      | Z       |            |        |        |      |          |          |          |         |
|          | Reset value                          |          | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x5F0    | OTG_HS_HCTS<br>IZ7                   | Reserved | DPI      | ID  |     |     |                | PK  | TCN | Т  |       |          |   |          |    |     |    |          |    |    |     | XF     | RSI      | Z       |            |        |        |      |          |          |          |         |
|          | Reset value                          | Bes      | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x610    | OTG_HS_HCTS<br>IZ8<br>Reset value    | erved    | DPI      | ID  |     |     |                | PK  | TCN | Т  |       |          |   |          |    |     |    | 1        |    |    |     | XF     | RSI      | Z       |            |        |        |      |          |          |          |         |
|          | Reset value                          | d Res    | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x630    | OTG_HS_HCTS<br>IZ9                   | Reserved | DPI      | ID  |     |     |                | PK  | TCN | Т  |       |          |   |          | -  |     |    |          |    |    |     | XF     | RSI      | Z       |            |        |        |      |          |          |          |         |
|          | Reset value<br>OTG_HS_HCTS           |          | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x650    | IZ10                                 | Reserved | DPI      | ID  |     |     |                | PK. | TCN | Т  |       |          |   |          |    |     | 1  | 1        |    |    |     | XF     | RSI      | Z       |            |        |        |      |          |          |          |         |
|          | Reset value                          |          | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x670    | OTG_HS_HCTS<br>IZ11                  | ×        | DPI      |     |     |     |                | -   | TCN | 1  | 1     |          |   |          |    | 1   | 1  |          |    |    |     |        | RSI      |         |            |        |        |      |          |          |          |         |
|          | Reset value OTG_HS_HCD               | Reser    | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |
| 0x514    | MA0                                  |          |          | ~ ' | 0.1 | ~ 1 | 0.1.0          |     |     |    |       |          | 0 | <u> </u> |    | MA/ |    |          | ~  | 0  | ~ 1 | ~ 1    | 0        | ~ '     | ~          | ~      |        |      |          |          | <u> </u> |         |
|          | Reset value                          | 0        | 0        | 0   | 0   | 0   | 0 0            | 0   | 0   | 0  | 0     | 0        | 0 | 0        | 0  | 0   | 0  | 0        | 0  | 0  | 0   | 0      | 0        | 0       | 0          | 0      | 0      | 0    | 0        | 0        | 0        | 0       |

| Table 162 | OTG_HS register map and reset values (continued)  |
|-----------|---------------------------------------------------|
|           | Ord_ris register map and reset values (continued) |



|        |                           |                |          |       |           |          |        |     | •       |          |      |          | <u>1 – 1</u> |            | -          | 1 1                 |           | r r      |                  |         |
|--------|---------------------------|----------------|----------|-------|-----------|----------|--------|-----|---------|----------|------|----------|--------------|------------|------------|---------------------|-----------|----------|------------------|---------|
| Offset | Register                  | 31<br>30<br>29 | 28<br>27 | 26    | 24        | 23       | 21     | 19  | 18      | 15<br>15 | 13 1 | 11       | 9            | ກ          | 2          | 9                   | 4         | З        | 1                | • •     |
| 0x524  | OTG_HS_HCD<br>MA1         |                |          |       |           |          |        |     | DN      | AADDR    |      |          |              |            |            |                     |           |          |                  |         |
|        | Reset value               | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    | 0 0 | 0 0     | 0 0 0    | 0 (  | 0 0      | 0 0          | 0 0        | 0          | 0 0                 | 0         | 0        | 0 0              | 0       |
| 0x544  | OTG_HS_HCD<br>MA2         |                |          |       |           |          |        |     | DN      | AADDR    |      |          |              |            |            |                     |           |          |                  |         |
| 0,044  | Reset value               | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    |     | 0 0     | 0 0 0    | 0 0  | 0 0      | 0 0          |            | 0          | 0 0                 | 0         | 0        | 0 0              | 0       |
| 0.504  | OTG_HS_HCD                |                |          |       |           |          |        |     | DN      | AADDR    |      |          |              |            |            |                     |           |          |                  | _       |
| 0x564  | MA3<br>Reset value        | 0 0 0          | 0 0      | 00    | 0 0       | 0 0      | 000    |     |         | 0 0 0    |      | 0 0      | 00           |            | 0          | 00                  | 0         | 0        | 0 0              | 0       |
|        | OTG_HS_HCD                |                |          |       | -   -     |          | 1-1-   | 1-1 | - I - I | AADDR    | 1-1  |          | 1 - 1 -      | - 1 -      | 1 -        | 1 - 1 -             | 1-        | <u> </u> |                  |         |
| 0x584  | MA4<br>Reset value        | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    | 0 0 |         |          | 0 0  | 0 0      | 0 (          |            | 0          | 0 0                 | 0         | 0        | 0 0              | 0       |
|        | OTG_HS_HCD                |                | 0 0      |       | 0 0       | 0 0      |        |     |         | AADDR    | , 0  | 0 0      |              |            | 0          |                     | 0         | U        | 0 0              |         |
| 0x5A4  | MA5                       |                |          |       |           |          |        |     |         |          |      | 010      |              |            |            |                     |           |          | 010              |         |
|        | Reset value<br>OTG_HS_HCD | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    | 0 0 |         | 0 0 0    | 0 0  | 0 0      | 0 (          | 0 0        | 0          | 0 0                 | 0         | 0        | 0 0              | 0       |
| 0x5C4  | MA6                       |                |          |       |           |          |        |     |         | AADDR    |      |          |              |            |            |                     |           |          |                  |         |
|        | Reset value<br>OTG_HS_HCD | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    | 0 0 |         | 0 0 0    | 0 0  | 0 0      | 0 0          | 0 0        | 0          | 0 0                 | 0         | 0        | 0 0              | 0       |
| 0x5E4  | MA7                       |                |          |       |           |          |        |     | DN      | AADDR    |      |          |              |            |            |                     |           |          |                  |         |
|        | Reset value               | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    | 0 0 | 0 0     | 0 0 0    | ) 0  | 0 0      | 0 (          | 0 0        | 0          | 0 0                 | 0         | 0        | 0 0              | 0       |
| 0x604  | OTG_HS_HCD<br>MA8         |                |          |       |           |          |        |     | DN      | AADDR    |      |          |              |            |            |                     |           |          |                  |         |
|        | Reset value               | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    | 0 0 | 0 0     | 0 0 0    | 0 0  | 0 0      | 0 0          | 0 0        | 0          | 0 0                 | 0         | 0        | 0 0              | 0       |
| 0x624  | OTG_HS_HCD<br>MA9         |                |          |       |           |          |        |     | DN      | AADDR    |      |          |              |            |            |                     |           |          |                  |         |
| 07024  | Reset value               | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    | 0 0 | 0 0     | 0 0 0    | 0    | 0 0      | 0 0          |            | 0          | 0 0                 | 0         | 0        | 0 0              | 0       |
| 0044   | OTG_HS_HCD<br>MA10        |                |          |       |           |          |        |     | DN      | AADDR    |      |          |              |            |            |                     |           | <u> </u> |                  |         |
| 0x644  | Reset value               | 0 0 0          | 0 0      | 00    | 0 0       | 0 0      | 00     |     | 0 0     | 0 0 0    |      | 0 0      | 00           |            | 0          | 00                  | 0         | 0        | 0 0              | 0       |
|        | OTG_HS_HCD                |                |          | 1 1   |           |          |        |     | DN      | AADDR    |      |          | 1            |            |            | <u> </u>            |           |          |                  |         |
| 0x664  | MA11<br>Reset value       | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 000    |     |         | 0 0 0    |      | 0 0      | 0 0          |            | 0          | 00                  | 0         | 0        | 0 0              | 0       |
|        | Tieset value              |                | 0 0      |       |           | 0 0      |        | 101 |         |          | , 10 |          |              |            | Ū          |                     | v         |          |                  |         |
|        | OTG_HS_                   |                |          |       | PERSCHIVL | /ed      |        |     |         |          |      | Ł        |              |            | 9          |                     |           | /ed      | NZLSOHSK         | DSPD    |
| 0x800  | DCFG                      | Rese           | erved    |       | RS(       | Reserved |        | R   | eserved |          |      | PFIVL    |              |            | DAD        |                     |           | Reserved | ILSC             | DSI     |
|        | Depatyclus                |                |          | L.    |           | Be       |        |     |         |          | _    | 010      |              |            |            |                     |           | Re       |                  |         |
|        | Reset value               |                |          |       | 1 0       |          |        |     |         |          |      | 0 0<br>Ш |              | 0 0        | -          | 0 0                 |           |          | 0 0              | 0       |
|        |                           |                |          |       |           |          |        |     |         |          |      | POPRGDNE | CGONAK       | CGINAK     | SGINAK     | 2                   |           | GONSTS   | S                | SIG     |
| 0x804  | OTG_HS_DCTL               |                |          |       |           | Res      | erved  |     |         |          |      | PRO      | 00           |            | <b>U</b> D | тстг                |           | ŇO       | GINSTS<br>SDIS   | RWUSI   |
|        |                           |                |          |       |           |          |        |     |         |          |      |          |              |            |            |                     |           | _        |                  |         |
|        | Reset value               |                |          |       |           |          |        |     |         |          |      | 0        | 0 (          | 0 0        | 0          | 0 0                 | 0         | 0        | 0 0              | -       |
|        |                           |                |          |       |           |          |        |     |         |          |      |          |              |            |            |                     |           | Ë        | ISP[             | STS     |
| 0x808  | OTG_HS_DSTS               |                | Res      | erved |           |          |        |     |         | FNSC     |      |          |              |            | I          | Reserv              | ed        | EERR     | ENUMSPD          | SUSPSTS |
|        | Reset value               |                |          |       |           |          | 010    |     | 0 0     |          |      | 0 0      |              |            | _          |                     |           | 0        | <u>后</u><br>0 0  |         |
|        | neset value               |                |          |       |           |          |        |     | 0 0     |          | , 0  |          |              |            |            |                     | ¥         | 0        | 0 0              |         |
|        | OTG_HS_DIEP               |                |          |       |           |          |        |     |         |          |      |          | 5            | NBN<br>NBN | rvec       |                     | NN<br>NN  | Σ        | M Ved            | CM      |
| 0x810  | MSK                       |                |          |       |           |          | Reserv | /ed |         |          |      |          | MIA          |            | Reserved   | INEPNEM             | ITTXFEMSK | TOM      | Reserved<br>EPDM | XFRCM   |
|        |                           |                |          |       |           |          |        |     |         |          |      |          |              |            |            |                     | -         |          | Ве               |         |
|        | Reset value               |                |          |       |           |          |        |     |         |          |      |          | (            | 0 0        | 0          | 0 0                 | 0         | 0        | 0                | _       |
|        | OTG_HS_DOE                |                |          |       |           |          |        |     |         |          |      |          | Σ            |            | (ed        | B2BSTUP<br>Reserved | OTEPDM    | PZ       | N ed             | XFRCM   |
| 0x814  | PMSK                      |                |          |       |           |          | Reserv | /ed |         |          |      |          | MICA         | OPEM       | Reserved   | 2BS<br>ese          | TE        | STUPM    | Reserved<br>EPDM | (FR     |
|        | Reset value               |                |          |       |           |          |        |     |         |          |      |          | -            |            | Be         |                     |           | 0        | o Be             |         |
|        | OTG_HS_DAIN               |                |          |       | OEP       |          |        |     |         |          |      |          |              |            | PINT       |                     | ľ         |          | 0                |         |
| 0x818  | T<br>Reset value          |                |          |       |           |          |        |     | 0101    |          |      | 010      | 1014         |            |            |                     |           |          | 010              |         |
|        | OTG_HS_DAIN               | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    | 0 0 | 0 0     | 0 0 0    | 0 0  | 0 0      | 0 (          |            |            | 0 0                 | 0         | 0        | 0 0              | 0       |
| 0x81C  | TMSK                      |                |          |       | OEI       |          |        |     |         |          |      |          |              |            | EPM        |                     |           |          |                  |         |
|        | Reset value               | 0 0 0          | 0 0      | 0     | 0 0       | 0 0      | 0 0    | 0 0 | 0 0     | 0 0 0    | 0 0  | 0 0      | 0 (          | 0 0        | 0          | 0 0                 | 0         | 0        | 0 0              | 0       |

| Table 162. | OTG_HS register ma | p and reset values ( | (continued) |
|------------|--------------------|----------------------|-------------|
|------------|--------------------|----------------------|-------------|



| Offset | Register                   | $ \frac{ V  }{ V  } =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V   =  V  $ |                           |      |          |          |       |          |       |        |                        |          |          |                    |          | າດ       |             | 0          |          |       |          |                   |
|--------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------|----------|----------|-------|----------|-------|--------|------------------------|----------|----------|--------------------|----------|----------|-------------|------------|----------|-------|----------|-------------------|
| 0000   | OTG_HS_DVB<br>USDIS        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1.11.                     |      |          |          |       |          |       |        |                        |          |          |                    |          | JSD.     | Т           |            |          |       |          |                   |
| 0x828  | Reset value                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |      |          | Reserved |       |          |       |        |                        | 0        | 0 0 1    | 0                  | 1 1 1    | 1        | 1           | 0          | 1        | 0 1   | 1        | 1                 |
| 0x82C  | OTG_HS_DVB<br>USPULSE      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          | Bos      | arvo  | Ч        |       |        |                        |          |          |                    |          | . [      | OVBL        | JSP        |          |       |          |                   |
| 0,020  | Reset value                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          | nest     | erve  | u        |       |        |                        |          |          | 0                  | 1 0 1    | 1        | 0           | 1          | 1        | 1 0   | 0        | 0                 |
| 0x830  | OTG_HS_DTH<br>RCTL         | Rese                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | erved                     |      | Reserved |          |       |          |       |        |                        |          | Reserved |                    |          |          |             |            |          |       | ISOTHREN | NONISOTHREN       |
|        | Reset value<br>OTG_HS_DIEP |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           | 0    |          | 0 0 0 0  | 0     | 0        | 0 0   | 0      | 0                      |          |          |                    |          |          |             | 0          | 0        | 0 0   | 0        | 0                 |
| 0x834  | EMPMSK<br>Reset value      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          | Reserved |       |          |       |        |                        | 0        | 0 0 0    | 0                  |          |          |             | 0          | 0        | 0 0   | 0        | 0                 |
|        | OTG_HS_DEA<br>CHINT        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      | _        |          |       |          |       |        |                        |          |          |                    |          |          |             |            |          |       |          | 'ved              |
| 0x838  | Reset value                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |      | F        | Reserved |       |          |       | 0      |                        |          |          |                    | Reserved |          |             |            |          |       | 0        | lesel             |
| 0x83C  | OTG_HS_DEA<br>CHINTMSK     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      | F        | Reserved |       |          |       |        |                        |          |          |                    | Reserved |          |             |            |          |       |          | Reserved Reserved |
|        | Reset value                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          |          |       |          |       | 0      |                        |          |          |                    |          |          |             |            |          |       | 0        | Res               |
| 0x840  | OTG_HS_DIEP<br>EACHMSK1    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          | Reserve  | d     |          |       |        |                        | WYYN Re  | serv     | p<br>BIM<br>TXFURM | Reserved | INEPNEM  | INEPNMM     | I I XFEMSK | Reserved | EPDM  | XFRCM    |                   |
|        | Reset value                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          |          |       |          |       |        |                        |          | 0        |                    | 0 0      | <u> </u> | 0           | 0          | 0        | 0     | 0        | 0                 |
| 0x880  | OTG_HS_DOE<br>PEACHMSK1    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          | Reserved |       |          |       |        | NYETM<br>NAKM<br>BERRM | Becorved |          | Reserved           | INEPNEM  | INEPNMM  | II I XFEMSK | Reserved   | EPDM     | XFRCM |          |                   |
|        | Reset value                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          |          |       |          |       |        |                        |          | 0 0 0    |                    |          | ш        | 0           |            |          | 0     | 0        | 0                 |
| 0x900  | OTG_HS_DIEP<br>CTL0        | EPENA<br>EPDIS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | SODDFRM<br>SDOPID/SEVNFRM | SNAK | CNAK     | TXFNUM   | STALL | Reserved | ЕРТҮР | NAKSTS | EONUM/DPID             | USBAEP   | Reserve  | d                  |          |          | М           | PSIZ       | 2        |       |          |                   |
|        | Reset value                | 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0 0                       |      | 0        | 0 0 0 0  | 0     |          | 0 0   | 0      | 0                      | 0        |          |                    | 0 0 0    | 0        | 0           | 0          | 0        | 0 0   | 0        | 0                 |
| 0x918  | TG_FS_DTXFS<br>TS0         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          | Reserved |       |          |       |        |                        |          |          |                    | INEP     | TFS      | AV          |            |          |       |          |                   |
|        | Reset value                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | . Ie                      | -    | 1        | Γ        | 1     |          | 1     | 1      | 1                      | 0        | 0 0 0    | 0                  | 0 1 0    | 0        | 0           | 0          | 0        | 0 0   | 0        | 0                 |
| 0x920  | OTG_HS_DIEP<br>CTL1        | EPENA<br>EPDIS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | SODDFRM<br>SD0PID/SEVNFRM |      | CNAK     | TXFNUM   | Stall | Reserved | ЕРТҮР | NAKSTS | EONUM/DPID             | USBAEP   | Reserve  | d                  |          |          | М           | PSIZ       | 2        |       |          |                   |
|        | Reset value                | 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0 0                       |      | 0        | 0 0 0 0  | 0     |          | 0 0   | 0      | 0                      | 0        |          |                    | 0 0 0    | 0        | 0           | 0          | 0        | 0 0   | 0        | 0                 |
| 0x938  | TG_FS_DTXFS<br>TS1         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      |          | Reserved |       |          |       |        |                        |          |          | -                  | INEP     |          |             |            | <u>.</u> | _     |          |                   |
|        | Reset value                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           | T    |          |          |       |          |       |        |                        | 0        | 0 0 0    | 0                  | 0 1 0    | 0        | 0           | 0          | 0        | 0 0   | 0        | 0                 |
| 0x940  |                            | EPENA<br>EPDIS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | SODDFRM<br>SD0PID/SEVNFRM |      | CNAK     | TXFNUM   | Stall | Reserved | ЕРТҮР | NAKSTS | EONUM/DPID             | USBAEP   | Reserve  | d                  |          |          |             | PSIZ       |          |       |          |                   |
|        | Reset value<br>TG_FS_DTXFS | 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0 0                       | 0    | 0        | 0 0 0 0  | 0     |          | 0 0   | 0      | 0                      | 0        |          |                    | 0 0 0    |          | 0           | 0          | 0        | 0 0   | 0        | 0                 |
| 0x958  | TS2<br>Reset value         | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |      |          | Reserved |       |          |       |        |                        | 0        | 0 0 0    | 0                  | INEP     |          |             | 0          | 0        | 0 0   | 0        | 0                 |
|        |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |      | -        |          | -     | -        |       | _      | -                      |          |          | -                  |          | -        | _           | ~ *        |          | _     |          | -                 |

# Table 162. OTG\_HS register map and reset values (continued)



| Offset | Register                           | 31      | 30      | 29       | 28             | 27     | 26     | 25<br>24<br>23<br>22 | 21      | 20       | 19        | 17       | 16         | 15       | 12 13 14 | 0 - 1 2 3 4 5 6 7 8 9 10 |
|--------|------------------------------------|---------|---------|----------|----------------|--------|--------|----------------------|---------|----------|-----------|----------|------------|----------|----------|--------------------------|
| 0x960  | OTG_HS_DIEP<br>CTL3                | EPENA   | EPDIS   |          | SD0PID/SEVNFRM | SNAK   | CNAK   | TXFNUM               | Stall   | Reserved | ЕРТҮР     | NAKSTS   | EONUM/DPID | USBAEP   | Reserved | MPSIZ                    |
|        | Reset value                        | 0       | 0       | 0        | 0              | 0      | 0      | 0 0 0 0              | 0       |          | 0 0       | 0        | 0          | 0        |          | 0 0 0 0 0 0 0 0 0 0 0    |
| 0x978  | TG_FS_DTXFS<br>TS3                 |         |         |          |                |        |        | Reserved             |         |          |           |          |            |          |          | INEPTFSAV                |
|        | Reset value                        |         | 1       |          |                |        |        |                      | r       |          | 1         | 1        | 1          | 0        | 0 0 0 0  | 0 1 0 0 0 0 0 0 0 0 0    |
| 0x980  | OTG_HS_DIEP<br>CTL4                | EPENA   | EPDIS   | SODDFRM  | SD0PID/SEVNFRM | SNAK   | CNAK   | TXFNUM               | Stall   | Reserved | ЕРТҮР     | NAKSTS   | EONUM/DPID | USBAEP   | Reserved | MPSIZ                    |
|        | Reset value                        | 0       | 0       | 0        | 0              | 0      | 0      | 0 0 0 0              | 0       |          | 0 0       | 0        | 0          | 0        |          | 0 0 0 0 0 0 0 0 0 0 0    |
| 0x9A0  | OTG_HS_DIEP<br>CTL5                | EPENA   | EPDIS   | SODDFRM  | SD0PID/SEVNFRM | SNAK   | CNAK   | TXFNUM               | STALL   | Reserved | ЕРТҮР     | NAKSTS   | EONUM/DPID | USBAEP   | Reserved | MPSIZ                    |
|        | Reset value                        | 0       | 0       | 0        | 0              | 0      | 0      | 0 0 0 0              | 0       |          | 0 0       | 0        | 0          | 0        |          | 0 0 0 0 0 0 0 0 0 0 0    |
| 0x9C0  | OTG_HS_DIEP<br>CTL6                | EPENA   | EPDIS   | SODDFRM  | SD0PID/SEVNFRM | SNAK   | CNAK   | TXFNUM               | STALL   | Reserved | ЕРТҮР     | NAKSTS   | EONUM/DPID | USBAEP   | Reserved | MPSIZ                    |
|        | Reset value                        | 0       | 0       |          | 0              | 0      | 0      | 0 0 0 0              | 0       |          | 0 0       | 0        | 0          | 0        | -        | 0 0 0 0 0 0 0 0 0 0 0 0  |
| 0x9E0  | OTG_HS_DIEP<br>CTL7                | EPENA   | EPDIS   | SODDFRM  | SD0PID/SEVNFRM | SNAK   | CNAK   | TXFNUM               | STALL   | Reserved | ЕРТҮР     | NAKSTS   | EONUM/DPID | USBAEP   | Reserved | MPSIZ                    |
|        | Reset value                        | 0       | 0       | 0        | 0              | 0      | 0      | 0 0 0 0              | 0       |          | 0 0       | 0        | 0          | 0        |          | 0 0 0 0 0 0 0 0 0 0 0    |
| 0xB00  | OTG_HS_DOE<br>PCTL0<br>Reset value | o EPENA | o EPDIS | Reserved |                | o SNAK | O CNAK | Reserved             | O STALL | o SNPM   | EPTY<br>P | o NAKSTS | Reserved   | - USBAEP |          | Reserved MPSI Z          |
|        | neset value                        | 0       | 0       |          |                | 0      | 0      |                      | 0       | 0        | 0 0       | 0        |            | -        |          | 0 0                      |
| 0xB20  |                                    | EPENA   | EPDIS   |          | SDOPI          |        | CNAK   | Reserved             | STALL   | SNPM     | ЕРТҮР     | NAKSTS   | EONUM/DPID | USBAEP   | Reserved | MPSIZ                    |
|        | Reset value                        | 0       | 0       | 0        | 10             | 0      | 0      |                      | 0       | 0        | 0 0       | 0        | 0          | 0        |          | 0 0 0 0 0 0 0 0 0 0 0    |
| 0xB40  | OTG_HS_DOE<br>PCTL2                | EPENA   | EPDIS   | SODDFRM  | SD0PID/SEVNFRM | SNAK   | CNAK   | Reserved             | Stall   | SNPM     | ЕРТҮР     | NAKSTS   | EONUM/DPID | USBAEP   | Reserved | MPSIZ                    |
|        | Reset value                        | 0       | 0       |          | 0              | 0      | 0      |                      | 0       | 0        | 0 0       | 0        | 0          | 0        |          | 0 0 0 0 0 0 0 0 0 0 0    |

| Table 162. | OTG_HS register map | o and reset values ( | (continued) |
|------------|---------------------|----------------------|-------------|
|            |                     |                      |             |



| Offset | Register                           | 31 | 30    | 29      | 28             | 27   | 26   | 25<br>24 | 23     | 12 | 20 | 19  | 17 | 16 | 15 | 14     | 13  | 12   | 11               | 10       | 6   | 8                 | 7    | 9         | 5        | 4      | З      | 2        | 1        | 0      |  |
|--------|------------------------------------|----|-------|---------|----------------|------|------|----------|--------|----|----|-----|----|----|----|--------|-----|------|------------------|----------|-----|-------------------|------|-----------|----------|--------|--------|----------|----------|--------|--|
| 0xB60  | OTG_HS_DOE<br>PCTL3                |    | EPDIS | SODDFRM | SD0PID/SEVNFRM | SNAK | CNAK | Rese     |        |    |    |     |    |    |    | R      |     | erve |                  | 0        |     |                   |      |           | MPSIZ    |        |        |          |          |        |  |
|        | Reset value                        | 0  | 0     | 0       | 0              | 0    | 0    |          |        | 0  | 0  | 0 0 | 0  | 0  | 0  |        |     |      | (0)              | 0        | 0   | 0                 | 0    | 0         | 0        | 0      | 0      | 0        | 0        | 0      |  |
| 0x908  | OTG_HS_DIEPI<br>NT0                |    |       |         |                |      |      | R        | leserv | ed |    |     |    |    |    |        | NAK |      | PKTDRPSTS        | Reserved | BNA | TXFIFOUDRN        | TXFE | INEPNE    | Reserved | ITTXFE |        | Reserved |          | XFRC   |  |
|        | Reset value                        |    |       |         |                |      |      |          |        |    |    |     |    |    |    |        | 0   |      | 0                |          | 0   | 0                 | 1    | 0         |          | 0      | 0      |          | 0        | 0      |  |
| 0x928  | otg_hs_diepi<br>Nt1                |    |       |         |                |      |      | R        | leserv | ed |    |     |    |    |    |        |     |      | PKTDRPSTS        | Reserved |     | TXFIFOUDRN        | TXFE | INEPNE    | Reserved | ITTXFE |        | Reserved | ш        | XFRC   |  |
|        | Reset value                        |    |       |         |                |      |      |          |        |    |    |     |    |    |    |        | 0   |      | 0                |          | 0   | 0                 | 1    | 0         |          | 0      | 0      |          | 0        | 0      |  |
| 0x948  | otg_hs_diepi<br>Nt2                |    |       |         |                |      |      | R        | leserv | ed |    |     |    |    |    |        | NAK | BERR | PKTDRPSTS        | Reserved | BNA | <b>TXFIFOUDRN</b> | TXFE | INEPNE    | Reserved | ITTXFE | TOC    | Reserved | EPDISD   | XFRC   |  |
|        | Reset value                        |    |       |         |                |      |      |          |        |    |    |     |    |    |    |        | 0   | 0    | 0                |          | 0   | 0                 | 1    | 0         |          | 0      | 0      |          | 0        | 0      |  |
| 0x968  | OTG_HS_DIEPI<br>NT3                |    |       |         |                |      |      | R        | leserv | ed |    |     |    |    |    |        | NAK | BERR | PKTDRPSTS        | Reserved | BNA | TXFIFOUDRN        | TXFE | INEPNE    | Reserved | ITTXFE | TOC    | Reserved | EPDISD   | XFRC   |  |
|        | Reset value                        |    |       |         |                |      |      |          |        |    |    |     |    |    |    | ŀ      | 0   | 0    | 0                |          | 0   | 0                 | 1    | 0         |          | 0      | 0      |          | 0        | 0      |  |
| 0x988  | OTG_HS_DIEPI<br>NT4                |    |       |         |                |      |      | R        | leserv | ed |    |     |    |    |    |        |     |      | PKTDRPSTS        | Reserved | BNA | TXFIFOUDRN        | TXFE | INEPNE    | Reserved | _      | TOC    | Reserved | ш        | XFRC   |  |
| -      | Reset value                        |    |       |         |                |      |      |          |        |    |    |     |    |    |    |        | 0   | 0    | 0                |          | 0   | 0                 | 1    | 0         |          | 0      | 0      |          | 0        | 0      |  |
| 0x9A8  | OTG_HS_DIEPI<br>NT5                |    |       |         |                |      |      | R        | leserv | ed |    |     |    |    |    |        | NAK | BERR | PKTDRPSTS        | Reserved | BNA | TXFIFOUDRN        | TXFE | INEPNE    | Reserved | ITTXFE | TOC    | Reserved | EPDISD   | XFRC   |  |
|        | Reset value                        |    |       |         |                |      |      |          |        |    |    |     |    |    |    |        | 0   |      | 0                |          | 0   | 0                 | 1    | 0         |          | 0      | 0      |          | 0        | 0      |  |
| 0x9C8  | OTG_HS_DIEPI<br>NT6                |    |       |         |                |      |      | R        | leserv | ed |    |     |    |    |    |        | NAK | BERR | PKTDRPSTS        | Reserved | BNA | TXFIFOUDRN        | TXFE | INEPNE    | Reserved | ITTXFE | TOC    | Reserved | EPDISD   | XFRC   |  |
|        | Reset value                        |    |       |         |                |      |      |          |        |    |    |     |    |    |    |        | 0   | 0    | 0                |          | 0   | 0                 | 1    | 0         |          | 0      | 0      |          | 0        | 0      |  |
| 0x9E8  | OTG_HS_DIEPI<br>NT7                |    |       |         |                |      |      | R        | leserv | ed |    |     |    |    |    |        |     |      | <b>PKTDRPSTS</b> | Reserved | BNA | <b>TXFIFOUDRN</b> | TXFE | INEPNE    | Reserved | ITTXFE | TOC    | Reserved | ш        | XFRC   |  |
|        | Reset value                        |    |       |         |                |      |      |          |        |    |    |     |    |    |    |        | 0   | 0    | 0                |          | 0   | 0                 | 1    | Р<br>0    |          | 0<br>S | 0      |          | 0        | 0      |  |
| 0xB08  | OTG_HS_DOE<br>PINT0<br>Reset value |    |       |         |                |      |      | Re       | serveo | ł  |    |     |    |    |    | o NYET |     |      | Re               | ser      | ved |                   |      | o B2BSTUP | Reserved |        | - STUP | Reserved | o EPDISD | o XFRC |  |

| Table 162. OTG_HS register map and reset values (contin | nued) |
|---------------------------------------------------------|-------|
|---------------------------------------------------------|-------|

57

| Offset | Register                           | 31       | 30       | 6  | 8 |     | 20   | 22 | 4 2      | 20   | 2  | 5  | 2         | 6 | 8<br>8 | 17 | 16  | 5   | 14     | 13   | 12  | ÷   | 10     | 6       | 8   | 2 | 9             | 5        | 4        | 3      | 2        | 1        | 0                        |
|--------|------------------------------------|----------|----------|----|---|-----|------|----|----------|------|----|----|-----------|---|--------|----|-----|-----|--------|------|-----|-----|--------|---------|-----|---|---------------|----------|----------|--------|----------|----------|--------------------------|
|        | 5                                  | 0        | 0        |    |   |     |      |    |          |      |    | (N |           | - | -      | -  | -   | -   | -      |      | - 1 | -   | -      |         |     |   |               | _        |          |        |          |          |                          |
| 0xB28  | OTG_HS_DOE<br>PINT1                |          |          |    |   |     |      | I  | Rese     | erve | ed |    |           |   |        |    |     |     | NYET   |      |     | Res | ser    | ved     |     |   | OB2BSTUP      | Reserved | OTEPDIS  | STUP   | Reserved | EPDISD   | XFRC                     |
|        | Reset value                        |          |          |    |   |     |      |    |          |      |    |    |           |   |        |    |     | ŀ   | 0      |      |     |     |        |         |     |   | <u>в</u><br>0 | Å        | 0        | 0      | Å        | 0        | 0                        |
| 0xB48  | OTG_HS_DOE<br>PINT2                |          |          |    |   |     |      | I  | Res      | erve | ed |    |           |   |        |    |     |     | NYET   |      |     | Res | ser    | ved     |     |   | o B2BSTUP     | Reserved | OTEPDIS  | STUP   | Reserved | EPDISD   | XFRC                     |
|        | Reset value                        |          |          |    |   |     |      |    |          |      |    |    |           |   |        |    |     |     | 0      |      |     |     |        |         |     |   |               | ш        | 0        | 0      | щ        | 0        | 0                        |
| 0xB68  | OTG_HS_DOE<br>PINT3                |          |          |    |   |     |      | I  | Rese     | erve | ed |    |           |   |        |    |     |     | NYET   |      |     | Res | ser    | ved     |     |   | o B2BSTUP     | Reserved | OTEPDIS  | STUP   | Reserved | EPDISD   | XFRC                     |
|        | Reset value                        |          |          |    |   |     |      |    |          |      |    |    |           |   |        |    |     |     | 0      |      |     |     |        |         |     |   |               | -        | 0        | 0      | -        | 0        | 0                        |
| 0xB88  | OTG_HS_DOE<br>PINT4<br>Reset value |          |          |    |   |     |      | I  | Rese     | erve | ed |    |           |   |        |    |     |     | o NYET |      |     | Res | ser    | ved     |     |   | o B2BSTUP     | Reserved |          | o STUP | Reserved | O EPDISD | <ul> <li>XFRC</li> </ul> |
|        | Tieset value                       |          |          |    |   |     |      |    |          |      |    |    |           |   |        |    |     |     | •      |      |     |     |        |         |     |   |               | _        |          |        | _        | -        |                          |
| 0xBA8  | OTG_HS_DOE<br>PINT5                |          |          |    |   |     |      | I  | Rese     | erve | ed |    |           |   |        |    |     |     | NYET   |      |     | Res | ser    | ved     |     |   | o B2BSTUP     | Reserved | OTEPDIS  | STUP   | Reserved | EPDISD   | XFRC                     |
|        | Reset value                        |          |          |    |   |     |      |    |          |      |    |    |           |   |        |    |     |     | 0      |      |     |     |        |         |     |   |               |          | 0        | 0      |          | 0        | 0                        |
| 0xBC8  | OTG_HS_DOE<br>PINT6                |          |          |    |   |     |      | I  | Rese     | erve | ed |    |           |   |        |    |     |     | NYET   |      |     | Res | ser    | ved     |     |   | O B2BSTUP     | Reserved | OTEPDIS  | STUP   | Reserved | EPDISD   | XFRC                     |
|        | Reset value                        |          |          |    |   |     |      |    |          |      |    |    |           |   |        |    |     |     | 0      |      |     |     |        |         |     |   | _             | Ē        | 0        | 0      | æ        | 0        | 0                        |
| 0xBE8  | OTG_HS_DOE<br>PINT7                |          |          |    |   |     |      | I  | Rese     | erve | ed |    |           |   |        |    |     |     | NYET   |      |     | Res | ser    | ved     |     |   | B2BSTUP       | Reserved | OTEPDIS  | STUP   | Reserved | EPDISD   | XFRC                     |
|        | Reset value                        |          |          |    |   |     |      |    |          |      |    |    |           |   |        |    |     |     | 0      |      |     |     |        |         |     |   | 0             | Ē        | 0        | 0      | Ē        | 0        | 0                        |
| 0x910  | OTG_HS_DIEP<br>TSIZ0               |          |          |    |   | Res | erve | ed |          |      |    |    | PKT<br>N1 |   |        |    |     |     | B      | eser | ved | 1   |        |         |     |   |               |          | XI       | FRS    | SIZ      |          |                          |
|        | Reset value                        |          | 1        |    |   |     |      |    |          |      |    | ·  | 0         | 0 |        |    |     |     |        |      |     |     |        |         |     |   | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |
| 0000   | OTG_HS_DIEP<br>TSIZ1               | rved     | MC       | NT |   |     |      | PI | ктс      | NT   |    |    |           |   |        |    |     |     |        |      |     |     | Х      | FR      | SIZ |   |               |          |          |        |          |          |                          |
| 0x930  | Reset value                        | Reserved | 0        | 0  | 0 | 0   | 0    | 0  | 0        | 0    | 0  | 0  | 0         | 0 | 0      | 0  | 0   | 0   | 0      | 0    | 0   | 0   | 0      | 0       | 0   | 0 | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |
| 0x934  | OTG_HS_DIEP<br>DMA1                | ш        |          |    |   |     |      |    |          |      |    |    |           |   |        | D  | MAA |     | R      |      |     |     |        |         |     |   |               |          |          |        |          |          |                          |
|        | Reset value<br>OTG_HS_DIEP         | 0        | 0        | 0  | 0 | 0   | 0    | 0  | 0        | 0    | 0  | 0  | 0         | 0 | 0      | 0  | 0   | 0   | 0      | 0    | 0   | 0   | 0      | 0       | 0   | 0 | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |
| 0x93C  | DMAB1                              | _        |          | -  | - |     |      | -  | -        | - 1  | -  | -  | -         | - | _      |    |     | ADD |        |      | -   | -   |        |         |     |   |               | -        |          | _      |          |          | -                        |
|        | Reset value<br>OTG HS DIEP         | 0<br>q   |          | 0  | 0 | 0   | 0    | -  |          |      | 0  | 0  | 0         | 0 | 0      | 0  | 0   | 0   | 0      | 0    | 0   | 0   | 0      | 0       |     | 0 | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |
| 0x950  | TSIZ2                              | served   | MCI      | NI |   |     |      | Ы  | ктс      | ;N I |    |    |           |   |        |    |     |     |        |      |     |     | х      | FR      | SIZ |   |               |          |          |        |          |          |                          |
|        | Reset value                        | Res      | 0        | 0  | 0 | 0   | 0    | 0  | 0        | 0    | 0  | 0  | 0         | 0 | 0      | 0  | 0   | 0   | 0      | 0    | 0   | 0   | 0      | 0       | 0   | 0 | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |
| 0x954  | OTG_HS_DIEP<br>DMA2<br>Reset value | 0        | 0        | 0  | 0 | 0   | 0    | 0  | 0        | 0    | 0  | 0  | 0         | 0 | 0      |    |     |     |        | 0    | 0 1 | 01  | 0      | 0       | 0   | 0 | 0             | 0        | 0        | 0      | 0        |          | 0                        |
|        | OTG_HS_DIEP                        | 0        | U        | 0  | U | 0   | 0    | 0  | 0        | 0    | 0  | 0  | U         | U | 0      |    |     |     |        | 0    | •   | 0   | 0      | 0       | 0   | 0 | 0             | U        | 0        | 0      | 0        | 0        | 0                        |
| 0x95C  | DMAB2<br>Reset value               | 0        |          | 0  | 0 | 0   | 0    | 0  |          | 0    | 0  | 0  | 0         | 0 | 0      | 0  | 0   |     | 0      | 0    | 0   | 0   | 0      |         | 10  | 0 | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |
| 0.070  | OTG_HS_DIEP<br>TSIZ3               | o bev    | 0<br>MCI |    | 0 | 0   | 0    |    | 0<br>ктс |      | 0  | 0  | 0         | 0 | 0      | 0  | 0   | 0   | 0      | 0    | 0   | 0   | 0<br>X | 0<br>FR |     | 0 | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |
| 0x970  | Reset value                        | Reserved | 0        | 0  | 0 | 0   | 0    | 0  | 0        | 0    | 0  | 0  | 0         | 0 | 0      | 0  | 0   | 0   | 0      | 0    | 0   | 0   | 0      | 0       | 0   | 0 | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |
| 0x974  | OTG_HS_DIEP<br>DMA3                | Ш.       | 1 1      |    |   |     |      |    |          |      |    |    |           |   |        | D  | MAA |     | R      |      |     |     |        | 1       |     |   | <u> </u>      | <u>I</u> | <u> </u> | I      | <u> </u> | <u> </u> |                          |
|        | Reset value                        | 0        | 0        | 0  | 0 | 0   | 0    | 0  | 0        | 0    | 0  | 0  | 0         | 0 | 0      | 0  | 0   | 0   | 0      | 0    | 0   | 0   | 0      | 0       | 0   | 0 | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |
| 0x97C  | OTG_HS_DIEP<br>DMAB3               |          |          | _  | _ |     | _    | _  | _        | _    | _  | _  |           | _ | _      | DN | 1AB | ADD | R      |      | _   | _   | -      | _       | _   | _ | _             | _        | _        | _      | _        | _        | ]                        |
| 0      | Reset value                        | 0        | 0        | 0  | 0 | 0   | 0    | 0  | 0        | 0    | 0  | 0  | 0         | 0 | 0      | 0  | 0   | 0   | 0      | 0    | 0   | 0   | 0      | 0       | 0   | 0 | 0             | 0        | 0        | 0      | 0        | 0        | 0                        |

| Table 162. OT | G HS register ma | p and reset values | (continued) |
|---------------|------------------|--------------------|-------------|
|---------------|------------------|--------------------|-------------|



|        | 62. OIG_F            |          |         | -        |    |    |    |     |     |     |    |    |    |    | •    |    |    |      |          | -    |     | - |             | -      | - |   | - |         |          |          | -       |
|--------|----------------------|----------|---------|----------|----|----|----|-----|-----|-----|----|----|----|----|------|----|----|------|----------|------|-----|---|-------------|--------|---|---|---|---------|----------|----------|---------|
| Offset | Register             | 31       | 30      | 29       | 28 | 27 | 26 | 25  | 24  | 23  | 22 | 21 | 20 | 19 | 18   | 17 | 16 | 15   | <b>+</b> | 13   | 215 | = | 0<br>-<br>- | s<br>Ø | 2 | 9 | 5 | 4       | e c      | 1        | 0       |
| 0xB10  | OTG_HS_DOE<br>PTSIZ0 | Reserved | CI      | UP<br>NT |    |    |    | Res | erv | ed  |    |    |    |    |      |    |    |      | Re       | eser | ved |   |             |        |   |   |   |         | RSIZ     |          |         |
|        | Reset value          | щ        |         | 0        |    |    |    |     |     |     |    |    |    | 0  |      |    |    |      |          |      |     |   |             |        |   | 0 | 0 | 0       | 0 0      | 0        | 0       |
| 0xB30  | OTG_HS_DOE<br>PTSIZ1 | Reserved | RXDPID/ | STUPCNT  |    |    |    |     |     | CNT |    |    |    |    |      |    |    |      |          |      |     |   | XFR         |        |   |   |   |         |          |          |         |
|        | Reset value          |          | 0       | 0        | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0 0  | )        | 0    | 0 0 | 0 | 0 0         | 0      | 0 | 0 | 0 | 0       | 0 0      | 0        | 0       |
| 0xB34  | OTG_HS_DOE<br>PDMA1  |          |         |          |    |    |    |     |     |     |    |    |    |    |      |    |    | DDR  |          |      |     |   |             |        |   |   |   |         |          |          |         |
|        | Reset value          | 0        | 0       | 0        | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0 0  | )        | 0    | 0 0 | 0 | 0 0         | 0      | 0 | 0 | 0 | 0       | 0 0      | 0        | 0       |
| 0xB3C  | OTG_HS_DOE<br>PDMAB1 |          |         |          |    |    |    |     |     |     |    |    |    |    |      |    |    | ADDF |          |      |     |   |             |        |   |   |   |         |          |          |         |
|        | Reset value          | 0        | 0       | 0        | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0 (  | )        | 0    | 0 0 | 0 | 0 0         | 0      | 0 | 0 | 0 | 0       | 0 0      | 0        | 0       |
| 0xB50  | OTG_HS_DOE<br>PTSIZ2 | Reserved | RXDPID/ | STUPCNT  |    |    |    | Ρ   | кто | СИТ |    |    |    |    |      |    |    |      |          |      |     |   | XFR         | SIZ    |   |   |   |         |          |          |         |
|        | Reset value          |          | 0       | 0        | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0 0  | )        | 0    | 0 0 | 0 | 0 0         | 0      | 0 | 0 | 0 | 0       | 0 0      | 0        | 0       |
| 0xB54  | OTG_HS_DOE<br>PDMA2  |          |         |          |    |    |    |     |     |     |    |    |    |    |      |    |    | DDR  |          |      |     |   |             |        |   |   |   |         |          |          |         |
|        | Reset value          | 0        | 0       | 0        | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0 0  | )        | 0    | 0 0 | 0 | 0 0         | 0      | 0 | 0 | 0 | 0       | 0 0      | 0        | 0       |
| 0xB5C  | OTG_HS_DOE<br>PDMAB2 |          |         |          |    |    |    |     |     |     |    |    |    |    |      |    |    | ADDF |          |      |     |   |             |        |   |   |   |         |          |          |         |
|        | Reset value          | 0        | 0       | 0        | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0 0  | )        | 0    | 0 0 | 0 | 0 0         | 0      | 0 | 0 | 0 | 0       | 0 0      | 0        | 0       |
| 0xB70  | OTG_HS_DOE<br>PTSIZ3 | Reserved | RXDPID/ | STUPCNT  |    |    |    | Ρ   | кто | CNT | -  |    |    |    |      |    |    |      |          |      |     |   | XFR         | SIZ    |   |   |   |         |          |          |         |
|        | Reset value          | _        | 0       | 0        | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0 0  | )        | 0    | 0 0 | 0 | 0 0         | 0      | 0 | 0 | 0 | 0       | 0 0      | 0        | 0       |
| 0xB74  | OTG_HS_DOE<br>PDMA3  |          |         |          |    |    |    |     |     |     |    |    |    |    |      |    |    | DDR  |          |      |     |   |             |        |   |   |   |         |          |          |         |
|        | Reset value          | 0        | 0       | 0        | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0 (  | )        | 0    | 0 0 | 0 | 0 0         | 0      | 0 | 0 | 0 | 0       | 0 0      | 0        | 0       |
| 0xB7C  | OTG_HS_DOE<br>PDMAB3 |          |         |          |    |    |    |     |     |     |    |    |    |    |      |    |    | ADDF |          |      |     |   |             |        |   |   |   |         |          |          |         |
|        | Reset value          | 0        | 0       | 0        | 0  | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0 0  | )        | 0    | 0 0 | 0 | 0 0         | 0      | 0 | 0 | 0 | 0       | 0 0      | -        |         |
| 0xE00  | OTG_HS_PCG<br>CCTL   |          |         |          |    |    |    |     |     |     |    |    |    | Re | serv | ed |    |      |          |      |     |   |             |        |   |   |   | PHYSUSP | Reserved | GATEHCLK | STPPCLK |
|        | Reset value          |          |         |          |    |    |    |     |     |     |    |    |    |    |      |    |    |      |          |      |     |   |             |        |   |   |   |         |          |          |         |

## Table 162. OTG\_HS register map and reset values (continued)

Refer to Table 1 on page 50 for the register boundary addresses.

# **30.13 OTG\_HS programming model**

## 30.13.1 Core initialization

The application must perform the core initialization sequence. If the cable is connected during power-up, the current mode of operation bit in the Core interrupt register (CMOD bit in OTG\_HS\_GINTSTS) reflects the mode. The OTG\_HS controller enters host mode when an "A" plug is connected or peripheral mode when a "B" plug is connected.

This section explains the initialization of the OTG\_HS controller after power-on. The application must follow the initialization sequence irrespective of host or peripheral mode operation. All core global registers are initialized according to the core's configuration:



- 1. Program the following fields in the Global AHB configuration (OTG\_HS\_GAHBCFG) register:
  - DMA mode bit
  - AHB burst length field
  - Global interrupt mask bit GINT = 1
  - RxFIFO nonempty (RXFLVL bit in OTG\_HS\_GINTSTS)
  - Periodic TxFIFO empty level
- 2. Program the following fields in OTG\_HS\_GUSBCFG register:
  - HNP capable bit
  - SRP capable bit
  - FS timeout calibration field
  - USB turnaround time field
- The software must unmask the following bits in the GINTMSK register: OTG interrupt mask

Mode mismatch interrupt mask

4. The software can read the CMOD bit in OTG\_HS\_GINTSTS to determine whether the OTG\_HS controller is operating in host or peripheral mode.

# 30.13.2 Host initialization

To initialize the core as host, the application must perform the following steps:

- 1. Program the HPRTINT in GINTMSK to unmask
- 2. Program the OTG\_HS\_HCFG register to select full-speed host
- 3. Program the PPWR bit in OTG\_HS\_HPRT to 1. This drives V<sub>BUS</sub> on the USB.
- 4. Wait for the PCDET interrupt in OTG\_HS\_HPRT0. This indicates that a device is connecting to the port.
- 5. Program the PRST bit in OTG\_HS\_HPRT to 1. This starts the reset process.
- 6. Wait at least 10 ms for the reset process to complete.
- 7. Program the PRST bit in OTG\_HS\_HPRT to 0.
- 8. Wait for the PENCHNG interrupt in OTG\_HS\_HPRT.
- 9. Read the PSPD bit in OTG\_HS\_HPRT to get the enumerated speed.
- 10. Program the HFIR register with a value corresponding to the selected PHY clock 1.
- 11. Program the FSLSPCS field in OTG\_FS\_HCFG register according to the speed of the detected device read in step 9. If FSLSPCS has been changed, reset the port.
- 12. Program the OTG\_HS\_GRXFSIZ register to select the size of the receive FIFO.
- 13. Program the OTG\_HS\_GNPTXFSIZ register to select the size and the start address of the nonperiodic transmit FIFO for nonperiodic transactions.
- 14. Program the OTG\_HS\_HPTXFSIZ register to select the size and start address of the periodic transmit FIFO for periodic transactions.

To communicate with devices, the system software must initialize and enable at least one channel.



## 30.13.3 Device initialization

The application must perform the following steps to initialize the core as a device on powerup or after a mode change from host to device.

- 1. Program the following fields in the OTG\_HS\_DCFG register:
  - Device speed
  - Nonzero-length status OUT handshake
- 2. Program the OTG\_HS\_GINTMSK register to unmask the following interrupts:
  - USB reset
  - Enumeration done
  - Early suspend
  - USB suspend
  - SOF
- 3. Program the VBUSBSEN bit in the OTG\_HS\_GCCFG register to enable V<sub>BUS</sub> sensing in "B" peripheral mode and supply the 5 volts across the pull-up resistor on the DP line.
- 4. Wait for the USBRST interrupt in OTG\_HS\_GINTSTS. It indicates that a reset has been detected on the USB that lasts for about 10 ms on receiving this interrupt.

Wait for the ENUMDNE interrupt in OTG\_HS\_GINTSTS. This interrupt indicates the end of reset on the USB. On receiving this interrupt, the application must read the OTG\_HS\_DSTS register to determine the enumeration speed and perform the steps listed in *Endpoint initialization on enumeration completion on page 1198*.

At this point, the device is ready to accept SOF packets and perform control transfers on control endpoint 0.

## 30.13.4 DMA mode

The OTG host uses the AHB master interface to fetch the transmit packet data (AHB to USB) and receive the data update (USB to AHB). The AHB master uses the programmed DMA address (HCDMAx register in host mode and DIEPDMAx/DOEPDMAx register in peripheral mode) to access the data buffers.

## 30.13.5 Host programming model

## Channel initialization

The application must initialize one or more channels before it can communicate with connected devices. To initialize and enable a channel, the application must perform the following steps:



- 1. Program the GINTMSK register to unmask the following:
- 2. Channel interrupt
  - Nonperiodic transmit FIFO empty for OUT transactions (applicable for Slave mode that operates in pipelined transaction-level with the packet count field programmed with more than one).
  - Nonperiodic transmit FIFO half-empty for OUT transactions (applicable for Slave mode that operates in pipelined transaction-level with the packet count field programmed with more than one).
- 3. Program the OTG\_HS\_HAINTMSK register to unmask the selected channels' interrupts.
- 4. Program the OTG\_HS\_HCINTMSK register to unmask the transaction-related interrupts of interest given in the host channel interrupt register.
- 5. Program the selected channel's OTG\_HS\_HCTSIZx register with the total transfer size, in bytes, and the expected number of packets, including short packets. The application must program the PID field with the initial data PID (to be used on the first OUT transaction or to be expected from the first IN transaction).
- 6. Program the selected channels in the OTG\_HS\_HCSPLTx register(s) with the hub and port addresses (split transactions only).
- 7. Program the selected channels in the HCDMAx register(s) with the buffer start address.
- 8. Program the OTG\_HS\_HCCHARx register of the selected channel with the device's endpoint characteristics, such as type, speed, direction, and so forth. (The channel can be enabled by setting the channel enable bit to 1 only when the application is ready to transmit or receive any packet).

## Halting a channel

The application can disable any channel by programming the OTG\_HS\_HCCHARx register with the CHDIS and CHENA bits set to 1. This enables the OTG\_HS host to flush the posted requests (if any) and generates a channel halted interrupt. The application must wait for the CHH interrupt in OTG\_HS\_HCINTx before reallocating the channel for other transactions. The OTG\_HS host does not interrupt the transaction that has already been started on the USB.

To disable a channel in DMA mode operation, the application does not need to check for space in the request queue. The OTG\_HS host checks for space to write the disable request on the disabled channel's turn during arbitration. Meanwhile, all posted requests are dropped from the request queue when the CHDIS bit in HCCHARx is set to 1.

Before disabling a channel, the application must ensure that there is at least one free space available in the nonperiodic request queue (when disabling a nonperiodic channel) or the periodic request queue (when disabling a periodic channel). The application can simply flush the posted requests when the Request queue is full (before disabling the channel), by programming the OTG\_HS\_HCCHARx register with the CHDIS bit set to 1, and the CHENA bit cleared to 0.

The application is expected to disable a channel on any of the following conditions:

- 1. When an XFRC interrupt in OTG\_HS\_HCINTx is received during a nonperiodic IN transfer or high-bandwidth interrupt IN transfer (Slave mode only)
- 2. When an STALL, TXERR, BBERR or DTERR interrupt in OTG\_HS\_HCINTx is received for an IN or OUT channel (Slave mode only). For high-bandwidth interrupt INs in Slave mode, once the application has received a DTERR interrupt it must disable the channel



and wait for a channel halted interrupt. The application must be able to receive other interrupts (DTERR, NAK, Data, TXERR) for the same channel before receiving the halt.

- 3. When a DISCINT (Disconnect Device) interrupt in OTG\_HS\_GINTSTS is received. (The application is expected to disable all enabled channels
- 4. When the application aborts a transfer before normal completion.

## **Ping protocol**

When the OTG\_HS host operates in high speed, the application must initiate the ping protocol when communicating with high-speed bulk or control (data and status stage) OUT endpoints.

The application must initiate the ping protocol when it receives a NAK/NYET/TXERR interrupt. When the HS\_OTG host receives one of the above responses, it does not continue any transaction for a specific endpoint, drops all posted or fetched OUT requests (from the request queue), and flushes the corresponding data (from the transmit FIFO).

This is valid in slave mode only. In Slave mode, the application can send a ping token either by setting the DOPING bit in HCTSIZx before enabling the channel or by just writing the HCTSIZx register with the DOPING bit set when the channel is already enabled. This enables the HS\_OTG host to write a ping request entry to the request queue. The application must wait for the response to the ping token (a NAK, ACK, or TXERR interrupt) before continuing the transaction or sending another ping token. The application can continue the data transaction only after receiving an ACK from the OUT endpoint for the requested ping. In DMA mode operation, the application does not need to set the DOPING bit in HCTSIZx for a NAK/NYET response in case of Bulk/Control OUT. The OTG\_HS host automatically sets the DOPING bit in HCTSIZx, and issues the ping tokens for Bulk/Control OUT. The HS\_OTG host continues sending ping tokens until it receives an ACK, and then switches automatically to the data transaction.

## **Operational model**

The application must initialize a channel before communicating to the connected device. This section explains the sequence of operation to be performed for different types of USB transactions.

## • Writing the transmit FIFO

The OTG\_HS host automatically writes an entry (OUT request) to the periodic/nonperiodic request queue, along with the last DWORD write of a packet. The application must ensure that at least one free space is available in the periodic/nonperiodic request queue before starting to write to the transmit FIFO. The application must always write to the transmit FIFO in DWORDs. If the packet size is nonDWORD aligned, the application must use padding. The OTG\_HS host determines the actual packet size based on the programmed maximum packet size and transfer size.





Figure 370. Transmit FIFO write task



## • Reading the receive FIFO

The application must ignore all packet statuses other than IN data packet (bx0010).

### Figure 371. Receive FIFO read task



## • Bulk and control OUT/SETUP transactions

A typical bulk or control OUT/SETUP pipelined transaction-level operation is shown in *Figure 372*. See channel 1 (ch\_1). Two bulk OUT packets are transmitted. A control



SETUP transaction operates in the same way but has only one packet. The assumptions are:

- The application is attempting to send two maximum-packet-size packets (transfer size = 1, 024 bytes).
- The nonperiodic transmit FIFO can hold two packets (128 bytes for FS).
- The nonperiodic request queue depth = 4.

## • Normal bulk and control OUT/SETUP operations

The sequence of operations for channel 1 is as follows:

- a) Initialize channel 1
- b) Write the first packet for channel 1
- c) Along with the last DWORD write, the core writes an entry to the nonperiodic request queue
- d) As soon as the nonperiodic queue becomes nonempty, the core attempts to send an OUT token in the current frame
- e) Write the second (last) packet for channel 1
- f) The core generates the XFRC interrupt as soon as the last transaction is completed successfully
- g) In response to the XFRC interrupt, de-allocate the channel for other transfers
- h) Handling nonACK responses





Figure 372. Normal bulk/control OUT/SETUP and bulk/control IN transactions - DMA mode





# Figure 373. Normal bulk/control OUT/SETUP and bulk/control IN transactions - Slave mode

The channel-specific interrupt service routine for bulk and control OUT/SETUP transactions in Slave mode is shown in the following code samples.

• Interrupt service routine for bulk/control OUT/SETUP and bulk/control IN transactions

```
a) Bulk/Control OUT/SETUP
Unmask (NAK/TXERR/STALL/XFRC)
if (XFRC)
{
    Reset Error Count
```



```
Mask ACK
  De-allocate Channel
  }
else if (STALL)
  {
  Transfer Done = 1
  Unmask CHH
  Disable Channel
  }
else if (NAK or TXERR )
  {
  Rewind Buffer Pointers
  Unmask CHH
  Disable Channel
  if (TXERR)
     {
     Increment Error Count
     Unmask ACK
     }
  else
     ł
     Reset Error Count
     }
else if (CHH)
  {
  Mask CHH
  if (Transfer Done or (Error count == 3))
     {
     De-allocate Channel
     }
  else
     {
     Re-initialize Channel
     }
  }
  else if (ACK)
     {
     Reset Error Count
     Mask ACK
     }
   The application is expected to write the data packets into the transmit FIFO as and
    when the space is available in the transmit FIFO and the Request queue. The
   application can make use of the NPTXFE interrupt in OTG_HS_GINTSTS to find the
   transmit FIFO space.
   b) Bulk/Control IN
Unmask (TXERR/XFRC/BBERR/STALL/DTERR)
if (XFRC)
  {
  Reset Error Count
  Unmask CHH
  Disable Channel
```



```
Reset Error Count
  Mask ACK
  }
else if (TXERR or BBERR or STALL)
  {
  Unmask CHH
  Disable Channel
  if (TXERR)
     ł
    Increment Error Count
    Unmask ACK
     }
  }
else if (CHH)
  {
  Mask CHH
  if (Transfer Done or (Error count == 3))
     {
    De-allocate Channel
     }
  else
    Re-initialize Channel
     }
  }
else if (ACK)
  {
  Reset Error Count
  Mask ACK
  }
else if (DTERR)
  {
  Reset Error Count
  }
```

The application is expected to write the requests as and when the Request queue space is available and until the XFRC interrupt is received.

## • Bulk and control IN transactions

A typical bulk or control IN pipelined transaction-level operation is shown in *Figure 374*. See channel 2 (ch\_2). The assumptions are:

- The application is attempting to receive two maximum-packet-size packets (transfer size = 1 024 bytes).
- The receive FIFO can contain at least one maximum-packet-size packet and two status DWORDs per packet (72 bytes for FS).
- The nonperiodic request queue depth = 4.







Figure 374. Bulk/control IN transactions - DMA mode





Figure 375. Bulk/control IN transactions - Slave mode

The sequence of operations is as follows:

- a) Initialize channel 2.
- b) Set the CHENA bit in HCCHAR2 to write an IN request to the nonperiodic request queue.
- c) The core attempts to send an IN token after completing the current OUT transaction.
- d) The core generates an RXFLVL interrupt as soon as the received packet is written to the receive FIFO.
- e) In response to the RXFLVL interrupt, mask the RXFLVL interrupt and read the received packet status to determine the number of bytes received, then read the



receive FIFO accordingly. Following this, unmask the RXFLVL interrupt.

- f) The core generates the RXFLVL interrupt for the transfer completion status entry in the receive FIFO.
- g) The application must read and ignore the receive packet status when the receive packet status is not an IN data packet (PKTSTS in GRXSTSR  $\neq$  0b0010).
- h) The core generates the XFRC interrupt as soon as the receive packet status is read.
- In response to the XFRC interrupt, disable the channel and stop writing the OTG\_HS\_HCCHAR2 register for further requests. The core writes a channel disable request to the nonperiodic request queue as soon as the OTG\_HS\_HCCHAR2 register is written.
- j) The core generates the RXFLVL interrupt as soon as the halt status is written to the receive FIFO.
- k) Read and ignore the receive packet status.
- I) The core generates a CHH interrupt as soon as the halt status is popped from the receive FIFO.
- m) In response to the CHH interrupt, de-allocate the channel for other transfers.
- n) Handling nonACK responses

#### • Control transactions in slave mode

Setup, Data, and Status stages of a control transfer must be performed as three separate transfers. Setup-, Data- or Status-stage OUT transactions are performed similarly to the bulk OUT transactions explained previously. Data- or Status-stage IN transactions are performed similarly to the bulk IN transactions explained previously. For all three stages, the application is expected to set the EPTYP field in OTG\_HS\_HCCHAR1 to Control. During the Setup stage, the application is expected to set the PID field in OTG\_HS\_HCTSIZ1 to SETUP.

### • Interrupt OUT transactions

A typical interrupt OUT operation in Slave mode is shown in *Figure 376*. The assumptions are:

- The application is attempting to send one packet in every frame (up to 1 maximum packet size), starting with the odd frame (transfer size = 1 024 bytes)
- The periodic transmit FIFO can hold one packet (1 KB)
- Periodic request queue depth = 4

The sequence of operations is as follows:

- a) Initialize and enable channel 1. The application must set the ODDFRM bit in OTG\_HS\_HCCHAR1.
- b) Write the first packet for channel 1. For a high-bandwidth interrupt transfer, the application must write the subsequent packets up to MCNT (maximum number of packets to be transmitted in the next frame times) before switching to another channel.
- c) Along with the last DWORD write of each packet, the OTG\_HS host writes an entry to the periodic request queue.
- d) The OTG\_HS host attempts to send an OUT token in the next (odd) frame.
- e) The OTG\_HS host generates an XFRC interrupt as soon as the last packet is transmitted successfully.
- f) In response to the XFRC interrupt, reinitialize the channel for the next transfer.





Figure 376. Normal interrupt OUT/IN transactions - DMA mode







Figure 377. Normal interrupt OUT/IN transactions - Slave mode

} else

```
(STALL or FRMOR)
if
  {
```



```
Mask ACK
     Unmask CHH
     Disable Channel
     if (STALL)
        {
        Transfer Done = 1
        }
     }
  else
     if (NAK or TXERR)
        {
        Rewind Buffer Pointers
        Reset Error Count
        Mask ACK
        Unmask CHH
        Disable Channel
        }
     else
        if (CHH)
        {
        Mask CHH
        if (Transfer Done or (Error_count == 3))
          {
          De-allocate Channel
          }
        else
          {
          Re-initialize Channel (in next b interval - 1 Frame)
           }
        }
     else
        if (ACK)
        {
        Reset Error Count
        Mask ACK
        }
    The application is expected to write the data packets into the transmit FIFO when the
    space is available in the transmit FIFO and the Request queue up to the count
    specified in the MCNT field before switching to another channel. The application uses
    the NPTXFE interrupt in OTG_HS_GINTSTS to find the transmit FIFO space.
    b) Interrupt IN
Unmask (NAK/TXERR/XFRC/BBERR/STALL/FRMOR/DTERR)
if (XFRC)
  {
  Reset Error Count
  Mask ACK
  if (OTG HS HCTSIZx.PKTCNT == 0)
     {
     De-allocate Channel
     }
  else
     {
```



```
Transfer Done = 1
    Unmask CHH
    Disable Channel
     }
  }
else
  if (STALL or FRMOR or NAK or DTERR or BBERR)
     {
    Mask ACK
    Unmask CHH
    Disable Channel
     if (STALL or BBERR)
       {
       Reset Error Count
       Transfer Done = 1
       }
     else
       if (!FRMOR)
       {
       Reset Error Count
       }
     }
else
  if (TXERR)
    {
    Increment Error Count
    Unmask ACK
    Unmask CHH
    Disable Channel
     }
else
  if (CHH)
     {
    Mask CHH
     if (Transfer Done or (Error_count == 3))
       {
      De-allocate Channel
       }
     else
      Re-initialize Channel (in next b interval - 1 /Frame)
     }
  }
else
  if (ACK)
    {
    Reset Error Count
    Mask ACK
```



}

The application is expected to write the requests for the same channel when the Request queue space is available up to the count specified in the MCNT field before switching to another channel (if any).

## • Interrupt IN transactions

The assumptions are:

- The application is attempting to receive one packet (up to 1 maximum packet size) in every frame, starting with odd (transfer size = 1 024 bytes).
- The receive FIFO can hold at least one maximum-packet-size packet and two status DWORDs per packet (1 031 bytes).
- Periodic request queue depth = 4.

# • Normal interrupt IN operation

The sequence of operations is as follows:

- a) Initialize channel 2. The application must set the ODDFRM bit in OTG\_HS\_HCCHAR2.
- b) Set the CHENA bit in OTG\_HS\_HCCHAR2 to write an IN request to the periodic request queue. For a high-bandwidth interrupt transfer, the application must write the OTG\_HS\_HCCHAR2 register MCNT (maximum number of expected packets in the next frame times) before switching to another channel.
- c) The OTG\_HS host writes an IN request to the periodic request queue for each OTG\_HS\_HCCHAR2 register write with the CHENA bit set.
- d) The OTG\_HS host attempts to send an IN token in the next (odd) frame.
- e) As soon as the IN packet is received and written to the receive FIFO, the OTG\_HS host generates an RXFLVL interrupt.
- f) In response to the RXFLVL interrupt, read the received packet status to determine the number of bytes received, then read the receive FIFO accordingly. The application must mask the RXFLVL interrupt before reading the receive FIFO, and unmask after reading the entire packet.
- g) The core generates the RXFLVL interrupt for the transfer completion status entry in the receive FIFO. The application must read and ignore the receive packet status when the receive packet status is not an IN data packet (PKTSTS in GRXSTSR ≠ 0b0010).
- h) The core generates an XFRC interrupt as soon as the receive packet status is read.
- i) In response to the XFRC interrupt, read the PKTCNT field in OTG\_HS\_HCTSIZ2. If the PKTCNT bit in OTG\_HS\_HCTSIZ2 is not equal to 0, disable the channel before re-initializing the channel for the next transfer, if any). If PKTCNT bit in



OTG\_HS\_HCTSIZ2 = 0, reinitialize the channel for the next transfer. This time, the application must reset the ODDFRM bit in OTG\_HS\_HCCHAR2.

### Isochronous OUT transactions

A typical isochronous OUT operation in Slave mode is shown in *Figure 378*. The assumptions are:

- The application is attempting to send one packet every frame (up to 1 maximum packet size), starting with an odd frame. (transfer size = 1 024 bytes).
- The periodic transmit FIFO can hold one packet (1 KB).
- Periodic request queue depth = 4.

The sequence of operations is as follows:

- a) Initialize and enable channel 1. The application must set the ODDFRM bit in OTG\_HS\_HCCHAR1.
- b) Write the first packet for channel 1. For a high-bandwidth isochronous transfer, the application must write the subsequent packets up to MCNT (maximum number of packets to be transmitted in the next frame times before switching to another channel.
- c) Along with the last DWORD write of each packet, the OTG\_HS host writes an entry to the periodic request queue.
- d) The OTG\_HS host attempts to send the OUT token in the next frame (odd).
- e) The OTG\_HS host generates the XFRC interrupt as soon as the last packet is transmitted successfully.
- f) In response to the XFRC interrupt, reinitialize the channel for the next transfer.
- g) Handling nonACK responses





Figure 378. Normal isochronous OUT/IN transactions - DMA mode





Figure 379. Normal isochronous OUT/IN transactions - Slave mode

# Interrupt service routine for isochronous OUT/IN transactions

Code sample: Isochronous OUT

```
Unmask (FRMOR/XFRC)
if (XFRC)
  {
   De-allocate Channel
   }
else
   if (FRMOR)
   {
    Unmask CHH
   Disable Channel
   }
```



```
else
  if (CHH)
    {
    Mask CHH
    De-allocate Channel
    }
   Code sample: Isochronous IN
Unmask (TXERR/XFRC/FRMOR/BBERR)
if (XFRC or FRMOR)
  {
  if (XFRC and (OTG_HS_HCTSIZx.PKTCNT == 0))
   {
    Reset Error Count
    De-allocate Channel
    }
  else
    {
    Unmask CHH
    Disable Channel
    }
  }
  else
    if (TXERR or BBERR)
       {
       Increment Error Count
       Unmask CHH
       Disable Channel
       }
    else
       if (CHH)
         {
         Mask CHH
         if (Transfer Done or (Error_count == 3))
            {
            De-allocate Channel
            }
         else
            {
            Re-initialize Channel
            }
          }
```



### • Isochronous IN transactions

The assumptions are:

- The application is attempting to receive one packet (up to 1 maximum packet size) in every frame starting with the next odd frame (transfer size = 1 024 bytes).
- The receive FIFO can hold at least one maximum-packet-size packet and two status DWORDs per packet (1 031 bytes).
- Periodic request queue depth = 4.

The sequence of operations is as follows:

- a) Initialize channel 2. The application must set the ODDFRM bit in OTG\_HS\_HCCHAR2.
- b) Set the CHENA bit in OTG\_HS\_HCCHAR2 to write an IN request to the periodic request queue. For a high-bandwidth isochronous transfer, the application must write the OTG\_HS\_HCCHAR2 register MCNT (maximum number of expected packets in the next frame times) before switching to another channel.
- c) The OTG\_HS host writes an IN request to the periodic request queue for each OTG\_HS\_HCCHAR2 register write with the CHENA bit set.
- d) The OTG\_HS host attempts to send an IN token in the next odd frame.
- e) As soon as the IN packet is received and written to the receive FIFO, the OTG\_HS host generates an RXFLVL interrupt.
- f) In response to the RXFLVL interrupt, read the received packet status to determine the number of bytes received, then read the receive FIFO accordingly. The application must mask the RXFLVL interrupt before reading the receive FIFO, and unmask it after reading the entire packet.
- g) The core generates an RXFLVL interrupt for the transfer completion status entry in the receive FIFO. This time, the application must read and ignore the receive packet status when the receive packet status is not an IN data packet (PKTSTS bit in OTG\_HS\_GRXSTSR ≠ 0b0010).
- h) The core generates an XFRC interrupt as soon as the receive packet status is read.
- i) In response to the XFRC interrupt, read the PKTCNT field in OTG\_HS\_HCTSIZ2. If PKTCNT≠ 0 in OTG\_HS\_HCTSIZ2, disable the channel before re-initializing the channel for the next transfer, if any. If PKTCNT = 0 in OTG\_HS\_HCTSIZ2, reinitialize the channel for the next transfer. This time, the application must reset the ODDFRM bit in OTG\_HS\_HCCHAR2.

### • Selecting the queue depth

Choose the periodic and nonperiodic request queue depths carefully to match the number of periodic/nonperiodic endpoints accessed.

The nonperiodic request queue depth affects the performance of nonperiodic transfers. The deeper the queue (along with sufficient FIFO size), the more often the core is able to pipeline nonperiodic transfers. If the queue size is small, the core is able to put in new requests only when the queue space is freed up.

The core's periodic request queue depth is critical to perform periodic transfers as scheduled. Select the periodic queue depth, based on the number of periodic transfers scheduled in a micro-frame. In Slave mode, however, the application must also take into account the disable entry that must be put into the queue. So, if there are two nonhigh-bandwidth periodic endpoints, the periodic request queue depth must be at least 4. If at least one high-bandwidth endpoint is supported, the queue depth must be



8. If the periodic request queue depth is smaller than the periodic transfers scheduled in a micro-frame, a frame overrun condition occurs.

### Handling babble conditions

OTG\_HS controller handles two cases of babble: packet babble and port babble. Packet babble occurs if the device sends more data than the maximum packet size for the channel. Port babble occurs if the core continues to receive data from the device at EOF2 (the end of frame 2, which is very close to SOF).

When OTG\_HS controller detects a packet babble, it stops writing data into the Rx buffer and waits for the end of packet (EOP). When it detects an EOP, it flushes already written data in the Rx buffer and generates a Babble interrupt to the application.

When OTG\_HS controller detects a port babble, it flushes the RxFIFO and disables the port. The core then generates a Port disabled interrupt (HPRTINT in OTG\_HS\_GINTSTS, PENCHNG in OTG\_HS\_HPRT). On receiving this interrupt, the application must determine that this is not due to an overcurrent condition (another cause of the Port Disabled interrupt) by checking POCA in OTG\_HS\_HPRT, then perform a soft reset. The core does not send any more tokens after it has detected a port babble condition.

### Bulk and control OUT/SETUP transactions in DMA mode

The sequence of operations is as follows:

- a) Initialize and enable channel 1 as explained in *Section : Channel initialization*.
- b) The HS\_OTG host starts fetching the first packet as soon as the channel is enabled. For internal DMA mode, the OTG\_HS host uses the programmed DMA address to fetch the packet.
- c) After fetching the last DWORD of the second (last) packet, the OTG\_HS host masks channel 1 internally for further arbitration.
- d) The HS\_OTG host generates a CHH interrupt as soon as the last packet is sent.
- e) In response to the CHH interrupt, de-allocate the channel for other transfers.

### NAK and NYET handling with internal DMA

- a) The OTG\_HS host sends a bulk OUT transaction.
- b) The device responds with NAK or NYET.
- c) If the application has unmasked NAK or NYET, the core generates the corresponding interrupt(s) to the application. The application is not required to



service these interrupts, since the core takes care of rewinding the buffer pointers and re-initializing the Channel without application intervention.

- d) The core automatically issues a ping token.
- e) When the device returns an ACK, the core continues with the transfer. Optionally, the application can utilize these interrupts, in which case the NAK or NYET interrupt is masked by the application.

The core does not generate a separate interrupt when NAK or NYET is received by the host functionality.

### • Bulk and control IN transactions in DMA mode

The sequence of operations is as follows:

- a) Initialize and enable the used channel (channel x) as explained in *Section : Channel initialization*.
- b) The OTG\_HS host writes an IN request to the request queue as soon as the channel receives the grant from the arbiter (arbitration is performed in a round-robin fashion).
- c) The OTG\_HS host starts writing the received data to the system memory as soon as the last byte is received with no errors.
- d) When the last packet is received, the OTG\_HS host sets an internal flag to remove any extra IN requests from the request queue.
- e) The OTG\_HS host flushes the extra requests.
- f) The final request to disable channel x is written to the request queue. At this point, channel 2 is internally masked for further arbitration.
- g) The OTG\_HS host generates the CHH interrupt as soon as the disable request comes to the top of the queue.
- h) In response to the CHH interrupt, de-allocate the channel for other transfers.

### Interrupt OUT transactions in DMA mode

- a) Initialize and enable channel x as explained in *Section : Channel initialization*.
- b) The OTG\_HS host starts fetching the first packet as soon the channel is enabled and writes the OUT request along with the last DWORD fetch. In high-bandwidth



transfers, the HS\_OTG host continues fetching the next packet (up to the value specified in the MC field) before switching to the next channel.

- c) The OTG\_HS host attempts to send the OUT token at the beginning of the next odd frame/micro-frame.
- d) After successfully transmitting the packet, the OTG\_HS host generates a CHH interrupt.
- e) In response to the CHH interrupt, reinitialize the channel for the next transfer.
- Interrupt IN transactions in DMA mode
  - The sequence of operations (channelx) is as follows:
  - a) Initialize and enable channel x as explained in *Section : Channel initialization*.
  - b) The OTG\_HS host writes an IN request to the request queue as soon as the channel x gets the grant from the arbiter (round-robin with fairness). In high-bandwidth transfers, the OTG\_HS host writes consecutive writes up to MC times.
  - c) The OTG\_HS host attempts to send an IN token at the beginning of the next (odd) frame/micro-frame.
  - d) As soon the packet is received and written to the receive FIFO, the OTG\_HS host generates a CHH interrupt.
  - e) In response to the CHH interrupt, reinitialize the channel for the next transfer.

### Isochronous OUT transactions in DMA mode

- a) Initialize and enable channel x as explained in *Section : Channel initialization*.
- b) The OTG\_HS host starts fetching the first packet as soon as the channel is enabled, and writes the OUT request along with the last DWORD fetch. In highbandwidth transfers, the OTG\_HS host continues fetching the next packet (up to the value specified in the MC field) before switching to the next channel.
- c) The OTG\_HS host attempts to send an OUT token at the beginning of the next (odd) frame/micro-frame.
- d) After successfully transmitting the packet, the HS\_OTG host generates a CHH interrupt.
- e) In response to the CHH interrupt, reinitialize the channel for the next transfer.

### • Isochronous IN transactions in DMA mode

The sequence of operations ((channel x) is as follows:

- a) Initialize and enable channel x as explained in *Section : Channel initialization*.
- b) The OTG\_HS host writes an IN request to the request queue as soon as the channel x gets the grant from the arbiter (round-robin with fairness). In high-



bandwidth transfers, the OTG\_HS host performs consecutive write operations up to MC times.

- c) The OTG\_HS host attempts to send an IN token at the beginning of the next (odd) frame/micro-frame.
- d) As soon the packet is received and written to the receive FIFO, the OTG\_HS host generates a CHH interrupt.
- e) In response to the CHH interrupt, reinitialize the channel for the next transfer.
- Bulk and control OUT/SETUP split transactions in DMA mode
  - The sequence of operations in (channel x) is as follows:
  - a) Initialize and enable channel x for start split as explained in *Section : Channel initialization*.
  - b) The OTG\_HS host starts fetching the first packet as soon the channel is enabled and writes the OUT request along with the last DWORD fetch.
  - c) After successfully transmitting start split, the OTG\_HS host generates the CHH interrupt.
  - d) In response to the CHH interrupt, set the COMPLSPLT bit in HCSPLT1 to send the complete split.
  - e) After successfully transmitting complete split, the OTG\_HS host generates the CHH interrupt.
  - f) In response to the CHH interrupt, de-allocate the channel.

### Bulk/Control IN split transactions in DMA mode

The sequence of operations (channel x) is as follows:

- a) Initialize and enable channel x as explained in *Section : Channel initialization*.
- b) The OTG\_HS host writes the start split request to the nonperiodic request after getting the grant from the arbiter. The OTG\_HS host masks the channel x internally for the arbitration after writing the request.
- c) As soon as the IN token is transmitted, the OTG\_HS host generates the CHH interrupt.
- d) In response to the CHH interrupt, set the COMPLSPLT bit in HCSPLT2 and reenable the channel to send the complete split token. This unmasks channel x for arbitration.
- e) The OTG\_HS host writes the complete split request to the nonperiodic request after receiving the grant from the arbiter.
- f) The OTG\_HS host starts writing the packet to the system memory after receiving the packet successfully.
- g) As soon as the received packet is written to the system memory, the OTG\_HS host generates a CHH interrupt.
- h) In response to the CHH interrupt, de-allocate the channel.

### • Interrupt OUT split transactions in DMA mode

The sequence of operations in (channel x) is as follows:

- a) Initialize and enable channel 1 for start split as explained in *Section : Channel initialization*. The application must set the ODDFRM bit in HCCHAR1.
- b) The HS\_OTG host starts reading the packet.
- c) The HS\_OTG host attempts to send the start split transaction.
- d) After successfully transmitting the start split, the OTG\_HS host generates the



CHH interrupt.

- e) In response to the CHH interrupt, set the COMPLSPLT bit in HCSPLT1 to send the complete split.
- f) After successfully completing the complete split transaction, the OTG\_HS host generates the CHH interrupt.
- g) In response to CHH interrupt, de-allocate the channel.

### • Interrupt IN split transactions in DMA mode

The sequence of operations in (channel x) is as follows:

- a) Initialize and enable channel x for start split as explained in *Section : Channel initialization*.
- b) The OTG\_HS host writes an IN request to the request queue as soon as channel x receives the grant from the arbiter.
- c) The OTG\_HS host attempts to send the start split IN token at the beginning of the next odd micro-frame.
- d) The OTG\_HS host generates the CHH interrupt after successfully transmitting the start split IN token.
- e) In response to the CHH interrupt, set the COMPLSPLT bit in HCSPLT2 to send the complete split.
- f) As soon as the packet is received successfully, the OTG\_HS host starts writing the data to the system memory.
- g) The OTG\_HS host generates the CHH interrupt after transferring the received data to the system memory.
- h) In response to the CHH interrupt, de-allocate or reinitialize the channel for the next start split.

### • Isochronous OUT split transactions in DMA mode

The sequence of operations (channel x) is as follows:

- a) Initialize and enable channel x for start split (begin) as explained in *Section : Channel initialization.* The application must set the ODDFRM bit in HCCHAR1. Program the MPS field.
- b) The HS\_OTG host starts reading the packet.
- c) After successfully transmitting the start split (begin), the HS\_OTG host generates the CHH interrupt.
- d) In response to the CHH interrupt, reinitialize the registers to send the start split (end).
- e) After successfully transmitting the start split (end), the OTG\_HS host generates a CHH interrupt.
- f) In response to the CHH interrupt, de-allocate the channel.

### • Isochronous IN split transactions in DMA mode

The sequence of operations (channel x) is as follows:

- a) Initialize and enable channel x for start split as explained in *Section : Channel initialization*.
- b) The OTG\_HS host writes an IN request to the request queue as soon as channel x receives the grant from the arbiter.
- c) The OTG\_HS host attempts to send the start split IN token at the beginning of the next odd micro-frame.



- d) The OTG\_HS host generates the CHH interrupt after successfully transmitting the start split IN token.
- e) In response to the CHH interrupt, set the COMPLSPLT bit in HCSPLT2 to send the complete split.
- f) As soon as the packet is received successfully, the OTG\_HS host starts writing the data to the system memory.
- g) The OTG\_HS host generates the CHH interrupt after transferring the received data to the system memory. In response to the CHH interrupt, de-allocate the channel or reinitialize the channel for the next start split.

# 30.13.6 Device programming model

# Endpoint initialization on USB reset

- 1. Set the NAK bit for all OUT endpoints
  - SNAK = 1 in OTG\_HS\_DOEPCTLx (for all OUT endpoints)
- 2. Unmask the following interrupt bits
  - INEP0 = 1 in OTG\_HS\_DAINTMSK (control 0 IN endpoint)
  - OUTEP0 = 1 in OTG\_HS\_DAINTMSK (control 0 OUT endpoint)
  - STUP = 1 in DOEPMSK
  - XFRC = 1 in DOEPMSK
  - XFRC = 1 in DIEPMSK
  - TOC = 1 in DIEPMSK
- 3. Set up the Data FIFO RAM for each of the FIFOs
  - Program the OTG\_HS\_GRXFSIZ register, to be able to receive control OUT data and setup data. If thresholding is not enabled, at a minimum, this must be equal to 1 max packet size of control endpoint 0 + 2 DWORDs (for the status of the control OUT data packet) + 10 DWORDs (for setup packets).
  - Program the OTG\_HS\_TX0FSIZ register (depending on the FIFO number chosen) to be able to transmit control IN data. At a minimum, this must be equal to 1 max packet size of control endpoint 0.
- 4. Program the following fields in the endpoint-specific registers for control OUT endpoint 0 to receive a SETUP packet
  - STUPCNT = 3 in OTG\_HS\_DOEPTSIZ0 (to receive up to 3 back-to-back SETUP packets)
- 5. In DMA mode, the DOEPDMA0 register should have a valid memory address to store any SETUP packets received.

At this point, all initialization required to receive SETUP packets is done.



## Endpoint initialization on enumeration completion

- 1. On the Enumeration Done interrupt (ENUMDNE in OTG\_HS\_GINTSTS), read the OTG\_HS\_DSTS register to determine the enumeration speed.
- 2. Program the MPSIZ field in OTG\_HS\_DIEPCTL0 to set the maximum packet size. This step configures control endpoint 0. The maximum packet size for a control endpoint depends on the enumeration speed.
- 3. In DMA mode, program the DOEPCTL0 register to enable control OUT endpoint 0, to receive a SETUP packet.
  - EPENA bit in DOEPCTL0 = 1

At this point, the device is ready to receive SOF packets and is configured to perform control transfers on control endpoint 0.

# Endpoint initialization on SetAddress command

This section describes what the application must do when it receives a SetAddress command in a SETUP packet.

- 1. Program the OTG\_HS\_DCFG register with the device address received in the SetAddress command
- 1. Program the core to send out a status IN packet

# Endpoint initialization on SetConfiguration/SetInterface command

This section describes what the application must do when it receives a SetConfiguration or SetInterface command in a SETUP packet.

- 1. When a SetConfiguration command is received, the application must program the endpoint registers to configure them with the characteristics of the valid endpoints in the new configuration.
- 2. When a SetInterface command is received, the application must program the endpoint registers of the endpoints affected by this command.
- 3. Some endpoints that were active in the prior configuration or alternate setting are not valid in the new configuration or alternate setting. These invalid endpoints must be deactivated.
- 4. Unmask the interrupt for each active endpoint and mask the interrupts for all inactive endpoints in the OTG\_HS\_DAINTMSK register.
- 5. Set up the Data FIFO RAM for each FIFO.
- 6. After all required endpoints are configured; the application must program the core to send a status IN packet.

At this point, the device core is configured to receive and transmit any type of data packet.

### **Endpoint activation**

This section describes the steps required to activate a device endpoint or to configure an existing device endpoint to a new type.



- 1. Program the characteristics of the required endpoint into the following fields of the OTG\_HS\_DIEPCTLx register (for IN or bidirectional endpoints) or the OTG HS DOEPCTLx register (for OUT or bidirectional endpoints).
  - Maximum packet size
  - USB active endpoint = 1
  - Endpoint start data toggle (for interrupt and bulk endpoints)
  - Endpoint type
  - TxFIFO number
- 2. Once the endpoint is activated, the core starts decoding the tokens addressed to that endpoint and sends out a valid handshake for each valid token received for the endpoint.

### **Endpoint deactivation**

This section describes the steps required to deactivate an existing endpoint.

- 1. In the endpoint to be deactivated, clear the USB active endpoint bit in the OTG\_HS\_DIEPCTLx register (for IN or bidirectional endpoints) or the OTG\_HS\_DOEPCTLx register (for OUT or bidirectional endpoints).
- 2. Once the endpoint is deactivated, the core ignores tokens addressed to that endpoint, which results in a timeout on the USB.
- Note: 1 The application must meet the following conditions to set up the device core to handle traffic: NPTXFEM and RXFLVLM in GINTMSK must be cleared.

# 30.13.7 Operational model

## **SETUP and OUT data transfers**

This section describes the internal data flow and application-level operations during data OUT transfers and SETUP transactions.

#### Packet read

This section describes how to read packets (OUT data and SETUP packets) from the receive FIFO in Slave mode.

- 1. On catching an RXFLVL interrupt (OTG\_HS\_GINTSTS register), the application must read the Receive status pop register (OTG\_HS\_GRXSTSP).
- 2. The application can mask the RXFLVL interrupt (in OTG\_HS\_GINTSTS) by writing to RXFLVL = 0 (in GINTMSK), until it has read the packet from the receive FIFO.
- 3. If the received packet's byte count is not 0, the byte count amount of data is popped from the receive Data FIFO and stored in memory. If the received packet byte count is 0, no data is popped from the receive data FIFO.
- 4. The receive FIFO's packet status readout indicates one of the following:
  - a) Global OUT NAK pattern:
     PKTSTS = Global OUT NAK, BCNT = 0x000, EPNUM = Don't Care (0x0),
     DPID = Don't Care (0b00).
     These data indicate that the global OUT NAK bit has taken effect.
  - b) SETUP packet pattern: PKTSTS = SETUP, BCNT = 0x008, EPNUM = Control EP Num, DPID = D0.



These data indicate that a SETUP packet for the specified endpoint is now available for reading from the receive FIFO.

- c) Setup stage done pattern:
  - PKTSTS = Setup Stage Done, BCNT = 0x0, EPNUM = Control EP Num,
     DPID = Don't Care (0b00).
     These data indicate that the Setup stage for the specified endpoint has completed and the Data stage has started. After this entry is popped from the receive FIFO, the core asserts a Setup interrupt on the specified control OUT endpoint.
- d) Data OUT packet pattern: PKTSTS = DataOUT, BCNT = size of the received data OUT packet (0 ≤ BCNT ≤ 1 024), EPNUM = EPNUM on which the packet was received, DPID = Actual Data PID.
- e) Data transfer completed pattern: PKTSTS = Data OUT Transfer Done, BCNT = 0x0, EPNUM = OUT EP Num on which the data transfer is complete, DPID = Don't Care (0b00). These data indicate that an OUT data transfer for the specified OUT endpoint has completed. After this entry is popped from the receive FIFO, the core asserts a Transfer Completed interrupt on the specified OUT endpoint.
- 5. After the data payload is popped from the receive FIFO, the RXFLVL interrupt (OTG\_HS\_GINTSTS) must be unmasked.
- 6. Steps 1–5 are repeated every time the application detects assertion of the interrupt line due to RXFLVL in OTG\_HS\_GINTSTS. Reading an empty receive FIFO can result in undefined core behavior.

Figure 380 provides a flowchart of the above procedure.



### Figure 380. Receive FIFO packet read in slave mode

### • SETUP transactions

This section describes how the core handles SETUP packets and the application's sequence for handling SETUP transactions.

• Application requirements





- 1. To receive a SETUP packet, the STUPCNT field (OTG\_HS\_DOEPTSIZx) in a control OUT endpoint must be programmed to a nonzero value. When the application programs the STUPCNT field to a nonzero value, the core receives SETUP packets and writes them to the receive FIFO, irrespective of the NAK status and EPENA bit setting in OTG\_HS\_DOEPCTLx. The STUPCNT field is decremented every time the control endpoint receives a SETUP packet. If the STUPCNT field is not programmed to a proper value before receiving a SETUP packet, the core still receives the SETUP packet and decrements the STUPCNT field, but the application may not be able to determine the correct number of SETUP packets received in the Setup stage of a control transfer.
  - STUPCNT = 3 in OTG\_HS\_DOEPTSIZx
- 2. The application must always allocate some extra space in the Receive data FIFO, to be able to receive up to three SETUP packets on a control endpoint.
  - The space to be reserved is 10 DWORDs. Three DWORDs are required for the first SETUP packet, 1 DWORD is required for the Setup stage done DWORD and 6 DWORDs are required to store two extra SETUP packets among all control endpoints.
  - 3 DWORDs per SETUP packet are required to store 8 bytes of SETUP data and 4 bytes of SETUP status (Setup packet pattern). The core reserves this space in the receive data.
  - FIFO to write SETUP data only, and never uses this space for data packets.
- 3. The application must read the 2 DWORDs of the SETUP packet from the receive FIFO.
- 4. The application must read and discard the Setup stage done DWORD from the receive FIFO.
- Internal data flow
- 5. When a SETUP packet is received, the core writes the received data to the receive FIFO, without checking for available space in the receive FIFO and irrespective of the endpoint's NAK and STALL bit settings.
  - The core internally sets the IN NAK and OUT NAK bits for the control IN/OUT endpoints on which the SETUP packet was received.
- 6. For every SETUP packet received on the USB, 3 DWORDs of data are written to the receive FIFO, and the STUPCNT field is decremented by 1.
  - The first DWORD contains control information used internally by the core
  - The second DWORD contains the first 4 bytes of the SETUP command
  - The third DWORD contains the last 4 bytes of the SETUP command
- When the Setup stage changes to a Data IN/OUT stage, the core writes an entry (Setup stage done DWORD) to the receive FIFO, indicating the completion of the Setup stage.
- 8. On the AHB side, SETUP packets are emptied by the application.
- 9. When the application pops the Setup stage done DWORD from the receive FIFO, the core interrupts the application with an STUP interrupt (OTG\_HS\_DOEPINTx), indicating it can process the received SETUP packet.
  - The core clears the endpoint enable bit for control OUT endpoints.
- Application programming sequence



1. Program the OTG\_HS\_DOEPTSIZx register.

```
– STUPCNT = 3
```

- 2. Wait for the RXFLVL interrupt (OTG\_HS\_GINTSTS) and empty the data packets from the receive FIFO.
- 3. Assertion of the STUP interrupt (OTG\_HS\_DOEPINTx) marks a successful completion of the SETUP Data Transfer.
  - On this interrupt, the application must read the OTG\_HS\_DOEPTSIZx register to determine the number of SETUP packets received and process the last received SETUP packet.

# Figure 381. Processing a SETUP packet



### • Handling more than three back-to-back SETUP packets

Per the USB 2.0 specification, normally, during a SETUP packet error, a host does not send more than three back-to-back SETUP packets to the same endpoint. However, the USB 2.0 specification does not limit the number of back-to-back SETUP packets a host can send to the same endpoint. When this condition occurs, the OTG\_HS controller generates an interrupt (B2BSTUP in OTG\_HS\_DOEPINTx).

# • Setting the global OUT NAK

- 1. When the application sets the Global OUT NAK (SGONAK bit in OTG\_HS\_DCTL), the core stops writing data, except SETUP packets, to the receive FIFO. Irrespective of the space availability in the receive FIFO, nonisochronous OUT tokens receive a NAK handshake response, and the core ignores isochronous OUT data packets
- 2. The core writes the Global OUT NAK pattern to the receive FIFO. The application must reserve enough receive FIFO space to write this data pattern.



- 3. When the application pops the Global OUT NAK pattern DWORD from the receive FIFO, the core sets the GONAKEFF interrupt (OTG\_HS\_GINTSTS).
- 4. Once the application detects this interrupt, it can assume that the core is in Global OUT NAK mode. The application can clear this interrupt by clearing the SGONAK bit in OTG\_HS\_DCTL.

Application programming sequence

- 1. To stop receiving any kind of data in the receive FIFO, the application must set the Global OUT NAK bit by programming the following field:
  - SGONAK = 1 in OTG\_HS\_DCTL
- 2. Wait for the assertion of the GONAKEFF interrupt in OTG\_HS\_GINTSTS. When asserted, this interrupt indicates that the core has stopped receiving any type of data except SETUP packets.
- 3. The application can receive valid OUT packets after it has set SGONAK in OTG\_HS\_DCTL and before the core asserts the GONAKEFF interrupt (OTG\_HS\_GINTSTS).
- 4. The application can temporarily mask this interrupt by writing to the GINAKEFFM bit in GINTMSK.
  - GINAKEFFM = 0 in GINTMSK
- Whenever the application is ready to exit the Global OUT NAK mode, it must clear the SGONAK bit in OTG\_HS\_DCTL. This also clears the GONAKEFF interrupt (OTG\_HS\_GINTSTS).
  - OTG\_HS\_DCTL = 1 in CGONAK
- 6. If the application has masked this interrupt earlier, it must be unmasked as follows:
  - GINAKEFFM = 1 in GINTMSK
- Disabling an OUT endpoint

The application must use this sequence to disable an OUT endpoint that it has enabled.

Application programming sequence:

- 1. Before disabling any OUT endpoint, the application must enable Global OUT NAK mode in the core.
  - SGONAK = 1 in OTG\_HS\_DCTL
- 2. Wait for the GONAKEFF interrupt (OTG\_HS\_GINTSTS)
- 3. Disable the required OUT endpoint by programming the following fields:
  - EPDIS = 1 in OTG\_HS\_DOEPCTLx
  - SNAK = 1 in OTG\_HS\_DOEPCTLx
- 4. Wait for the EPDISD interrupt (OTG\_HS\_DOEPINTx), which indicates that the OUT endpoint is completely disabled. When the EPDISD interrupt is asserted, the core also clears the following bits:
  - EPDIS = 0 in OTG\_HS\_DOEPCTLx
  - EPENA = 0 in OTG\_HS\_DOEPCTLx
- 5. The application must clear the Global OUT NAK bit to start receiving data from other nondisabled OUT endpoints.
  - SGONAK = 0 in OTG\_HS\_DCTL
- Generic nonisochronous OUT data transfers



This section describes a regular nonisochronous OUT data transfer (control, bulk, or interrupt).

Application requirements:

- 1. Before setting up an OUT transfer, the application must allocate a buffer in the memory to accommodate all data to be received as part of the OUT transfer.
- 2. For OUT transfers, the transfer size field in the endpoint's transfer size register must be a multiple of the maximum packet size of the endpoint, adjusted to the DWORD boundary.
  - transfer size[EPNUM] =  $n \times (MPSIZ[EPNUM] + 4 (MPSIZ[EPNUM] \mod 4))$
  - packet count[EPNUM] = n
  - *n* > 0
- 3. On any OUT endpoint interrupt, the application must read the endpoint's transfer size register to calculate the size of the payload in the memory. The received payload size can be less than the programmed transfer size.
  - Payload size in memory = application programmed initial transfer size core updated final transfer size
  - Number of USB packets in which this payload was received = application programmed initial packet count – core updated final packet count

- 1. The application must set the transfer size and packet count fields in the endpointspecific registers, clear the NAK bit, and enable the endpoint to receive the data.
- 2. Once the NAK bit is cleared, the core starts receiving data and writes it to the receive FIFO, as long as there is space in the receive FIFO. For every data packet received on the USB, the data packet and its status are written to the receive FIFO. Every packet (maximum packet size or short packet) written to the receive FIFO decrements the packet count field for that endpoint by 1.
  - OUT data packets received with bad data CRC are flushed from the receive FIFO automatically.
  - After sending an ACK for the packet on the USB, the core discards nonisochronous OUT data packets that the host, which cannot detect the ACK, resends. The application does not detect multiple back-to-back data OUT packets on the same endpoint with the same data PID. In this case the packet count is not decremented.
  - If there is no space in the receive FIFO, isochronous or nonisochronous data packets are ignored and not written to the receive FIFO. Additionally, nonisochronous OUT tokens receive a NAK handshake reply.
  - In all the above three cases, the packet count is not decremented because no data are written to the receive FIFO.
- 3. When the packet count becomes 0 or when a short packet is received on the endpoint, the NAK bit for that endpoint is set. Once the NAK bit is set, the isochronous or nonisochronous data packets are ignored and not written to the receive FIFO, and nonisochronous OUT tokens receive a NAK handshake reply.
- 4. After the data are written to the receive FIFO, the application reads the data from the receive FIFO and writes it to external memory, one packet at a time per endpoint.
- 5. At the end of every packet write on the AHB to external memory, the transfer size for the endpoint is decremented by the size of the written packet.



- 6. The OUT data transfer completed pattern for an OUT endpoint is written to the receive FIFO on one of the following conditions:
  - The transfer size is 0 and the packet count is 0
  - The last OUT data packet written to the receive FIFO is a short packet (0 ≤ packet size < maximum packet size)</li>
- 7. When either the application pops this entry (OUT data transfer completed), a transfer completed interrupt is generated for the endpoint and the endpoint enable is cleared.

Application programming sequence:

- 1. Program the OTG\_HS\_DOEPTSIZx register for the transfer size and the corresponding packet count.
- 2. Program the OTG\_HS\_DOEPCTLx register with the endpoint characteristics, and set the EPENA and CNAK bits.
  - EPENA = 1 in OTG\_HS\_DOEPCTLx
  - CNAK = 1 in OTG\_HS\_DOEPCTLx
- 3. Wait for the RXFLVL interrupt (in OTG\_HS\_GINTSTS) and empty the data packets from the receive FIFO.
  - This step can be repeated many times, depending on the transfer size.
- 4. Asserting the XFRC interrupt (OTG\_HS\_DOEPINTx) marks a successful completion of the nonisochronous OUT data transfer.
- 5. Read the OTG\_HS\_DOEPTSIZx register to determine the size of the received data payload.
- Generic isochronous OUT data transfer

This section describes a regular isochronous OUT data transfer.

Application requirements:

- 1. All the application requirements for nonisochronous OUT data transfers also apply to isochronous OUT data transfers.
- 2. For isochronous OUT data transfers, the transfer size and packet count fields must always be set to the number of maximum-packet-size packets that can be received in a single frame and no more. Isochronous OUT data transfers cannot span more than 1 frame.
- The application must read all isochronous OUT data packets from the receive FIFO (data and status) before the end of the periodic frame (EOPF interrupt in OTG\_HS\_GINTSTS).
- 4. To receive data in the following frame, an isochronous OUT endpoint must be enabled after the EOPF (OTG\_HS\_GINTSTS) and before the SOF (OTG\_HS\_GINTSTS).

- 1. The internal data flow for isochronous OUT endpoints is the same as that for nonisochronous OUT endpoints, but for a few differences.
- 2. When an isochronous OUT endpoint is enabled by setting the Endpoint Enable and clearing the NAK bits, the Even/Odd frame bit must also be set appropriately. The core receives data on an isochronous OUT endpoint in a particular frame only if the following condition is met:
  - EONUM (in OTG\_HS\_DOEPCTLx) = SOFFN[0] (in OTG\_HS\_DSTS)
- 3. When the application completely reads an isochronous OUT data packet (data and status) from the receive FIFO, the core updates the RXDPID field in



OTG\_HS\_DOEPTSIZx with the data PID of the last isochronous OUT data packet read from the receive FIFO.

Application programming sequence:

- 1. Program the OTG\_HS\_DOEPTSIZx register for the transfer size and the corresponding packet count
- 2. Program the OTG\_HS\_DOEPCTLx register with the endpoint characteristics and set the Endpoint Enable, ClearNAK, and Even/Odd frame bits.
  - EPENA = 1
  - CNAK = 1
  - EONUM = (0: Even/1: Odd)
- 3. In Slave mode, wait for the RXFLVL interrupt (in OTG\_HS\_GINTSTS) and empty the data packets from the receive FIFO
  - This step can be repeated many times, depending on the transfer size.
- 4. The assertion of the XFRC interrupt (in OTG\_HS\_DOEPINTx) marks the completion of the isochronous OUT data transfer. This interrupt does not necessarily mean that the data in memory are good.
- 5. This interrupt cannot always be detected for isochronous OUT transfers. Instead, the application can detect the IISOOXFRM interrupt in OTG\_HS\_GINTSTS.
- 6. Read the OTG\_HS\_DOEPTSIZx register to determine the size of the received transfer and to determine the validity of the data received in the frame. The application must treat the data received in memory as valid only if one of the following conditions is met:
  - RXDPID = D0 (in OTG\_HS\_DOEPTSIZx) and the number of USB packets in which this payload was received = 1
  - RXDPID = D1 (in OTG\_HS\_DOEPTSIZx) and the number of USB packets in which this payload was received = 2
  - RXDPID = D2 (in OTG\_HS\_DOEPTSIZx) and the number of USB packets in which this payload was received = 3

The number of USB packets in which this payload was received = Application programmed initial packet count – Core updated final packet count

The application can discard invalid data packets.

### • Incomplete isochronous OUT data transfers

This section describes the application programming sequence when isochronous OUT data packets are dropped inside the core.

- 1. For isochronous OUT endpoints, the XFRC interrupt (in OTG\_HS\_DOEPINTx) may not always be asserted. If the core drops isochronous OUT data packets, the application could fail to detect the XFRC interrupt (OTG\_HS\_DOEPINTx) under the following circumstances:
  - When the receive FIFO cannot accommodate the complete ISO OUT data packet, the core drops the received ISO OUT data
  - When the isochronous OUT data packet is received with CRC errors
  - When the isochronous OUT token received by the core is corrupted
  - When the application is very slow in reading the data from the receive FIFO
- 2. When the core detects an end of periodic frame before transfer completion to all isochronous OUT endpoints, it asserts the incomplete Isochronous OUT data interrupt



(IISOOXFRM in OTG\_HS\_GINTSTS), indicating that an XFRC interrupt (in OTG\_HS\_DOEPINTx) is not asserted on at least one of the isochronous OUT endpoints. At this point, the endpoint with the incomplete transfer remains enabled, but no active transfers remain in progress on this endpoint on the USB.

Application programming sequence:

- 1. Asserting the IISOOXFRM interrupt (OTG\_HS\_GINTSTS) indicates that in the current frame, at least one isochronous OUT endpoint has an incomplete transfer.
- 2. If this occurs because isochronous OUT data is not completely emptied from the endpoint, the application must ensure that the application empties all isochronous OUT data (data and status) from the receive FIFO before proceeding.
  - When all data are emptied from the receive FIFO, the application can detect the XFRC interrupt (OTG\_HS\_DOEPINTx). In this case, the application must reenable the endpoint to receive isochronous OUT data in the next frame.
- 3. When it receives an IISOOXFRM interrupt (in OTG\_HS\_GINTSTS), the application must read the control registers of all isochronous OUT endpoints (OTG\_HS\_DOEPCTLx) to determine which endpoints had an incomplete transfer in the current micro-frame. An endpoint transfer is incomplete if both the following conditions are met:
  - EONUM bit (in OTG\_HS\_DOEPCTLx) = SOFFN[0] (in OTG\_HS\_DSTS)
  - EPENA = 1 (in OTG\_HS\_DOEPCTLx)
- 4. The previous step must be performed before the SOF interrupt (in OTG\_HS\_GINTSTS) is detected, to ensure that the current frame number is not changed.
- 5. For isochronous OUT endpoints with incomplete transfers, the application must discard the data in the memory and disable the endpoint by setting the EPDIS bit in OTG\_HS\_DOEPCTLx.
- 6. Wait for the EPDIS interrupt (in OTG\_HS\_DOEPINTx) and enable the endpoint to receive new data in the next frame.
  - Because the core can take some time to disable the endpoint, the application may not be able to receive the data in the next frame after receiving bad isochronous data.

#### • Stalling a nonisochronous OUT endpoint

This section describes how the application can stall a nonisochronous endpoint.

- 1. Put the core in the Global OUT NAK mode.
- 2. Disable the required endpoint
  - When disabling the endpoint, instead of setting the SNAK bit in OTG\_HS\_DOEPCTL, set STALL = 1 (in OTG\_HS\_DOEPCTL).

The STALL bit always takes precedence over the NAK bit.

- 3. When the application is ready to end the STALL handshake for the endpoint, the STALL bit (in OTG\_HS\_DOEPCTLx) must be cleared.
- 4. If the application is setting or clearing a STALL for an endpoint due to a SetFeature.Endpoint Halt or ClearFeature.Endpoint Halt command, the STALL bit must be set or cleared before the application sets up the Status stage transfer on the control endpoint.



## Examples

This section describes and depicts some fundamental transfer types and scenarios.

• Slave mode bulk OUT transaction

*Figure 382* depicts the reception of a single Bulk OUT Data packet from the USB to the AHB and describes the events involved in the process.





After a SetConfiguration/SetInterface command, the application initializes all OUT endpoints by setting CNAK = 1 and EPENA = 1 (in  $OTG_HS_DOEPCTLx$ ), and setting a suitable XFRSIZ and PKTCNT in the  $OTG_HS_DOEPTSIZx$  register.

- 1. Host attempts to send data (OUT token) to an endpoint.
- 2. When the core receives the OUT token on the USB, it stores the packet in the RxFIFO because space is available there.
- 3. After writing the complete packet in the RxFIFO, the core then asserts the RXFLVL interrupt (in OTG\_HS\_GINTSTS).
- 4. On receiving the PKTCNT number of USB packets, the core internally sets the NAK bit for this endpoint to prevent it from receiving any more packets.
- 5. The application processes the interrupt and reads the data from the RxFIFO.
- 6. When the application has read all the data (equivalent to XFRSIZ), the core generates an XFRC interrupt (in OTG\_HS\_DOEPINTx).
- 7. The application processes the interrupt and uses the setting of the XFRC interrupt bit (in OTG\_HS\_DOEPINTx) to determine that the intended transfer is complete.



### IN data transfers

### • Packet write

This section describes how the application writes data packets to the endpoint FIFO in Slave mode when dedicated transmit FIFOs are enabled.

- 1. The application can either choose the polling or the interrupt mode.
  - In polling mode, the application monitors the status of the endpoint transmit data FIFO by reading the OTG\_HS\_DTXFSTSx register, to determine if there is enough space in the data FIFO.
  - In interrupt mode, the application waits for the TXFE interrupt (in OTG\_HS\_DIEPINTx) and then reads the OTG\_HS\_DTXFSTSx register, to determine if there is enough space in the data FIFO.
  - To write a single nonzero length data packet, there must be space to write the entire packet in the data FIFO.
  - To write zero length packet, the application must not look at the FIFO space.
- 2. Using one of the above mentioned methods, when the application determines that there is enough space to write a transmit packet, the application must first write into the endpoint control register, before writing the data into the data FIFO. Typically, the application, must do a read modify write on the OTG\_HS\_DIEPCTLx register to avoid modifying the contents of the register, except for setting the Endpoint Enable bit.

The application can write multiple packets for the same endpoint into the transmit FIFO, if space is available. For periodic IN endpoints, the application must write packets only for one micro-frame. It can write packets for the next periodic transaction only after getting transfer complete for the previous transaction.

### • Setting IN endpoint NAK

Internal data flow:

- 1. When the application sets the IN NAK for a particular endpoint, the core stops transmitting data on the endpoint, irrespective of data availability in the endpoint's transmit FIFO.
- 2. Nonisochronous IN tokens receive a NAK handshake reply
  - Isochronous IN tokens receive a zero-data-length packet reply
- 3. The core asserts the INEPNE (IN endpoint NAK effective) interrupt in OTG\_HS\_DIEPINTx in response to the SNAK bit in OTG\_HS\_DIEPCTLx.
- 4. Once this interrupt is seen by the application, the application can assume that the endpoint is in IN NAK mode. This interrupt can be cleared by the application by setting the CNAK bit in OTG\_HS\_DIEPCTLx.

Application programming sequence:



1. To stop transmitting any data on a particular IN endpoint, the application must set the IN NAK bit. To set this bit, the following field must be programmed.

– SNAK = 1 in OTG\_HS\_DIEPCTLx

- 2. Wait for assertion of the INEPNE interrupt in OTG\_HS\_DIEPINTx. This interrupt indicates that the core has stopped transmitting data on the endpoint.
- 3. The core can transmit valid IN data on the endpoint after the application has set the NAK bit, but before the assertion of the NAK Effective interrupt.
- 4. The application can mask this interrupt temporarily by writing to the INEPNEM bit in DIEPMSK.
  - INEPNEM = 0 in DIEPMSK
- To exit Endpoint NAK mode, the application must clear the NAK status bit (NAKSTS) in OTG\_HS\_DIEPCTLx. This also clears the INEPNE interrupt (in OTG\_HS\_DIEPINTx).
   CNAK = 1 in OTG\_HS\_DIEPCTLx
- 6. If the application masked this interrupt earlier, it must be unmasked as follows:
  - INEPNEM = 1 in DIEPMSK

# • IN endpoint disable

Use the following sequence to disable a specific IN endpoint that has been previously enabled.

Application programming sequence:

- 1. The application must stop writing data on the AHB for the IN endpoint to be disabled.
- 2. The application must set the endpoint in NAK mode.
  - SNAK = 1 in OTG\_HS\_DIEPCTLx
- 3. Wait for the INEPNE interrupt in OTG\_HS\_DIEPINTx.
- 4. Set the following bits in the OTG\_HS\_DIEPCTLx register for the endpoint that must be disabled.
  - EPDIS = 1 in OTG\_HS\_DIEPCTLx
  - SNAK = 1 in OTG\_HS\_DIEPCTLx
- 5. Assertion of the EPDISD interrupt in OTG\_HS\_DIEPINTx indicates that the core has completely disabled the specified endpoint. Along with the assertion of the interrupt, the core also clears the following bits:
  - EPENA = 0 in OTG\_HS\_DIEPCTLx
  - EPDIS = 0 in OTG\_HS\_DIEPCTLx
- 6. The application must read the OTG\_HS\_DIEPTSIZx register for the periodic IN EP, to calculate how much data on the endpoint were transmitted on the USB.
- 7. The application must flush the data in the Endpoint transmit FIFO, by setting the following fields in the OTG\_HS\_GRSTCTL register:
  - TXFNUM (in OTG\_HS\_GRSTCTL) = Endpoint transmit FIFO number
  - TXFFLSH in (OTG\_HS\_GRSTCTL) = 1

The application must poll the OTG\_HS\_GRSTCTL register, until the TXFFLSH bit is cleared by the core, which indicates the end of flush operation. To transmit new data on this endpoint, the application can re-enable the endpoint at a later point.

### • Generic nonperiodic IN data transfers

Application requirements:



- 1. Before setting up an IN transfer, the application must ensure that all data to be transmitted as part of the IN transfer are part of a single buffer.
- 2. For IN transfers, the Transfer Size field in the Endpoint Transfer Size register denotes a payload that constitutes multiple maximum-packet-size packets and a single short packet. This short packet is transmitted at the end of the transfer.
  - To transmit a few maximum-packet-size packets and a short packet at the end of the transfer:

Transfer size[EPNUM] =  $x \times MPSIZ[EPNUM] + sp$ 

If (sp > 0), then packet count[EPNUM] = x + 1.

Otherwise, packet count[EPNUM] = x

- To transmit a single zero-length data packet:

Transfer size[EPNUM] = 0

Packet count[EPNUM] = 1

 To transmit a few maximum-packet-size packets and a zero-length data packet at the end of the transfer, the application must split the transfer into two parts. The first sends maximum-packet-size data packets and the second sends the zerolength data packet alone.

First transfer: transfer size[EPNUM] =  $x \times MPSIZ[epnum]$ ; packet count = *n*; Second transfer: transfer size[EPNUM] = 0; packet count = 1;

- 3. Once an endpoint is enabled for data transfers, the core updates the Transfer size register. At the end of the IN transfer, the application must read the Transfer size register to determine how much data posted in the transmit FIFO have already been sent on the USB.
- 4. Data fetched into transmit FIFO = Application-programmed initial transfer size coreupdated final transfer size
  - Data transmitted on USB = (application-programmed initial packet count Core updated final packet count) × MPSIZ[EPNUM]
  - Data yet to be transmitted on USB = (Application-programmed initial transfer size – data transmitted on USB)

- 1. The application must set the transfer size and packet count fields in the endpointspecific registers and enable the endpoint to transmit the data.
- 2. The application must also write the required data to the transmit FIFO for the endpoint.
- 3. Every time a packet is written into the transmit FIFO by the application, the transfer size for that endpoint is decremented by the packet size. The data is fetched from the memory by the application, until the transfer size for the endpoint becomes 0. After writing the data into the FIFO, the "number of packets in FIFO" count is incremented (this is a 3-bit count, internally maintained by the core for each IN endpoint transmit FIFO. The maximum number of packets maintained by the core at any time in an IN endpoint FIFO is eight). For zero-length packets, a separate flag is set for each FIFO, without any data in the FIFO.
- 4. Once the data are written to the transmit FIFO, the core reads them out upon receiving an IN token. For every nonisochronous IN data packet transmitted with an ACK



handshake, the packet count for the endpoint is decremented by one, until the packet count is zero. The packet count is not decremented on a timeout.

- 5. For zero length packets (indicated by an internal zero length flag), the core sends out a zero-length packet for the IN token and decrements the packet count field.
- 6. If there are no data in the FIFO for a received IN token and the packet count field for that endpoint is zero, the core generates an "IN token received when TxFIFO is empty" (ITTXFE) Interrupt for the endpoint, provided that the endpoint NAK bit is not set. The core responds with a NAK handshake for nonisochronous endpoints on the USB.
- 7. The core internally rewinds the FIFO pointers and no timeout interrupt is generated.
- 8. When the transfer size is 0 and the packet count is 0, the transfer complete (XFRC) interrupt for the endpoint is generated and the endpoint enable is cleared.

Application programming sequence:

- 1. Program the OTG\_HS\_DIEPTSIZx register with the transfer size and corresponding packet count.
- 2. Program the OTG\_HS\_DIEPCTLx register with the endpoint characteristics and set the CNAK and EPENA (Endpoint Enable) bits.
- 3. When transmitting nonzero length data packet, the application must poll the OTG\_HS\_DTXFSTSx register (where x is the FIFO number associated with that endpoint) to determine whether there is enough space in the data FIFO. The application can optionally use TXFE (in OTG\_HS\_DIEPINTx) before writing the data.

### • Generic periodic IN data transfers

This section describes a typical periodic IN data transfer.

Application requirements:

- 1. Application requirements 1, 2, 3, and 4 of *Generic nonperiodic IN data transfers on page 1210* also apply to periodic IN data transfers, except for a slight modification of requirement 2.
  - The application can only transmit multiples of maximum-packet-size data packets or multiples of maximum-packet-size packets, plus a short packet at the end. To



transmit a few maximum-packet-size packets and a short packet at the end of the transfer, the following conditions must be met:

transfer size[EPNUM] =  $x \times MPSIZ[EPNUM] + sp$ (where x is an integer  $\ge 0$ , and  $0 \le sp < MPSIZ[EPNUM]$ ) If (sp > 0), packet count[EPNUM] = x + 1Otherwise, packet count[EPNUM] = x; MCNT[EPNUM] = packet count[EPNUM]

- The application cannot transmit a zero-length data packet at the end of a transfer.
   It can transmit a single zero-length data packet by itself. To transmit a single zero-length data packet:
- transfer size[EPNUM] = 0
   packet count[EPNUM] = 1
   MCNT[EPNUM] = packet count[EPNUM]
- 2. The application can only schedule data transfers one frame at a time.
  - $(MCNT 1) \times MPSIZ \leq XFERSIZ \leq MCNT \times MPSIZ$
  - PKTCNT = MCNT (in OTG\_HS\_DIEPTSIZx)
  - If XFERSIZ < MCNT × MPSIZ, the last data packet of the transfer is a short packet.
  - Note that: MCNT is in OTG\_HS\_DIEPTSIZx, MPSIZ is in OTG\_HS\_DIEPCTLx, PKTCNT is in OTG\_HS\_DIEPTSIZx and XFERSIZ is in OTG\_HS\_DIEPTSIZx
- 3. The complete data to be transmitted in the frame must be written into the transmit FIFO by the application, before the IN token is received. Even when 1 DWORD of the data to be transmitted per frame is missing in the transmit FIFO when the IN token is received, the core behaves as when the FIFO is empty. When the transmit FIFO is empty:
  - A zero data length packet would be transmitted on the USB for isochronous IN endpoints
  - A NAK handshake would be transmitted on the USB for interrupt IN endpoints
- 4. For a high-bandwidth IN endpoint with three packets in a frame, the application can program the endpoint FIFO size to be 2 × max\_pkt\_size and have the third packet loaded in after the first packet has been transmitted on the USB.

- 1. The application must set the transfer size and packet count fields in the endpointspecific registers and enable the endpoint to transmit the data.
- 2. The application must also write the required data to the associated transmit FIFO for the endpoint.
- 3. Every time the application writes a packet to the transmit FIFO, the transfer size for that endpoint is decremented by the packet size. The data are fetched from application memory until the transfer size for the endpoint becomes 0.
- 4. When an IN token is received for a periodic endpoint, the core transmits the data in the FIFO, if available. If the complete data payload (complete packet, in dedicated FIFO mode) for the frame is not present in the FIFO, then the core generates an IN token received when TxFIFO empty interrupt for the endpoint.
  - A zero-length data packet is transmitted on the USB for isochronous IN endpoints
  - A NAK handshake is transmitted on the USB for interrupt IN endpoints
- 5. The packet count for the endpoint is decremented by 1 under the following conditions:



- For isochronous endpoints, when a zero- or nonzero-length data packet is transmitted
- For interrupt endpoints, when an ACK handshake is transmitted
- When the transfer size and packet count are both 0, the transfer completed interrupt for the endpoint is generated and the endpoint enable is cleared.
- 6. At the "Periodic frame Interval" (controlled by PFIVL in OTG\_HS\_DCFG), when the core finds nonempty any of the isochronous IN endpoint FIFOs scheduled for the current frame nonempty, the core generates an IISOIXFR interrupt in OTG\_HS\_GINTSTS.

Application programming sequence:

- 1. Program the OTG\_HS\_DIEPCTLx register with the endpoint characteristics and set the CNAK and EPENA bits.
- 2. Write the data to be transmitted in the next frame to the transmit FIFO.
- 3. Asserting the ITTXFE interrupt (in OTG\_HS\_DIEPINTx) indicates that the application has not yet written all data to be transmitted to the transmit FIFO.
- 4. If the interrupt endpoint is already enabled when this interrupt is detected, ignore the interrupt. If it is not enabled, enable the endpoint so that the data can be transmitted on the next IN token attempt.
- Asserting the XFRC interrupt (in OTG\_HS\_DIEPINTx) with no ITTXFE interrupt in OTG\_HS\_DIEPINTx indicates the successful completion of an isochronous IN transfer. A read to the OTG\_HS\_DIEPTSIZx register must give transfer size = 0 and packet count = 0, indicating all data were transmitted on the USB.
- 6. Asserting the XFRC interrupt (in OTG\_HS\_DIEPINTx), with or without the ITTXFE interrupt (in OTG\_HS\_DIEPINTx), indicates the successful completion of an interrupt IN transfer. A read to the OTG\_HS\_DIEPTSIZx register must give transfer size = 0 and packet count = 0, indicating all data were transmitted on the USB.
- 7. Asserting the incomplete isochronous IN transfer (IISOIXFR) interrupt in OTG\_HS\_GINTSTS with none of the aforementioned interrupts indicates the core did not receive at least 1 periodic IN token in the current frame.
- Incomplete isochronous IN data transfers

This section describes what the application must do on an incomplete isochronous IN data transfer.

Internal data flow:

- 1. An isochronous IN transfer is treated as incomplete in one of the following conditions:
  - a) The core receives a corrupted isochronous IN token on at least one isochronous IN endpoint. In this case, the application detects an incomplete isochronous IN transfer interrupt (IISOIXFR in OTG\_HS\_GINTSTS).
  - b) The application is slow to write the complete data payload to the transmit FIFO and an IN token is received before the complete data payload is written to the FIFO. In this case, the application detects an IN token received when TxFIFO empty interrupt in OTG\_HS\_DIEPINTx. The application can ignore this interrupt, as it eventually results in an incomplete isochronous IN transfer interrupt (IISOIXFR in OTG\_HS\_GINTSTS) at the end of periodic frame.

The core transmits a zero-length data packet on the USB in response to the received IN token.



- 2. The application must stop writing the data payload to the transmit FIFO as soon as possible.
- 3. The application must set the NAK bit and the disable bit for the endpoint.
- 4. The core disables the endpoint, clears the disable bit, and asserts the Endpoint Disable interrupt for the endpoint.

Application programming sequence

- 1. The application can ignore the IN token received when TxFIFO empty interrupt in OTG\_HS\_DIEPINTx on any isochronous IN endpoint, as it eventually results in an incomplete isochronous IN transfer interrupt (in OTG\_HS\_GINTSTS).
- Assertion of the incomplete isochronous IN transfer interrupt (in OTG\_HS\_GINTSTS) indicates an incomplete isochronous IN transfer on at least one of the isochronous IN endpoints.
- 3. The application must read the Endpoint Control register for all isochronous IN endpoints to detect endpoints with incomplete IN data transfers.
- 4. The application must stop writing data to the Periodic Transmit FIFOs associated with these endpoints on the AHB.
- 5. Program the following fields in the OTG\_HS\_DIEPCTLx register to disable the endpoint:
  - SNAK = 1 in OTG\_HS\_DIEPCTLx
  - EPDIS = 1 in OTG\_HS\_DIEPCTLx
- 6. The assertion of the Endpoint Disabled interrupt in OTG\_HS\_DIEPINTx indicates that the core has disabled the endpoint.
  - At this point, the application must flush the data in the associated transmit FIFO or overwrite the existing data in the FIFO by enabling the endpoint for a new transfer in the next micro-frame. To flush the data, the application must use the OTG\_HS\_GRSTCTL register.

#### Stalling nonisochronous IN endpoints

This section describes how the application can stall a nonisochronous endpoint.

Application programming sequence:

- 1. Disable the IN endpoint to be stalled. Set the STALL bit as well.
- 2. EPDIS = 1 in OTG\_HS\_DIEPCTLx, when the endpoint is already enabled
  - STALL = 1 in OTG\_HS\_DIEPCTLx
  - The STALL bit always takes precedence over the NAK bit
- 3. Assertion of the Endpoint Disabled interrupt (in OTG\_HS\_DIEPINTx) indicates to the application that the core has disabled the specified endpoint.
- 4. The application must flush the nonperiodic or periodic transmit FIFO, depending on the endpoint type. In case of a nonperiodic endpoint, the application must re-enable the other nonperiodic endpoints that do not need to be stalled, to transmit data.
- 5. Whenever the application is ready to end the STALL handshake for the endpoint, the STALL bit must be cleared in OTG\_HS\_DIEPCTLx.
- 6. If the application sets or clears a STALL bit for an endpoint due to a SetFeature.Endpoint Halt command or ClearFeature.Endpoint Halt command, the STALL bit must be set or cleared before the application sets up the Status stage transfer on the control endpoint.

Special case: stalling the control OUT endpoint



The core must stall IN/OUT tokens if, during the data stage of a control transfer, the host sends more IN/OUT tokens than are specified in the SETUP packet. In this case, the application must enable the ITTXFE interrupt in OTG\_HS\_DIEPINTx and the OTEPDIS interrupt in OTG\_HS\_DOEPINTx during the data stage of the control transfer, after the core has transferred the amount of data specified in the SETUP packet. Then, when the application receives this interrupt, it must set the STALL bit in the corresponding endpoint control register, and clear this interrupt.

# 30.13.8 Worst case response time

When the OTG\_HS controller acts as a device, there is a worst case response time for any tokens that follow an isochronous OUT. This worst case response time depends on the AHB clock frequency.

The core registers are in the AHB domain, and the core does not accept another token before updating these register values. The worst case is for any token following an isochronous OUT, because for an isochronous transaction, there is no handshake and the next token could come sooner. This worst case value is 7 PHY clocks when the AHB clock is the same as the PHY clock. When the AHB clock is faster, this value is smaller.

If this worst case condition occurs, the core responds to bulk/interrupt tokens with a NAK and drops isochronous and SETUP tokens. The host interprets this as a timeout condition for SETUP and retries the SETUP packet. For isochronous transfers, the Incomplete isochronous IN transfer interrupt (IISOIXFR) and Incomplete isochronous OUT transfer interrupt (IISOOXFR) inform the application that isochronous IN/OUT packets were dropped.

# Choosing the value of TRDT in OTG\_HS\_GUSBCFG

The value in TRDT (OTG\_HS\_GUSBCFG) is the time it takes for the MAC, in terms of PHY clocks after it has received an IN token, to get the FIFO status, and thus the first data from the PFC block. This time involves the synchronization delay between the PHY and AHB clocks. The worst case delay for this is when the AHB clock is the same as the PHY clock. In this case, the delay is 5 clocks.

Once the MAC receives an IN token, this information (token received) is synchronized to the AHB clock by the PFC (the PFC runs on the AHB clock). The PFC then reads the data from the SPRAM and writes them into the dual clock source buffer. The MAC then reads the data out of the source buffer (4 deep).

If the AHB is running at a higher frequency than the PHY, the application can use a smaller value for TRDT (in OTG\_HS\_GUSBCFG).

*Figure 383* has the following signals:

- tkn\_rcvd: Token received information from MAC to PFC
- dynced\_tkn\_rcvd: Doubled sync tkn\_rcvd, from PCLK to HCLK domain
- spr\_read: Read to SPRAM
- spr\_addr: Address to SPRAM
- spr\_rdata: Read data from SPRAM
- srcbuf\_push: Push to the source buffer
- srcbuf\_rdata: Read data from the source buffer. Data seen by MAC



The application can use the following formula to calculate the value of TRDT:

 $4 \times AHB \operatorname{clock} + 1 \operatorname{PHY} \operatorname{clock} = (2 \operatorname{clock} \operatorname{sync} + 1 \operatorname{clock} \operatorname{memory} \operatorname{address} + 1 \operatorname{clock} \operatorname{memory} \operatorname{data}$  from sync RAM) + (1 PHY clock (next PHY clock MAC can sample the 2 clock FIFO outputs)





# 30.13.9 OTG programming model

The OTG\_HS controller is an OTG device supporting HNP and SRP. When the core is connected to an "A" plug, it is referred to as an A-device. When the core is connected to a "B" plug it is referred to as a B-device. In host mode, the OTG\_HS controller turns off V<sub>BUS</sub> to conserve power. SRP is a method by which the B-device signals the A-device to turn on V<sub>BUS</sub> power. A device must perform both data-line pulsing and V<sub>BUS</sub> pulsing, but a host can detect either data-line pulsing or V<sub>BUS</sub> pulsing for SRP. HNP is a method by which the B-device suspends the bus and reverts to the device role.



### A-device session request protocol

The application must set the SRP-capable bit in the Core USB configuration register. This enables the OTG\_HS controller to detect SRP as an A-device.





1. DRV\_VBUS =  $V_{BUS}$  drive signal to the PHY VBUS\_VALID =  $V_{BUS}$  valid signal from PHY A\_VALID = A-device  $V_{BUS}$  level signal to PHY DP = Data plus line DM = Data minus line

- 1. To save power, the application suspends and turns off port power when the bus is idle by writing the port suspend and port power bits in the host port control and status register.
- 2. PHY indicates port power off by deasserting the VBUS\_VALID signal.
- 3. The device must detect SE0 for at least 2 ms to start SRP when V<sub>BUS</sub> power is off.
- 4. To initiate SRP, the device turns on its data line pull-up resistor for 5 to 10 ms. The OTG\_HS controller detects data-line pulsing.
- 5. The device drives  $V_{BUS}$  above the A-device session valid (2.0 V minimum) for  $V_{BUS}$  pulsing.

The OTG\_HS controller interrupts the application on detecting SRP. The Session request detected bit is set in Global interrupt status register (SRQINT set in OTG\_HS\_GINTSTS).

- 6. The application must service the Session request detected interrupt and turn on the port power bit by writing the port power bit in the host port control and status register. The PHY indicates port power-on by asserting the VBUS\_VALID signal.
- 7. When the USB is powered, the device connects, completing the SRP process.



### **B-device session request protocol**

The application must set the SRP-capable bit in the Core USB configuration register. This enables the OTG\_HS controller to initiate SRP as a B-device. SRP is a means by which the OTG\_HS controller can request a new session from the host.

Figure 385. B-device SRP

| VBUS_VALID   | Suspend 6                     |
|--------------|-------------------------------|
| B_VALID      | 3                             |
| DISCHRG_VBUS |                               |
| SESS_END     | 4                             |
| OTG_HS_FS_DP | 5 Data line pulsing Connect   |
| OTG_HS_FS_DM | Low                           |
| CHRG_VBUS    | 7<br>V <sub>BUS</sub> pulsing |

1. VBUS\_VALID =  $V_{BUS}$  valid signal from PHY B\_VALID = B-device valid session to PHY DISCHRG\_VBUS = discharge signal to PHY SESS\_END = session end signal to PHY CHRG\_VBUS = charge V<sub>BUS</sub> signal to PHY DP = Data plus line DM = Data minus line

1. To save power, the host suspends and turns off port power when the bus is idle.

The OTG\_HS controller sets the early suspend bit in the Core interrupt register after 3 ms of bus idleness. Following this, the OTG\_HS controller sets the USB suspend bit in the Core interrupt register.

The OTG\_HS controller informs the PHY to discharge  $\ensuremath{\mathsf{V}_{\mathsf{BUS}}}$  .

2. The PHY indicates the session's end to the device. This is the initial condition for SRP. The OTG\_HS controller requires 2 ms of SE0 before initiating SRP.

For a USB 1.1 full-speed serial transceiver, the application must wait until  $V_{BUS}$  discharges to 0.2 V after BSVLD (in OTG\_HS\_GOTGCTL) is deasserted. This



discharge time can be obtained from the transceiver vendor and varies from one transceiver to another.

- 3. The USB OTG core informs the PHY to speed up V<sub>BUS</sub> discharge.
- The application initiates SRP by writing the session request bit in the OTG Control and status register. The OTG\_HS controller perform data-line pulsing followed by V<sub>BUS</sub> pulsing.
- 5. The host detects SRP from either the data-line or  $V_{BUS}$  pulsing, and turns on  $V_{BUS}$ . The PHY indicates  $V_{BUS}$  power-on to the device.
- 6. The OTG\_HS controller performs V<sub>BUS</sub> pulsing.

The host starts a new session by turning on  $V_{BUS}$ , indicating SRP success. The OTG\_HS controller interrupts the application by setting the session request success status change bit in the OTG interrupt status register. The application reads the session request success bit in the OTG control and status register.

7. When the USB is powered, the OTG\_HS controller connects, completing the SRP process.

## A-device host negotiation protocol

HNP switches the USB host role from the A-device to the B-device. The application must set the HNP-capable bit in the Core USB configuration register to enable the OTG\_HS controller to perform HNP as an A-device.



#### Figure 386. A-device HNP

1. DPPULLDOWN = signal from core to PHY to enable/disable the pull-down on the DP line inside the PHY. DMPULLDOWN = signal from core to PHY to enable/disable the pull-down on the DM line inside the PHY.

1. The OTG\_HS controller sends the B-device a SetFeature b\_hnp\_enable descriptor to enable HNP support. The B-device's ACK response indicates that the B-device supports HNP. The application must set host Set HNP Enable bit in the OTG Control



and status register to indicate to the OTG\_HS controller that the B-device supports HNP.

- 2. When it has finished using the bus, the application suspends by writing the Port suspend bit in the host port control and status register.
- 3. When the B-device observes a USB suspend, it disconnects, indicating the initial condition for HNP. The B-device initiates HNP only when it must switch to the host role; otherwise, the bus continues to be suspended.

The OTG\_HS controller sets the host negotiation detected interrupt in the OTG interrupt status register, indicating the start of HNP.

The OTG\_HS controller deasserts the DM pull down and DM pull down in the PHY to indicate a device role. The PHY enables the OTG\_HS\_DP pull-up resistor to indicate a connect for B-device.

The application must read the current mode bit in the OTG Control and status register to determine peripheral mode operation.

- 4. The B-device detects the connection, issues a USB reset, and enumerates the OTG\_HS controller for data traffic.
- 5. The B-device continues the host role, initiating traffic, and suspends the bus when done.

The OTG\_HS controller sets the early suspend bit in the Core interrupt register after 3 ms of bus idleness. Following this, the OTG\_HS controller sets the USB Suspend bit in the Core interrupt register.

- 6. In Negotiated mode, the OTG\_HS controller detects the suspend, disconnects, and switches back to the host role. The OTG\_HS controller asserts the DM pull down and DM pull down in the PHY to indicate its assumption of the host role.
- 7. The OTG\_HS controller sets the Connector ID status change interrupt in the OTG Interrupt Status register. The application must read the connector ID status in the OTG Control and Status register to determine the OTG\_HS controller operation as an Adevice. This indicates the completion of HNP to the application. The application must read the Current mode bit in the OTG control and status register to determine host mode operation.
- 8. The B-device connects, completing the HNP process.

### **B-device host negotiation protocol**

HNP switches the USB host role from B-device to A-device. The application must set the HNP-capable bit in the Core USB configuration register to enable the OTG\_HS controller to perform HNP as a B-device.





#### Figure 387. B-device HNP

- DPPULLDOWN = signal from core to PHY to enable/disable the pull-down on the DP line inside the PHY. DMPULLDOWN = signal from core to PHY to enable/disable the pull-down on the DM line inside the PHY.
- The A-device sends the SetFeature b\_hnp\_enable descriptor to enable HNP support. The OTG\_HS controller's ACK response indicates that it supports HNP. The application must set the Device HNP enable bit in the OTG Control and status register to indicate HNP support.

The application sets the HNP request bit in the OTG Control and status register to indicate to the OTG\_HS controller to initiate HNP.

2. When it has finished using the bus, the A-device suspends by writing the Port suspend bit in the host port control and status register.

The OTG\_HS controller sets the Early suspend bit in the Core interrupt register after 3 ms of bus idleness. Following this, the OTG\_HS controller sets the USB suspend bit in the Core interrupt register.

The OTG\_HS controller disconnects and the A-device detects SE0 on the bus, indicating HNP. The OTG\_HS controller asserts the DP pull down and DM pull down in the PHY to indicate its assumption of the host role.

The A-device responds by activating its OTG\_HS\_DP pull-up resistor within 3 ms of detecting SE0. The OTG\_HS controller detects this as a connect.

The OTG\_HS controller sets the host negotiation success status change interrupt in the OTG Interrupt status register, indicating the HNP status. The application must read the host negotiation success bit in the OTG Control and status register to determine



host negotiation success. The application must read the current Mode bit in the Core interrupt register (OTG\_HS\_GINTSTS) to determine host mode operation.

- 3. The application sets the reset bit (PRST in OTG\_HS\_HPRT) and the OTG\_HS controller issues a USB reset and enumerates the A-device for data traffic.
- 4. The OTG\_HS controller continues the host role of initiating traffic, and when done, suspends the bus by writing the Port suspend bit in the host port control and status register.
- 5. In Negotiated mode, when the A-device detects a suspend, it disconnects and switches back to the host role. The OTG\_HS controller deasserts the DP pull down and DM pull down in the PHY to indicate the assumption of the device role.
- 6. The application must read the current mode bit in the Core interrupt (OTG\_HS\_GINTSTS) register to determine the host mode operation.
- 7. The OTG\_HS controller connects, completing the HNP process.



# 31 Flexible static memory controller (FSMC)

# 31.1 FSMC main features

The FSMC block is able to interface with synchronous and asynchronous memories and 16bit PC memory cards. Its main purpose is to:

- Translate the AHB transactions into the appropriate external device protocol
- Meet the access timing requirements of the external devices

All external memories share the addresses, data and control signals with the controller. Each external device is accessed by means of a unique chip select. The FSMC performs only one access at a time to an external device.

The FSMC has the following main features:

- Interfaces with static memory-mapped devices including:
  - Static random access memory (SRAM)
  - Read-only memory (ROM)
  - NOR Flash memory/OneNAND Flash memory
  - PSRAM (4 memory banks)
- Two banks of NAND Flash with ECC hardware that checks up to 8 Kbytes of data
- 16-bit PC Card compatible devices
- Supports burst mode access to synchronous devices (NOR Flash and PSRAM)
- 8- or 16-bit wide databus
- Independent chip select control for each memory bank
- Independent configuration for each memory bank
- Programmable timings to support a wide range of devices, in particular:
  - Programmable wait states (up to 15)
  - Programmable bus turnaround cycles (up to 15)
  - Programmable output enable and write enable delays (up to 15)
  - Independent read and write timings and protocol, so as to support the widest variety of memories and timings
- Write enable and byte lane select outputs for use with PSRAM and SRAM devices
- Translation of 32-bit wide AHB transactions into consecutive 16-bit or 8-bit accesses to external 16-bit or 8-bit devices
- A Write FIFO, 2 words long, each word is 32 bits wide, only stores data and not the address. Therefore, this FIFO only buffers AHB write burst transactions. This makes it possible to write to slow memories and free the AHB quickly for other operations. Only one burst at a time is buffered: if a new AHB burst or single transaction occurs while an operation is in progress, the FIFO is drained. The FSMC will insert wait states until the current memory access is complete).
- External asynchronous wait control

The FSMC registers that define the external device type and associated characteristics are usually set at boot time and do not change until the next reset or power-up. However, it is possible to change the settings at any time.



# 31.2 Block diagram

The FSMC consists of four main blocks:

- The AHB interface (including the FSMC configuration registers)
- The NOR Flash/PSRAM controller
- The NAND Flash/PC Card controller
- The external device interface

The block diagram is shown in *Figure 388*.

## Figure 388. FSMC block diagram



# 31.3 AHB interface

The AHB slave interface enables internal CPUs and other bus master peripherals to access the external static memories.

AHB transactions are translated into the external device protocol. In particular, if the selected external memory is 16 or 8 bits wide, 32-bit wide transactions on the AHB are split into consecutive 16- or 8-bit accesses. The Chip Select toggles for each access.



Doc ID 018909 Rev 1

The FSMC generates an AHB error in the following conditions:

- When reading or writing to an FSMC bank which is not enabled
- When reading or writing to the NOR Flash bank while the FACCEN bit is reset in the FSMC\_BCRx register.
- When reading or writing to the PC Card banks while the input pin FSMC\_CD (Card Presence Detection) is low.

The effect of this AHB error depends on the AHB master which has attempted the R/W access:

- If it is the Cortex<sup>TM</sup>-M4F CPU, a hard fault interrupt is generated
- If is a DMA, a DMA transfer error is generated and the corresponding DMA channel is automatically disabled.

The AHB clock (HCLK) is the reference clock for the FSMC.

## 31.3.1 Supported memories and transactions

## **General transaction rules**

The requested AHB transaction data size can be 8-, 16- or 32-bit wide whereas the accessed external device has a fixed data width. This may lead to inconsistent transfers.

Therefore, some simple transaction rules must be followed:

- AHB transaction size and memory data size are equal There is no issue in this case.
- AHB transaction size is greater than the memory size In this case, the FSMC splits the AHB transaction into smaller consecutive memory accesses in order to meet the external data width.
- AHB transaction size is smaller than the memory size Asynchronous transfers may or not be consistent depending on the type of external device.
  - Asynchronous accesses to devices that have the byte select feature (SRAM, ROM, PSRAM).

a) FSMC allows write transactions accessing the right data through its byte lanes NBL[1:0]

b) Read transactions are allowed (the controller reads the entire memory word and uses the needed byte only). The NBL[1:0] are always kept low during read transactions.

Asynchronous accesses to devices that do not have the byte select feature (NOR and NAND Flash 16-bit).
 This situation occurs when a byte access is requested to a 16-bit wide Flash

memory. Clearly, the device cannot be accessed in byte mode (only 16-bit words can be read from/written to the Flash memory) therefore:

- a) Write transactions are not allowed
- b) Read transactions are allowed (the controller reads the entire 16-bit memory word and uses the needed byte only).



## **Configuration registers**

The FSMC can be configured using a register set. See *Section 31.5.6*, for a detailed description of the NOR Flash/PSRAM controller registers. See *Section 31.6.8*, for a detailed description of the NAND Flash/PC Card registers.

# 31.4 External device address mapping

From the FSMC point of view, the external memory is divided into 4 fixed-size banks of 256 Mbytes each (Refer to *Figure 389*):

- Bank 1 used to address up to 4 NOR Flash or PSRAM memory devices. This bank is split into 4 NOR/PSRAM regions with 4 dedicated Chip Select.
- Banks 2 and 3 used to address NAND Flash devices (1 device per bank)
- Bank 4 used to address a PC Card device

For each bank the type of memory to be used is user-defined in the Configuration register.

### Figure 389. FSMC memory banks



## 31.4.1 NOR/PSRAM address mapping

HADDR[27:26] bits are used to select one of the four memory banks as shown in Table 163.

### Table 163. NOR/PSRAM bank selection

| HADDR[27:26] <sup>(1)</sup> | Selected bank      |
|-----------------------------|--------------------|
| 00                          | Bank 1 NOR/PSRAM 1 |
| 01                          | Bank 1 NOR/PSRAM 2 |



| Table 163. | NOR/PSRAM bank selection (continued) |
|------------|--------------------------------------|
|------------|--------------------------------------|

| HADDR[27:26] <sup>(1)</sup> | Selected bank      |
|-----------------------------|--------------------|
| 10                          | Bank 1 NOR/PSRAM 3 |
| 11                          | Bank 1 NOR/PSRAM 4 |

1. HADDR are internal AHB address lines that are translated to external memory.

HADDR[25:0] contain the external memory address. Since HADDR is a byte address whereas the memory is addressed in words, the address actually issued to the memory varies according to the memory data width, as shown in the following table.

Table 164. External memory address

| Memory width <sup>(1)</sup> | Data address issued to the memory | Maximum memory capacity (bits) |
|-----------------------------|-----------------------------------|--------------------------------|
| 8-bit                       | HADDR[25:0]                       | 64 Mbytes x 8 = 512 Mbit       |
| 16-bit                      | HADDR[25:1] >> 1                  | 64 Mbytes/2 x 16 = 512 Mbit    |

 In case of a 16-bit external memory width, the FSMC will internally use HADDR[25:1] to generate the address for external memory FSMC\_A[24:0]. Whatever the external memory width (16-bit or 8-bit), FSMC\_A[0] should be connected to external memory address A[0].

## Wrap support for NOR Flash/PSRAM

Wrap burst mode for synchronous memories is not supported. The memories must be configured in linear burst mode of undefined length.

## 31.4.2 NAND/PC Card address mapping

In this case, three banks are available, each of them divided into memory spaces as indicated in *Table 165*.

| Start address | End address | FSMC Bank            | Memory space | Timing register   |
|---------------|-------------|----------------------|--------------|-------------------|
| 0x9C00 0000   | 0x9FFF FFFF |                      | I/O          | FSMC_PIO4 (0xB0)  |
| 0x9800 0000   | 0x9BFF FFFF | Bank 4 - PC card     | Attribute    | FSMC_PATT4 (0xAC) |
| 0x9000 0000   | 0x93FF FFFF |                      | Common       | FSMC_PMEM4 (0xA8) |
| 0x8800 0000   | 0x8BFF FFFF | Bank 3 - NAND Flash  | Attribute    | FSMC_PATT3 (0x8C) |
| 0x8000 0000   | 0x83FF FFFF | Dalik 3 - MAND Flash | Common       | FSMC_PMEM3 (0x88) |
| 0x7800 0000   | 0x7BFF FFFF | Bank 2- NAND Flash   | Attribute    | FSMC_PATT2 (0x6C) |
| 0x7000 0000   | 0x73FF FFFF | Dank 2- NAND Flash   | Common       | FSMC_PMEM2 (0x68) |

 Table 165.
 Memory mapping and timing registers

For NAND Flash memory, the common and attribute memory spaces are subdivided into three sections (see in *Table 166* below) located in the lower 256 Kbytes:

- Data section (first 64 Kbytes in the common/attribute memory space)
- Command section (second 64 Kbytes in the common / attribute memory space)
- Address section (next 128 Kbytes in the common / attribute memory space)



| Section name    | HADDR[17:16] | Address range     |
|-----------------|--------------|-------------------|
| Address section | 1X           | 0x020000-0x03FFFF |
| Command section | 01           | 0x010000-0x01FFFF |
| Data section    | 00           | 0x000000-0x0FFFF  |

#### Table 166. NAND bank selections

The application software uses the 3 sections to access the NAND Flash memory:

- **To send a command to NAND Flash memory**: the software must write the command value to any memory location in the command section.
- To specify the NAND Flash address that must be read or written: the software must write the address value to any memory location in the address section. Since an address can be 4 or 5 bytes long (depending on the actual memory size), several consecutive writes to the address section are needed to specify the full address.
- **To read or write data**: the software reads or writes the data value from or to any memory location in the data section.

Since the NAND Flash memory automatically increments addresses, there is no need to increment the address of the data section to access consecutive memory locations.

# 31.5 NOR Flash/PSRAM controller

The FSMC generates the appropriate signal timings to drive the following types of memories:

- Asynchronous SRAM and ROM
  - 8-bit
  - 16-bit
  - 32-bit
- PSRAM (Cellular RAM)
  - Asynchronous mode
  - Burst mode
  - Multiplexed or nonmultiplexed
- NOR Flash
  - Asynchronous mode or burst mode
  - Multiplexed or nonmultiplexed

The FSMC outputs a unique chip select signal NE[4:1] per bank. All the other signals (addresses, data and control) are shared.

For synchronous accesses, the FSMC issues the clock (CLK) to the selected external device. This clock is a submultiple of the HCLK clock. The size of each bank is fixed and equal to 64 Mbytes.

Each bank is configured by means of dedicated registers (see Section 31.5.6).

The programmable memory parameters include access timings (see *Table 167*) and support for wait management (for PSRAM and NOR Flash accessed in burst mode).



| Parameter             | Function                                                                               | Access mode                       | Unit                        | Min. | Max. |
|-----------------------|----------------------------------------------------------------------------------------|-----------------------------------|-----------------------------|------|------|
| Address<br>setup      | Duration of the address setup phase                                                    | Asynchronous                      | AHB clock cycle<br>(HCLK)   | 0    | 15   |
| Address hold          | Duration of the address hold phase                                                     | Asynchronous,<br>muxed I/Os       | AHB clock cycle<br>(HCLK)   | 1    | 15   |
| Data setup            | Duration of the data setup phase                                                       | Asynchronous                      | AHB clock cycle<br>(HCLK)   | 1    | 256  |
| Bust turn             | Duration of the bus<br>turnaround phase                                                | Asynchronous and synchronous read | AHB clock cycle<br>(HCLK)   | 0    | 15   |
| Clock divide<br>ratio | Number of AHB clock cycles<br>(HCLK) to build one memory<br>clock cycle (CLK)          | Synchronous                       | AHB clock cycle<br>(HCLK)   | 1    | 16   |
| Data latency          | Number of clock cycles to<br>issue to the memory before<br>the first data of the burst | Synchronous                       | Memory clock<br>cycle (CLK) | 2    | 17   |

 Table 167.
 Programmable NOR/PSRAM access parameters

## 31.5.1 External memory interface signals

*Table 168, Table 169* and *Table 170* list the signals that are typically used to interface NOR Flash, SRAM and PSRAM.

Note: Prefix "N". specifies the associated signal as active low.

### NOR Flash, nonmultiplexed I/Os

#### Table 168. Nonmultipled I/O NOR Flash

| FSMC signal name | I/O | Function                                                                            |
|------------------|-----|-------------------------------------------------------------------------------------|
| CLK              | 0   | Clock (for synchronous burst)                                                       |
| A[25:0]          | 0   | Address bus                                                                         |
| D[15:0]          | I/O | Bidirectional data bus                                                              |
| NE[x]            | 0   | Chip select, $x = 14$                                                               |
| NOE              | 0   | Output enable                                                                       |
| NWE              | 0   | Write enable                                                                        |
| NL(=NADV)        | 0   | Latch enable (this signal is called address valid, NADV, by some NOR Flash devices) |
| NWAIT            | I   | NOR Flash wait input signal to the FSMC                                             |

NOR Flash memories are addressed in 16-bit words. The maximum capacity is 512 Mbit (26 address lines).



## NOR Flash, multiplexed I/Os

| Table 169. | Multiplexed I/O NOR Flash |
|------------|---------------------------|
|------------|---------------------------|

| FSMC signal name | I/O | Function                                                                            |
|------------------|-----|-------------------------------------------------------------------------------------|
| CLK              | 0   | Clock (for synchronous burst)                                                       |
| A[25:16]         | 0   | Address bus                                                                         |
| AD[15:0]         | I/O | 16-bit multiplexed, bidirectional address/data bus                                  |
| NE[x]            | 0   | Chip select, x = 14                                                                 |
| NOE              | 0   | Output enable                                                                       |
| NWE              | 0   | Write enable                                                                        |
| NL(=NADV)        | 0   | Latch enable (this signal is called address valid, NADV, by some NOR Flash devices) |
| NWAIT            | I   | NOR Flash wait input signal to the FSMC                                             |

NOR-Flash memories are addressed in 16-bit words. The maximum capacity is 512 Mbit (26 address lines).

### PSRAM/SRAM, nonmultiplexed I/Os

| FSMC signal name | I/O | Function                                                           |
|------------------|-----|--------------------------------------------------------------------|
| CLK              | 0   | Clock (only for PSRAM synchronous burst)                           |
| A[25:0]          | 0   | Address bus                                                        |
| D[15:0]          | I/O | Data bidirectional bus                                             |
| NE[x]            | 0   | Chip select, x = 14 (called NCE by PSRAM (Cellular RAM i.e. CRAM)) |
| NOE              | 0   | Output enable                                                      |
| NWE              | 0   | Write enable                                                       |
| NL(= NADV)       | 0   | Address valid only for PSRAM input (memory signal name: NADV)      |
| NWAIT            | Ι   | PSRAM wait input signal to the FSMC                                |
| NBL[1]           | 0   | Upper byte enable (memory signal name: NUB)                        |
| NBL[0]           | 0   | Lowed byte enable (memory signal name: NLB)                        |

#### Table 170. Nonmultiplexed I/Os PSRAM/SRAM

PSRAM memories are addressed in 16-bit words. The maximum capacity is 512 Mbit (26 address lines).



## PSRAM, multiplexed I/Os

| Table 171. | Multiplexed I/O PSRAM |
|------------|-----------------------|
|------------|-----------------------|

| FSMC signal name | I/O | Function                                                           |
|------------------|-----|--------------------------------------------------------------------|
| CLK              | 0   | Clock (for synchronous burst)                                      |
| A[25:16]         | 0   | Address bus                                                        |
| AD[15:0]         | I/O | 16-bit multiplexed, bidirectional address/data bus                 |
| NE[x]            | 0   | Chip select, x = 14 (called NCE by PSRAM (Cellular RAM i.e. CRAM)) |
| NOE              | 0   | Output enable                                                      |
| NWE              | 0   | Write enable                                                       |
| NL(= NADV)       | 0   | Address valid PSRAM input (memory signal name: NADV)               |
| NWAIT            | Ι   | PSRAM wait input signal to the FSMC                                |
| NBL[1]           | 0   | Upper byte enable (memory signal name: NUB)                        |
| NBL[0]           | 0   | Lowed byte enable (memory signal name: NLB)                        |

PSRAM memories are addressed in 16-bit words. The maximum capacity is 512 Mbit (26 address lines).

## 31.5.2 Supported memories and transactions

*Table 172* below displays an example of the supported devices, access modes and transactions when the memory data bus is 16-bit for NOR, PSRAM and SRAM. Transactions not allowed (or not supported) by the FSMC in this example appear in gray.

| Device                               | Mode              | R/W | AHB<br>data<br>size | Memory<br>data size | Allowed/<br>not<br>allowed | Comments                   |
|--------------------------------------|-------------------|-----|---------------------|---------------------|----------------------------|----------------------------|
|                                      | Asynchronous      | R   | 8                   | 16                  | Y                          |                            |
|                                      | Asynchronous      | W   | 8                   | 16                  | Ν                          |                            |
|                                      | Asynchronous      | R   | 16                  | 16                  | Y                          |                            |
|                                      | Asynchronous      | W   | 16                  | 16                  | Y                          |                            |
| NOR Flash                            | Asynchronous      | R   | 32                  | 16                  | Y                          | Split into 2 FSMC accesses |
| (muxed I/Os<br>and nonmuxed<br>I/Os) | Asynchronous      | w   | 32                  | 16                  | Y                          | Split into 2 FSMC accesses |
|                                      | Asynchronous page | R   | -                   | 16                  | N                          | Mode is not supported      |
|                                      | Synchronous       | R   | 8                   | 16                  | Ν                          |                            |
|                                      | Synchronous       | R   | 16                  | 16                  | Y                          |                            |
|                                      | Synchronous       | R   | 32                  | 16                  | Y                          |                            |

 Table 172.
 NOR Flash/PSRAM supported memories and transactions



| Device                   | Mode              | R/W | AHB<br>data<br>size | Memory<br>data size | Allowed/<br>not<br>allowed | Comments                   |
|--------------------------|-------------------|-----|---------------------|---------------------|----------------------------|----------------------------|
|                          | Asynchronous      | R   | 8                   | 16                  | Y                          |                            |
|                          | Asynchronous      | W   | 8                   | 16                  | Y                          | Use of byte lanes NBL[1:0] |
|                          | Asynchronous      | R   | 16                  | 16                  | Y                          |                            |
|                          | Asynchronous      | W   | 16                  | 16                  | Y                          |                            |
| PSRAM                    | Asynchronous      | R   | 32                  | 16                  | Y                          | Split into 2 FSMC accesses |
| (multiplexed<br>I/Os and | Asynchronous      | W   | 32                  | 16                  | Y                          | Split into 2 FSMC accesses |
| nonmultiplexed<br>I/Os)  | Asynchronous page | R   | -                   | 16                  | N                          | Mode is not supported      |
|                          | Synchronous       | R   | 8                   | 16                  | N                          |                            |
|                          | Synchronous       | R   | 16                  | 16                  | Y                          |                            |
|                          | Synchronous       | R   | 32                  | 16                  | Y                          |                            |
|                          | Synchronous       | W   | 8                   | 16                  | Y                          | Use of byte lanes NBL[1:0] |
|                          | Synchronous       | W   | 16/32               | 16                  | Y                          |                            |
|                          | Asynchronous      | R   | 8 / 16              | 16                  | Y                          |                            |
|                          | Asynchronous      | W   | 8 / 16              | 16                  | Y                          | Use of byte lanes NBL[1:0] |
| SRAM and ROM             | Asynchronous      | R   | 32                  | 16                  | Y                          | Split into 2 FSMC accesses |
|                          | Asynchronous      | W   | 32                  | 16                  | Y                          | Split into 2 FSMC accesses |

 Table 172.
 NOR Flash/PSRAM supported memories and transactions (continued)

## 31.5.3 General timing rules

## Signals synchronization

- All controller output signals change on the rising edge of the internal clock (HCLK)
- In synchronous read and write mode, the output data changes on the falling edge of the memory clock (FSMC\_CLK).

# 31.5.4 NOR Flash/PSRAM controller asynchronous transactions

## Asynchronous static memories (NOR Flash, SRAM)

- Signals are synchronized by the internal clock HCLK. This clock is not issued to the memory
- The FSMC always samples the data before de-asserting the chip select signal NE. This guarantees that the memory data-hold timing constraint is met (chip enable high to data transition, usually 0 ns min.)
- When extended mode is set, it is possible to mix modes A, B, C and D in read and write (it is for instance possible to read in mode A and write in mode B).



## Mode 1 - SRAM/CRAM





### Figure 391. Mode1 write accesses



1. NBL[1:0] are driven low during read access.



The one HCLK cycle at the end of the write transaction helps guarantee the address and data hold time after the NWE rising edge. Due to the presence of this one HCLK cycle, the DATAST value must be greater than zero (DATAST > 0).

| Bit<br>number | Bit name  | Value to set                                                       |
|---------------|-----------|--------------------------------------------------------------------|
| 31-16         |           | 0x0000                                                             |
| 15            | ASYNCWAIT | Set to 1 if the memory supports this feature. Otherwise keep at 0. |
| 14-10         |           | 0x0                                                                |
| 9             | WAITPOL   | Meaningful only if bit 15 is 1                                     |
| 8             | BURSTEN   | 0x0                                                                |
| 7             |           | -                                                                  |
| 6             | FACCEN    | -                                                                  |
| 5-4           | MWID      | As needed                                                          |
| 3-2           | MTYP      | As needed, exclude 10 (NOR Flash)                                  |
| 1             | MUXEN     | 0x0                                                                |
| 0             | MBKEN     | 0x1                                                                |

Table 173. FSMC\_BCRx bit fields

#### Table 174. FSMC\_BTRx bit fields

| Bit<br>number | Bit name | Value to set                                                                                                         |
|---------------|----------|----------------------------------------------------------------------------------------------------------------------|
| 31-20         |          | 0x0000                                                                                                               |
| 19-16         | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK)                                                                      |
| 15-8          | DATAST   | Duration of the second access phase (DATAST+1 HCLK cycles for write accesses, DATAST HCLK cycles for read accesses). |
| 7-4           |          | 0x0                                                                                                                  |
| 3-0           | ADDSET   | Duration of the first access phase (ADDSET HCLK cycles).<br>Minimum value for ADDSET is 0.                           |



## Mode A - SRAM/PSRAM (CRAM) OE toggling





#### Figure 393. ModeA write accesses



<sup>1.</sup> NBL[1:0] are driven low during read access.



RM0090

The differences compared with mode1 are the toggling of NOE and the independent read and write timings.

| Bit<br>number | Bit name  | Value to set                                                       |
|---------------|-----------|--------------------------------------------------------------------|
| 31-16         |           | 0x0000                                                             |
| 15            | ASYNCWAIT | Set to 1 if the memory supports this feature. Otherwise keep at 0. |
| 14            | EXTMOD    | 0x1                                                                |
| 13-10         |           | 0x0                                                                |
| 9             | WAITPOL   | Meaningful only if bit 15 is 1                                     |
| 8             | BURSTEN   | 0x0                                                                |
| 7             |           | -                                                                  |
| 6             | FACCEN    | -                                                                  |
| 5-4           | MWID      | As needed                                                          |
| 3-2           | MTYP      | As needed, exclude 10 (NOR Flash)                                  |
| 1             | MUXEN     | 0x0                                                                |
| 0             | MBKEN     | 0x1                                                                |

Table 175. FSMC\_BCRx bit fields

#### Table 176. FSMC\_BTRx bit fields

| Bit<br>number | Bit name | Value to set                                                                                       |
|---------------|----------|----------------------------------------------------------------------------------------------------|
| 31-30         |          | 0x0                                                                                                |
| 29-28         | ACCMOD   | 0x0                                                                                                |
| 27-20         |          | 0x000                                                                                              |
| 19-16         | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK)                                                    |
| 15-8          | DATAST   | Duration of the second access phase (DATAST HCLK cycles) in read.                                  |
| 7-4           |          | 0x0                                                                                                |
| 3-0           | ADDSET   | Duration of the first access phase (ADDSET HCLK cycles) in read.<br>Minimum value for ADDSET is 1. |

### Table 177. FSMC\_BWTRx bit fields

| Bit<br>number | Bit name | Value to set                                     |  |
|---------------|----------|--------------------------------------------------|--|
| 31-30         |          | 0x0                                              |  |
| 29-28         | ACCMOD   | 0x0                                              |  |
| 27-20         |          | 0x000                                            |  |
| 19-16         | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK). |  |



Doc ID 018909 Rev 1

| Bit<br>number | Bit name | Value to set                                                                                       |
|---------------|----------|----------------------------------------------------------------------------------------------------|
| 15-8          | DATAST   | Duration of the second access phase (DATAST+1 HCLK cycles) in write.                               |
| 7-4           |          | 0x0                                                                                                |
| 3-0           | ADDSET   | Duration of the first access phase (ADDSET HCLK cycles) in write<br>Minimum value for ADDSET is 1. |

Table 177. FSMC\_BWTRx bit fields (continued)

## Mode 2/B - NOR Flash







57









The differences with mode1 are the toggling of NADV and the independent read and write timings when extended mode is set (Mode B).

Doc ID 018909 Rev 1

Bit

number

31-16

15

14

9

8

7

6

5-4

3-2

1

0

13-10

| it fields                                                          |  |  |  |  |  |
|--------------------------------------------------------------------|--|--|--|--|--|
| Value to set                                                       |  |  |  |  |  |
| 0x0000                                                             |  |  |  |  |  |
| Set to 1 if the memory supports this feature. Otherwise keep at 0. |  |  |  |  |  |
| 0x1 for mode B, 0x0 for mode 2                                     |  |  |  |  |  |

Table 178. FSMC\_BCRx bit fields

ASYNCWAIT

EXTMOD

WAITPOL

BURSTEN

FACCEN

MWID

MTYP

MUXEN

MBKEN

Bit name

0x0

0x0

0x1

0x0

0x1

As needed

10 (NOR Flash)

-

Meaningful only if bit 15 is 1

## Table 179. FSMC\_BTRx bit fields

| Bit number | Bit name | Value to set                                                                                       |
|------------|----------|----------------------------------------------------------------------------------------------------|
| 31-30      |          | 0x0                                                                                                |
| 29-28      | ACCMOD   | 0x1 if extended mode is set                                                                        |
| 27-20      |          | 0x000                                                                                              |
| 19-16      | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK)                                                    |
| 15-8       | DATAST   | Duration of the access second phase (DATAST HCLK cycles) in read.                                  |
| 7-4        |          | 0x0                                                                                                |
| 3-0        | ADDSET   | Duration of the access first phase (ADDSET HCLK cycles) in read.<br>Minimum value for ADDSET is 1. |

### Table 180. FSMC\_BWTRx bit fields

| Bit<br>number | Bit name | Value to set                                                         |
|---------------|----------|----------------------------------------------------------------------|
| 31-30         |          | 0x0                                                                  |
| 29-28         | ACCMOD   | 0x1 if extended mode is set                                          |
| 27-20         |          | 0x000                                                                |
| 19-16         | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK)                      |
| 15-8          | DATAST   | Duration of the access second phase (DATAST+1 HCLK cycles) in write. |



| Bit<br>number | Bit name | Value to set                                                                                        |
|---------------|----------|-----------------------------------------------------------------------------------------------------|
| 7-4           |          | 0x0                                                                                                 |
| 3-0           | ADDSET   | Duration of the access first phase (ADDSET HCLK cycles) in write.<br>Minimum value for ADDSET is 1. |

| Table 180. FSMC_BWTRx bit fields (continued) |
|----------------------------------------------|
|----------------------------------------------|

*Note:* The FSMC\_BWTRx register is valid only if extended mode is set (mode B), otherwise all its content is don't care.

## Mode C - NOR Flash - OE toggling



### Figure 397. ModeC read accesses





Figure 398. ModeC write accesses

The differences compared with mode1 are the toggling of NOE and NADV and the independent read and write timings.

| Bit No. | Bit name  | Value to set                                                       |
|---------|-----------|--------------------------------------------------------------------|
| 31-16   |           | 0x0000                                                             |
| 15      | ASYNCWAIT | Set to 1 if the memory supports this feature. Otherwise keep at 0. |
| 14      | EXTMOD    | 0x1                                                                |
| 13-10   |           | 0x0                                                                |
| 9       | WAITPOL   | Meaningful only if bit 15 is 1                                     |
| 8       | BURSTEN   | 0x0                                                                |
| 7       |           | -                                                                  |
| 6       | FACCEN    | 1                                                                  |
| 5-4     | MWID      | As needed                                                          |
| 3-2     | MTYP      | 0x02 (NOR Flash)                                                   |
| 1       | MUXEN     | 0x0                                                                |
| 0       | MBKEN     | 0x1                                                                |

Table 181. FSMC\_BCRx bit fields



| Bit No. | Bit name | Value to set                                                                                      |
|---------|----------|---------------------------------------------------------------------------------------------------|
| 31-30   |          | 0x0                                                                                               |
| 29-28   | ACCMOD   | 0x2                                                                                               |
| 27-20   |          | 0x000                                                                                             |
| 19-16   | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK)                                                   |
| 15-8    | DATAST   | Duration of the second access phase (DATAST HCLK cycles) in read.                                 |
| 7-4     |          | 0x0                                                                                               |
| 3-0     | ADDSET   | Duration of the first access phase (ADDSETHCLK cycles) in read.<br>Minimum value for ADDSET is 1. |

## Table 182. FSMC\_BTRx bit fields

## Table 183. FSMC\_BWTRx bit fields

| Bit No. | Bit name | Value to set                                                                                        |
|---------|----------|-----------------------------------------------------------------------------------------------------|
| 31-30   |          | 0x0                                                                                                 |
| 29-28   | ACCMOD   | 0x2                                                                                                 |
| 27-20   |          | 0x000                                                                                               |
| 19-16   | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK)                                                     |
| 15-8    | DATAST   | Duration of the second access phase (DATAST+1 HCLK cycles) in write.                                |
| 7-4     |          | 0x0                                                                                                 |
| 3-0     | ADDSET   | Duration of the first access phase (ADDSET HCLK cycles) in write.<br>Minimum value for ADDSET is 1. |







## Figure 400. ModeD write accesses



Doc ID 018909 Rev 1



The differences with mode1 are the toggling of NADV, NOE that goes on toggling after NADV changes and the independent read and write timings.

| Bit No. | Bit name  | Value to set                                                       |
|---------|-----------|--------------------------------------------------------------------|
| 31-16   |           | 0x0000                                                             |
| 15      | ASYNCWAIT | Set to 1 if the memory supports this feature. Otherwise keep at 0. |
| 14      | EXTMOD    | 0x1                                                                |
| 13-10   |           | 0x0                                                                |
| 9       | WAITPOL   | Meaningful only if bit 15 is 1                                     |
| 8       | BURSTEN   | 0x0                                                                |
| 7       |           | -                                                                  |
| 6       | FACCEN    | Set according to memory support                                    |
| 5-4     | MWID      | As needed                                                          |
| 3-2     | MTYP      | As needed                                                          |
| 1       | MUXEN     | 0x0                                                                |
| 0       | MBKEN     | 0x1                                                                |

 Table 184.
 FSMC\_BCRx bit fields

#### Table 185. FSMC\_BTRx bit fields

| Bit No. | Bit name | Value to set                                                                                      |
|---------|----------|---------------------------------------------------------------------------------------------------|
| 31-30   |          | 0x0                                                                                               |
| 29-28   | ACCMOD   | 0x2                                                                                               |
| 27-20   |          | 0x000                                                                                             |
| 19-16   | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK)                                                   |
| 15-8    | DATAST   | Duration of the second access phase (DATAST HCLK cycles) in read.                                 |
| 7-4     | ADDHLD   | Duration of the middle phase of the read access (ADDHLD HCLK cycles)                              |
| 3-0     | ADDSET   | Duration of the first access phase (ADDSETHCLK cycles) in read.<br>Minimum value for ADDSET is 1. |

#### Table 186. FSMC\_BWTRx bit fields

| Bit No. | Bit name | Value to set                                                         |
|---------|----------|----------------------------------------------------------------------|
| 31-30   |          | 0x0                                                                  |
| 29-28   | ACCMOD   | 0x2                                                                  |
| 27-20   |          | 0x000                                                                |
| 19-16   | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK)                      |
| 15-8    | DATAST   | Duration of the second access phase (DATAST+1 HCLK cycles) in write. |



| Bit No. | Bit name | Value to set                                                                                        |
|---------|----------|-----------------------------------------------------------------------------------------------------|
| 7-4     | ADDHLD   | Duration of the middle phase of the write access (ADDHLD HCLK cycles)                               |
| 3-0     | ADDSET   | Duration of the first access phase (ADDSET HCLK cycles) in write.<br>Minimum value for ADDSET is 1. |

Table 186. FSMC\_BWTRx bit fields (continued)

# Mode muxed - asynchronous access muxed NOR Flash









Figure 402. Multiplexed write accesses

The difference with mode D is the drive of the lower address byte(s) on the databus.

| Table 187. | FSMC_BCRx bit fields |  |
|------------|----------------------|--|
|------------|----------------------|--|

| Bit No. | Bit name  | Value to set                                                       |
|---------|-----------|--------------------------------------------------------------------|
| 31-16   |           | 0x0000                                                             |
| 15      | ASYNCWAIT | Set to 1 if the memory supports this feature. Otherwise keep at 0. |
| 14      | EXTMOD    | 0x0                                                                |
| 13-10   |           | 0x0                                                                |
| 9       | WAITPOL   | Meaningful only if bit 15 is 1                                     |
| 8       | BURSTEN   | 0x0                                                                |
| 7       |           | -                                                                  |
| 6       | FACCEN    | 0x1                                                                |
| 5-4     | MWID      | As needed                                                          |
| 3-2     | MTYP      | 0x2 (NOR)                                                          |
| 1       | MUXEN     | 0x1                                                                |
| 0       | MBKEN     | 0x1                                                                |

### Table 188. FSMC\_BTRx bit fields

| Bit No. | Bit name | Value to set                                    |
|---------|----------|-------------------------------------------------|
| 31-20   |          | 0x0000                                          |
| 19-16   | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK) |



Doc ID 018909 Rev 1

| Bit No. | Bit name | Value to set                                                                                                            |
|---------|----------|-------------------------------------------------------------------------------------------------------------------------|
| 15-8    | DATAST   | Duration of the second access phase (DATAST HCLK cycles for read accesses and DATAST+1 HCLK cycles for write accesses). |
| 7-4     | ADDHLD   | Duration of the middle phase of the access (ADDHLD HCLK cycles).                                                        |
| 3-0     | ADDSET   | Duration of the first access phase (ADDSET HCLK cycles).<br>Minimum value for ADDSET is 1.                              |

Table 188. FSMC\_BTRx bit fields (continued)

### WAIT management in asynchronous accesses

If the asynchronous memory asserts a WAIT signal to advise that it's not yet ready to accept or to provide data, the ASYNCWAIT bit has to be set in FSMC\_BCRx register.

If the WAIT signal is active (high or low depending on the WAITPOL bit), the second access phase (Data setup phase) programmed by the DATAST bits, is extended until WAIT becomes inactive. Unlike the data setup phase, the first access phases (Address setup and Address hold phases), programmed by the ADDSET and ADDHLD bits, are not WAIT sensitive and so they are not prolonged.

The data phase must be programmed so that WAIT can be detected 4 HCLK cycles before the data sampling. The following cases must be considered:

1. Memory asserts the WAIT signal aligned to NOE/NWE which toggles:

data\_setup phase >= 4 \* HCLK + max\_wait\_assertion\_time

2. Memory asserts the WAIT signal aligned to NEx (or NOE/NWE not toggling):

if max\_wait\_assertion\_time > (address\_phase + hold\_phase)

data\_setup phase >= 4 \* HCLK + (max\_wait\_assertion\_time - address\_phase - hold\_phase)

otherwise

data\_setup phase >= 4 \* HCLK

Where max\_wait\_assertion\_time is the maximum time taken by the memory to assert the WAIT signal once NEx/NOE/NWE is low.

The *Figure 403* and *Figure 404* show the number of HCLK clock cycles that memory access is extended after WAIT is removed by the asynchronous memory (independently of the above cases).





Figure 403. Asynchronous wait during a read access

Figure 404. Asynchronous wait during a write access





## 31.5.5 Synchronous burst transactions

The memory clock, CLK, is a submultiple of HCLK according to the value of parameter CLKDIV.

NOR Flash memories specify a minimum time from NADV assertion to CLK high. To meet this constraint, the FSMC does not issue the clock to the memory during the first internal clock cycle of the synchronous access (before NADV assertion). This guarantees that the rising edge of the memory clock occurs *in the middle* of the NADV low pulse.

## Data latency versus NOR Flash latency

The data latency is the number of cycles to wait before sampling the data. The DATLAT value must be consistent with the latency value specified in the NOR Flash configuration register. The FSMC does not include the clock cycle when NADV is low in the data latency count.

- **Caution:** Some NOR Flash memories include the NADV Low cycle in the data latency count, so the exact relation between the NOR Flash latency and the FMSC DATLAT parameter can be either of:
  - NOR Flash latency = DATLAT + 2
  - NOR Flash latency = DATLAT + 3

Some recent memories assert NWAIT during the latency phase. In such cases DATLAT can be set to its minimum value. As a result, the FSMC samples the data and waits long enough to evaluate if the data are valid. Thus the FSMC detects when the memory exits latency and real data are taken.

Other memories do not assert NWAIT during latency. In this case the latency must be set correctly for both the FSMC and the memory, otherwise invalid data are mistaken for good data, or valid data are lost in the initial phase of the memory access.

## Single-burst transfer

When the selected bank is configured in synchronous burst mode, if an AHB single-burst transaction is requested, the FSMC performs a burst transaction of length 1 (if the AHB transfer is 16-bit), or length 2 (if the AHB transfer is 32-bit) and de-assert the chip select signal when the last data is strobed.

Clearly, such a transfer is not the most efficient in terms of cycles (compared to an asynchronous read). Nevertheless, a random asynchronous access would first require to reprogram the memory access mode, which would altogether last longer.

### Wait management

For synchronous burst NOR Flash, NWAIT is evaluated after the programmed latency period, (DATALAT+2) CLK clock cycles.

If NWAIT is sensed active (low level when WAITPOL = 0, high level when WAITPOL = 1), wait states are inserted until NWAIT is sensed inactive (high level when WAITPOL = 0, low level when WAITPOL = 1).

When NWAIT is inactive, the data is considered valid either immediately (bit WAITCFG = 1) or on the next clock edge (bit WAITCFG = 0).



During wait-state insertion via the NWAIT signal, the controller continues to send clock pulses to the memory, keeping the chip select and output enable signals valid, and does not consider the data valid.

There are two timing configurations for the NOR Flash NWAIT signal in burst mode:

- Flash memory asserts the NWAIT signal one data cycle before the wait state (default after reset)
- Flash memory asserts the NWAIT signal during the wait state

These two NOR Flash wait state configurations are supported by the FSMC, individually for each chip select, thanks to the WAITCFG bit in the FSMC\_BCRx registers (x = 0..3).



#### Figure 405. Wait configurations





#### Figure 406. Synchronous multiplexed read mode - NOR, PSRAM (CRAM)

1. Byte lane outputs BL are not shown; for NOR access, they are held high, and, for PSRAM (CRAM) access, they are held low.

| Bit No. | Bit name | Value to set                                                                                                      |
|---------|----------|-------------------------------------------------------------------------------------------------------------------|
| 31-20   |          | 0x0000                                                                                                            |
| 19      | CBURSTRW | No effect on synchronous read                                                                                     |
| 18-15   |          | 0x0                                                                                                               |
| 14      | EXTMOD   | 0x0                                                                                                               |
| 13      | WAITEN   | When high, the first data after latency period is taken as always valid, regardless of the wait from memory value |
| 12      | WREN     | no effect on synchronous read                                                                                     |
| 11      | WAITCFG  | to be set according to memory                                                                                     |
| 10      | WRAPMOD  | no effect                                                                                                         |
| 9       | WAITPOL  | to be set according to memory                                                                                     |

#### Table 189. FSMC\_BCRx bit fields



| Bit No. | Bit name | Value to set                                       |
|---------|----------|----------------------------------------------------|
| 8       | BURSTEN  | 0x1                                                |
| 7       | FWPRLVL  | Set to protect memory from accidental write access |
| 6       | FACCEN   | Set according to memory support                    |
| 5-4     | MWID     | As needed                                          |
| 3-2     | MTYP     | 0x1 or 0x2                                         |
| 1       | MUXEN    | As needed                                          |
| 0       | MBKEN    | 0x1                                                |

Table 189. FSMC\_BCRx bit fields (continued)

## Table 190. FSMC\_BTRx bit fields

| Bit No. | Bit name | Value to set                                           |
|---------|----------|--------------------------------------------------------|
| 27-24   | DATLAT   | Data latency                                           |
| 23-20   | CLKDIV   | 0x0 to get CLK = HCLK<br>0x1 to get CLK = 2 × HCLK<br> |
| 19-16   | BUSTURN  | Time between NEx high to NEx low (BUSTURN HCLK)        |
| 15-8    | DATAST   | no effect                                              |
| 7-4     | ADDHLD   | no effect                                              |
| 3-0     | ADDSET   | no effect                                              |





### Figure 407. Synchronous multiplexed write mode - PSRAM (CRAM)

1. Memory must issue NWAIT signal one cycle in advance, accordingly WAITCFG must be programmed to 0.

2. Byte Lane (NBL) outputs are not shown, they are held low while NEx is active.





| Bit No. | Bit name | Value to set                                                                                                      |
|---------|----------|-------------------------------------------------------------------------------------------------------------------|
| 31-20   |          | 0x0000                                                                                                            |
| 19      | CBURSTRW | 0x1                                                                                                               |
| 18-15   |          | 0x0                                                                                                               |
| 14      | EXTMOD   | 0x0                                                                                                               |
| 13      | WAITEN   | When high, the first data after latency period is taken as always valid, regardless of the wait from memory value |
| 12      | WREN     | no effect on synchronous read                                                                                     |
| 11      | WAITCFG  | 0x0                                                                                                               |
| 10      | WRAPMOD  | no effect                                                                                                         |
| 9       | WAITPOL  | to be set according to memory                                                                                     |
| 8       | BURSTEN  | no effect on synchronous write                                                                                    |
| 7       | FWPRLVL  | Set to protect memory from accidental writes                                                                      |
| 6       | FACCEN   | Set according to memory support                                                                                   |
| 5-4     | MWID     | As needed                                                                                                         |
| 3-2     | MTYP     | 0x1                                                                                                               |
| 1       | MUXEN    | As needed                                                                                                         |
| 0       | MBKEN    | 0x1                                                                                                               |

# Table 191. FSMC\_BCRx bit fields

### Table 192. FSMC\_BTRx bit fields

| Bit No. | Bit name | Value to set                                                   |
|---------|----------|----------------------------------------------------------------|
| 31-30   | -        | 0x0                                                            |
| 27-24   | DATLAT   | Data latency                                                   |
| 23-20   | CLKDIV   | 0 to get CLK = HCLK (not supported)<br>1 to get CLK = 2 × HCLK |
| 19-16   | BUSTURN  | No effect                                                      |
| 15-8    | DATAST   | No effect                                                      |
| 7-4     | ADDHLD   | No effect                                                      |
| 3-0     | ADDSET   | No effect                                                      |

## 31.5.6 NOR/PSRAM controller registers

### SRAM/NOR-Flash chip-select control registers 1..4 (FSMC\_BCR1..4)

Address offset: 0xA000 0000 + 8 \* (x - 1), x = 1...4

Reset value: 0x0000 30DX

This register contains the control information of each memory bank, used for SRAMs, ROMs and asynchronous or burst NOR Flash memories.

| 31 30 29 28 27 26 25 24 23 22 21 20 | 19       | 18 | 17    | 16 | 15        | 14     | 13     | 12   | 11      | 10      | 9       | 8       | 7        | 6      | 5  | 4    | 3     | 2  | 1     | 0     |
|-------------------------------------|----------|----|-------|----|-----------|--------|--------|------|---------|---------|---------|---------|----------|--------|----|------|-------|----|-------|-------|
| Reserved                            | CBURSTRW | Re | serve | əd | ASCYCWAIT | EXTMOD | WAITEN | WREN | WAITCFG | WRAPMOD | WAITPOL | BURSTEN | Reserved | FACCEN |    | CIMM | avt.M |    | MUXEN | MBKEN |
|                                     | rw       |    |       |    | rw        | rw     | rw     | rw   | rw      | rw      | rw      | rw      |          | rw     | rw | rw   | rw    | rw | rw    | rw    |

Bit 19 **CBURSTRW:** Write burst enable.

For Cellular RAM, the bit enables synchronous burst protocol during write operations. For Flash memory access in burst mode, this bit enables/disables the wait state insertion via the NWAIT signal. The enable bit for the synchronous burst protocol during read access is the BURSTEN bit in the FSMC\_BCRx register.

0: Write operations are always performed in asynchronous mode

1: Write operations are performed in synchronous mode.

### Bit 15 ASYNCWAIT: Wait signal during asynchronous transfers

This bit enables the FSMC to use the wait signal even during an asynchronous protocol. 0: NWAIT signal is not taken in to account when running an asynchronous protocol (default after reset)

- 1: NWAIT signal is taken in to account when running an asynchronous protocol
- Bit 14 EXTMOD: Extended mode enable.

This bit enables the FSMC to program inside the FSMC\_BWTR register, so it allows different timings for read and write.

- 0: values inside FSMC\_BWTR register are not taken into account (default after reset)
- 1: values inside FSMC\_BWTR register are taken into account

#### Bit 13 WAITEN: Wait enable bit.

For Flash memory access in burst mode, this bit enables/disables wait-state insertion via the NWAIT signal:

0: NWAIT signal is disabled (its level not taken into account, no wait state inserted after the programmed Flash latency period)

1: NWAIT signal is enabled (its level is taken into account after the programmed Flash latency period to insert wait states if asserted) (default after reset)

### Bit 12 WREN: Write enable bit.

- This bit indicates whether write operations are enabled/disabled in the bank by the FSMC:
- 0: Write operations are disabled in the bank by the FSMC, an AHB error is reported,
- 1: Write operations are enabled for the bank by the FSMC (default after reset).



Bit 11 WAITCFG: Wait timing configuration.

For memory access in burst mode, the NWAIT signal indicates whether the data from the memory are valid or if a wait state must be inserted. This configuration bit determines if NWAIT is asserted by the memory one clock cycle before the wait state or during the wait state:

0: NWAIT signal is active one data cycle before wait state (default after reset),

1: NWAIT signal is active during wait state (not for Cellular RAM).

#### Bit 10 WRAPMOD: Wrapped burst mode support.

Defines whether the controller will or not split an AHB burst wrap access into two linear accesses. Valid only when accessing memories in burst mode

- 0: Direct wrapped burst is not enabled (default after reset),
- 1: Direct wrapped burst is enabled.

Note: This bit has no effect as the CPU and DMA cannot generate wrapping burst transfers.

#### Bit 9 WAITPOL: Wait signal polarity bit.

Defines the polarity of the wait signal from memory. Valid only when accessing the memory in burst mode:

0: NWAIT active low (default after reset),

1: NWAIT active high.

#### Bit 8 BURSTEN: Burst enable bit.

Enables the burst access mode for the memory. Valid only with synchronous burst memories: 0: Burst access mode disabled (default after reset)

- 1: Burst access mode enable
- Bit 7 Reserved, must be kept at reset value..

#### Bit 6 FACCEN: Flash access enable

Enables NOR Flash memory access operations.

0: Corresponding NOR Flash memory access is disabled

1: Corresponding NOR Flash memory access is enabled (default after reset)

#### Bits 5:4 MWID: Memory databus width.

Defines the external memory device width, valid for all type of memories.

00: 8 bits,

- 01: 16 bits (default after reset),
- 10: reserved, do not use,
- 11: reserved, do not use.

### Bits 3:2 MTYP: Memory type.

Defines the type of external memory attached to the corresponding memory bank:

00: SRAM, ROM (default after reset for Bank 2...4)

01: PSRAM (Cellular RAM: CRAM)

10: NOR Flash/OneNAND Flash (default after reset for Bank 1)

11: reserved

#### Bit 1 MUXEN: Address/data multiplexing enable bit.

When this bit is set, the address and data values are multiplexed on the databus, valid only with NOR and PSRAM memories:

- 0: Address/Data nonmultiplexed
- 1: Address/Data multiplexed on databus (default after reset)
- Bit 0 MBKEN: Memory bank enable bit.

Enables the memory bank. After reset Bank1 is enabled, all others are disabled. Accessing a disabled bank causes an ERROR on AHB bus.

- 0: Corresponding memory bank is disabled
- 1: Corresponding memory bank is enabled





### SRAM/NOR-Flash chip-select timing registers 1..4 (FSMC\_BTR1..4)

Address offset: 0xA000 0000 + 0x04 + 8 \* (x - 1), x = 1..4

Reset value: 0x0FFF FFFF

This register contains the control information of each memory bank, used for SRAMs, ROMs and NOR Flash memories. If the EXTMOD bit is set in the FSMC\_BCRx register, then this register is partitioned for write and read access, that is, 2 registers are available: one to configure read accesses (this register) and one to configure write accesses (FSMC\_BWTRx registers).

| 3 | 30       | 29 | 28       | 27 | 26 | 25     | 24 | 23 | 22 | 21     | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5      | 4  | 3  | 2  | 1      | 0  |
|---|----------|----|----------|----|----|--------|----|----|----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|--------|----|
|   | leserved |    | AUCINION |    |    | DALLAI |    |    |    | CENDIN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | אעטורט |    |    |    | AUUSEI |    |
|   | ш.       | rw | rw       | rw | rw | rw     | rw | rw | rw | rw     | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw     | rw | rw | rw | rw     | rw |

Bits 29:28 ACCMOD: Access mode

Specifies the asynchronous access modes as shown in the timing diagrams. These bits are taken into account only when the EXTMOD bit in the FSMC\_BCRx register is 1.

- 00: access mode A
- 01: access mode B
- 10: access mode C
- 11: access mode D
- Bits 27:24 DATLAT: Data latency for synchronous burst NOR Flash memory

For NOR Flash with synchronous burst mode enabled, defines the number of memory clock cycles (+2) to issue to the memory before getting the first data: 0000: Data latency of 2 CLK clock cycles for first burst access

1111: Data latency of 17 CLK clock cycles for first burst access (default value after reset)

Note: This timing parameter is not expressed in HCLK periods, but in Flash clock (CLK) periods. In asynchronous NOR Flash, SRAM or ROM accesses, this value is don't care. In the case of CRAM, this field must be set to '0'.

#### Bits 23:20 **CLKDIV:** Clock divide ratio (for CLK signal)

Defines the period of CLK clock output signal, expressed in number of HCLK cycles: 0000: Reserved

0001: CLK period =  $2 \times HCLK$  periods

0010: CLK period =  $3 \times$  HCLK periods

1111: CLK period =  $16 \times HCLK$  periods (default value after reset)

In asynchronous NOR Flash, SRAM or ROM accesses, this value is don't care.



Bits 19:16 BUSTURN: Bus turnaround phase duration

These bits are written by software to insert the bus turnaround delay after a read access only from multiplexed NOR Flash memory to avoid bus contention if the controller needs to drive addresses on the databus for the next side-by-side transaction. BUSTURN can be set to the minimum if the slowest memory does not take more than 6 HCLK clock cycles to put the databus in Hi-Z state.

These bits are written by software to add a delay at the end of a write/read transaction. This delay allows to match the minimum time between consecutive transactions ( $t_{EHEL}$  from NEx high to NEx low) and the maximum time needed by the memory to free the data bus after a read access (tEHQZ):

(BUSTRUN + 1)HCLK period  $\geq$  t<sub>EHELmin</sub> and (BUSTRUN + 2)HCLK period  $\geq$  t<sub>EHQZmax</sub> if EXTMOD = '0'

 $(BUSTRUN + 2)HCLK \text{ period} \geq max (t_{EHELmin}, t_{EHQZmax}) \text{ if EXTMOD} = `1`. 0000: BUSTURN phase duration = 0 HCLK clock cycle added$ 

1111: BUSTURN phase duration = 15 × HCLK clock cycles (default value after reset)

Bits 15:8 **DATAST:** Data-phase duration

These bits are written by software to define the duration of the data phase (refer to *Figure 390* to *Figure 402*), used in SRAMs, ROMs and asynchronous NOR Flash accesses: 0000 0000: Reserved 0000 0001: DATAST phase duration =  $1 \times HCLK$  clock cycles 0000 0011: DATAST phase duration =  $2 \times HCLK$  clock cycles

0000 0010: DATAST phase duration = 2 × HCLK clock cycles

1111 1111: DATAST phase duration =  $255 \times \text{HCLK}$  clock cycles (default value after reset) For each memory type and access mode data-phase duration, please refer to the respective figure (*Figure 390* to *Figure 402*).

Example: Mode1, write access, DATAST=1: Data-phase duration= DATAST+1 = 2 HCLK clock cycles.

Note: In synchronous accesses, this value is don't care.

#### Bits 7:4 ADDHLD: Address-hold phase duration

These bits are written by software to define the duration of the *address hold* phase (refer to *Figure 399* to *Figure 402*), used in mode D and multiplexed accesses:

0000: Reserved

0001: ADDHLD phase duration  $=1 \times$  HCLK clock cycle 0010: ADDHLD phase duration  $= 2 \times$  HCLK clock cycle

1111: ADDHLD phase duration =  $15 \times$  HCLK clock cycles (default value after reset) For each access mode address-hold phase duration, please refer to the respective figure (*Figure 399* to *Figure 402*).

Note: In synchronous accesses, this value is not used, the address hold phase is always 1 memory clock period duration.

#### Bits 3:0 ADDSET: Address setup phase duration

These bits are written by software to define the duration of the *address setup* phase (refer to *Figure 390* to *Figure 402*), used in SRAMs, ROMs and asynchronous NOR Flash accesses: 0000: ADDSET phase duration =  $0 \times HCLK$  clock cycle

1111: ADDSET phase duration =  $1615 \times \text{HCLK}$  clock cycles (default value after reset) For each access mode address setup phase duration, please refer to the respective figure (refer to *Figure 390* to *Figure 402*).

Note: In synchronous accesses, this value is don't care.



Note: PSRAMs (CRAMs) have a variable latency due to internal refresh. Therefore these memories issue the NWAIT signal during the whole latency phase to prolong the latency as needed.

With PSRAMs (CRAMs) the filed DATLAT must be set to 0, so that the FSMC exits its latency phase soon and starts sampling NWAIT from memory, then starts to read or write when the memory is ready.

This method can be used also with the latest generation of synchronous Flash memories that issue the NWAIT signal, unlike older Flash memories (check the datasheet of the specific Flash memory being used).

## SRAM/NOR-Flash write timing registers 1..4 (FSMC\_BWTR1..4)

Address offset: 0xA000 0000 + 0x104 + 8 \* (x - 1), x = 1...4

Reset value: 0x0FFF FFFF

This register contains the control information of each memory bank, used for SRAMs, ROMs and NOR Flash memories. When the EXTMOD bit is set in the FSMC\_BCRx register, then this register is active for write access.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 | 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------|
|-------------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------|

| Res. |    | CM<br>D |    | DAT | LAT |    |    | CLK | DIV |    | Reserved |    | DATAST |    |    |    |    |    | ADD | HLD |    |    | ADD | SET |    |    |    |
|------|----|---------|----|-----|-----|----|----|-----|-----|----|----------|----|--------|----|----|----|----|----|-----|-----|----|----|-----|-----|----|----|----|
|      | rw | rw      | rw | rw  | rw  | rw | rw | rw  | rw  | rw |          | rw | rw     | rw | rw | rw | rw | rw | rw  | rw  | rw | rw | rw  | rw  | rw | rw | rw |

Bits 29:28 ACCMOD: Access mode.

Specifies the asynchronous access modes as shown in the next timing diagrams. These bits are taken into account only when the EXTMOD bit in the FSMC\_BCRx register is 1.

- 00: access mode A
- 01: access mode B
- 10: access mode C
- 11: access mode D

#### Bits 27:24 DATLAT: Data latency (for synchronous burst NOR Flash).

For NOR Flash with Synchronous burst mode enabled, defines the number of memory clock cycles (+2) to issue to the memory before getting the first data:

0000: (0x0) Data latency of 2 CLK clock cycles for first burst access

1111: (0xF) Data latency of 17 CLK clock cycles for first burst access (default value after reset)

Note: This timing parameter is not expressed in HCLK periods, but in Flash clock (**CLK**) periods. In asynchronous NOR Flash, SRAM or ROM accesses, this value is don't care. In case of CRAM, this field must be set to 0

Bits 23:20 **CLKDIV:** Clock divide ratio (for CLK signal).

Defines the period of CLK clock output signal, expressed in number of HCLK cycles: 0000: Reserved

0001 CLK period =  $2 \times HCLK$  periods

0010 CLK period = 3 × HCLK periods

1111: CLK period = 16 × HCLK periods (default value after reset)

In asynchronous NOR Flash, SRAM or ROM accesses, this value is don't care.



Bits 19:16 BUSTURN: Bus turnaround phase duration

These bits are written by software to add a delay at the end of a write transaction to match the minimum time between consecutive transactions ( $t_{EHEL}$  from ENx high to ENx low): (BUSTRUN + 1) HCLK period  $\ge t_{EHELmin}$ . 0000: BUSTURN phase duration = 0 HCLK clock cycle added

1111: BUSTURN phase duration = 15 HCLK clock cycles added (default value after reset)

Bits 15:8 DATAST: Data-phase duration.

These bits are written by software to define the duration of the data phase (refer to *Figure 390* to *Figure 402*), used in SRAMs, ROMs and asynchronous NOR Flash accesses: 0000 0000: Reserved 0000 0001: DATAST phase duration =  $1 \times HCLK$  clock cycles 0000 0010: DATAST phase duration =  $2 \times HCLK$  clock cycles

1111 1111: DATAST phase duration = 255 × HCLK clock cycles (default value after reset) Note: In synchronous accesses, this value is don't care.

Bits 7:4 **ADDHLD:** Address-hold phase duration.

These bits are written by software to define the duration of the *address hold* phase (refer to *Figure 399* to *Figure 402*), used in SRAMs, ROMs and asynchronous multiplexed NOR Flash accesses: 0000: Reserved 0001: ADDHLD phase duration = 1 × HCLK clock cycle

0010: ADDHLD phase duration = 2 × HCLK clock cycle

1111: ADDHLD phase duration = 15 × HCLK clock cycles (default value after reset)

Note: In synchronous NOR Flash accesses, this value is not used, the address hold phase is always 1 Flash clock period duration.

#### Bits 3:0 **ADDSET:** Address setup phase duration.

These bits are written by software to define the duration of the *address setup* phase in HCLK cycles (refer to *Figure 399* to *Figure 402*), used in SRAMs, ROMs and asynchronous NOR Flash accessed:

0000: ADDSET phase duration = 0 × HCLK clock cycle

1111: ADDSET phase duration = 15 × HCLK clock cycles (default value after reset) Note: In synchronous NOR Flash accesses, this value is don't care.

# 31.6 NAND Flash/PC Card controller

The FSMC generates the appropriate signal timings to drive the following types of device:

- NAND Flash
- 8-bit
  - 16-bit
- 16-bit PC Card compatible devices

The NAND/PC Card controller can control three external banks. Bank 2 and bank 3 support NAND Flash devices. Bank 4 supports PC Card devices.

Each bank is configured by means of dedicated registers (*Section 31.6.8*). The programmable memory parameters include access timings (shown in *Table 193*) and ECC configuration.





| Parameter                | Function                                                                                                                           | Access mode | Unit                      | Min. | Max. |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------|------|------|
| Memory setup<br>time     | Number of clock cycles (HCLK)<br>to set up the address before the<br>command assertion                                             | Read/Write  | AHB clock cycle<br>(HCLK) | 1    | 256  |
| Memory wait              | Minimum duration (HCLK clock cycles) of the command assertion                                                                      | Read/Write  | AHB clock cycle<br>(HCLK) | 2    | 256  |
| Memory hold              | Number of clock cycles (HCLK)<br>to hold the address (and the data<br>in case of a write access) after<br>the command de-assertion | Read/Write  | AHB clock cycle<br>(HCLK) | 1    | 255  |
| Memory<br>databus high-Z | Number of clock cycles (HCLK)<br>during which the databus is kept<br>in high-Z state after the start of a<br>write access          | Write       | AHB clock cycle<br>(HCLK) | 0    | 255  |

 Table 193.
 Programmable NAND/PC Card access parameters

# 31.6.1 External memory interface signals

The following tables list the signals that are typically used to interface NAND Flash and PC Card.

- **Caution:** When using a PC Card or a CompactFlash in I/O mode, the NIOS16 input pin must remain at ground level during the whole operation, otherwise the FSMC may not operate properly. This means that the NIOS16 input pin must *not* be connected to the card, but directly to ground (only 16-bit accesses are allowed).
- Note: Prefix "N". specifies the associated signal as active low.

## 8-bit NAND Flash

### Table 194.8-bit NAND Flash

| FSMC signal name | I/O | Function                                             |
|------------------|-----|------------------------------------------------------|
| A[17]            | 0   | NAND Flash address latch enable (ALE) signal         |
| A[16]            | 0   | NAND Flash command latch enable (CLE) signal         |
| D[7:0]           | I/O | 8-bit multiplexed, bidirectional address/data bus    |
| NCE[x]           | 0   | Chip select, x = 2, 3                                |
| NOE(= NRE)       | 0   | Output enable (memory signal name: read enable, NRE) |
| NWE              | 0   | Write enable                                         |
| NWAIT/INT[3:2]   | I   | NAND Flash ready/busy input signal to the FSMC       |

There is no theoretical capacity limitation as the FSMC can manage as many address cycles as needed.



# 16-bit NAND Flash

| Table 195. | 16-bit NAND Flash |
|------------|-------------------|
|------------|-------------------|

| FSMC signal name | I/O | Function                                             |
|------------------|-----|------------------------------------------------------|
| A[17]            | 0   | NAND Flash address latch enable (ALE) signal         |
| A[16]            | 0   | NAND Flash command latch enable (CLE) signal         |
| D[15:0]          | I/O | 16-bit multiplexed, bidirectional address/data bus   |
| NCE[x]           | 0   | Chip select, x = 2, 3                                |
| NOE(= NRE)       | 0   | Output enable (memory signal name: read enable, NRE) |
| NWE              | 0   | Write enable                                         |
| NWAIT/INT[3:2]   | I   | NAND Flash ready/busy input signal to the FSMC       |

There is no theoretical capacity limitation as the FSMC can manage as many address cycles as needed.

| FSMC signal name | I/O | Function                                                                                                                                                                        |
|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A[10:0]          | 0   | Address bus                                                                                                                                                                     |
| NIOS16           | Ι   | Data transfer in I/O space. It must be shorted to GND (16-bit transfer only)                                                                                                    |
| NIORD            | 0   | Output enable for I/O space                                                                                                                                                     |
| NIOWR            | 0   | Write enable for I/O space                                                                                                                                                      |
| NREG             | 0   | Register signal indicating if access is in Common or Attribute space                                                                                                            |
| D[15:0]          | I/O | Bidirectional databus                                                                                                                                                           |
| NCE4_1           | 0   | Chip select 1                                                                                                                                                                   |
| NCE4_2           | 0   | Chip select 2 (indicates if access is 16-bit or 8-bit)                                                                                                                          |
| NOE              | 0   | Output enable in Common and in Attribute space                                                                                                                                  |
| NWE              | 0   | Write enable in Common and in Attribute space                                                                                                                                   |
| NWAIT            | Ι   | PC Card wait input signal to the FSMC (memory signal name IORDY)                                                                                                                |
| INTR             | I   | PC Card interrupt to the FSMC (only for PC Cards that can generate an interrupt)                                                                                                |
| CD               | I   | PC Card presence detection. Active high. If an access is performed to the PC Card banks while CD is low, an AHB error is generated. Refer to <i>Section 31.3: AHB interface</i> |

### Table 196. 16-bit PC Card



# 31.6.2 NAND Flash / PC Card supported memories and transactions

*Table 197* below shows the supported devices, access modes and transactions. Transactions not allowed (or not supported) by the NAND Flash / PC Card controller appear in gray.

| Device        | Mode         | R/W | AHB<br>data size | Memory<br>data size | Allowed/<br>not allowed | Comments                   |
|---------------|--------------|-----|------------------|---------------------|-------------------------|----------------------------|
|               | Asynchronous | R   | 8                | 8                   | Y                       |                            |
|               | Asynchronous | W   | 8                | 8                   | Y                       |                            |
| NAND 8-bit    | Asynchronous | R   | 16               | 8                   | Y                       | Split into 2 FSMC accesses |
| INAIND O-DIL  | Asynchronous | W   | 16               | 8                   | Y                       | Split into 2 FSMC accesses |
|               | Asynchronous | R   | 32               | 8                   | Y                       | Split into 4 FSMC accesses |
|               | Asynchronous | W   | 32               | 8                   | Y                       | Split into 4 FSMC accesses |
|               | Asynchronous | R   | 8                | 16                  | Y                       |                            |
|               | Asynchronous | W   | 8                | 16                  | N                       |                            |
| NAND 16-bit   | Asynchronous | R   | 16               | 16                  | Y                       |                            |
| INAIND TO-DIL | Asynchronous | W   | 16               | 16                  | Y                       |                            |
|               | Asynchronous | R   | 32               | 16                  | Y                       | Split into 2 FSMC accesses |
|               | Asynchronous | W   | 32               | 16                  | Y                       | Split into 2 FSMC accesses |

Table 197. Supported memories and transactions

# 31.6.3 Timing diagrams for NAND and PC Card

Each PC Card/CompactFlash and NAND Flash memory bank is managed through a set of registers:

- Control register: FSMC\_PCRx
- Interrupt status register: FSMC\_SRx
- ECC register: FSMC\_ECCRx
- Timing register for Common memory space: FSMC\_PMEMx
- Timing register for Attribute memory space: FSMC\_PATTx
- Timing register for I/O space: FSMC\_PIOx

Each timing configuration register contains three parameters used to define number of HCLK cycles for the three phases of any PC Card/CompactFlash or NAND Flash access, plus one parameter that defines the timing for starting driving the databus in the case of a write. *Figure 408* shows the timing parameter definitions for common memory accesses, knowing that Attribute and I/O (only for PC Card) memory space access timings are similar.







1. NOE remains high (inactive) during write access. NWE remains high (inactive) during read access.

# 31.6.4 NAND Flash operations

The command latch enable (CLE) and address latch enable (ALE) signals of the NAND Flash device are driven by some address signals of the FSMC controller. This means that to send a command or an address to the NAND Flash memory, the CPU has to perform a write to a certain address in its memory space.

A typical page read operation from the NAND Flash device is as follows:

- Program and enable the corresponding memory bank by configuring the FSMC\_PCRx and FSMC\_PMEMx (and for some devices, FSMC\_PATTx, see Section 31.6.5: NAND Flash pre-wait functionality on page 1266) registers according to the characteristics of the NAND Flash (PWID bits for the databus width of the NAND Flash, PTYP = 1, PWAITEN = 1, PBKEN = 1, see section Common memory space timing register 2..4 (FSMC\_PMEM2..4) on page 1272 for timing configuration).
- 2. The CPU performs a byte write in the common memory space, with data byte equal to one Flash command byte (for example 0x00 for Samsung NAND Flash devices). The CLE input of the NAND Flash is active during the write strobe (low pulse on NWE), thus the written byte is interpreted as a command by the NAND Flash. Once the command is latched by the NAND Flash device, it does not need to be written for the following page read operations.
- 3. The CPU can send the start address (STARTAD) for a read operation by writing four bytes (or three for smaller capacity devices), STARTAD[7:0], then STARTAD[16:9], STARTAD[24:17] and finally STARTAD[25] for 64 Mb x 8 bit NAND Flash) in the common memory or attribute space. The ALE input of the NAND Flash device is active during the write strobe (low pulse on NWE), thus the written bytes are interpreted as the start address for read operations. Using the attribute memory space makes it



possible to use a different timing configuration of the FSMC, which can be used to implement the prewait functionality needed by some NAND Flash memories (see details in *Section 31.6.5: NAND Flash pre-wait functionality on page 1266*).

- 4. The controller waits for the NAND Flash to be ready (R/NB signal high) to become active, before starting a new access (to same or another memory bank). While waiting, the controller maintains the NCE signal active (low).
- 5. The CPU can then perform byte read operations in the common memory space to read the NAND Flash page (data field + Spare field) byte by byte.
- 6. The next NAND Flash page can be read without any CPU command or address write operation, in three different ways:
  - by simply performing the operation described in step 5
  - a new random address can be accessed by restarting the operation at step 3
  - a new command can be sent to the NAND Flash device by restarting at step 2

### 31.6.5 NAND Flash pre-wait functionality

Some NAND Flash devices require that, after writing the last part of the address, the controller wait for the R/NB signal to go low as shown in *Figure 409*.



#### Figure 409. Access to non 'CE don't care' NAND-Flash

- 1. CPU wrote byte 0x00 at address 0x7001 0000.
- 2. CPU wrote byte A7~A0 at address 0x7002 0000.
- 3. CPU wrote byte A16~A9 at address 0x7002 0000.
- 4. CPU wrote byte A24~A17 at address 0x7002 0000.
- 5. CPU wrote byte A25 at address 0x7802 0000: FSMC performs a write access using FSMC\_PATT2 timing definition, where ATTHOLD ≥ 7 (providing that (7+1) × HCLK = 112 ns > t<sub>WB</sub> max). This guarantees that NCE remains low until R/NB goes low and high again (only requested for NAND Flash memories where NCE is not don't care).



When this functionality is needed, it can be guaranteed by programming the MEMHOLD value to meet the  $t_{WB}$  timing, however any CPU read or write access to the NAND Flash then has the hold delay of (MEMHOLD + 1) HCLK cycles inserted from the rising edge of the NWE signal to the next access.

To overcome this timing constraint, the attribute memory space can be used by programming its timing register with an ATTHOLD value that meets the  $t_{WB}$  timing, and leaving the MEMHOLD value at its minimum. Then, the CPU must use the common memory space for all NAND Flash read and write accesses, except when writing the last address byte to the NAND Flash device, where the CPU must write to the attribute memory space.

# 31.6.6 Error correction code computation ECC (NAND Flash)

The FSMC PC-Card controller includes two error correction code computation hardware blocks, one per memory bank. They are used to reduce the host CPU workload when processing the error correction code by software in the system.

These two registers are identical and associated with bank 2 and bank 3, respectively. As a consequence, no hardware ECC computation is available for memories connected to bank 4.

The error correction code (ECC) algorithm implemented in the FSMC can perform 1-bit error correction and 2-bit error detection per 256, 512, 1 024, 2 048, 4 096 or 8 192 bytes read from or written to NAND Flash.

The ECC modules monitor the NAND Flash databus and read/write signals (NCE and NWE) each time the NAND Flash memory bank is active.

The functional operations are:

- When access to NAND Flash is made to bank 2 or bank 3, the data present on the D[15:0] bus is latched and used for ECC computation.
- When access to NAND Flash occurs at any other address, the ECC logic is idle, and does not perform any operation. Thus, write operations for defining commands or addresses to NAND Flash are not taken into account for ECC computation.

Once the desired number of bytes has been read from/written to the NAND Flash by the host CPU, the FSMC\_ECCR2/3 registers must be read in order to retrieve the computed value. Once read, they should be cleared by resetting the ECCEN bit to zero. To compute a new data block, the ECCEN bit must be set to one in the FSMC\_PCR2/3 registers.

# 31.6.7 PC Card/CompactFlash operations

### Address spaces & memory accesses

The FSMC supports Compact Flash storage or PC Cards in Memory Mode and I/O Mode (True IDE mode is not supported).

The Compact Flash storage and PC Cards are made of 3 memory spaces:

- Common Memory Space
- Attribute Space
- I/O Memory Space

The nCE2 and nCE1 pins (FSMC\_NCE4\_2 and FSMC\_NCE4\_1 respectively) select the card and indicate whether a byte or a word operation is being performed: nCE2 accesses



the odd byte on D15-8 and nCE1 accesses the even byte on D7-0 if A0=0 or the odd byte on D7-0 if A0=1. The full word is accessed on D15-0 if both nCE2 and nCE1 are low.

The memory space is selected by asserting low nOE for read accesses or nWE for write accesses, combined with the low assertion of nCE2/nCE1 and nREG.

- If pin nREG=1 during the memory access, the common memory space is selected
- If pin nREG=0 during the memory access, the attribute memory space is selected

The I/O Space is selected by asserting low nIORD for read accesses or nIOWR for write accesses [instead of nOE/nWE for memory Space], combined with nCE2/nCE1. Note that nREG must also be asserted low during accesses to I/O Space.

Three type of accesses are allowed for a 16-bit PC Card:

 Accesses to Common Memory Space for data storage can be either 8-bit accesses at even addresses or 16 bit AHB accesses.

Note that 8-bit accesses at odd addresses are not supported and will not lead to the low assertion of nCE2. A 32-bit AHB request is translated into two 16-bit memory accesses.

 Accesses to Attribute Memory Space where the PC Card stores configuration information are limited to 8-bit AHB accesses at even addresses.

Note that a 16-bit AHB access will be converted into a single 8-bit memory transfer: nCE1 will be asserted low, NCE2 will be asserted high and only the even Byte on D7-D0 will be valid. Instead a 32-bit AHB access will be converted into two 8-bit memory transfers at even addresses: nCE1 will be asserted low, NCE2 will be asserted high and only the even bytes will be valid.

Accesses to I/O Space must be limited to AHB 16 bit accesses.

| nCE2 | nCE1 | nREG | nOE/nWE | nIORD /nIOWR | A10 | 6 <b>0</b> | A7-1 | AO | Space              | Access Type                                       | Allowed/not<br>Allowed |
|------|------|------|---------|--------------|-----|------------|------|----|--------------------|---------------------------------------------------|------------------------|
| 1    | 0    | 1    | 0       | 1            | Х   | Х          | X-X  | Х  |                    | Read/Write byte on D7-D0                          | YES                    |
|      | YES  |      |         |              |     |            |      |    | Common             | Thead/ while byte of D7-D0                        | YES                    |
| 0    | 1    | 1    | 0       | 1            | Х   | Х          | X-X  | Х  | Memory<br>Space    | Read/Write byte on D15-D8                         | Not supported          |
| 0    | 0    | 1    | 0       | 1            | Х   | Х          | X-X  | 0  |                    | Read/Write word on D15-D0                         | YES                    |
| x    | 0    | 0    | 0       | 1            | 0   | 1          | x-x  | 0  | Attribute          | Read or Write Configuration Registers             | YES                    |
| x    | 0    | 0    | 0       | 1            | 0   | 0          | x-x  | 0  | Space              | Read or Write CIS (Card<br>Information Structure) | YES                    |
| 1    | 0    | 0    | 0       | 1            | Х   | Х          | X-X  | 1  | Invalid            | Read or Write (odd address)                       | YES                    |
| 0    | 1    | 0    | 0       | 1            | х   | х          | X-X  | x  | Attribute<br>Space | Read or Write (odd address)                       | YES                    |

 Table 198.
 16-bit PC-Card signals and access type



| nCE2 | nCE1 | nREG | nOE/nWE | nIORD /nIOWR | A10 | A9 | A7-1 | AO | Space     | Access Type             | Allowed/not<br>Allowed |
|------|------|------|---------|--------------|-----|----|------|----|-----------|-------------------------|------------------------|
| 1    | 0    | 0    | 1       | 0            | Х   | Х  | X-X  | 0  |           | Read Even Byte on D7-0  | Not supported          |
| 1    | 0    | 0    | 1       | 0            | Х   | Х  | X-X  | 1  |           | Read Odd Byte on D7-0   | Not supported          |
| 1    | 0    | 0    | 1       | 0            | Х   | Х  | X-X  | 0  |           | Write Even Byte on D7-0 | Not supported          |
| 1    | 0    | 0    | 1       | 0            | Х   | Х  | X-X  | 1  | 1/0 00000 | Write Odd Byte on D7-0  | Not supported          |
| 0    | 0    | 0    | 1       | 0            | Х   | Х  | X-X  | 0  | I/O space | Read Word on D15-0      | YES                    |
| 0    | 0    | 0    | 1       | 0            | Х   | Х  | X-X  | 0  |           | Write word on D15-0     | YES                    |
| 0    | 1    | 0    | 1       | 0            | Х   | Х  | X-X  | Х  |           | Read Odd Byte on D15-8  | Not supported          |
| 0    | 1    | 0    | 1       | 0            | Х   | Х  | X-X  | Х  |           | Write Odd Byte on D15-8 | Not supported          |

Table 198. 16-bit PC-Card signals and access type (continued)

The FSMC Bank 4 gives access to those 3 memory spaces as described in *Section 31.4.2: NAND/PC Card address mapping - Table 165: Memory mapping and timing registers* 

### Wait Feature

The CompactFlash Storage or PC Card may request the FSMC to extend the length of the access phase programmed by MEMWAITx/ATTWAITx/IOWAITx bits, asserting the nWAIT signal after nOE/nWE or nIORD/nIOWR activation if the wait feature is enabled through the PWAITEN bit in the FSMC\_PCRx register. In order to detect the nWAIT assertion correctly, the MEMWAITx/ATTWAITx/IOWAITx bits must be programmed as follows:

xxWAITx >= 4 + max\_wait\_assertion\_time/HCLK

Where max\_wait\_assertion\_time is the maximum time taken by NWAIT to go low once nOE/nWE or nIORD/nIOWR is low.

After the de-assertion of nWAIT, the FSMC extends the WAIT phase for 4 HCLK clock cycles.



## 31.6.8 NAND Flash/PC Card controller registers

#### PC Card/NAND Flash control registers 2..4 (FSMC\_PCR2..4)

Address offset: 0xA000000 + 0x40 + 0x20 \* (x - 1), x = 2..4

Reset value: 0x0000 0018

| 31 | 30 29 | 28 | 27 26 | 25 | 24       | 23 | 22 | 21         | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|-------|----|-------|----|----------|----|----|------------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0. | 00 20 |    | 2, 20 | 20 | <u> </u> | 20 |    | <u>-</u> . | 20 | 10 | 10 |    |    | 10 |    | .0 |    |    | 10 | 0 | 0 |   | • | 0 |   | 0 | _ |   | • |

| Reserved | E  | ССР | S  |    | TA | R  |    |    | тс | LR |    | Res. | ECCEN | P٧ | VID | РТҮР | PBKEN | PWAITEN | leserved |
|----------|----|-----|----|----|----|----|----|----|----|----|----|------|-------|----|-----|------|-------|---------|----------|
|          | rw | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw |      | rw    | rw | rw  | rw   | rw    | rw      | ш.       |

#### Bits 19:17 ECCPS: ECC page size.

Defines the page size for the extended ECC:

- 000: 256 bytes 001: 512 bytes 010: 1024 bytes 011: 2048 bytes 100: 4096 bytes
- 101: 8192 bytes
- Bits 16:13 TAR: ALE to RE delay.

Sets time from ALE low to RE low in number of AHB clock cycles (HCLK). Time is: t\_ar = (TAR + SET + ) × THCLK where THCLK is the HCLK clock period 0000: 1 HCLK cycle (default) 1111: 16 HCLK cycles

Note: SET is MEMSET or ATTSET according to the addressed space.

Bits 12:9 TCLR: CLE to RE delay.

Sets time from CLE low to RE low in number of AHB clock cycles (HCLK). Time is  $t_clr = (TCLR + SET +) \times THCLK$  where THCLK is the HCLK clock period 0000: 1 HCLK cycle (default) 1111: 16 HCLK cycles

Note: SET is MEMSET or ATTSET according to the addressed space.

- Bits 8:7 Reserved, must be kept at reset value..
  - Bits 6 **ECCEN:** ECC computation logic enable bit

0: ECC logic is disabled and reset (default after reset), 1: ECC logic is enabled.

#### Bits 5:4 PWID: Databus width.

Defines the external memory device width.

- 00: 8 bits (default after reset)
- 01: 16 bits (mandatory for PC Card)
- 10: reserved, do not use
- 11: reserved, do not use

### Bit 3 **PTYP:** Memory type.

Defines the type of device attached to the corresponding memory bank: 0: PC Card, CompactFlash, CF+ or PCMCIA

1: NAND Flash (default after reset)



- Bit 2 PBKEN: PC Card/NAND Flash memory bank enable bit.
  - Enables the memory bank. Accessing a disabled memory bank causes an ERROR on AHB bus
  - 0: Corresponding memory bank is disabled (default after reset)
  - 1: Corresponding memory bank is enabled
- Bit 1 **PWAITEN:** Wait feature enable bit.
  - Enables the Wait feature for the PC Card/NAND Flash memory bank:
  - 0: disabled
  - 1: enabled
  - Note: For a PC Card, when the wait feature is enabled, the MEMWAITx/ATTWAITx/IOWAITx bits must be programmed to a value as follows:  $xxWAITx \ge 4 + max\_wait\_assertion\_time/HCLK$ Where max\\_wait\\_assertion\\_time is the maximum time taken by NWAIT to go low once nOE/nWE or nIORD/nIOWR is low.
- Bit 0 Reserved, must be kept at reset value..

### FIFO status and interrupt register 2..4 (FSMC\_SR2..4)

Address offset: 0xA000 0000 + 0x44 + 0x20 \* (x-1), x = 2..4

Reset value: 0x0000 0040

This register contains information about FIFO status and interrupt. The FSMC has a FIFO that is used when writing to memories to store up to16 words of data from the AHB. This is used to quickly write to the AHB and free it for transactions to peripherals other than the FSMC, while the FSMC is draining its FIFO into the memory. This register has one of its bits that indicates the status of the FIFO, for ECC purposes.

The ECC is calculated while the data are written to the memory, so in order to read the correct ECC the software must wait until the FIFO is empty.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 | 2 1 0 |
|---------------------------------------------------------------------------------|-------|
|---------------------------------------------------------------------------------|-------|

| perve | FEMPT | IFEN | ILEN | IREN | IFS | ILS | IRS |   |
|-------|-------|------|------|------|-----|-----|-----|---|
| ä     | r     | rw   | rw   | rw   | rw  | rw  | rw  | 1 |

#### Bit 6 FEMPT: FIFO empty.

Read-only bit that provides the status of the FIFO 0: FIFO not empty 1: FIFO empty

- Bit 5 IFEN: Interrupt falling edge detection enable bit
  - 0: Interrupt falling edge detection request disabled
  - 1: Interrupt falling edge detection request enabled
- Bit 4 ILEN: Interrupt high-level detection enable bit
  - 0: Interrupt high-level detection request disabled
  - 1: Interrupt high-level detection request enabled
- Bit 3 IREN: Interrupt rising edge detection enable bit
  - 0: Interrupt rising edge detection request disabled
  - 1: Interrupt rising edge detection request enabled



#### Bit 2 IFS: Interrupt falling edge status

The flag is set by hardware and reset by software.

0: No interrupt falling edge occurred

1: Interrupt falling edge occurred

#### Bit 1 ILS: Interrupt high-level status

The flag is set by hardware and reset by software.

0: No Interrupt high-level occurred

- 1: Interrupt high-level occurred
- Bit 0 IRS: Interrupt rising edge status

The flag is set by hardware and reset by software.

0: No interrupt rising edge occurred

1: Interrupt rising edge occurred

#### Common memory space timing register 2..4 (FSMC\_PMEM2..4)

Address offset: Address:  $0xA000\ 0000 + 0x48 + 0x20 * (x - 1), x = 2..4$ 

#### Reset value: 0xFCFC FCFC

Each FSMC\_PMEMx (x = 2..4) read/write register contains the timing information for PC Card or NAND Flash memory bank x, used for access to the common memory space of the 16-bit PC Card/CompactFlash, or to access the NAND Flash for command, address write access and data read/write access.

| _   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| - F |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|    |    |    | MEN | IHIZ | C  |    |    |    |    | M  | IEMF | HOLL | )X |    |    |    |    |    |    | NAII | х  |    |    |    |    |    | MEW | SED | x  |    |    |
|----|----|----|-----|------|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|------|----|----|----|----|----|----|-----|-----|----|----|----|
| rw | rw | rw | rw  | rw   | rw | rw | rw | rw | rw | rw | rw   | rw   | rw | rw | rw | rw | rw | rw | rw | rw   | rw | rw | rw | rw | rw | rw | rw  | rw  | rw | rw | rw |

Bits 31:24 MEMHIZx: Common memory x databus HiZ time

Defines the number of HCLK clock cycles during which the databus is kept in HiZ after the start of a PC Card/NAND Flash write access to common memory space on socket x. Only valid for write transaction:

0000 0000: (0x00) 0 HCLK cycle (for PC Card)

1111 1111: (0xFF) 255 HCLK cycles (for PC Card) - (default value after reset)

Bits 23:16 MEMHOLDx: Common memory x hold time

Defines the number of HCLK clock cycles to hold address (and data for write access) after the command deassertion (NWE, NOE), for PC Card/NAND Flash read or write access to common memory space on socket x:

0000 0000: reserved

0000 0001: 1 HCLK cycle

1111 1111: 255 HCLK cycles (default value after reset)

Bits 15:8 MEMWAITx: Common memory x wait time

Defines the minimum number of HCLK (+1) clock cycles to assert the command (NWE, NOE), for PC Card/NAND Flash read or write access to common memory space on socket x. The duration for command assertion is extended if the wait signal (NWAIT) is active (low) at the end of the programmed value of HCLK:

0000 0000: reserved

0000 0001: 2HCLK cycles (+ wait cycle introduced by deasserting NWAIT) 1111 1111: 256 HCLK cycles (+ wait cycle introduced by the Card deasserting NWAIT) (default value after reset)

Doc ID 018909 Rev 1



Bits 7:0 MEMSETx: Common memory x setup time

Defines the number of HCLK () clock cycles to set up the address before the command assertion (NWE, NOE), for PC Card/NAND Flash read or write access to common memory space on socket x: 0000 0000: 1 HCLK cycle (for PC Card) / HCLK cycles (for NAND Flash) 1111 1111: 256 HCLK cycles (for PC Card) / 257 HCLK cycles (for NAND Flash) - (default value after reset)

### Attribute memory space timing registers 2..4 (FSMC\_PATT2..4)

Address offset: 0xA000 0000 + 0x4C + 0x20 \* (x - 1), x = 2..4

Reset value: 0xFCFC FCFC

Each FSMC\_PATTx (x = 2..4) read/write register contains the timing information for PC Card/CompactFlash or NAND Flash memory bank x. It is used for 8-bit accesses to the attribute memory space of the PC Card/CompactFlash or to access the NAND Flash for the last address write access if the timing must differ from that of previous accesses (for Ready/Busy management, refer to *Section 31.6.5: NAND Flash pre-wait functionality*).

| 31 | 30 | 29 | 28  | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11   | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3    | 2  | 1  | 0  |
|----|----|----|-----|------|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|------|------|----|----|----|
|    |    |    | ATT | HIZx |    |    |    |    |    | A  | πтн | OLD | х  |    |    |    |    | ļ  | ATTV | VAIT | x  |    |    |    |    |    | ATTS | SETx | (  |    |    |
| rw | rw | rw | rw  | rw   | rw | rw | rw | rw | rw | rw | rw  | rw  | rw | rw | rw | rw | rw | rw | rw   | rw   | rw | rw | rw | rw | rw | rw | rw   | rw   | rw | rw | rw |

Bits 31:24 ATTHIZx: Attribute memory x databus HiZ time

Defines the number of HCLK clock cycles during which the databus is kept in HiZ after the start of a PC CARD/NAND Flash write access to attribute memory space on socket x. Only valid for write transaction: 0000 0000: 0 HCLK cycle

1111 1111: 255 HCLK cycles (default value after reset)

#### Bits 23:16 ATTHOLDx: Attribute memory x hold time

Defines the number of HCLK clock cycles to hold address (and data for write access) after the command deassertion (NWE, NOE), for PC Card/NAND Flash read or write access to attribute memory space on socket x 0000 0000: reserved

0000 0001: 1 HCLK cycle

1111 1111: 255 HCLK cycles (default value after reset)

#### Bits 15:8 ATTWAITx: Attribute memory x wait time

Defines the minimum number of HCLK (+1) clock cycles to assert the command (NWE, NOE), for PC Card/NAND Flash read or write access to attribute memory space on socket x. The duration for command assertion is extended if the wait signal (NWAIT) is active (low) at the end of the programmed value of HCLK:

0000 0000: reserved

0000 0001: 2 HCLK cycles (+ wait cycle introduced by deassertion of NWAIT) 1111 1111: 256 HCLK cycles (+ wait cycle introduced by the card deasserting NWAIT)

(default value after reset)



Bits 7:0 ATTSETx: Attribute memory x setup time

Defines the number of HCLK (+1) clock cycles to set up address before the command assertion (NWE, NOE), for PC CARD/NAND Flash read or write access to attribute memory space on socket x: 0000 0000: 1 HCLK cycle 1111 1111: 256 HCLK cycles (default value after reset)

### I/O space timing register 4 (FSMC\_PIO4)

Address offset: 0xA000 0000 + 0xB0 Reset value: 0xFCFCFCFC

The FSMC\_PIO4 read/write registers contain the timing information used to gain access to the I/O space of the 16-bit PC Card/CompactFlash.

| 31 | 30 | 29 | 28  | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19        | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11   | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
|----|----|----|-----|-----|----|----|----|----|----|----|------|-----------|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|-----|-----|----|----|----|
|    |    |    | IOH | ΗZx |    |    |    |    |    |    | IOHO | )<br>DLD> | (  |    |    |    |    |    | IOW | AITx |    |    |    |    |    |    | IOS | ETx |    |    |    |
| rv | rw | rw | rw  | rw  | rw | rw | rw | rw | rw | rw | rw   | rw        | rw | rw | rw | rw | rw | rw | rw  | rw   | rw | rw | rw | rw | rw | rw | rw  | rw  | rw | rw | rw |

Bits 31:24 IOHIZx: I/O x databus HiZ time

Defines the number of HCLK clock cycles during which the databus is kept in HiZ after the start of a PC Card write access to I/O space on socket x. Only valid for write transaction: 0000 0000: 0 HCLK cycle

1111 1111: 255 HCLK cycles (default value after reset)

Bits 23:16 IOHOLDx: I/O x hold time

Defines the number of HCLK clock cycles to hold address (and data for write access) after the command deassertion (NWE, NOE), for PC Card read or write access to I/O space on socket x:

0000 0000: reserved 0000 0001: 1 HCLK cycle

1111 1111: 255 HCLK cycles (default value after reset)

Bits 15:8 IOWAITx: I/O x wait time

Defines the minimum number of HCLK (+1) clock cycles to assert the command (SMNWE, SMNOE), for PC Card read or write access to I/O space on socket x. The duration for command assertion is extended if the wait signal (NWAIT) is active (low) at the end of the programmed value of HCLK:

0000 0000: reserved, do not use this value

0000 0001: 2 HCLK cycles (+ wait cycle introduced by deassertion of NWAIT)

1111 1111: 256 HCLK cycles (+ wait cycle introduced by the Card deasserting NWAIT) (default value after reset)

Bits 7:0 IOSETx: I/O x setup time

Defines the number of HCLK (+1) clock cycles to set up the address before the command assertion (NWE, NOE), for PC Card read or write access to I/O space on socket x: 0000 0000: 1 HCLK cycle

1111 1111: 256 HCLK cycles (default value after reset)



## ECC result registers 2/3 (FSMC\_ECCR2/3)

Address offset:  $0xA000\ 0000 + 0x54 + 0x20 * (x - 1), x = 2 \text{ or } 3$ 

Reset value: 0x0000 0000

These registers contain the current error correction code value computed by the ECC computation modules of the FSMC controller (one module per NAND Flash memory bank). When the CPU reads the data from a NAND Flash memory page at the correct address (refer to *Section 31.6.6: Error correction code computation ECC (NAND Flash)*), the data read from or written to the NAND Flash are processed automatically by ECC computation module. At the end of X bytes read (according to the ECCPS field in the FSMC\_PCRx registers), the CPU must read the computed ECC value from the FSMC\_ECCx registers, and then verify whether these computed parity data are the same as the parity value recorded in the spare area, to determine whether a page is valid, and, to correct it if applicable. The FSMC\_ECCRx registers should be cleared after being read by setting the ECCEN bit to zero. For computing a new data block, the ECCEN bit must be set to one.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EC | Сх |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | r  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Bits 31:0 ECCx: ECC result

This field provides the value computed by the ECC computation logic. *Table 199* hereafter describes the contents of these bit fields.

| Table 199. ECC result relevant bit |
|------------------------------------|
|------------------------------------|

| ECCPS[2:0] | Page size in bytes | ECC bits  |
|------------|--------------------|-----------|
| 000        | 256                | ECC[21:0] |
| 001        | 512                | ECC[23:0] |
| 010        | 1024               | ECC[25:0] |
| 011        | 2048               | ECC[27:0] |
| 100        | 4096               | ECC[29:0] |
| 101        | 8192               | ECC[31:0] |



# 31.6.9 FSMC register map

The following table summarizes the FSMC registers.

# Table 200. FSMC register map

| Offset         | Register    | 3<br>3<br>3 | 1 1       |        | - 1 | 1     | 24  | 33       | 3  | 15         | 20  | 19       | 0   | 17    | 16      | 15        | 14     | 13     | 12   | 1       | 10      | 6       | œ       | 7        | 9      | 5    | 4     | e     | 2     | -       | 0        |
|----------------|-------------|-------------|-----------|--------|-----|-------|-----|----------|----|------------|-----|----------|-----|-------|---------|-----------|--------|--------|------|---------|---------|---------|---------|----------|--------|------|-------|-------|-------|---------|----------|
| 0xA000<br>0000 | FSMC_BCR1   |             | <u></u>   |        |     | eserv |     | <u> </u> |    |            |     | CBURSTRW | F   | leser | ved     | ASYNCWAIT | EXTMOD | WAITEN | WREN | WAITCFG |         | WAITPOL | BURSTEN | Reserved | FACCEN |      | )     | МТҮР  |       | MUXEN   | MBKEN    |
|                | Reset value |             |           |        |     |       |     |          |    |            |     |          |     |       |         |           |        |        |      |         |         |         |         |          |        |      |       |       |       |         |          |
| 0xA000<br>0008 | FSMC_BCR2   |             |           |        | R   | eserv | red |          |    |            |     | CBURSTRW | F   | leser |         | ASYNCWAIT | EXTMOD | WAITEN | WREN | WAITCFG | WRAPMOD | WAITPOL | BURSTEN | Reserved | FACCEN |      |       | МТҮР  |       | MUXEN   | MBKEN    |
| 0xA000<br>0010 | FSMC_BCR3   |             |           |        | R   | eserv | ed  |          |    |            |     | CBURSTRW | F   | leser | ved     | ASYNCWAIT | EXTMOD | WAITEN | WREN | WAITCFG | WRAPMOD | WAITPOL | BURSTEN | Reserved | FACCEN |      |       | МТҮР  |       | MUXEN   | MBKEN    |
| 0xA000<br>0018 | FSMC_BCR4   |             |           |        | R   | eserv | ed  |          |    |            |     | CBURSTRW | F   | leser | ved     | ASYNCWAIT | EXTMOD | WAITEN | WREN | WAITCFG | WRAPMOD | WAITPOL | BURSTEN | Reserved | FACCEN |      | )     | MTYP  |       | MUXEN   | MBKEN    |
| 0xA000<br>0004 | FSMC_BTR1   | Res.        | ACC<br>OE |        | C   | ATLA  | λT  |          | CL | .KD        | IV  | В        | 808 | STUF  | N       |           |        | l      | DAT  | AST     |         |         |         | A        | ADD    | HLC  | )     | А     |       | SET     |          |
| 0xA000<br>000C | FSMC_BTR2   | Res.        | ACC<br>OE |        | C   | ATLA  | λT  |          | CL | .KD        | IV  | В        | 808 | STUF  | N       |           |        | ļ      | DAT  | AST     |         |         |         | ļ        | ADD    | HLC  | )     | A     |       | SET     |          |
| 0xA000<br>0014 | FSMC_BTR3   | Res.        | ACC<br>OE |        | C   | ATLA  | λT  |          | CL | .KD        | IV  | В        | 808 | STUF  | N       |           |        | I      | DAT  | AST     |         |         |         | ļ        | ٩DD    | HLC  | )     | A     |       | SET     |          |
| 0xA000<br>001C | FSMC_BTR4   | Res.        | ACC<br>OE |        | C   | ATLA  | λT  |          | CL | .KD        | IV  | BUSTURN  |     |       |         | DATAST    |        |        |      |         |         |         | ļ       | ADDHLD   |        |      |       | ADDSE |       |         |          |
| 0xA000<br>0104 | FSMC_BWTR1  | Res.        | ACC<br>OE |        | C   | ATLA  | λT  |          | CL | .KD        | IV  | Reserved |     |       |         | DATAST    |        |        |      |         |         | Å       | ADDHLD  |          |        |      | ADDSE |       |       |         |          |
| 0xA000<br>010C | FSMC_BWTR2  | Res.        | ACC<br>OE |        | C   | ATLA  | λT  |          | CL | .KD        | IV  | Reserved |     |       |         | DATAST    |        |        |      |         |         | Å       | ADD     | HLC      | )      | ADDS |       |       |       |         |          |
| 0xA000<br>0114 | FSMC_BWTR3  | Res.        | ACC<br>OE |        | C   | ATLA  | λT  |          | CL | .KD        | IV  | F        | Re  | serve | d       |           |        |        | DAT  | AST     |         |         |         | ļ        | ٩DD    | HLC  | )     | A     |       | SET     |          |
| 0xA000<br>011C | FSMC_BWTR4  | Res.        | ACC<br>OE | M<br>D | C   | ATLA  | λT  |          | CL | .KD        | IV  | F        | Re  | serve | d       |           |        | l      | DAT  | AST     |         |         |         | Å        | ٩DD    | HLC  | )     | А     |       | SET     |          |
| 0xA000<br>0060 | FSMC_PCR2   |             |           |        | R   | eser  | red |          |    |            |     | E        | СС  | PS    |         | TA        | ٨R     |        |      | тс      | LR      |         | Re      | es.      | ECCEN  | PW   | VID   | РТҮР  | PBKEN | PWAITEN | Reserved |
| 0xA000<br>0080 | FSMC_PCR3   |             |           |        | R   | eser  | red |          |    |            |     | E        | СС  | CPS   |         | TA        | ٨R     |        |      | тс      | LR      |         | Re      | es.      | ECCEN  | ΡV   | ١D    | РТҮР  | PBKEN | PWAITEN | Reserved |
| 0xA000<br>00A0 | FSMC_PCR4   |             |           |        | R   | eserv | red |          |    |            |     | E        | СС  | PS    |         | TA        | ٨R     |        |      | тс      | LR      |         | Re      | es.      | ECCEN  | P٧   | VID   | РТҮР  | PBKEN | PWAITEN | Reserved |
| 0xA000<br>0064 | FSMC_SR2    |             |           |        |     |       |     |          |    |            | R   | eser     | ve  | d     | <b></b> |           |        |        |      |         |         |         |         |          | FEMPT  | IFEN | ILEN  | IREN  |       |         | IRS      |
| 0xA000<br>0084 | FSMC_SR3    |             |           |        |     |       |     |          |    |            | R   | eser     | ve  | d     |         |           |        |        |      |         |         |         |         |          | FEMPT  | IFEN | ILEN  | IREN  | IFS   | ILS     | IRS      |
| 0xA000<br>00A4 | FSMC_SR4    |             |           |        |     |       |     | Reserved |    |            |     |          |     |       |         |           |        | FEMPT  | IFEN | ILEN    | IREN    | IFS     | ILS     | IRS      |        |      |       |       |       |         |          |
| 0xA000<br>0068 | FSMC_PMEM2  | MEMHIZX MEM |           |        |     |       | MEM | HOL      | Dx | MEMWAITx N |     |          |     |       |         | IEM       | EMSETx |        |      |         |         |         |         |          |        |      |       |       |       |         |          |
| 0xA000<br>0088 | FSMC_PMEM3  |             | MEMHIZx   |        |     |       |     |          |    | I          | MEM | HOL      | Dx  | [     |         |           |        | Μ      | EMV  | VAI     | Гх      |         |         |          |        | N    | 1EM   | SET   | x     |         |          |

Doc ID 018909 Rev 1



# Table 200. FSMC register map (continued)

| Offset         | Register   | -  | 0       | 9 | 8       | 2    | G | ß | 4 | 3 | N | - | . 0  | ရ    | 8  | 2  | G  | ß  | 4 | e | N   | 1    | 0  |   |   |         |   |   | -    |      | •  |   |   |
|----------------|------------|----|---------|---|---------|------|---|---|---|---|---|---|------|------|----|----|----|----|---|---|-----|------|----|---|---|---------|---|---|------|------|----|---|---|
| Oliset         | negistei   | 31 | Э       | Ň | Ñ       | N.   | 2 | Ñ | Ñ | Ň | Ň | Ś | 20   | Ť    | Ĩ  | 17 | ۱L | Ť  | ÷ | ۲ | i L | Ļ    | 10 | 6 | 8 | 7       | 9 | 2 | 4    | e    | CN | 1 | 0 |
| 0xA000<br>00A8 | FSMC_PMEM4 |    |         | Ν | IEN     | 1HIZ | x |   |   |   |   | N | 1EM  | HOL  | Dx |    |    |    |   | М | EM  | NAI. | Тx |   |   |         |   | Ν | 1EM  | SET  | x  |   |   |
| 0xA000<br>006C | FSMC_PATT2 |    | ATTHIZx |   | ATTHIZx |      |   |   |   |   |   | A | ATTH | IOLE | Dx |    |    |    |   | A | ттν | VAIT | x  |   |   | ATTSETx |   |   |      |      |    |   |   |
| 0xA000<br>008C | FSMC_PATT3 |    |         | A | TΤ      | HIZ× | ( |   |   |   |   | A | ATTH | IOLE | Эx |    |    |    |   | A | ттν | VAIT | x  |   |   |         |   |   | ATTS | SET  | ¢  |   |   |
| 0xA000<br>00AC | FSMC_PATT4 |    |         | A | TΤ      | HIZ× | ¢ |   |   |   |   | A | ATTH | IOLE | Dx |    |    |    |   | A | ттν | VAIT | x  |   |   |         |   |   | ATTS | SET: | ¢  |   |   |
| 0xA000<br>00B0 | FSMC_PIO4  |    |         |   | IOF     | ΗZx  |   |   |   |   |   |   | IOH  | OLD  | х  |    |    |    |   | I | ow  | AIT  | ¢  |   |   |         |   |   | IOS  | ETx  |    |   |   |
| 0xA000<br>0074 | FSMC_ECCR2 |    |         |   |         |      |   |   |   |   |   |   |      |      |    |    | EC | Cx |   |   |     |      |    |   |   |         |   |   |      |      |    |   |   |
| 0xA000<br>0094 | FSMC_ECCR3 |    |         |   |         |      |   |   |   |   |   |   |      |      |    |    | EC | Cx |   |   |     |      |    |   |   |         |   |   |      |      |    |   |   |

Refer to Table 1 on page 50 for the register boundary addresses.



# 32 Debug support (DBG)

# 32.1 Overview

The STM32F40x and STM32F41x are built around a Cortex<sup>™</sup>-M4F core which contains hardware extensions for advanced debugging features. The debug extensions allow the core to be stopped either on a given instruction fetch (breakpoint) or data access (watchpoint). When stopped, the core's internal state and the system's external state may be examined. Once examination is complete, the core and the system may be restored and program execution resumed.

The debug features are used by the debugger host when connecting to and debugging the STM32F40x and STM32F41x MCUs.

Two interfaces for debug are available:

- Serial wire
- JTAG debug port



### Figure 410. Block diagram of STM32 MCU and Cortex<sup>™</sup>-M4F-level debug support

Note: The debug features embedded in the Cortex<sup>™</sup>-M4F core are a subset of the ARM CoreSight Design Kit.



The ARM Cortex<sup>™</sup>-M4F core provides integrated on-chip debug support. It is comprised of:

- SWJ-DP: Serial wire / JTAG debug port
- AHP-AP: AHB access port
- ITM: Instrumentation trace macrocell
- FPB: Flash patch breakpoint
- DWT: Data watchpoint trigger
- TPUI: Trace port unit interface (available on larger packages, where the corresponding pins are mapped)
- ETM: Embedded Trace Macrocell (available on larger packages, where the corresponding pins are mapped)

It also includes debug features dedicated to the STM32F40x and STM32F41x:

- Flexible debug pinout assignment
- MCU debug box (support for low-power modes, control over peripheral clocks, etc.)

Note: For further information on debug functionality supported by the ARM Cortex<sup>™</sup>-M4F core, refer to the Cortex<sup>™</sup>-M4F-r0p1 Technical Reference Manual and to the CoreSight Design Kit-r0p1 TRM (see Section 32.2: Reference ARM documentation).

# 32.2 Reference ARM documentation

- Cortex<sup>™</sup>-M4F r0p1 Technical Reference Manual (TRM) (see Related documents on page 1)
- ARM Debug Interface V5
- ARM CoreSight Design Kit revision r0p1 Technical Reference Manual

# 32.3 SWJ debug port (serial wire and JTAG)

The STM32F40x and STM32F41x core integrates the Serial Wire / JTAG Debug Port (SWJ-DP). It is an ARM standard CoreSight debug port that combines a JTAG-DP (5-pin) interface and a SW-DP (2-pin) interface.

- The JTAG Debug Port (JTAG-DP) provides a 5-pin standard JTAG interface to the AHP-AP port.
- The Serial Wire Debug Port (SW-DP) provides a 2-pin (clock + data) interface to the AHP-AP port.

In the SWJ-DP, the two JTAG pins of the SW-DP are multiplexed with some of the five JTAG pins of the JTAG-DP.





Figure 411. SWJ debug port

*Figure 411* shows that the asynchronous TRACE output (TRACESWO) is multiplexed with TDO. This means that the asynchronous trace can only be used with SW-DP, not JTAG-DP.

# 32.3.1 Mechanism to select the JTAG-DP or the SW-DP

By default, the JTAG-Debug Port is active.

If the debugger host wants to switch to the SW-DP, it must provide a dedicated JTAG sequence on TMS/TCK (respectively mapped to SWDIO and SWCLK) which disables the JTAG-DP and enables the SW-DP. This way it is possible to activate the SWDP using only the SWCLK and SWDIO pins.

This sequence is:

- 1. Send more than 50 TCK cycles with TMS (SWDIO) =1
- 2. Send the 16-bit sequence on TMS (SWDIO) = 0111100111100111 (MSB transmitted first)
- 3. Send more than 50 TCK cycles with TMS (SWDIO) =1

# 32.4 Pinout and debug port pins

The STM32F40x and STM32F41x MCUs are available in various packages with different numbers of available pins. As a result, some functionality (ETM) related to pin availability may differ between packages.



# 32.4.1 SWJ debug port pins

Five pins are used as outputs from the STM32F40x and STM32F41x for the SWJ-DP as *alternate functions* of general-purpose I/Os. These pins are available on all packages.

| SWJ-DP pin name |      | JTAG debug port             |      | Pin<br>assign                      |      |
|-----------------|------|-----------------------------|------|------------------------------------|------|
| SW3-DF pin name | Туре | Description                 | Туре | Debug assignment                   | ment |
| JTMS/SWDIO      | I    | JTAG Test Mode<br>Selection | ю    | Serial Wire Data<br>Input/Output   | PA13 |
| JTCK/SWCLK      | Ι    | JTAG Test Clock             | Ι    | Serial Wire Clock                  | PA14 |
| JTDI            | I    | JTAG Test Data Input        | -    | -                                  | PA15 |
| JTDO/TRACESWO   | 0    | JTAG Test Data Output       | -    | TRACESWO if async trace is enabled | PB3  |
| NJTRST          | Ι    | JTAG Test nReset            | -    | -                                  | PB4  |

Table 201. SWJ debug port pins

# 32.4.2 Flexible SWJ-DP pin assignment

After RESET (SYSRESETn or PORESETn), all five pins used for the SWJ-DP are assigned as dedicated pins immediately usable by the debugger host (note that the trace outputs are not assigned except if explicitly programmed by the debugger host).

However, the STM32F40x and STM32F41x MCUs offer the possibility of disabling some or all of the SWJ-DP ports and so, of releasing the associated pins for general-purpose IO (GPIO) usage. For more details on how to disable SWJ-DP port pins, please refer to *Section 6.3.2: I/O pin multiplexer and mapping.* 

|                                               |                          | SWJ IO pin assigned      |                |               |                |  |  |  |  |  |  |  |
|-----------------------------------------------|--------------------------|--------------------------|----------------|---------------|----------------|--|--|--|--|--|--|--|
| Available debug ports                         | PA13 /<br>JTMS/<br>SWDIO | PA14 /<br>JTCK/<br>SWCLK | PA15 /<br>JTDI | PB3 /<br>JTDO | PB4/<br>NJTRST |  |  |  |  |  |  |  |
| Full SWJ (JTAG-DP + SW-DP) - Reset State      | Х                        | Х                        | Х              | Х             | Х              |  |  |  |  |  |  |  |
| Full SWJ (JTAG-DP + SW-DP) but without NJTRST | Х                        | Х                        | Х              | Х             |                |  |  |  |  |  |  |  |
| JTAG-DP Disabled and SW-DP Enabled            | Х                        | Х                        |                |               | _              |  |  |  |  |  |  |  |
| JTAG-DP Disabled and SW-DP Disabled           |                          |                          | Rele           | ased          |                |  |  |  |  |  |  |  |

Table 202. Flexible SWJ-DP pin assignment

Note:

When the APB bridge write buffer is full, it takes one extra APB cycle when writing the GPIO\_AFR register. This is because the deactivation of the JTAGSW pins is done in two cycles to guarantee a clean level on the nTRST and TCK input signals of the core.

- Cycle 1: the JTAGSW input signals to the core are tied to 1 or 0 (to 1 for nTRST, TDI and TMS, to 0 for TCK)
- Cycle 2: the GPIO controller takes the control signals of the SWJTAG IO pins (like controls of direction, pull-up/down, Schmitt trigger activation, etc.).



# 32.4.3 Internal pull-up and pull-down on JTAG pins

It is necessary to ensure that the JTAG input pins are not floating since they are directly connected to flip-flops to control the debug mode features. Special care must be taken with the SWCLK/TCK pin which is directly connected to the clock of some of these flip-flops.

To avoid any uncontrolled IO levels, the device embeds internal pull-ups and pull-downs on the JTAG input pins:

- NJTRST: Internal pull-up
- JTDI: Internal pull-up
- JTMS/SWDIO: Internal pull-up
- TCK/SWCLK: Internal pull-down

Once a JTAG IO is released by the user software, the GPIO controller takes control again. The reset states of the GPIO control registers put the I/Os in the equivalent state:

- NJTRST: Input pull-up
- JTDI: Input pull-up
- JTMS/SWDIO: Input pull-up
- JTCK/SWCLK: Input pull-down
- JTDO: Input floating

The software can then use these I/Os as standard GPIOs.

Note: The JTAG IEEE standard recommends to add pull-ups on TDI, TMS and nTRST but there is no special recommendation for TCK. However, for JTCK, the device needs an integrated pull-down.

Having embedded pull-ups and pull-downs removes the need to add external resistors.



# 32.4.4 Using serial wire and releasing the unused debug pins as GPIOs

To use the serial wire DP to release some GPIOs, the user software must change the GPIO (PA15, PB3 and PB4) configuration mode in the GPIO\_MODER register. This releases PA15, PB3 and PB4 which now become available as GPIOs.

When debugging, the host performs the following actions:

- Under system reset, all SWJ pins are assigned (JTAG-DP + SW-DP).
- Under system reset, the debugger host sends the JTAG sequence to switch from the JTAG-DP to the SW-DP.
- Still under system reset, the debugger sets a breakpoint on vector reset.
- The system reset is released and the Core halts.
- All the debug communications from this point are done using the SW-DP. The other JTAG pins can then be reassigned as GPIOs by the user software.

Note: For user software designs, note that:

To release the debug pins, remember that they will be first configured either in input-pull-up (nTRST, TMS, TDI) or pull-down (TCK) or output tristate (TDO) for a certain duration after reset until the instant when the user software releases the pins.

When debug pins (JTAG or SW or TRACE) are mapped, changing the corresponding IO pin configuration in the IOPORT controller has no effect.

# 32.5 STM32F40x and STM32F41x JTAG TAP connection

The STM32F40x and STM32F41x MCUs integrate two serially connected JTAG TAPs, the boundary scan TAP (IR is 5-bit wide) and the Cortex<sup>™</sup>-M4F TAP (IR is 4-bit wide).

To access the TAP of the Cortex<sup>™</sup>-M4F for debug purposes:

- 1. First, it is necessary to shift the BYPASS instruction of the boundary scan TAP.
- 2. Then, for each IR shift, the scan chain contains 9 bits (=5+4) and the unused TAP instruction must be shifted in using the BYPASS instruction.
- 3. For each data shift, the unused TAP, which is in BYPASS mode, adds 1 extra data bit in the data scan chain.
- Note: **Important**: Once Serial-Wire is selected using the dedicated ARM JTAG sequence, the boundary scan TAP is automatically disabled (JTMS forced high).





#### Figure 412. JTAG TAP connections

# 32.6 ID codes and locking mechanism

There are several ID codes inside the STM32F40x and STM32F41x MCUs. ST strongly recommends tools designers to lock their debuggers using the MCU DEVICE ID code located in the external PPB memory map at address 0xE0042000.

## 32.6.1 MCU device ID code

The STM32F40x and STM32F41x MCUs integrate an MCU ID code. This ID identifies the ST MCU part-number and the die revision. It is part of the DBG\_MCU component and is mapped on the external PPB bus (see *Section 32.16 on page 1296*). This code is accessible using the JTAG debug port (4 to 5 pins) or the SW debug port (two pins) or by the user software. It is even accessible while the MCU is under system reset.

## DBGMCU\_IDCODE

Address: 0xE004 2000

Only 32-bits access supported. Read-only.

| 31 | 30   | 29    | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21   | 20 | 19 | 18 | 17 | 16 |
|----|------|-------|----|----|----|----|----|------|----|------|----|----|----|----|----|
|    |      |       |    |    |    |    | RE | V_ID |    |      |    |    |    |    |    |
| r  | r    | r     | r  | r  | r  | r  | r  | r    | r  | r    | r  | r  | r  | r  | r  |
| 15 | 14   | 13    | 12 | 11 | 10 | 9  | 8  | 7    | 6  | 5    | 4  | 3  | 2  | 1  | 0  |
|    | Boo  | erved |    |    |    |    |    |      | DE | V_ID |    |    |    |    |    |
|    | nest | erveu |    | r  | r  | r  | r  | r    | r  | r    | r  | r  | r  | r  | r  |



#### Bits 31:16 REV\_ID(15:0) Revision identifier

This field indicates the revision of the device: 0x1000 =Revision A

- Bits 15:12 Reserved, must be kept at reset value.
- Bits 11:0 **DEV\_ID(11:0)**: Device identifier The device ID is 0x413

## 32.6.2 Boundary scan TAP

### JTAG ID code

The TAP of the STM32F40x and STM32F41x BSC (boundary scan) integrates a JTAG ID code equal to 0x06413041.

## 32.6.3 Cortex<sup>™</sup>-M4F TAP

The TAP of the ARM Cortex<sup>™</sup>-M4F integrates a JTAG ID code. This ID code is the ARM default one and has not been modified. This code is only accessible by the JTAG Debug Port.

This code is **0x4BA00477** (corresponds to Cortex<sup>™</sup>-M4F r0p1, see *Section 32.2: Reference ARM documentation*).

Only the DEV\_ID(11:0) should be used for identification by the debugger/programmer tools.

# 32.6.4 Cortex<sup>™</sup>-M4F JEDEC-106 ID code

The ARM Cortex<sup>™</sup>-M4F integrates a JEDEC-106 ID code. It is located in the 4KB ROM table mapped on the internal PPB bus at address 0xE00FF000\_0xE00FFFFF.

This code is accessible by the JTAG Debug Port (4 to 5 pins) or by the SW Debug Port (two pins) or by the user software.

# **32.7 JTAG debug port**

A standard JTAG state machine is implemented with a 4-bit instruction register (IR) and five data registers (for full details, refer to the Cortex<sup>™</sup>-M4Fr0p1 Techni*cal Reference Manual (TRM), for references, please see Section 32.2: Reference ARM documentation).* 

| IR(3:0) | Data register       | Details                                                     |
|---------|---------------------|-------------------------------------------------------------|
| 1111    | BYPASS<br>[1 bit]   |                                                             |
| 1110    | IDCODE<br>[32 bits] | <i>ID CODE</i><br>0x4BA00477 (ARM Cortex™-M4F r0p1 ID Code) |

Table 203. JTAG debug port data registers



| IR(3:0) | Data register      | Details                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1010    | DPACC<br>[35 bits] | <ul> <li>Debug port access register</li> <li>This initiates a debug port and allows access to a debug port register.</li> <li>When transferring data IN:<br/>Bits 34:3 = DATA[31:0] = 32-bit data to transfer for a write request<br/>Bits 2:1 = A[3:2] = 2-bit address of a debug port register.<br/>Bit 0 = RnW = Read request (1) or write request (0).</li> <li>When transferring data OUT:<br/>Bits 34:3 = DATA[31:0] = 32-bit data which is read following a read<br/>request<br/>Bits 2:0 = ACK[2:0] = 3-bit Acknowledge:<br/>010 = OK/FAULT<br/>001 = WAIT<br/>OTHER = reserved</li> </ul>                                                                                                                                                                                |
|         |                    | Refer to <i>Table 204</i> for a description of the A(3:2) bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1011    | APACC<br>[35 bits] | <ul> <li>Access port access register</li> <li>Initiates an access port and allows access to an access port register.</li> <li>When transferring data IN:<br/>Bits 34:3 = DATA[31:0] = 32-bit data to shift in for a write request<br/>Bits 2:1 = A[3:2] = 2-bit address (sub-address AP registers).<br/>Bit 0 = RnW= Read request (1) or write request (0).</li> <li>When transferring data OUT:<br/>Bits 34:3 = DATA[31:0] = 32-bit data which is read following a read<br/>request<br/>Bits 2:0 = ACK[2:0] = 3-bit Acknowledge:<br/>010 = OK/FAULT<br/>001 = WAIT<br/>OTHER = reserved</li> <li>There are many AP Registers (see AHB-AP) addressed as the<br/>combination of:</li> <li>The shifted value A[3:2]</li> <li>The current value of the DP SELECT register</li> </ul> |
| 1000    | ABORT<br>[35 bits] | Abort register<br>– Bits 31:1 = Reserved<br>– Bit 0 = DAPABORT: write 1 to generate a DAP abort.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Table 203. JTAG debug port data registers | (continued) |
|-------------------------------------------|-------------|
|-------------------------------------------|-------------|

| Table 204. | 32-bit debug port registers addressed through the shifted value A[3:2] |  |
|------------|------------------------------------------------------------------------|--|
|------------|------------------------------------------------------------------------|--|

| Address | A(3:2) value | Description                                                                                                                                                                                                                                                                                  |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0     | 00           | Reserved, must be kept at reset value.                                                                                                                                                                                                                                                       |
| 0x4     | 01           | <ul> <li>DP CTRL/STAT register. Used to:</li> <li>Request a system or debug power-up</li> <li>Configure the transfer operation for AP accesses</li> <li>Control the pushed compare and pushed verify operations.</li> <li>Read some status flags (overrun, power-up acknowledges)</li> </ul> |



| Address | A(3:2) value | Description                                                                                                                                                                                                                                                                                                                 |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x8     | 10           | <ul> <li>DP SELECT register: Used to select the current access port and the active 4-words register window.</li> <li>Bits 31:24: APSEL: select the current AP</li> <li>Bits 23:8: reserved</li> <li>Bits 7:4: APBANKSEL: select the active 4-words register window on the current AP</li> <li>Bits 3:0: reserved</li> </ul> |
| 0xC     | 11           | DP RDBUFF register: Used to allow the debugger to get the final result<br>after a sequence of operations (without requesting new JTAG-DP<br>operation)                                                                                                                                                                      |

### Table 204. 32-bit debug port registers addressed through the shifted value A[3:2]

# 32.8 SW debug port

# **32.8.1** SW protocol introduction

This synchronous serial protocol uses two pins:

- SWCLK: clock from host to target
- SWDIO: bidirectional

The protocol allows two banks of registers (DPACC registers and APACC registers) to be read and written to.

Bits are transferred LSB-first on the wire.

For SWDIO bidirectional management, the line must be pulled-up on the board (100 K $\Omega$  recommended by ARM).

Each time the direction of SWDIO changes in the protocol, a turnaround time is inserted where the line is not driven by the host nor the target. By default, this turnaround time is one bit time, however this can be adjusted by configuring the SWCLK frequency.

# 32.8.2 SW protocol sequence

Each sequence consist of three phases:

- 1. Packet request (8 bits) transmitted by the host
- 2. Acknowledge response (3 bits) transmitted by the target
- 3. Data transfer phase (33 bits) transmitted by the host or the target

| Table 205. | Packet request (8-bits) |
|------------|-------------------------|
|------------|-------------------------|

| Bit | Name  | Description                         |  |
|-----|-------|-------------------------------------|--|
| 0   | Start | Must be "1"                         |  |
| 1   | APnDP | 0: DP Access<br>1: AP Access        |  |
| 2   | RnW   | 0: Write Request<br>1: Read Request |  |



| Bit | Name   | Description                                                                      |  |
|-----|--------|----------------------------------------------------------------------------------|--|
| 4:3 | A(3:2) | Address field of the DP or AP registers (refer to Table 204)                     |  |
| 5   | Parity | Single bit parity of preceding bits                                              |  |
| 6   | Stop   | 0                                                                                |  |
| 7   | Park   | Not driven by the host. Must be read as "1" by the target because of the pull-up |  |

 Table 205.
 Packet request (8-bits) (continued)

Refer to the Cortex<sup>™</sup>-M4Fr0p1 *TRM* for a detailed description of DPACC and APACC registers.

The packet request is always followed by the turnaround time (default 1 bit) where neither the host nor target drive the line.

Table 206. ACK response (3 bits)

| Bit | Name | Description                        |
|-----|------|------------------------------------|
| 02  | ACK  | 001: FAULT<br>010: WAIT<br>100: OK |

The ACK Response must be followed by a turnaround time only if it is a READ transaction or if a WAIT or FAULT acknowledge has been received.

### Table 207. DATA transfer (33 bits)

| Bit | Name              | Name Description                  |  |
|-----|-------------------|-----------------------------------|--|
| 031 | WDATA or<br>RDATA | Write or Read data                |  |
| 32  | Parity            | Single parity of the 32 data bits |  |

The DATA transfer must be followed by a turnaround time only if it is a READ transaction.

## 32.8.3 SW-DP state machine (reset, idle states, ID code)

The State Machine of the SW-DP has an internal ID code which identifies the SW-DP. It follows the JEP-106 standard. This ID code is the default ARM one and is set to **0x2BA01477** (corresponding to Cortex<sup>™</sup>-M4F r0p1).

Note:

Note that the SW-DP state machine is inactive until the target reads this ID code.

- The SW-DP state machine is in RESET STATE either after power-on reset, or after the DP has switched from JTAG to SWD or after the line is high for more than 50 cycles
- The SW-DP state machine is in IDLE STATE if the line is low for at least two cycles after RESET state.
- After RESET state, it is **mandatory** to first enter into an IDLE state AND to perform a READ access of the DP-SW ID CODE register. Otherwise, the target will issue a FAULT acknowledge response on another transactions.

Doc ID 018909 Rev 1



Further details of the SW-DP state machine can be found in the  $Cortex^{TM}$ -M4F r0p1 TRM and the CoreSight Design Kit r0p1 TRM.

## 32.8.4 DP and AP read/write accesses

- Read accesses to the DP are not posted: the target response can be immediate (if ACK=OK) or can be delayed (if ACK=WAIT).
- Read accesses to the AP are posted. This means that the result of the access is returned on the next transfer. If the next access to be done is NOT an AP access, then the DP-RDBUFF register must be read to obtain the result. The READOK flag of the DP-CTRL/STAT register is updated on every AP read access or RDBUFF read request to know if the AP read access was successful.
- The SW-DP implements a write buffer (for both DP or AP writes), that enables it to accept a write operation even when other transactions are still outstanding. If the write buffer is full, the target acknowledge response is "WAIT". With the exception of IDCODE read or CTRL/STAT read or ABORT write which are accepted even if the write buffer is full.
- Because of the asynchronous clock domains SWCLK and HCLK, two extra SWCLK cycles are needed after a write transaction (after the parity bit) to make the write effective internally. These cycles should be applied while driving the line low (IDLE state)

This is particularly important when writing the CTRL/STAT for a power-up request. If the next transaction (requiring a power-up) occurs immediately, it will fail.

# 32.8.5 SW-DP registers

Access to these registers are initiated when APnDP=0

| A(3:2) | R/W        | CTRLSEL bit<br>of SELECT<br>register | Register        | Notes                                                                                                                                                                                                                                                                       |
|--------|------------|--------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00     | Read       |                                      | IDCODE          | The manufacturer code is not set to ST code. <b>0x2BA01477</b> (identifies the SW-DP)                                                                                                                                                                                       |
| 00     | Write      |                                      | ABORT           |                                                                                                                                                                                                                                                                             |
| 01     | Read/Write | 0                                    | DP-CTRL/STAT    | <ul> <li>Purpose is to:</li> <li>request a system or debug power-up</li> <li>configure the transfer operation for AP accesses</li> <li>control the pushed compare and pushed verify operations.</li> <li>read some status flags (overrun, power-up acknowledges)</li> </ul> |
| 01     | Read/Write | 1                                    | WIRE<br>CONTROL | Purpose is to configure the physical serial<br>port protocol (like the duration of the<br>turnaround time)                                                                                                                                                                  |
| 10     | Read       |                                      | READ<br>RESEND  | Enables recovery of the read data from a corrupted debugger transfer, without repeating the original AP transfer.                                                                                                                                                           |

#### Table 208.SW-DP registers



| A(3:2) | R/W        | CTRLSEL bit<br>of SELECT<br>register | Register       | Notes                                                                                                                                                                                                                                                                               |
|--------|------------|--------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10     | Write      |                                      | SELECT         | The purpose is to select the current access port and the active 4-words register window                                                                                                                                                                                             |
| 11     | Read/Write |                                      | READ<br>BUFFER | This read buffer is useful because AP<br>accesses are posted (the result of a read AP<br>request is available on the next AP<br>transaction).<br>This read buffer captures data from the AP,<br>presented as the result of a previous read,<br>without initiating a new transaction |

Table 208. SW-DP registers (continued)

#### 32.8.6 SW-AP registers

Access to these registers are initiated when APnDP=1

There are many AP Registers (see AHB-AP) addressed as the combination of:

- The shifted value A[3:2]
- The current value of the DP SELECT register

# 32.9 AHB-AP (AHB access port) - valid for both JTAG-DP and SW-DP

#### Features:

- System access is independent of the processor status.
- Either SW-DP or JTAG-DP accesses AHB-AP.
- The AHB-AP is an AHB master into the Bus Matrix. Consequently, it can access all the data buses (Dcode Bus, System Bus, internal and external PPB bus) but the ICode bus.
- Bitband transactions are supported.
- AHB-AP transactions bypass the FPB.

The address of the 32-bits AHP-AP resisters are 6-bits wide (up to 64 words or 256 bytes) and consists of:

- c) Bits [7:4] = the bits [7:4] APBANKSEL of the DP SELECT register
- d) Bits [3:2] = the 2 address bits of A(3:2) of the 35-bit packet request for SW-DP.



The AHB-AP of the Cortex<sup>™</sup>-M4F includes 9 x 32-bits registers:

| Table 209. | Cortex <sup>™</sup> -M4F AHB-AP registers |
|------------|-------------------------------------------|
|------------|-------------------------------------------|

| Address<br>offset | Register name                     | Notes                                                                                                                        |
|-------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| 0x00              | AHB-AP Control and Status<br>Word | Configures and controls transfers through the AHB interface (size, hprot, status on current transfer, address increment type |
| 0x04              | AHB-AP Transfer Address           |                                                                                                                              |
| 0x0C              | AHB-AP Data Read/Write            |                                                                                                                              |
| 0x10              | AHB-AP Banked Data 0              |                                                                                                                              |
| 0x14              | AHB-AP Banked Data 1              | Directly maps the 4 aligned data words without rewriting                                                                     |
| 0x18              | AHB-AP Banked Data 2              | the Transfer Address Register.                                                                                               |
| 0x1C              | AHB-AP Banked Data 3              |                                                                                                                              |
| 0xF8              | AHB-AP Debug ROM Address          | Base Address of the debug interface                                                                                          |
| 0xFC              | AHB-AP ID Register                |                                                                                                                              |

Refer to the *Cortex™-M4F r0p1 TRM* for further details.

# 32.10 Core debug

Core debug is accessed through the core debug registers. Debug access to these registers is by means of the *Advanced High-performance Bus* (AHB-AP) port. The processor can access these registers directly over the internal *Private Peripheral Bus* (PPB).

It consists of 4 registers:

| Table 210. | Core | debug | registers |
|------------|------|-------|-----------|
|------------|------|-------|-----------|

| Register | Description                                                                                                                                                                                                   |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DHCSR    | The 32-bit Debug Halting Control and Status Register<br>This provides status information about the state of the processor enable core debug<br>halt and step the processor                                    |
| DCRSR    | The 17-bit Debug Core Register Selector Register:<br>This selects the processor register to transfer data to or from.                                                                                         |
| DCRDR    | <i>The 32-bit Debug Core Register Data Register:</i><br>This holds data for reading and writing registers to and from the processor selected by the DCRSR (Selector) register.                                |
| DEMCR    | <i>The 32-bit Debug Exception and Monitor Control Register:</i><br>This provides Vector Catching and Debug Monitor Control. This register contains a bit named <b>TRCENA</b> which enable the use of a TRACE. |

*Note: Important*: these registers are not reset by a system reset. They are only reset by a poweron reset.

Refer to the *Cortex™-M4F r0p1 TRM* for further details.



Doc ID 018909 Rev 1

To Halt on reset, it is necessary to:

- enable the bit0 (VC\_CORRESET) of the Debug and Exception Monitor Control Register
- enable the bit0 (C\_DEBUGEN) of the Debug Halting Control and Status Register.

# 32.11 Capability of the debugger host to connect under system reset

The STM32F40x and STM32F41x MCUs' reset system comprises the following reset sources:

- POR (power-on reset) which asserts a RESET at each power-up.
- Internal watchdog reset
- Software reset
- External reset

The Cortex<sup>™</sup>-M4F differentiates the reset of the debug part (generally PORRESETn) and the other one (SYSRESETn)

This way, it is possible for the debugger to connect under System Reset, programming the Core Debug Registers to halt the core when fetching the reset vector. Then the host can release the system reset and the core will immediately halt without having executed any instructions. In addition, it is possible to program any debug features under System Reset.

*Note:* It is highly recommended for the debugger host to connect (set a breakpoint in the reset vector) under system reset.

# 32.12 FPB (Flash patch breakpoint)

The FPB unit:

- implements hardware breakpoints
- patches code and data from code space to system space. This feature gives the possibility to correct software bugs located in the Code Memory Space.

The use of a Software Patch or a Hardware Breakpoint is exclusive.

The FPB consists of:

- 2 literal comparators for matching against literal loads from Code Space and remapping to a corresponding area in the System Space.
- 6 instruction comparators for matching against instruction fetches from Code Space. They can be used either to remap to a corresponding area in the System Space or to generate a Breakpoint Instruction to the core.



# 32.13 DWT (data watchpoint trigger)

The DWT unit consists of four comparators. They are configurable as:

- a hardware watchpoint or
- a trigger to an ETM or
- a PC sampler or
- a data address sampler

The DWT also provides some means to give some profiling informations. For this, some counters are accessible to give the number of:

- Clock cycle
- Folded instructions
- Load store unit (LSU) operations
- Sleep cycles
- CPI (clock per instructions)
- Interrupt overhead

# **32.14 ITM (instrumentation trace macrocell)**

#### 32.14.1 General description

The ITM is an application-driven trace source that supports *printf* style debugging to trace *Operating System* (OS) and application events, and emits diagnostic system information. The ITM emits trace information as packets which can be generated as:

- **Software trace.** Software can write directly to the ITM stimulus registers to emit packets.
- Hardware trace. The DWT generates these packets, and the ITM emits them.
- **Time stamping.** Timestamps are emitted relative to packets. The ITM contains a 21-bit counter to generate the timestamp. The Cortex<sup>™</sup>-M4F clock or the bit clock rate of the *Serial Wire Viewer* (SWV) output clocks the counter.

The packets emitted by the ITM are output to the TPIU (Trace Port Interface Unit). The formatter of the TPIU adds some extra packets (refer to TPIU) and then output the complete packets sequence to the debugger host.

The bit TRCEN of the Debug Exception and Monitor Control Register must be enabled before you program or use the ITM.

#### 32.14.2 Time stamp packets, synchronization and overflow packets

Time stamp packets encode time stamp information, generic control and synchronization. It uses a 21-bit timestamp counter (with possible prescalers) which is reset at each time stamp packet emission. This counter can be either clocked by the CPU clock or the SWV clock.

A synchronization packet consists of 6 bytes equal to 0x80\_00\_00\_00\_00\_00 which is emitted to the TPIU as 00 00 00 00 00 80 (LSB emitted first).

A synchronization packet is a timestamp packet control. It is emitted at each DWT trigger.



For this, the DWT must be configured to trigger the ITM: the bit CYCCNTENA (bit0) of the DWT Control Register must be set. In addition, the bit2 (SYNCENA) of the ITM Trace Control Register must be set.

Note: If the SYNENA bit is not set, the DWT generates Synchronization triggers to the TPIU which will send only TPIU synchronization packets and not ITM synchronization packets.

An overflow packet consists is a special timestamp packets which indicates that data has been written but the FIFO was full.

| Address               | Register                        | Details                                                                                                                                                   |  |  |  |
|-----------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| @E0000FB0             | ITM lock access                 | Write 0xC5ACCE55 to unlock Write Access to the other ITM registers                                                                                        |  |  |  |
|                       |                                 | Bits 31-24 = Always 0                                                                                                                                     |  |  |  |
|                       |                                 | Bits 23 = Busy                                                                                                                                            |  |  |  |
|                       |                                 | Bits 22-16 = 7-bits ATB ID which identifies the source of the trace data.                                                                                 |  |  |  |
|                       |                                 | Bits 15-10 = Always 0                                                                                                                                     |  |  |  |
|                       |                                 | Bits 9:8 = TSPrescale = Time Stamp Prescaler                                                                                                              |  |  |  |
| @E0000E80             |                                 | Bits 7-5 = Reserved                                                                                                                                       |  |  |  |
|                       | ITM trace control               | Bit 4 = SWOENA = Enable SWV behavior (to clock the timestamp counter by the SWV clock).                                                                   |  |  |  |
|                       |                                 | Bit 3 = DWTENA: Enable the DWT Stimulus                                                                                                                   |  |  |  |
|                       |                                 | Bit 2 = SYNCENA: this bit must be to 1 to enable the DWT to generate synchronization triggers so that the TPIU can then emit the synchronization packets. |  |  |  |
|                       |                                 | Bit 1 = TSENA (Timestamp Enable)                                                                                                                          |  |  |  |
|                       |                                 | Bit 0 = ITMENA: Global Enable Bit of the ITM                                                                                                              |  |  |  |
|                       |                                 | Bit 3: mask to enable tracing ports31:24                                                                                                                  |  |  |  |
| @E0000E40             | ITM troop privilege             | Bit 2: mask to enable tracing ports23:16                                                                                                                  |  |  |  |
| @E0000E40             | ITM trace privilege             | Bit 1: mask to enable tracing ports15:8                                                                                                                   |  |  |  |
|                       |                                 | Bit 0: mask to enable tracing ports7:0                                                                                                                    |  |  |  |
| @E0000E00             | ITM trace enable                | Each bit enables the corresponding Stimulus port to generate trace.                                                                                       |  |  |  |
| @E000000-<br>E000007C | Stimulus port<br>registers 0-31 | Write the 32-bits data on the selected Stimulus Port (32 available) to be traced out.                                                                     |  |  |  |

Table 211. Main ITM registers



#### Example of configuration

To output a simple value to the TPIU:

- Configure the TPIU and assign TRACE I/Os by configuring the DBGMCU\_CR (refer to Section 32.17.2: TRACE pin assignment and Section 32.16.3: Debug MCU configuration register)
- Write 0xC5ACCE55 to the ITM Lock Access Register to unlock the write access to the ITM registers
- Write 0x00010005 to the ITM Trace Control Register to enable the ITM with Sync enabled and an ATB ID different from 0x00
- Write 0x1 to the ITM Trace Enable Register to enable the Stimulus Port 0
- Write 0x1 to the ITM Trace Privilege Register to unmask stimulus ports 7:0
- Write the value to output in the Stimulus Port Register 0: this can be done by software (using a printf function)

# 32.15 ETM (Embedded trace macrocell)

#### 32.15.1 General description

The ETM enables the reconstruction of program execution. Data are traced using the Data Watchpoint and Trace (DWT) component or the Instruction Trace Macrocell (ITM) whereas instructions are traced using the Embedded Trace Macrocell (ETM).

The ETM transmits information as packets and is triggered by embedded resources. These resources must be programmed independently and the trigger source is selected using the Trigger Event Register (0xE0041008). An event could be a simple event (address match from an address comparator) or a logic equation between 2 events. The trigger source is one of the fourth comparators of the DWT module, The following events can be monitored:

- Clock cycle matching
- Data address matching

For more informations on the trigger resources refer to *Section 32.13: DWT (data watchpoint trigger)*.

The packets transmitted by the ETM are output to the TPIU (Trace Port Interface Unit). The formatter of the TPIU adds some extra packets (refer to *Section 32.17: TPIU (trace port interface unit)*) and then outputs the complete packet sequence to the debugger host.

#### 32.15.2 Signal protocol, packet types

This part is described in the chapter 7 ETMv3 Signal Protocol of the ARM IHI 0014N document.



## 32.15.3 Main ETM registers

For more information on registers refer to the chapter 3 of the ARM IHI 0014N specification.

| Table 212. | Main | ЕТМ | registers |
|------------|------|-----|-----------|
|            | mann |     | regiotore |

| Address    | Register                 | Details                                                                                                |  |  |  |  |  |  |  |  |
|------------|--------------------------|--------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 0xE0041FB0 | ETM Lock Access          | Write 0xC5ACCE55 to unlock the write access to the other ETM registers.                                |  |  |  |  |  |  |  |  |
| 0xE0041000 | ETM Control              | This register controls the general operation of the ETM, for instance how tracing is enabled.          |  |  |  |  |  |  |  |  |
| 0xE0041010 | ETM Status               | This register provides information about the current status of the trace and trigger logic.            |  |  |  |  |  |  |  |  |
| 0xE0041008 | ETM Trigger Event        | This register defines the event that will control trigger.                                             |  |  |  |  |  |  |  |  |
| 0xE004101C | ETM Trace Enable Control | This register defines which comparator is selected.                                                    |  |  |  |  |  |  |  |  |
| 0xE0041020 | ETM Trace Enable Event   | This register defines the trace enabling event.                                                        |  |  |  |  |  |  |  |  |
| 0xE0041024 | ETM Trace Start/Stop     | This register defines the traces used by the trigger source to start and stop the trace, respectively. |  |  |  |  |  |  |  |  |

### 32.15.4 Configuration example

To output a simple value to the TPIU:

- Configure the TPIU and enable the I/IO\_TRACEN to assign TRACE I/Os in the STM32F40x and STM32F41x debug configuration register.
- Write 0xC5ACCE55 to the ETM Lock Access Register to unlock the write access to the ITM registers
- Write 0x00001D1E to the control register (configure the trace)
- Write 0000406F to the Trigger Event register (define the trigger event)
- Write 0000006F to the Trace Enable Event register (define an event to start/stop)
- Write 00000001 to the Trace Start/stop register (enable the trace)
- Write 0000191E to the ETM Control Register (end of configuration)

# 32.16 MCU debug component (DBGMCU)

The MCU debug component helps the debugger provide support for:

- Low-power modes
- Clock control for timers, watchdog, I2C and bxCAN during a breakpoint
- Control of the trace pins assignment

#### 32.16.1 Debug support for low-power modes

To enter low-power mode, the instruction WFI or WFE must be executed.

The MCU implements several low-power modes which can either deactivate the CPU clock or reduce the power of the CPU.



The core does not allow FCLK or HCLK to be turned off during a debug session. As these are required for the debugger connection, during a debug, they must remain active. The MCU integrates special means to allow the user to debug software in low-power modes.

For this, the debugger host must first set some debug configuration registers to change the low-power mode behavior:

- In Sleep mode, DBG\_SLEEP bit of DBGMCU\_CR register must be previously set by the debugger. This will feed HCLK with the same clock that is provided to FCLK (system clock previously configured by the software).
- In Stop mode, the bit DBG\_STOP must be previously set by the debugger. This will enable the internal RC oscillator clock to feed FCLK and HCLK in STOP mode.

## 32.16.2 Debug support for timers, watchdog, bxCAN and I<sup>2</sup>C

During a breakpoint, it is necessary to choose how the counter of timers and watchdog should behave:

- They can continue to count inside a breakpoint. This is usually required when a PWM is controlling a motor, for example.
- They can stop to count inside a breakpoint. This is required for watchdog purposes.

For the bxCAN, the user can choose to block the update of the receive register during a breakpoint.

For the I<sup>2</sup>C, the user can choose to block the SMBUS timeout during a breakpoint.

#### 32.16.3 Debug MCU configuration register

This register allows the configuration of the MCU under DEBUG. This concerns:

- Low-power mode support
- Timer and watchdog counter support
- bxCAN communication support
- Trace pin assignment

This DBGMCU\_CR is mapped on the External PPB bus at address 0xE0042004

It is asynchronously reset by the PORESET (and not the system reset). It can be written by the debugger under system reset.

If the debugger host does not support these features, it is still possible for the user software to write to these registers.

#### DBGMCU\_CR

Address: 0xE004 2004

Only 32-bit access supported

POR Reset: 0x0000 0000 (not reset by system reset)



| 31       | 30 | 29 | 28 | 27 | 26 | 25              | 24  | 23             | 22   | 21    | 20                  | 19           | 18            | 17 | 16 |
|----------|----|----|----|----|----|-----------------|-----|----------------|------|-------|---------------------|--------------|---------------|----|----|
|          |    |    |    |    |    |                 | Res | erved          |      |       |                     |              |               |    |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9               | 8   | 7              | 6    | 5     | 4                   | 3            | 2             | 1  | 0  |
| Reserved |    |    |    |    |    | TRA<br>MC<br>[1 |     | TRACE_<br>IOEN | Rese | erved | DBG_<br>STAND<br>BY | DBG_<br>STOP | DBG_<br>SLEEP |    |    |
|          |    |    |    |    |    |                 |     | rw             | rw   | rw    |                     |              | rw            | rw | rw |

Bits 31:8 Reserved, must be kept at reset value.

#### Bits 7:5 TRACE\_MODE[1:0] and TRACE\_IOEN: Trace pin assignment control

- With TRACE\_IOEN=0:
  - TRACE\_MODE=xx: TRACE pins not assigned (default state)
- With TRACE\_IOEN=1:
  - TRACE\_MODE=00: TRACE pin assignment for Asynchronous Mode
  - TRACE\_MODE=01: TRACE pin assignment for Synchronous Mode with a TRACEDATA size of 1
  - TRACE\_MODE=10: TRACE pin assignment for Synchronous Mode with a TRACEDATA size of 2
  - TRACE\_MODE=11: TRACE pin assignment for Synchronous Mode with a TRACEDATA size of 4

Bits 4:3 Reserved, must be kept at reset value.

#### Bit 2 DBG\_STANDBY: Debug Standby mode

0: (FCLK=Off, HCLK=Off) The whole digital part is unpowered. From software point of view, exiting from Standby is identical than fetching reset vector (except a few status bit indicated that the MCU is resuming from Standby) 1: (FCLK=On, HCLK=On) In this case, the digital part is not unpowered and FCLK and HCLK are provided by the internal RC oscillator which remains active. In addition, the MCU generate a system reset during Standby mode so that exiting from Standby is identical than fetching from reset

#### Bit 1 **DBG\_STOP:** Debug Stop mode

0: (FCLK=Off, HCLK=Off) In STOP mode, the clock controller disables all clocks (including HCLK and FCLK). When exiting from STOP mode, the clock configuration is identical to the one after RESET (CPU clocked by the 8 MHz internal RC oscillator (HSI)). Consequently, the software must reprogram the clock controller to enable the PLL, the Xtal, etc. 1: (FCLK=On, HCLK=On) In this case, when entering STOP mode, FCLK and HCLK are provided by the internal RC oscillator which remains active in STOP mode. When exiting STOP mode, the software must reprogram the clock controller to enable the PLL, the Xtal, etc. (in the same way it would do in case of DBG\_STOP=0)

#### Bit 0 DBG\_SLEEP: Debug Sleep mode

0: (FCLK=On, HCLK=Off) In Sleep mode, FCLK is clocked by the system clock as previously configured by the software while HCLK is disabled.

In Sleep mode, the clock controller configuration is not reset and remains in the previously programmed state. Consequently, when exiting from Sleep mode, the software does not need to reconfigure the clock controller.

1: (FCLK=On, HCLK=On) In this case, when entering Sleep mode, HCLK is fed by the same clock that is provided to FCLK (system clock as previously configured by the software).



# 32.16.4 Debug MCU APB1 freeze register (DBGMCU\_APB1\_FZ)

The DBGMCU\_APB1\_FZ register is used to configure the MCU under Debug. It concerns APB1 peripherals. It is mapped on the external PPB bus at address 0xE004 2008.

The register is asynchronously reset by the POR (and not the system reset). It can be written by the debugger under system reset.

Address : 0xE004 2008

Only 32-bits access are supported.

Power on reset (POR): 0x0000 0000 (not reset by system reset)

| 31 | 30       | 29       | 28            | 27            | 26            | 25            | 24             | 23                     | 22                     | 21                     | 20                                                                                | 19 | 18 | 17    | 16 |
|----|----------|----------|---------------|---------------|---------------|---------------|----------------|------------------------|------------------------|------------------------|-----------------------------------------------------------------------------------|----|----|-------|----|
|    |          | Reservec | I             |               | DBG_CAN2_STOP | DBG_CAN1_STOP | Reserved       | DBG_I2C3_SMBUS_TIMEOUT | DBG_I2C2_SMBUS_TIMEOUT | DBG_I2C1_SMBUS_TIMEOUT | Reserved                                                                          |    |    |       |    |
|    |          |          |               |               | rw            | rw            |                | rw                     | rw                     | rw                     |                                                                                   |    |    |       |    |
| 15 | 14       | 13       | 12            | 11            | 10            | 9             | 8              | 7                      | 6                      | 5                      | 4                                                                                 | 3  | 2  | 1     | 0  |
|    | Reserved | 1        | DBG_IWDG_STOP | DBG_WWDG_STOP | DBG_RTC_STOP  | Reserved      | DBG_TIM14_STOP | DBG_TIM13_STOP         | DBG_TIM12_STOP         | DBG_TIM7_STOP          | DBG_TIM6_STOP<br>DBG_TIM5_STOP<br>DBG_TIM4_STOP<br>DBG_TIM3_STOP<br>DBG_TIM3_STOP |    |    | TIM2_ |    |
|    |          |          |               | rw            | rw            |               | rw             | rw                     | rw                     | rw                     | rw                                                                                | rw | rw | rw    | rw |

Bits 31:27 Reserved, must be kept at reset value.

#### Bit 26 **DBG\_CAN2\_STOP:** Debug CAN2 stopped when Core is halted

- 0: Same behavior as in normal mode
- 1: The CAN2 receive registers are frozen
- Bit 25 **DBG\_CAN1\_STOP:** Debug CAN2 stopped when Core is halted
  - 0: Same behavior as in normal mode
  - 1: The CAN2 receive registers are frozen
- Bit 24 Reserved, must be kept at reset value.
- Bit 23 **DBG\_I2C3\_SMBUS\_TIMEOUT:** SMBUS timeout mode stopped when Core is halted 0: Same behavior as in normal mode
  - 1: The SMBUS timeout is frozen
- Bit 22 **DBG\_I2C2\_SMBUS\_TIMEOUT:** SMBUS timeout mode stopped when Core is halted
  - 0: Same behavior as in normal mode
  - 1: The SMBUS timeout is frozen
- Bit 21 DBG\_I2C1\_SMBUS\_TIMEOUT: SMBUS timeout mode stopped when Core is halted
  - 0: Same behavior as in normal mode
  - 1: The SMBUS timeout is frozen



Doc ID 018909 Rev 1

- Bit 20:13 Reserved, must be kept at reset value.
  - Bit 12 **DBG\_IWDG\_STOP:** Debug independent watchdog stopped when core is halted 0: The independent watchdog counter clock continues even if the core is halted 1: The independent watchdog counter clock is stopped when the core is halted
  - Bit 11 **DBG\_WWDG\_STOP:** Debug Window Watchdog stopped when Core is halted 0: The window watchdog counter clock continues even if the core is halted 1: The window watchdog counter clock is stopped when the core is halted
  - Bit 10 **DBG\_RTC\_STOP:** RTC stopped when Core is halted
    - 0: The RTC counter clock continues even if the core is halted
    - 1: The RTC counter clock is stopped when the core is halted
  - Bit 9 Reserved, must be kept at reset value.
- Bits 8:0 DBG\_TIMx\_STOP: TIMx counter stopped when core is halted (x=2..7, 12..14)
  - 0: The clock of the involved Timer Counter is fed even if the core is halted
    - 1: The clock of the involved Timer counter is stopped when the core is halted

#### 32.16.5 Debug MCU APB2 Freeze register (DBGMCU\_APB2\_FZ)

The DBGMCU\_APB2\_FZ register is used to configure the MCU under Debug. It concerns APB2 peripherals.

This register is mapped on the external PPB bus at address 0xE004 200C

It is asynchronously reset by the POR (and not the system reset). It can be written by the debugger under system reset.

Address: 0xE004 200C

Only 32-bit access is supported.

POR: 0x0000 0000 (not reset by system reset)

| 31 | 30       | 29 | 28 | 27 | 26 | 25       | 24 | 23 | 22 | 21 | 20                | 19                | 18                 | 17                 | 16                |
|----|----------|----|----|----|----|----------|----|----|----|----|-------------------|-------------------|--------------------|--------------------|-------------------|
|    |          |    |    |    | F  | Reserved | 4  |    |    |    |                   |                   | DBG_TIM11<br>_STOP | DBG_TIM10<br>_STOP | DBG_TIM9_<br>STOP |
|    |          |    |    |    |    |          |    |    |    |    | rw                | rw                | rw                 |                    |                   |
| 15 | 14       | 13 | 12 | 11 | 10 | 9        | 8  | 7  | 6  | 5  | 4                 | 3                 | 2                  | 1                  | 0                 |
|    | Reserved |    |    |    |    |          |    |    |    |    | DBG_TIM8_<br>STOP | DBG_TIM1_<br>STOP |                    |                    |                   |
|    |          |    |    |    |    |          |    |    |    |    | rw                | rw                |                    |                    |                   |

Bits 31:19 Reserved, must be kept at reset value.

Bits 18:16 **DBG\_TIMx\_STOP:** TIMx counter stopped when core is halted (x=9..11)

0: The clock of the involved Timer Counter is fed even if the core is halted

- 1: The clock of the involved Timer counter is stopped when the core is halted
- Bits 15:2 Reserved, must be kept at reset value.

Bit 1 **DBG\_TIM8\_STOP**: TIM8 counter stopped when core is halted

- 0: The clock of the involved Timer Counter is fed even if the core is halted
- 1: The clock of the involved Timer counter is stopped when the core is halted



Bit 0 **DBG\_TIM1\_STOP:** TIM1 counter stopped when core is halted

- 0: The clock of the involved Timer Counter is fed even if the core is halted
- 1: The clock of the involved Timer counter is stopped when the core is halted

# **32.17 TPIU (trace port interface unit)**

#### 32.17.1 Introduction

The TPIU acts as a bridge between the on-chip trace data from the ITM and the ETM.

The output data stream encapsulates the trace source ID, that is then captured by a *trace port analyzer* (TPA).

The core embeds a simple TPIU, especially designed for low-cost debug (consisting of a special version of the CoreSight TPIU).

Figure 413. TPIU block diagram



#### 32.17.2 TRACE pin assignment

• Asynchronous mode

The asynchronous mode requires 1 extra pin and is available on all packages. It is only available if using Serial Wire mode (not in JTAG mode).



| TPUI pin name  |      | Trace synchronous mode  | STM32F40x and<br>STM32F41x pin |
|----------------|------|-------------------------|--------------------------------|
| Tr of pin name | Туре | Description             | assignment                     |
| TRACESWO       | 0    | TRACE Async Data Output | PB3                            |

#### Table 213. Asynchronous TRACE pin assignment

• Synchronous mode

The synchronous mode requires from 2 to 6 extra pins depending on the data trace size and is only available in the larger packages. In addition it is available in JTAG mode and in Serial Wire mode and provides better bandwidth output capabilities than asynchronous trace.

| Table 214. | Synchronous | <b>TRACE</b> pin | assignment |
|------------|-------------|------------------|------------|
|------------|-------------|------------------|------------|

| TPUI pin name |      | Trace synchronous mode                       | STM32F40x and<br>STM32F41x pin |
|---------------|------|----------------------------------------------|--------------------------------|
|               | Туре | Description                                  | assignment                     |
| TRACECK       | 0    | TRACE Clock                                  | PE2                            |
| TRACED[3:0]   | 0    | TRACE Sync Data Outputs<br>Can be 1, 2 or 4. | PE[6:3]                        |

#### **TPUI TRACE** pin assignment

By default, these pins are NOT assigned. They can be assigned by setting the TRACE\_IOEN and TRACE\_MODE bits in the *MCU Debug component configuration register*. This configuration has to be done by the debugger host.

In addition, the number of pins to assign depends on the trace configuration (asynchronous or synchronous).

- Asynchronous mode: 1 extra pin is needed
- **Synchronous mode**: from 2 to 5 extra pins are needed depending on the size of the data trace port register (1, 2 or 4):
  - TRACECK
  - TRACED(0) if port size is configured to 1, 2 or 4
  - TRACED(1) if port size is configured to 2 or 4
  - TRACED(2) if port size is configured to 4
  - TRACED(3) if port size is configured to 4

To assign the TRACE pin, the debugger host must program the bits TRACE\_IOEN and TRACE\_MODE[1:0] of the Debug MCU configuration Register (DBGMCU\_CR). By default the TRACE pins are not assigned.

This register is mapped on the external PPB and is reset by the PORESET (and not by the SYSTEM reset). It can be written by the debugger under SYSTEM reset.



|                | DBGMCU_CR<br>register | Pins                        |                                | т                       | RACE IO pin        | assigned                  |                          |                    |
|----------------|-----------------------|-----------------------------|--------------------------------|-------------------------|--------------------|---------------------------|--------------------------|--------------------|
| TRACE_<br>IOEN | TRACE_<br>MODE[1:0]   | assigned for:               | <b>PB3 /</b> JTDO/<br>TRACESWO | <b>PE2 /</b><br>TRACECK | PE3 /<br>TRACED[0] | <b>PE4 /</b><br>TRACED[1] | PE5 /<br>TRACED[2]       | PE6 /<br>TRACED[3] |
| 0              | XX                    | No Trace<br>(default state) | Released <sup>(1)</sup>        |                         |                    |                           |                          |                    |
| 1              | 00                    | Asynchronous<br>Trace       | TRACESWO                       |                         |                    | (u:                       | Released<br>sable as GPI | O)                 |
| 1              | 01                    | Synchronous<br>Trace 1 bit  |                                | TRACECK                 | TRACED[0]          |                           |                          |                    |
| 1              | 10                    | Synchronous<br>Trace 2 bit  | Released <sup>(1)</sup>        | TRACECK                 | TRACED[0]          | TRACED[1]                 |                          |                    |
| 1              | 11                    | Synchronous<br>Trace 4 bit  |                                | TRACECK                 | TRACED[0]          | TRACED[1]                 | TRACED[2]                | TRACED[3]          |

Table 215. Flexible TRACE pin assignment

1. When Serial Wire mode is used, it is released. But when JTAG is used, it is assigned to JTDO.

Note: By default, the TRACECLKIN input clock of the TPIU is tied to GND. It is assigned to HCLK two clock cycles after the bit TRACE\_IOEN has been set.

The debugger must then program the Trace Mode by writing the PROTOCOL[1:0] bits in the SPP\_R (Selected Pin Protocol) register of the TPIU.

- PROTOCOL=00: Trace Port Mode (synchronous)
- PROTOCOL=01 or 10: Serial Wire (Manchester or NRZ) Mode (asynchronous mode). Default state is 01

It then also configures the TRACE port size by writing the bits [3:0] in the CPSPS\_R (Current Sync Port Size Register) of the TPIU:

- 0x1 for 1 pin (default state)
- 0x2 for 2 pins
- 0x8 for 4 pins

# 32.17.3 TPUI formatter

The formatter protocol outputs data in 16-byte frames:

- seven bytes of data
- eight bytes of mixed-use bytes consisting of:
  - 1 bit (LSB) to indicate it is a DATA byte ('0) or an ID byte ('1).
  - 7 bits (MSB) which can be data or change of source ID trace.
- one byte of auxiliary bits where each bit corresponds to one of the eight mixed-use bytes:
  - if the corresponding byte was a data, this bit gives bit0 of the data.
  - if the corresponding byte was an ID change, this bit indicates when that ID change takes effect.

Note: Refer to the ARM CoreSight Architecture Specification v1.0 (ARM IHI 0029B) for further information



Doc ID 018909 Rev 1

#### 32.17.4 TPUI frame synchronization packets

The TPUI can generate two types of synchronization packets:

- The Frame Synchronization packet (or Full Word Synchronization packet)
   It consists of the word: 0x7F\_FF\_FF (LSB emitted first). This sequence can not occur at any other time provided that the ID source code 0x7F has not been used.
   It is output periodically *between* frames.
   In continuous mode, the TPA must discard all these frames once a synchronization frame has been found.
- The Half-Word Synchronization packet

It consists of the half word: 0x7F\_FF (LSB emitted first).

It is output periodically between or within frames.

These packets are only generated in continuous mode and enable the TPA to detect that the TRACE port is in IDLE mode (no TRACE to be captured). When detected by the TPA, it must be discarded.

#### 32.17.5 Transmission of the synchronization frame packet

There is no Synchronization Counter register implemented in the TPIU of the core. Consequently, the synchronization trigger can only be generated by the **DWT**. Refer to the registers DWT Control Register (bits SYNCTAP[11:10]) and the DWT Current PC Sampler Cycle Count Register.

The TPUI Frame synchronization packet (0x7F\_FF\_FF\_FF) is emitted:

- after each TPIU reset release. This reset is synchronously released with the rising edge of the TRACECLKIN clock. This means that this packet is transmitted when the TRACE\_IOEN bit in the DBGMCU\_CFG register is set. In this case, the word 0x7F\_FF\_FF\_FF is not followed by any formatted packet.
- at each DWT trigger (assuming DWT has been previously configured). Two cases occur:
  - If the bit SYNENA of the ITM is reset, only the word 0x7F\_FF\_FF\_FF is emitted without any formatted stream which follows.
  - If the bit SYNENA of the ITM is set, then the ITM synchronization packets will follow (0x80\_00\_00\_00\_00\_00), formatted by the TPUI (trace source ID added).

#### 32.17.6 Synchronous mode

The trace data output size can be configured to 4, 2 or 1 pin: TRACED(3:0)

The output clock is output to the debugger (TRACECK)

Here, TRACECLKIN is driven internally and is connected to HCLK only when TRACE is used.

Note: In this synchronous mode, it is not required to provide a stable clock frequency.

The TRACE I/Os (including TRACECK) are driven by the rising edge of TRACLKIN (equal to HCLK). Consequently, the output frequency of TRACECK is equal to HCLK/2.



#### 32.17.7 Asynchronous mode

This is a low cost alternative to output the trace using only 1 pin: this is the asynchronous output pin TRACESWO. Obviously there is a limited bandwidth.

TRACESWO is multiplexed with JTDO when using the SW-DP pin. This way, this functionality is available in all STM32F40x and STM32F41x packages.

This asynchronous mode requires a constant frequency for TRACECLKIN. For the standard UART (NRZ) capture mechanism, 5% accuracy is needed. The Manchester encoded version is tolerant up to 10%.

#### 32.17.8 TRACECLKIN connection inside the STM32F40x and STM32F41x

In the STM32F40x and STM32F41x, this TRACECLKIN input is internally connected to HCLK. This means that when in asynchronous trace mode, the application is restricted to use to time frames where the CPU frequency is stable.

#### Note: **Important:** when using asynchronous trace: it is important to be aware that:

The default clock of the STM32F40x and STM32F41x MCUs is the internal RC oscillator. Its frequency under reset is different from the one after reset release. This is because the RC calibration is the default one under system reset and is updated at each system reset release.

Consequently, the trace port analyzer (TPA) should not enable the trace (with the TRACE\_IOEN bit) under system reset, because a Synchronization Frame Packet will be issued with a different bit time than trace packets which will be transmitted after reset release.



# 32.17.9 TPIU registers

The TPIU APB registers can be read and written only if the bit TRCENA of the Debug Exception and Monitor Control Register (DEMCR) is set. Otherwise, the registers are read as zero (the output of this bit enables the PCLK of the TPIU).

| Address    | Register                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xE0040004 | Current port size           | Allows the trace port size to be selected:<br>Bit 0: Port size = 1<br>Bit 1: Port size = 2<br>Bit 2: Port size = 3, not supported<br>Bit 3: Port Size = 4<br>Only 1 bit must be set. By default, the port size is one bit.<br>(0x00000001)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0xE00400F0 | Selected pin<br>protocol    | Allows the Trace Port Protocol to be selected:<br>Bit1:0=<br>00: Sync Trace Port Mode<br>01: Serial Wire Output - manchester (default value)<br>10: Serial Wire Output - NRZ<br>11: reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0xE0040304 | Formatter and flush control | Bit 31-9 = always '0<br>Bit 8 = TrigIn = always '1 to indicate that triggers are indicated<br>Bit 7-4 = always 0<br>Bit 3-2 = always 0<br>Bit 1 = EnFCont. In Sync Trace mode (Select_Pin_Protocol<br>register bit1:0=00), this bit is forced to '1: the formatter is<br>automatically enabled in continuous mode. In asynchronous<br>mode (Select_Pin_Protocol register bit1:0 <> 00), this bit can<br>be written to activate or not the formatter.<br>Bit 0 = always 0<br>The resulting default value is 0x102<br><b>Note:</b> In synchronous mode, because the TRACECTL pin is not<br>mapped outside the chip, the formatter is always enabled in<br>continuous mode -this way the formatter inserts some control<br>packets to identify the source of the trace packets). |
| 0xE0040300 | Formatter and flush status  | Not used in Cortex™-M4F, always read as 0x00000008                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Table 216. Important TPIU registers



# 32.17.10 Example of configuration

- Set the bit TRCENA in the Debug Exception and Monitor Control Register (DEMCR)
- Write the TPIU Current Port Size Register to the desired value (default is 0x1 for a 1-bit port size)
- Write TPIU Formatter and Flush Control Register to 0x102 (default value)
- Write the TPIU Select Pin Protocol to select the sync or async mode. Example: 0x2 for async NRZ mode (UART like)
- Write the DBGMCU control register to 0x20 (bit IO\_TRACEN) to assign TRACE I/Os for async mode. A TPIU Sync packet is emitted at this time (FF\_FF\_FF\_7F)
- Configure the ITM and write the ITM Stimulus register to output a value

# 32.18 DBG register map

The following table summarizes the Debug registers

| Addr.          | Register                   | 59 33 33 33<br>58 59 39 33 | 27<br>26      | 25                        | 23                     | 22                     | 21                     | 20                             | 18               | 17               | 16                     | 15<br>13<br>13 | 12  | 1             | 10       | 6            | 8              | 2                         | 9                         | 5                          | 4             | З             | 2             | ۲               | 0               |
|----------------|----------------------------|----------------------------|---------------|---------------------------|------------------------|------------------------|------------------------|--------------------------------|------------------|------------------|------------------------|----------------|-----|---------------|----------|--------------|----------------|---------------------------|---------------------------|----------------------------|---------------|---------------|---------------|-----------------|-----------------|
| 0xE004<br>2000 | DBGMCU_IDC<br>ODE          |                            |               | RE                        | V_IC                   | )                      |                        |                                |                  |                  |                        | Reserved       |     |               |          |              |                | D                         | EV_                       | _ID                        | 1             |               | L             |                 |                 |
|                | Reset value <sup>(1)</sup> | XXXX                       | ХХ            | хх                        | Х                      | Х                      | Х                      | х х                            | Х                | Х                | Х                      |                | -   | Х             | Х        | Х            | Х              | X                         | <                         | Х                          | Х             | Х             | Х             | Х               | Х               |
| 0xE004<br>2004 | DBGMCU_CR                  |                            | Reserv        | ved                       |                        |                        |                        | DBG_TIM7_STOP<br>DBG_TIM6_STOP | DBG_TIM5_STOP    | DBG_TIM8_STOP    | DBG_I2C2_SMBUS_TIMEOUT | Re             | ese | rve           | ł        |              |                | TRA<br>E_<br>VIOE<br>[1:0 | AC /<br>_ E<br>DE I<br>0] | TR<br>AC<br>E_IO<br>E<br>N | Reserved      | 0000          | DBG_STANDBY   | DBG_STOP        | DBG_SLEEP       |
|                | Reset value                |                            |               |                           |                        |                        | -                      | 0 0                            | 0                | 0                | 0                      |                |     |               |          |              | -              | 0                         | 0                         | 0                          |               |               | 0             | 0               | 0               |
| 0xE004<br>2008 | DBGMCU_<br>APB1_FZ         | Reserved                   | DBG_CAN2_STOP | DBG_CAN1_STOP<br>Reserved | DBG_I2C3_SMBUS_TIMEOUT | DBG_I2C2_SMBUS_TIMEOUT | DBG_I2C1_SMBUS_TIMEOUT |                                | I                | Res              | erve                   | d<br>CCTC CCM  |     | DBG_WWDG_STOP | Reserved | DBG_RTC_STOP | DBG_TIM14_STOP | DBG_IIM13_STOP            |                           | DBG_TIM7_STOP              | DBG_TIM6_STOP | DBG_TIM5_STOP | DBG_TIM4_STOP | DBG_TIM3_STOP   | DBG_TIM2_STOP   |
|                | Reset value                |                            | 0             | 0 0                       |                        | 0                      | 0                      |                                |                  |                  | 1                      |                | 0   | 0             |          | 0            | 0              | 0                         | 0                         | 0                          | 0             | 0             |               | 0               | 0               |
| 0xE004<br>200C | DBGMCU_<br>APB2_FZ         |                            | Re            | servec                    | I                      |                        |                        |                                | o DBG_TIM11_STOP | o DBG_TIM10_STOP | OBG_TIM9_STOP          |                |     |               | R        | ese          | rved           |                           |                           |                            |               |               |               | O DBG_TIM8_STOP | o DBG_TIM1_STOP |

#### Table 217. DBG register map and reset values

1. The reset value is product dependent. For more information, refer to Section 32.6.1: MCU device ID code.



# 33 Device electronic signature

The electronic signature is stored in the System memory area in the Flash memory module, and can be read using the JTAG/SWD or the CPU. It contains factory-programmed identification data that allow the user firmware or other external devices to automatically match its interface to the characteristics of the STM32F40x and STM32F41x microcontroller.

# 33.1 Unique device ID register (96 bits)

The unique device identifier is ideally suited:

- for use as serial numbers (for example USB string serial numbers or other end applications)
- for use as security keys in order to increase the security of code in Flash memory while using and combining this unique ID with software cryptographic primitives and protocols before programming the internal Flash memory
- to activate secure boot processes, etc.

The 96-bit unique device identifier provides a reference number which is unique for any device and in any context. These bits can never be altered by the user.

The 96-bit unique device identifier can also be read in single bytes/half-words/words in different ways and then be concatenated using a custom algorithm.

#### Base address: 0x1FFF 7A10

Address offset: 0x00

Read only = 0xXXXX XXXX where X is factory-programmed

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | ι  | J_ID | (32:0 | )) |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r    | r     | r  | r  | r  | r  | r  | r | r | r | r | r | r | r | r | r | r |

Bits 31:0 U\_ID(31:0): 31:0 unique ID bits

Address offset: 0x04

Read only = 0xXXXX XXXX where X is factory-programmed

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | U_ID( | 63:48) |    |    |    |    |    |    |    |
| r  | r  | r  | r  | r  | r  | r  | r     | r      | r  | r  | r  | r  | r  | r  | r  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | U_ID( | 47:32) |    |    |    |    |    |    |    |
| r  | r  | r  | r  | r  | r  | r  | r     | r      | r  | r  | r  | r  | r  | r  | r  |

Bits 31:0 U\_ID(63:32): 63:32 unique ID bits

Doc ID 018909 Rev 1



# 33.2 Flash size

Base address: 0x1FFF 7A10

Address offset: 0x00

Read only = 0xXXXX where X is factory-programmed

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|-----|-----|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   | F_S | IZE |   |   |   |   |   |   |   |
| r  | r  | r  | r  | r  | r  | r | r   | r   | r | r | r | r | r | r | r |

Bits 15:0 F\_ID(15:0): Flash memory size

This bitfield indicates the size of the device Flash memory expressed in Kbytes. As an example, 0x4000 corresponds to 1024 Kbytes.



#### Address offset: 0x08

#### Read only = 0xXXXX XXXX where X is factory-programmed

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | U_ID( | 95:80) |    |    |    |    |    |    |    |
| r  | r  | r  | r  | r  | r  | r  | r     | r      | r  | r  | r  | r  | r  | r  | r  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | U_ID( | 79:64) |    |    |    |    |    |    |    |
| r  | r  | r  | r  | r  | r  | r  | r     | r      | r  | r  | r  | r  | r  | r  | r  |

Bits 31:0 U\_ID(95:64): 95:64 Unique ID bits.



# **Revision history**

#### Table 218. Document revision history

| Date        | Version | Changes          |
|-------------|---------|------------------|
| 16-Sep-2011 | 1       | Initial release. |



# Index

# Α

# С

| CAN_BTR      |
|--------------|
| CAN_ESR      |
| CAN_FA1R806  |
| CAN_FFA1R806 |
| CAN_FiRx     |
| CAN_FM1R805  |
| CAN_FMR804   |
| CAN_FS1R805  |
| CAN_IER      |
| CAN_MCR      |
| CAN_MSR789   |
| CAN_RDHxR803 |
| CAN_RDLxR803 |
| CAN_RDTxR802 |
| CAN_RF0R792  |
| CAN_RF1R793  |
| CAN_RIxR801  |
| CAN_TDHxR800 |
| CAN_TDLxR800 |
| CAN_TDTxR799 |
| CAN_TIxR798  |
| CAN_TSR790   |
| CRC_DR61     |
| CRC_IDR61    |
| CRYP_CR501   |
| CRYP_DIN504  |
| CRYP_DMACR   |

# D

| DAC_CR              |
|---------------------|
| DAC_DHR12L1         |
| DAC_DHR12L2         |
| DAC_DHR12LD         |
| DAC_DHR12R1264      |
| DAC_DHR12R2265      |
| DAC_DHR12RD         |
| DAC_DHR8R1265       |
| DAC_DHR8R2266       |
| DAC_DHR8RD267       |
| DAC_DOR1            |
| DAC_DOR2 268        |
| DAC_SR              |
| DAC_SWTRIGR264      |
| DBGMCU_APB1 1299    |
| DBGMCU_APB2_FZ 1300 |
| DBGMCU_CR 1297      |
| DBGMCU_IDCODE 1284  |
| DCMI_CR             |
| DCMI_CWSIZE 290     |
| DCMI_CWSTRT290      |
| DCMI_DR             |
| DCMI_ESCR           |
| DCMI_ESUR           |
| DCMI_ICR            |
| DCMI_IER            |
| DCMI_MIS            |
| DCMI_RIS            |
| DCMI_SR             |



| MA_HIFCR18   |
|--------------|
| DMA_HISR     |
| DMA_LIFCR    |
| DMA_LISR     |
| DMA_SxCR     |
| DMA_SxFCR    |
| DMA_SxM0AR18 |
| DMA_SxM1AR18 |
| DMA_SxNDTR18 |
| MA_SxPAR18   |

# Ε

| ETH_DMABMR    | 911 |
|---------------|-----|
| ETH_DMACHRBAR | 925 |
| ETH_DMACHRDR  |     |
| ETH_DMACHTBAR |     |
| ETH_DMACHTDR  |     |
| ETH_DMAIER    | 921 |
| ETH_DMAMFBOCR | 923 |
| ETH_DMAOMR    | 918 |
| ETH_DMARDLAR  | 914 |
| ETH_DMARPDR   |     |
| ETH_DMARSWTR  |     |
| ETH_DMASR     | 915 |
| ETH_DMATDLAR  | 915 |
| ETH_DMATPDR   | 913 |
| ETH_MACA0HR   | 894 |
| ETH_MACA0LR   |     |
| ETH_MACA1HR   | 895 |
| ETH_MACA1LR   | 896 |
| ETH_MACA2HR   | 896 |
| ETH_MACA2LR   | 897 |
| ETH_MACA3HR   | 897 |
| ETH_MACA3LR   | 898 |
| ETH_MACCR     |     |
| ETH_MACDBGR   | 891 |
| ETH_MACFCR    | 887 |
| ETH_MACFFR    | 883 |
| ETH_MACHTHR   |     |
| ETH_MACHTLR   | 885 |
| ETH_MACIMR    | 894 |
| ETH_MACMIIAR  | 885 |
| ETH_MACMIIDR  | 886 |
| ETH_MACPMTCSR |     |
| ETH_MACRWUFFR | 889 |
| ETH_MACSR     | 893 |
| ETH_MACVLANTR | 888 |
| ETH_MMCCR     | 899 |
| ETH_MMCRFAECR | 904 |
| ETH_MMCRFCECR |     |
| ETH_MMCRGUFCR | 904 |
|               |     |

| ETH MMCRIMR90      | 1 |
|--------------------|---|
| —                  |   |
| ETH_MMCRIR         |   |
| ETH_MMCTGFCR903    | 3 |
| ETH_MMCTGFMSCCR903 | 3 |
| ETH_MMCTGFSCCR 902 | 2 |
| ETH_MMCTIMR        | 2 |
| ETH_MMCTIR         | 0 |
| ETH_PTPPPSCR91     |   |
| ETH_PTPSSIR        |   |
| ETH_PTPTSAR        |   |
| ETH_PTPTSCR90      |   |
| ETH_PTPTSHR90      |   |
| ETH PTPTSHUR       |   |
| ETH PTPTSLR        |   |
| ETH PTPTSLUR       |   |
| —                  |   |
| ETH_PTPTSSR        |   |
| ETH_PTPTTHR        |   |
| ETH_PTPTTLR91      |   |
| EXTI_EMR           | 3 |
| EXTI_FTSR          | 4 |
| EXTI IMR           | 3 |
| EXTI PR            | 5 |
| EXTI_RTSR          |   |
| EXTI_SWIER         |   |
|                    |   |

# F

| FSMC_BCR14 . |  | <br> |  |  |  |  |  | <br>1256 |
|--------------|--|------|--|--|--|--|--|----------|
| FSMC_BTR14 . |  | <br> |  |  |  |  |  | <br>1258 |
| FSMC_BWTR14  |  | <br> |  |  |  |  |  | <br>1260 |

# G

| GPIOx_AFRH    |   | <br> | <br> | <br> |  |  |  |  | 153 |
|---------------|---|------|------|------|--|--|--|--|-----|
| GPIOx_AFRL    |   | <br> | <br> | <br> |  |  |  |  | 152 |
| GPIOx_BSRR    |   | <br> | <br> | <br> |  |  |  |  | 150 |
| GPIOx_IDR     |   | <br> | <br> | <br> |  |  |  |  | 150 |
| GPIOx_LCKR    |   | <br> | <br> | <br> |  |  |  |  | 151 |
| GPIOx_MODER   |   | <br> | <br> | <br> |  |  |  |  | 148 |
| GPIOx_ODR     |   | <br> | <br> | <br> |  |  |  |  | 150 |
| GPIOx_OSPEEDF | 2 | <br> | <br> | <br> |  |  |  |  | 149 |
| GPIOx_OTYPER  |   | <br> | <br> |      |  |  |  |  | 148 |
| GPIOx_PUPDR . |   | <br> | <br> | <br> |  |  |  |  | 149 |

# Η

| HASH_CR . |    |  |  | <br> |  |  |  |  |  |  |  | 527 |
|-----------|----|--|--|------|--|--|--|--|--|--|--|-----|
| HASH_CSR  | х. |  |  | <br> |  |  |  |  |  |  |  | 534 |
| HASH_DIN  |    |  |  | <br> |  |  |  |  |  |  |  | 529 |
| HASH_HR0  |    |  |  | <br> |  |  |  |  |  |  |  | 531 |
| HASH_HR1  |    |  |  | <br> |  |  |  |  |  |  |  | 531 |
| HASH_HR2  |    |  |  | <br> |  |  |  |  |  |  |  | 531 |
| HASH_HR3  |    |  |  | <br> |  |  |  |  |  |  |  | 531 |



| HASH_HR4 |      |  | <br> |  |  |  |  |  |  | .532 |
|----------|------|--|------|--|--|--|--|--|--|------|
| HASH_IMR | <br> |  | <br> |  |  |  |  |  |  | .532 |
| HASH_SR  | <br> |  | <br> |  |  |  |  |  |  | .533 |
| HASH_STR |      |  | <br> |  |  |  |  |  |  | .530 |

# I

# 0

| •                 |            |
|-------------------|------------|
| OTG_FS_CID        | 978, 1114  |
| OTG_FS_DAINT      | 996, 1134  |
| OTG_FS_DAINTMSK   | 997, 1134  |
| OTG_FS_DCFG       |            |
| OTG_FS_DCTL       | 992, 1129  |
| OTG_FS_DIEPCTL0   |            |
| OTG_FS_DIEPEMPMSK |            |
| OTG_FS_DIEPINTx   | 1007, 1147 |
| OTG_FS_DIEPMSK    | 994, 1132  |
| OTG_FS_DIEPTSIZ0  | 1009, 1150 |
| OTG_FS_DIEPTSIZx  | 1011, 1152 |
| OTG_FS_DIEPTXFx   | 980, 1114  |
| OTG_FS_DOEPCTL0   | 1003, 1143 |
| OTG_FS_DOEPCTLx   | 1004, 1144 |
| OTG_FS_DOEPINTx   | 1008, 1149 |
| OTG_FS_DOEPMSK    |            |
| OTG_FS_DOEPTSIZ0  | 1010, 1151 |
| OTG_FS_DOEPTSIZX  |            |
| OTG_FS_DSTS       |            |
| OTG_FS_DTXFSTSx   | 1012, 1153 |
| OTG_FS_DVBUSDIS   |            |
| OTG_FS_DVBUSPULSE |            |
| OTG_FS_GAHBCFG    | 962, 1094  |
| OTG_FS_GCCFG      |            |
| OTG_FS_GINTMSK    | 971, 1105  |
| OTG_FS_GNPTXFSIZ  | 076 1110   |
| OTG_FS_GNPTXSTS   | 976 1110   |
| OTG_FS_GOTGCTL    | 958 1091   |
| OTG FS GOTGINT    |            |
|                   |            |

| OTG_FS_GRSTCTL     | 965, 1098  |
|--------------------|------------|
| OTG_FS_GRXFSIZ     | 975, 1109  |
| OTG_FS_GRXSTSP     |            |
| OTG_FS_GRXSTSR     |            |
| OTG_FS_GUSBCFG     |            |
| OTG_FS_HAINT       | 983, 1118  |
| OTG_FS_HAINTMSK    |            |
| OTG_FS_HCCHARx     | 987, 1121  |
| OTG_FS_HCFG        |            |
| OTG_FS_HCINTMSKx   | 989, 1125  |
| OTG_FS_HCINTx      |            |
| OTG_FS_HCTSIZx     |            |
| OTG_FS_HFIR        |            |
| OTG_FS_HFNUM       |            |
| OTG_FS_HPRT        |            |
| OTG_FS_HPTXFSIZ    |            |
| OTG_FS_HPTXSTS     | 982, 1117  |
| OTG_FS_PCGCCTL     | 1013, 1154 |
| OTG_HS_DCFG        |            |
| OTG_HS_DEACHINTMSK | 1138       |
| OTG_HS_DIEPDMAx    | 1154       |
| OTG_HS_DOEPDMAx    | 1154       |
| OTG_HS_DTHRCTL     | 1136       |
| OTG_HS_HCSPLTx     |            |
|                    |            |

# Ρ

| PWR_CR  |  |  |  |  |  |  |  |  |  |  |  |  |  | 78 |
|---------|--|--|--|--|--|--|--|--|--|--|--|--|--|----|
| PWR_CSR |  |  |  |  |  |  |  |  |  |  |  |  |  | 79 |

# R

| RCC_AHB1ENR 110    |
|--------------------|
| RCC_AHB1LPENR      |
| RCC_AHB1RSTR 102   |
| RCC_AHB2ENR 112    |
| RCC_AHB2LPENR 121  |
| RCC_AHB2RSTR 104   |
| RCC_AHB3ENR 113    |
| RCC_AHB3LPENR 122  |
| RCC_AHB3RSTR 105   |
| RCC_APB1ENR113     |
| RCC_APB1LPENR123   |
| RCC_APB1RSTR 105   |
| RCC_APB2ENR117     |
| RCC_APB2LPENR126   |
| RCC_APB2RSTR 108   |
| RCC_BDCR 128       |
| RCC_CFGR97         |
| RCC_CIR99          |
| RCC_CR93           |
| RCC_CSR 129        |
| RCC_PLLCFGR95, 132 |



| RCC_SSCGR131    |
|-----------------|
| RNG_CR515       |
| RNG_DR516       |
| RNG_SR515       |
| RTC_ALRMAR561   |
| RTC_ALRMBR      |
| RTC_ALRMBSSR572 |
| RTC_BKxR        |
| RTC_CALIBR      |
| RTC_CALR568     |
| RTC_CR          |
| RTC_DR          |
| RTC_ISR557      |
| RTC_PRER559     |
| RTC_SHIFTR565   |
| RTC_SSR563      |
| RTC_TR553       |
| RTC_TSDR567     |
| RTC_TSSSR567    |
| RTC_TSTR566     |
| RTC_WPR566      |
| RTC_WUTR        |

# S

| 0                 |
|-------------------|
| SDIO_CLKCR        |
| SDIO_DCOUNT757    |
| SDIO_DCTRL756     |
| SDIO_DLEN755      |
| SDIO_DTIMER755    |
| SDIO_FIFO764      |
| SDIO_FIFOCNT      |
| SDIO_ICR759       |
| SDIO_MASK761      |
| SDIO_POWER751     |
| SDIO_RESPCMD      |
| SDIO_RESPx        |
| SDIO_STA          |
| SPI_CR1           |
| SPI_CR2           |
| SPI_CRCPR         |
| SPI_DR            |
| SPI_I2SCFGR       |
| SPI_I2SPR         |
| SPI_RXCRCR        |
| SPI_SR            |
| SPI_TXCRCR        |
| SYSCFG_EXTICR1156 |
| SYSCFG_EXTICR2157 |
| SYSCFG_EXTICR3157 |
| SYSCFG_EXTICR4    |
| SYSCFG_MEMRMP155  |
|                   |

# т

| TIM2_OR    |                         |
|------------|-------------------------|
| TIM5_OR    |                         |
| TIMx_ARR   | 406, 444, 453, 465      |
| TIMx_BDTR  |                         |
| TIMx_CCER  |                         |
| TIMx_CCMR1 |                         |
| TIMx_CCMR2 |                         |
| TIMx_CCR1  | 353, 407, 445, 454      |
| TIMx_CCR2  |                         |
| TIMx_CCR3  |                         |
| TIMx_CCR4  |                         |
| TIMx_CNT   |                         |
| TIMx_CR1   | 333, 392, 434, 447, 462 |
| TIMx_CR2   |                         |
| TIMx_DCR   |                         |
| TIMx_DIER  |                         |
| TIMx_DMAR  |                         |
| TIMx_EGR   |                         |
| TIMx_PSC   |                         |
| TIMx_RCR   |                         |
| TIMx_SMCR  |                         |
| TIMx_SR    | 341, 397, 438, 448, 464 |

# U

| USART_BRR . | <br> | <br> | <br> |  |  |  |  |  | . 649 |
|-------------|------|------|------|--|--|--|--|--|-------|
| USART_CR1 . | <br> | <br> | <br> |  |  |  |  |  | . 649 |
| USART_CR2 . | <br> | <br> | <br> |  |  |  |  |  | . 652 |
| USART_CR3 . | <br> | <br> |      |  |  |  |  |  | . 653 |
| USART_DR    | <br> | <br> |      |  |  |  |  |  | . 648 |
| USART_GTPR  |      | <br> | <br> |  |  |  |  |  | . 656 |
| USART_SR    | <br> | <br> | <br> |  |  |  |  |  | . 646 |

# W

| WWDG_CFR | 477 |
|----------|-----|
| WWDG_CR  | 476 |
| WWDG_SR  | 477 |



#### Please Read Carefully:

Information in this document is provided solely in connection with ST products. STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, modifications or improvements, to this document, and the products and services described herein at any time, without notice.

All ST products are sold pursuant to ST's terms and conditions of sale.

Purchasers are solely responsible for the choice, selection and use of the ST products and services described herein, and ST assumes no liability whatsoever relating to the choice, selection or use of the ST products and services described herein.

No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted under this document. If any part of this document refers to any third party products or services it shall not be deemed a license grant by ST for the use of such third party products or services, or any intellectual property contained therein or considered as a warranty covering the use in any manner whatsoever of such third party products or services or any intellectual property contained therein.

UNLESS OTHERWISE SET FORTH IN ST'S TERMS AND CONDITIONS OF SALE ST DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY WITH RESPECT TO THE USE AND/OR SALE OF ST PRODUCTS INCLUDING WITHOUT LIMITATION IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE (AND THEIR EQUIVALENTS UNDER THE LAWS OF ANY JURISDICTION), OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT.

UNLESS EXPRESSLY APPROVED IN WRITING BY TWO AUTHORIZED ST REPRESENTATIVES, ST PRODUCTS ARE NOT RECOMMENDED, AUTHORIZED OR WARRANTED FOR USE IN MILITARY, AIR CRAFT, SPACE, LIFE SAVING, OR LIFE SUSTAINING APPLICATIONS, NOR IN PRODUCTS OR SYSTEMS WHERE FAILURE OR MALFUNCTION MAY RESULT IN PERSONAL INJURY, DEATH, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE. ST PRODUCTS WHICH ARE NOT SPECIFIED AS "AUTOMOTIVE GRADE" MAY ONLY BE USED IN AUTOMOTIVE APPLICATIONS AT USER'S OWN RISK.

Resale of ST products with provisions different from the statements and/or technical features set forth in this document shall immediately void any warranty granted by ST for the ST product or service described herein and shall not create or extend in any manner whatsoever, any liability of ST.

ST and the ST logo are trademarks or registered trademarks of ST in various countries.

Information in this document supersedes and replaces all information previously supplied.

The ST logo is a registered trademark of STMicroelectronics. All other names are the property of their respective owners.

© 2011 STMicroelectronics - All rights reserved

STMicroelectronics group of companies

Australia - Belgium - Brazil - Canada - China - Czech Republic - Finland - France - Germany - Hong Kong - India - Israel - Italy - Japan -Malaysia - Malta - Morocco - Philippines - Singapore - Spain - Sweden - Switzerland - United Kingdom - United States of America

www.st.com

Doc ID 018909 Rev 1

