

FIFO out of reset, enable Receive FIFO, receivers, and set watermark). Making sure to clear the receiver enable bits (RE0-RE3). RPR must remain set.

5. Take the receiver section out of the individual reset state by clearing RPR.
6. Enable the receivers by setting their RE bits.
7. From now on the receivers are operating and can be serviced either by polling, interrupts, or DMA.

## 25.6 ESAI Memory Map/Register Definition

**ESAI memory map**

| Absolute address (hex) | Register name                                    | Width (in bits) | Access                | Reset value | Section/ page    |
|------------------------|--------------------------------------------------|-----------------|-----------------------|-------------|------------------|
| 202_4000               | ESAI Transmit Data Register (ESAI_ETDR)          | 32              | W<br>(always reads 0) | 0000_0000h  | 25.6.1/1243      |
| 202_4004               | ESAI Receive Data Register (ESAI_ERDR)           | 32              | R                     | 0000_0000h  | 25.6.2/1244      |
| 202_4008               | ESAI Control Register (ESAI_ECR)                 | 32              | R/W                   | 0000_0000h  | 25.6.3/1244      |
| 202_400C               | ESAI Status Register (ESAI_ESR)                  | 32              | R                     | 0000_0000h  | 25.6.4/1245      |
| 202_4010               | Transmit FIFO Configuration Register (ESAI_TFCR) | 32              | R/W                   | 0000_0000h  | 25.6.5/1247      |
| 202_4014               | Transmit FIFO Status Register (ESAI_TFSR)        | 32              | R                     | 0000_0000h  | 25.6.6/1249      |
| 202_4018               | Receive FIFO Configuration Register (ESAI_RFCR)  | 32              | R/W                   | 0000_0000h  | 25.6.7/1250      |
| 202_401C               | Receive FIFO Status Register (ESAI_RFSR)         | 32              | R                     | 0000_0000h  | 25.6.8/1251      |
| 202_4080               | Transmit Data Register n (ESAI_TX0)              | 32              | W<br>(always reads 0) | 0000_0000h  | 25.6.9/1252      |
| 202_4084               | Transmit Data Register n (ESAI_TX1)              | 32              | W<br>(always reads 0) | 0000_0000h  | 25.6.9/1252      |
| 202_4088               | Transmit Data Register n (ESAI_TX2)              | 32              | W<br>(always reads 0) | 0000_0000h  | 25.6.9/1252      |
| 202_408C               | Transmit Data Register n (ESAI_TX3)              | 32              | W<br>(always reads 0) | 0000_0000h  | 25.6.9/1252      |
| 202_4090               | Transmit Data Register n (ESAI_TX4)              | 32              | W<br>(always reads 0) | 0000_0000h  | 25.6.9/1252      |
| 202_4094               | Transmit Data Register n (ESAI_TX5)              | 32              | W<br>(always reads 0) | 0000_0000h  | 25.6.9/1252      |
| 202_4098               | ESAI Transmit Slot Register (ESAI TSRMLS)        | 32              | W<br>(always reads 0) | 0000_0000h  | 25.6.10/<br>1253 |

*Table continues on the next page...*

## ESAI memory map (continued)

| Absolute address (hex) | Register name                                        | Width (in bits) | Access | Reset value | Section/page     |
|------------------------|------------------------------------------------------|-----------------|--------|-------------|------------------|
| 202_40A0               | Receive Data Register n (ESAI_RX0)                   | 32              | R      | 0000_0000h  | 25.6.11/<br>1253 |
| 202_40A4               | Receive Data Register n (ESAI_RX1)                   | 32              | R      | 0000_0000h  | 25.6.11/<br>1253 |
| 202_40A8               | Receive Data Register n (ESAI_RX2)                   | 32              | R      | 0000_0000h  | 25.6.11/<br>1253 |
| 202_40AC               | Receive Data Register n (ESAI_RX3)                   | 32              | R      | 0000_0000h  | 25.6.11/<br>1253 |
| 202_40CC               | Serial Audio Interface Status Register (ESAI_SAISR)  | 32              | R      | 0000_0000h  | 25.6.12/<br>1254 |
| 202_40D0               | Serial Audio Interface Control Register (ESAI_SAICR) | 32              | R/W    | 0000_0000h  | 25.6.13/<br>1256 |
| 202_40D4               | Transmit Control Register (ESAI_TCR)                 | 32              | R/W    | 0000_0000h  | 25.6.14/<br>1259 |
| 202_40D8               | Transmit Clock Control Register (ESAI_TCCR)          | 32              | R/W    | 0000_0000h  | 25.6.15/<br>1266 |
| 202_40DC               | Receive Control Register (ESAI_RCR)                  | 32              | R/W    | 0000_0000h  | 25.6.16/<br>1270 |
| 202_40E0               | Receive Clock Control Register (ESAI_RCCR)           | 32              | R/W    | 0000_0000h  | 25.6.17/<br>1274 |
| 202_40E4               | Transmit Slot Mask Register A (ESAI_TSMA)            | 32              | R/W    | 0000_FFFFh  | 25.6.18/<br>1277 |
| 202_40E8               | Transmit Slot Mask Register B (ESAI_TSMB)            | 32              | R/W    | 0000_FFFFh  | 25.6.19/<br>1278 |
| 202_40EC               | Receive Slot Mask Register A (ESAI_RSMA)             | 32              | R/W    | 0000_FFFFh  | 25.6.20/<br>1279 |
| 202_40F0               | Receive Slot Mask Register B (ESAI_RSMB)             | 32              | R/W    | 0000_FFFFh  | 25.6.21/<br>1280 |
| 202_40F8               | Port C Direction Register (ESAI_PRRC)                | 32              | R/W    | 0000_0000h  | 25.6.22/<br>1281 |
| 202_40FC               | Port C Control Register (ESAI_PCRC)                  | 32              | R/W    | 0000_0000h  | 25.6.23/<br>1281 |

## 25.6.1 ESAI Transmit Data Register (ESAI\_ETDR)

Address: 202\_4000h base + 0h offset = 202\_4000h

| 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 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |

**ESAI\_ETDR field descriptions**

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ETDR  | ESAI Transmit Data Register. Writing to this register stores the data written into the ESAI Transmit FIFO. Writing to this register when the Transmit FIFO is full causes the data written to be lost (the existing data within the FIFO is not overwritten). When multiple ESAI transmitters are enabled, the data for each transmitter must be interleaved from lowest transmitter to highest transmitter (for example, if transmitters 0, 2 and 3 are enabled then data must be written as follows: transmitter #0, transmitter #2, transmitter #3, transmitter #0, transmitter #2, transmitter #3, transmitter #0, etc). Data within the ESAI Transmit FIFO is passed to the ESAI transmit shifter registers as defined by the Transmit Word Alignment configuration bits. |

**25.6.2 ESAI Receive Data Register (ESAI\_ERDR)**

Address: 202\_4000h base + 4h offset = 202\_4004h

| 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 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |

**ESAI\_ERDR field descriptions**

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ERDR  | ESAI Receive Data Register. Reading this register returns the data within the ESAI Receive FIFO. Reading this register when the Receive FIFO is empty returns the last valid data word. When multiple ESAI receivers are enabled, the data for each receiver is interleaved from lowest receiver to highest receiver (for example, if receivers 0, 2 and 3 are enabled then data is returned as follows: receiver #0, receiver #2, receiver #3, receiver #0, receiver #2, receiver #3, receiver #0, etc). Data is passed from the ESAI receive shift registers to the ESAI Receive FIFO as defined by the Receiver Word Alignment configuration bits either zero or sign-extended based on the Receive Extension control bit. |

**25.6.3 ESAI Control Register (ESAI\_ECR)**

Address: 202\_4000h base + 8h offset = 202\_4008h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

  

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

  

|       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

**ESAI\_ESR field descriptions**

| Field             | Description                                                                                                                                                                                                                       |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–20<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                           |
| 19<br>ETI         | EXTAL Transmitter In. Mux EXTAL in place of the High Frequency Transmitter Clock input pin. HCKT can still be used to drive a divided down EXTAL or as GPIO.<br>0 HCKT pin has normal function.<br>1 EXTAL muxed into HCKT input. |
| 18<br>ETO         | EXTAL Transmitter Out. Drive the EXTAL input on the High Frequency Transmitter Clock pin.<br>0 HCKT pin has normal function.<br>1 EXTAL driven onto HCKT pin.                                                                     |
| 17<br>ERI         | EXTAL Receiver In. Mux EXTAL in place of the High Frequency Receiver Clock input pin. HCKR can still be used to drive a divided down EXTAL or as GPIO.<br>0 HCKR pin has normal function.<br>1 EXTAL muxed into HCKR input.       |
| 16<br>ERO         | EXTAL Receiver Out. Drive the EXTAL input on the High Frequency Receiver Clock pin.<br>0 HCKR pin has normal function.<br>1 EXTAL driven onto HCKR pin.                                                                           |
| 15–2<br>Reserved  | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                           |
| 1<br>ERST         | ESAI Reset. Reset the ESAI core logic (including configuration registers) but not the ESAI FIFOs.<br>0 ESAI not reset.<br>1 ESAI reset.                                                                                           |
| 0<br>ESAIVEN      | ESAI Enable. Enables/disables the ESAI logic clock. Enable the ESAI before reading or writing other ESAI registers.<br>0 ESAI disabled.<br>1 ESAI enabled.                                                                        |

**25.6.4 ESAI Status Register (ESAI\_ESR)**

Address: 202\_4000h base + Ch offset = 202\_400Ch

| Bit   | 31 | 30 | 29 | 28 | 27    | 26  | 25  | 24  | 23  | 22  | 21 | 20  | 19  | 18  | 17 | 16 |
|-------|----|----|----|----|-------|-----|-----|-----|-----|-----|----|-----|-----|-----|----|----|
| R     |    |    |    |    |       |     |     |     | 0   |     |    |     |     |     |    |    |
| W     |    |    |    |    |       |     |     |     |     |     |    |     |     |     |    |    |
| Reset | 0  | 0  | 0  | 0  | 0     | 0   | 0   | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11    | 10  | 9   | 8   | 7   | 6   | 5  | 4   | 3   | 2   | 1  | 0  |
| R     |    |    | 0  |    | TINIT | RFF | TFE | TLS | TDE | TED | TD | RLS | RDE | RED | RD |    |
| W     |    |    |    |    |       |     |     |     |     |     |    |     |     |     |    |    |
| Reset | 0  | 0  | 0  | 0  | 0     | 0   | 0   | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0  |

**ESAI\_ESR field descriptions**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–11<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10<br>TINIT       | Transmit Initialization. Indicates that the Transmit FIFO is writing the first word for each enabled transmitter into the Transmit Data Registers. This bit sets when the Transmit FIFO is enabled (provided Transmit Initialization is enabled) and clears after the Transmit Data Registers have been initialized. The Transmit Enable bits in the Transmit Control Register should not be set until this flag has cleared.<br><br>0 Transmitter has finished initializing the Transmit Data Registers (or Transmit FIFO is not enabled or Transmit Initialization is not enabled).<br>1 Transmitter has not finished initializing the Transmit Data Registers. |
| 9<br>RFF          | Receive FIFO Full. Indicates that the number of data words in the Receive FIFO has equaled or exceeded the Receive FIFO Watermark. This flag also drives the ESAI Receiver DMA request line. ESAI FIFO DMA requests see <a href="#">ESAI DMA Requests from the FIFOs</a> .<br><br>0 Number of words in Receive FIFO less than Receive FIFO watermark.<br>1 Number of words in Receive FIFO is equal to or greater than Receive FIFO watermark.                                                                                                                                                                                                                    |
| 8<br>TFE          | Transmit FIFO Empty. Indicates that the number of empty slots in the Transmit FIFO has met or exceeded the Transmit FIFO Watermark. This flag also drives the ESAI Transmitter DMA request line. ESAI FIFO DMA request see <a href="#">ESAI DMA Requests from the FIFOs</a> .<br><br>0 Number of empty slots in Transmit FIFO less than Transmit FIFO watermark.<br>1 Number of empty slots in Transmit FIFO is equal to or greater than Transmit FIFO watermark.                                                                                                                                                                                                 |
| 7<br>TLS          | Transmit Last Slot. Reading this register when TLS is set will negate the Transmit Last Slot interrupt.<br><br>0 TLS is not the highest priority active interrupt.<br>1 TLS is the highest priority active interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6<br>TDE          | Transmit Data Exception.<br><br>0 TDE is not the highest priority active interrupt.<br>1 TDE is the highest priority active interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5<br>TED          | Transmit Even Data.<br><br>0 TED is not the highest priority active interrupt.<br>1 TED is the highest priority active interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4<br>TD           | Transmit Data.<br><br>0 TD is not the highest priority active interrupt.<br>1 TD is the highest priority active interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3<br>RLS          | Receive Last Slot. Reading this register when RLS is set will negate the Receive Last Slot interrupt.<br><br>0 RLS is not the highest priority active interrupt.<br>1 RLS is the highest priority active interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2<br>RDE          | Receive Data Exception.<br><br>0 RDE is not the highest priority active interrupt.<br>1 RDE is the highest priority active interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1<br>RED          | Receive Even Data.<br><br>0 RED is not the highest priority active interrupt.<br>1 RED is the highest priority active interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

*Table continues on the next page...*

**ESAI\_ESR field descriptions (continued)**

| Field   | Description                                                                                                           |
|---------|-----------------------------------------------------------------------------------------------------------------------|
| 0<br>RD | Receive Data.<br>0 RD is not the highest priority active interrupt.<br>1 RD is the highest priority active interrupt. |

**25.6.5 Transmit FIFO Configuration Register (ESAI\_TFCR)**

Address: 202\_4000h base + 10h offset = 202\_4010h

|       |    |    |    |    |    |    |    |    |           |    |     |     |     |          |     |     |     |
|-------|----|----|----|----|----|----|----|----|-----------|----|-----|-----|-----|----------|-----|-----|-----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23        | 22 | 21  | 20  | 19  | 18       | 17  | 16  |     |
| R     |    |    |    |    |    |    |    | 0  |           |    |     |     |     | TIEN     |     |     |     |
| W     |    |    |    |    |    |    |    |    |           |    |     |     |     | TWA[2:0] |     |     |     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0   | 0   | 0   | 0        | 0   | 0   |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7         | 6  | 5   | 4   | 3   | 2        | 1   | 0   |     |
| R     |    |    |    |    |    |    |    |    | TFWM[7:0] |    | TE5 | TE4 | TE3 | TE2      | TE1 | TE0 | TFR |
| W     |    |    |    |    |    |    |    |    |           |    |     |     |     |          |     | TFE |     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0   | 0   | 0   | 0        | 0   | 0   |     |

**ESAI\_TFCR field descriptions**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–20<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 19<br>TIEN        | Transmitter Initialization Enable. Enables the initialization of the Transmit Data Registers when the Transmitter FIFO is enabled. TIEN=1 is recommended.<br><br>0 Transmit Data Registers are not initialized from the FIFO once the Transmit FIFO is enabled. Software must manually initialize the Transmit Data Registers separately.<br>1 Transmit Data Registers are initialized from the FIFO once the Transmit FIFO is enabled.                                                                                                                                                                                                                                                                                                                                                                                                      |
| 18–16<br>TWA[2:0] | Transmit Word Alignment. Configures the alignment of the data written into the ESAI Transmit Data Register and then passed to the relevant 24 bit Transmit shift register.<br><br>000 MSB of data is bit 31. Data bits 7-0 are ignored when passed to transmit shift register.<br>001 MSB of data is bit 27. Data bits 3-0 are ignored when passed to transmit shift register.<br>010 MSB of data is bit 23.<br>011 MSB of data is bit 19. Bottom 4 bits of transmit shift register are zeroed.<br>100 MSB of data is bit 15. Bottom 8 bits of transmit shift register are zeroed.<br>101 MSB of data is bit 11. Bottom 12 bits of transmit shift register are zeroed.<br>110 MSB of data is bit 7. Bottom 16 bits of transmit shift register are zeroed.<br>111 MSB of data is bit 3. Bottom 20 bits of transmit shift register are zeroed. |
| 15–8<br>TFWM[7:0] | Transmit FIFO Watermark. These bits configure the threshold at which the Transmit FIFO Empty flag will set. The TFE is set when the number of empty slots in the Transmit FIFO equal or exceed the selected threshold.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7<br>TE5          | Transmitter #5 FIFO Enable. This bit enables transmitter #5 to use the Transmit FIFO. Do not change this bit when the Transmitter FIFO is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

Table continues on the next page...

**ESAI\_TFCR field descriptions (continued)**

| Field    | Description                                                                                                                                                                                                                                                |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 0 Transmitter #5 is not using the Transmit FIFO.<br>1 Transmitter #5 is using the Transmit FIFO.                                                                                                                                                           |
| 6<br>TE4 | Transmitter #4 FIFO Enable. This bit enables transmitter #4 to use the Transmit FIFO. Do not change this bit when the Transmitter FIFO is enabled.<br><br>0 Transmitter #4 is not using the Transmit FIFO.<br>1 Transmitter #4 is using the Transmit FIFO. |
| 5<br>TE3 | Transmitter #3 FIFO Enable. This bit enables transmitter #3 to use the Transmit FIFO. Do not change this bit when the Transmitter FIFO is enabled.<br><br>0 Transmitter #3 is not using the Transmit FIFO.<br>1 Transmitter #3 is using the Transmit FIFO. |
| 4<br>TE2 | Transmitter #2 FIFO Enable. This bit enables transmitter #2 to use the Transmit FIFO. Do not change this bit when the Transmitter FIFO is enabled.<br><br>0 Transmitter #2 is not using the Transmit FIFO.<br>1 Transmitter #2 is using the Transmit FIFO. |
| 3<br>TE1 | Transmitter #1 FIFO Enable. This bit enables transmitter #1 to use the Transmit FIFO. Do not change this bit when the Transmitter FIFO is enabled.<br><br>0 Transmitter #1 is not using the Transmit FIFO.<br>1 Transmitter #1 is using the Transmit FIFO. |
| 2<br>TE0 | Transmitter #0 FIFO Enable. This bit enables transmitter #0 to use the Transmit FIFO. Do not change this bit when the Transmitter FIFO is enabled.<br><br>0 Transmitter #0 is not using the Transmit FIFO.<br>1 Transmitter #0 is using the Transmit FIFO. |
| 1<br>TFR | Transmit FIFO Reset. This bit resets the Transmit FIFO pointers.<br><br>0 Transmit FIFO not reset.<br>1 Transmit FIFO reset.                                                                                                                               |
| 0<br>TFE | Transmit FIFO Enable. This bit enables the use of the Transmit FIFO.<br><br>0 Transmit FIFO disabled.<br>1 Transmit FIFO enabled.                                                                                                                          |

## 25.6.6 Transmit FIFO Status Register (ESAI\_TFSR)

Address: 202\_4000h base + 14h offset = 202\_4014h

| Bit   | 31 | 30        | 29 | 28 | 27        | 26 | 25         | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----------|----|----|-----------|----|------------|----|----|----|----|----|----|----|----|----|
| R     | 0  |           |    |    |           |    |            |    |    |    |    |    |    |    |    |    |
| W     |    |           |    |    |           |    |            |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0         | 0  | 0  | 0         | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14        | 13 | 12 | 11        | 10 | 9          | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | 0  | NTFO[2:0] |    | 0  | NTFI[2:0] |    | TFCNT[7:0] |    |    |    |    |    |    |    |    |    |
| W     |    |           |    |    |           |    |            |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0         | 0  | 0  | 0         | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**ESAI\_TFSR field descriptions**

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–15<br>Reserved  | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14–12<br>NTFO[2:0] | Next Transmitter FIFO Out. Indicates which Transmit Data Register receives the top word of the Transmit FIFO. This will usually equal the lowest enabled transmitter, unless the transmit FIFO is empty.<br><br>000 Transmitter #0 receives next word from the Transmit FIFO.<br>001 Transmitter #1 receives next word from the Transmit FIFO.<br>010 Transmitter #2 receives next word from the Transmit FIFO.<br>011 Transmitter #3 receives next word from the Transmit FIFO.<br>100 Transmitter #4 receives next word from the Transmit FIFO.<br>101 Transmitter #5 receives next word from the Transmit FIFO.<br>110 Reserved.<br>111 Reserved. |
| 11<br>Reserved     | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 10–8<br>NTFI[2:0]  | Next Transmitter FIFO In. Indicates which transmitter receives the next word written to the FIFO.<br><br>000 Transmitter #0 receives next word written to the Transmit FIFO.<br>001 Transmitter #1 receives next word written to the Transmit FIFO.<br>010 Transmitter #2 receives next word written to the Transmit FIFO.<br>011 Transmitter #3 receives next word written to the Transmit FIFO.<br>100 Transmitter #4 receives next word written to the Transmit FIFO.<br>101 Transmitter #5 receives next word written to the Transmit FIFO.<br>110 Reserved.<br>111 Reserved.                                                                    |
| TFCNT[7:0]         | Transmit FIFO Counter. These bits indicate the number of data words stored in the Transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## 25.6.7 Receive FIFO Configuration Register (ESAI\_RFCR)

Address: 202\_4000h base + 18h offset = 202\_4018h

|       |    |    |    |    |    |    |    |    |           |    |    |    |      |          |     |     |     |
|-------|----|----|----|----|----|----|----|----|-----------|----|----|----|------|----------|-----|-----|-----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23        | 22 | 21 | 20 | 19   | 18       | 17  | 16  |     |
| R     |    |    |    |    |    |    | 0  |    |           |    |    |    | REXT |          |     |     |     |
| W     |    |    |    |    |    |    |    |    |           |    |    |    |      | RWA[2:0] |     |     |     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0  | 0    | 0        | 0   | 0   |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7         | 6  | 5  | 4  | 3    | 2        | 1   | 0   |     |
| R     |    |    |    |    |    |    |    |    | RFWM[7:0] |    | 0  |    | RE3  | RE2      | RE1 | RE0 | RFR |
| W     |    |    |    |    |    |    |    |    |           |    |    |    |      |          |     | RFE |     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0  | 0    | 0        | 0   | 0   |     |

### ESAI\_RFCR field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–20<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 19<br>REXT        | Receive Extension. Enables the receive data to be returned sign extended when the Receive Word Alignment is configured to return data where the MSB is not aligned with bit 31.<br><br>0 Receive data is zero extended.<br>1 Receive data is sign extended.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 18–16<br>RWA[2:0] | Receive Word Alignment. Configures the alignment of the data passed from the relevant 24 bit Receive shift register and read out the ESAI Receive Data Register.<br><br>000 MSB of data is at bit 31. Data bits 7-0 are zeroed.<br>001 MSB of data is at bit 27. Data bits 3-0 are zeroed.<br>010 MSB of data is at bit 23.<br>011 MSB of data is at bit 19. Data bits 3-0 from receive shift register are ignored.<br>100 MSB of data is at bit 15. Data bits 7-0 from receive shift register are ignored.<br>101 MSB of data is at bit 11. Data bits 11-0 from receive shift register are ignored.<br>110 MSB of data is at bit 7. Data bits 15-0 from receive shift register are ignored.<br>111 MSB of data is at bit 3. Data bits 19-0 from receive shift register are ignored. |
| 15–8<br>RFWM[7:0] | Receive FIFO Watermark. These bits configure the threshold at which the Receive FIFO Full flag will set. The RFF is set when the number of words in the Receive FIFO equal or exceed the selected threshold. It can be set to a non-zero value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7–6<br>Reserved   | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5<br>RE3          | Receiver #3 FIFO Enable. This bit enables receiver #3 to use the Receive FIFO. Do not change this bit when the Receiver FIFO is enabled.<br><br>0 Receiver #3 is not using the Receive FIFO.<br>1 Receiver #3 is using the Receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4<br>RE2          | Receiver #2 FIFO Enable. This bit enables receiver #2 to use the Receive FIFO. Do not change this bit when the Receiver FIFO is enabled.<br><br>0 Receiver #2 is not using the Receive FIFO.<br>1 Receiver #2 is using the Receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Table continues on the next page...

**ESAI\_RFCR field descriptions (continued)**

| Field    | Description                                                                                                                                                                                                                              |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>RE1 | Receiver #1 FIFO Enable. This bit enables receiver #1 to use the Receive FIFO. Do not change this bit when the Receiver FIFO is enabled.<br><br>0 Receiver #1 is not using the Receive FIFO.<br>1 Receiver #1 is using the Receive FIFO. |
| 2<br>RE0 | Receiver #0 FIFO Enable. This bit enables receiver #0 to use the Receive FIFO. Do not change this bit when the Receiver FIFO is enabled.<br><br>0 Receiver #0 is not using the Receive FIFO.<br>1 Receiver #0 is using the Receive FIFO. |
| 1<br>RFR | Receive FIFO Reset. This bit resets the Receive FIFO pointers.<br><br>0 Receive FIFO not reset.<br>1 Receive FIFO reset.                                                                                                                 |
| 0<br>RFE | Receive FIFO Enable. This bit enables the use of the Receive FIFO.<br><br>0 Receive FIFO disabled.<br>1 Receive FIFO enabled.                                                                                                            |

**25.6.8 Receive FIFO Status Register (ESAI\_RFSR)**

Address: 202\_4000h base + 1Ch offset = 202\_401Ch

|       |    |    |           |    |    |    |           |    |   |    |    |    |    |    |    |    |    |
|-------|----|----|-----------|----|----|----|-----------|----|---|----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29        | 28 | 27 | 26 | 25        | 24 |   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| R     |    |    |           |    |    |    |           |    | 0 |    |    |    |    |    |    |    |    |
| W     |    |    |           |    |    |    |           |    |   |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0         | 0  | 0  | 0  | 0         | 0  |   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13        | 12 | 11 | 10 | 9         | 8  |   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | 0  |    | NRFI[1:0] |    | 0  |    | NRFO[1:0] |    |   |    |    |    |    |    |    |    |    |
| W     |    |    |           |    |    |    |           |    |   |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0         | 0  | 0  | 0  | 0         | 0  |   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**ESAI\_RFSR field descriptions**

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–14<br>Reserved  | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                      |
| 13–12<br>NRFI[1:0] | Next Receiver FIFO In. Indicates which Receiver Data Register the Receive FIFO will load next. This will usually equal the lowest enabled receiver, unless the receive FIFO is full.<br><br>00 Receiver #0 returns next word to the Receive FIFO.<br>01 Receiver #1 returns next word to the Receive FIFO.<br>10 Receiver #2 returns next word to the Receive FIFO.<br>11 Receiver #3 returns next word to the Receive FIFO. |

Table continues on the next page...

**ESAI\_RFSR field descriptions (continued)**

| Field             | Description                                                                                                                                                                                                                                                                                                                            |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11–10<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                |
| 9–8<br>NRFO[1:0]  | Next Receiver FIFO Out. Indicates which receiver returns the top word of the Receive FIFO.<br>00 Receiver #0 returns next word from the Receive FIFO.<br>01 Receiver #1 returns next word from the Receive FIFO.<br>10 Receiver #2 returns next word from the Receive FIFO.<br>11 Receiver #3 returns next word from the Receive FIFO. |
| RFCNT[7:0]        | Receive FIFO Counter. These bits indicate the number of data words stored in the Receive FIFO.                                                                                                                                                                                                                                         |

**25.6.9 Transmit Data Register n (ESAI\_TXn)**

ESAI\_TX5, ESAI\_TX4, ESAI\_TX3, ESAI\_TX2, ESAI\_TX1 and ESAI\_TX0 are 32-bit write-only registers. Data to be transmitted is written into these registers and is automatically transferred to the transmit shift registers ([Figure 25-2](#) and [Figure 25-3](#)). The data written (8, 12, 16, 20, or 24 bits) should occupy the most significant portion of the TXn according to the ALC control bit setting. The unused bits (least significant portion and the 8 most significant bits when ALC=1) of the TXn are don't care bits. The Core is interrupted whenever the TXn becomes empty if the transmit data register empty interrupt has been enabled.

Address: 202\_4000h base + 80h offset + (4d × i), where i=0d to 5d

| 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 |
|-------|----|----|----|----|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     | 0  |    |    |    | 0         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    | TXn[23:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |

**ESAI\_TXn field descriptions**

| Field             | Description                                                                                                                                                |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                    |
| TXn[23:0]         | Stores the data to be transmitted and is automatically transferred to the transmit shift registers.<br>See <a href="#">ESAI Transmit Shift Registers</a> . |

## 25.6.10 ESAI Transmit Slot Register (ESAI\_TSR)

Address: 202\_4000h base + 98h offset = 202\_4098h

| 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 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |

### ESAI\_TSR field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| TSR[23:0]         | The write-only Transmit Slot Register (ESAI_TSR) is effectively a null data register that is used when the data is not to be transmitted in the available transmit time slot. The transmit data pins of all the enabled transmitters are in the high-impedance state for the respective time slot where TSR has been written. The Transmitter External Buffer Enable pin (FSR pin when SYN=1, TEBE=1, RFSD=1) disables the external buffers during the slot when the ESAI_TSR register has been written. |

## 25.6.11 Receive Data Register n (ESAI\_RXn)

ESAI\_RX3, ESAI\_RX2, ESAI\_RX1, and ESAI\_RX0 are 32-bit read-only registers that accept data from the receive shift registers when they become full ([Figure 25-2](#) and [Figure 25-3](#)). The data occupies the most significant portion of the receive data registers, according to the ALC control bit setting. The unused bits (least significant portion and 8 most significant bits when ALC=1) read as zeros. The Core is interrupted whenever RXn becomes full if the associated interrupt is enabled.

Address: 202\_4000h base + A0h offset + (4d × i), where i=0d to 3d

| 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 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |

### ESAI\_RXn field descriptions

| Field             | Description                                                                                                            |
|-------------------|------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                |
| RXn[23:0]         | Accept data from the receive shift registers when they become full<br>See <a href="#">ESAI Receive Shift Registers</a> |

## 25.6.12 Serial Audio Interface Status Register (ESAI\_SAISR)

The Status Register (ESAI\_SAISR) is a read-only status register used by the ARM Core to read the status and serial input flags of the ESAI.

Address: 202\_4000h base + CCh offset = 202\_40CCh

| Bit   | 31  | 30  | 29  | 28 | 27   | 26   | 25  | 24  | 23  | 22 | 21  | 20  | 19  | 18 | 17   | 16   |
|-------|-----|-----|-----|----|------|------|-----|-----|-----|----|-----|-----|-----|----|------|------|
| R     |     |     |     |    |      |      |     |     | 0   |    |     |     |     |    | TDFE | TEDE |
| W     |     |     |     |    |      |      |     |     |     |    |     |     |     |    |      |      |
| Reset | 0   | 0   | 0   | 0  | 0    | 0    | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0    | 0    |
| Bit   | 15  | 14  | 13  | 12 | 11   | 10   | 9   | 8   | 7   | 6  | 5   | 4   | 3   | 2  | 1    | 0    |
| R     | TDE | TUE | TFS | 0  | RODF | REDF | RDF | ROE | RFS | 0  | IF2 | IF1 | IF0 |    |      |      |
| W     |     |     |     |    |      |      |     |     |     |    |     |     |     |    |      |      |
| Reset | 0   | 0   | 0   | 0  | 0    | 0    | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0    | 0    |

### ESAI\_SAISR field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–18<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 17<br>TDFE        | ESAI_SAISR Transmit Odd-Data Register Empty. When set, TDFE indicates that the enabled transmitter data registers became empty at the beginning of an odd time slot. Odd time slots are all odd-numbered slots (1, 3, 5, and so on). Time slots are numbered from zero to N-1, where N is the number of time slots in the frame. This flag is set when the contents of the transmit data register of all the enabled transmitters are transferred to the transmit shift registers; it is also set for a TSR disabled time slot period in network mode (as if data were being transmitted after the TSR was written). When set, TDFE indicates that data should be written to all the TX registers of the enabled transmitters or to the transmit slot register (ESAI_TS). TODE is cleared when the Core writes to all the transmit data registers of the |

*Table continues on the next page...*

**ESAI\_SAISR field descriptions (continued)**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | enabled transmitters, or when the Core writes to the TSR to disable transmission of the next time slot. If TIE is set, an ESAI transmit data interrupt request is issued when TODFE is set. Hardware, software, ESAI individual reset clear TODFE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16<br>TEDE        | ESAI_SAISR Transmit Even-DataRegister Empty. When set, TEDE indicates that the enabled transmitter data registers became empty at the beginning of an even time slot. Even time slots are all even-numbered slots (0, 2, 4, 6, etc.). Time slots are numbered from zero to N-1, where N is the number of time slots in the frame. The zero time slot is considered even. This flag is set when the contents of the transmit data register of all the enabled transmitters are transferred to the transmit shift registers; it is also set for a TSR disabled time slot period in network mode (as if data were being transmitted after the TSR was written). When set, TEDE indicates that data should be written to all the TX registers of the enabled transmitters or to the transmit slot register (ESAI_TSR). TEDE is cleared when the Core writes to all the transmit data registers of the enabled transmitters, or when the Core writes to the TSR to disable transmission of the next time slot. If TIE is set, an ESAI transmit data interrupt request is issued when TEDE is set. Hardware, software, ESAI individual reset clear TEDE. |
| 15<br>TDE         | ESAI_SAISR Transmit Data Register Empty. TDE is set when the contents of the transmit data register of all the enabled transmitters are transferred to the transmit shift registers; it is also set for a TSR disabled time slot period in network mode (as if data were being transmitted after the TSR was written). When set, TDE indicates that data should be written to all the TX registers of the enabled transmitters or to the transmit slot register (ESAI_TSR). TDE is cleared when the Core writes to all the transmit data registers of the enabled transmitters, or when the Core writes to the TSR to disable transmission of the next time slot. If TIE is set, an ESAI transmit data interrupt request is issued when TDE is set. Hardware, software, ESAI individual reset clear TDE.                                                                                                                                                                                                                                                                                                                                           |
| 14<br>TUE         | ESAI_SAISR Transmit Underrun Error Flag. TUE is set when at least one of the enabled serial transmit shift registers is empty (no new data to be transmitted) and a transmit time slot occurs. When a transmit underrun error occurs, the previous data (which is still present in the TX registers that were not written) is retransmitted. If TEIE is set, an ESAI transmit data with exception (underrun error) interrupt request is issued when TUE is set. Hardware, software, ESAI individual reset clear TUE. TUE is also cleared by reading the ESAI_SAISR with TUE set, followed by writing to all the enabled transmit data registers or to ESAI_TSR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13<br>TFS         | ESAI_SAISR Transmit Frame Sync Flag. When set, TFS indicates that a transmit frame sync occurred in the current time slot. TFS is set at the start of the first time slot in the frame and cleared during all other time slots. Data written to a transmit data register during the time slot when TFS is set is transmitted (in network mode), if the transmitter is enabled, during the second time slot in the frame. TFS is useful in network mode to identify the start of a frame. TFS is cleared by hardware, software, ESAI individual reset. TFS is valid only if at least one transmitter is enabled, that is, one or more of TE0, TE1, TE2, TE3, TE4 and TE5 are set. (In normal mode, TFS always reads as a one when transmitting data because there is only one time slot per frame - the "frame sync" time slot)                                                                                                                                                                                                                                                                                                                     |
| 12–11<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10<br>RODF        | ESAI_SAISR Receive Odd-Data Register Full. When set, RODF indicates that the received data in the receive data registers of the enabled receivers have arrived during an odd time slot when operating in the network mode. Odd time slots are all odd-numbered slots (1, 3, 5, and so on). Time slots are numbered from zero to N-1, where N is the number of time slots in the frame. RODF is set when the contents of the receive shift registers are transferred to the receive data registers. RODF is cleared when the Core reads all the enabled receive data registers or cleared by hardware, software, ESAI individual resets.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9<br>REDF         | ESAI_SAISR Receive Even-Data Register Full. When set, REDF indicates that the received data in the receive data registers of the enabled receivers have arrived during an even time slot when operating in the network mode. Even time slots are all even-numbered slots (0, 2, 4, 6, and so on). Time slots are numbered from zero to N-1, where N is the number of time slots in the frame. The zero time slot is considered even. REDF is set when the contents of the receive shift registers are transferred to the receive data registers. REDF is cleared when the Core reads all the enabled receive data registers or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

**ESAI\_SAISR field descriptions (continued)**

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | cleared by hardware, software, ESAI individual resets. If REDIE is set, an ESAI receive even slot data interrupt request is issued when REDF is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8<br>RDF        | ESAI_SAISR Receive Data Register Full. RDF is set when the contents of the receive shift register of an enabled receiver is transferred to the respective receive data register. RDF is cleared when the Core reads the receive data register of all enabled receivers or cleared by hardware, software, ESAI individual reset. If RIE is set, an ESAI receive data interrupt request is issued when RDF is set.                                                                                                                                                                                                                                                      |
| 7<br>ROE        | ESAI_SAISR Receive Overrun Error Flag. The ROE flag is set when the serial receive shift register of an enabled receiver is full and ready to transfer to its receiver data register (RXn) and the register is already full (RDF=1). If REIE is set, an ESAI receive data with exception (overrun error) interrupt request is issued when ROE is set. Hardware, software, ESAI individual reset clear ROE. ROE is also cleared by reading the SAISR with ROE set, followed by reading all the enabled receive data registers.                                                                                                                                         |
| 6<br>RFS        | ESAI_SAISR Receive Frame Sync Flag. When set, RFS indicates that a receive frame sync occurred during reception of the words in the receiver data registers. This indicates that the data words are from the first slot in the frame. When RFS is clear and a word is received, it indicates (only in the network mode) that the frame sync did not occur during reception of that word. RFS is cleared by hardware, software, ESAI individual reset. RFS is valid only if at least one of the receivers is enabled (REx=1). (In normal mode, RFS always reads as a one when reading data because there is only one time slot per frame - the "frame sync" time slot) |
| 5–3<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2<br>IF2        | ESAI_SAISR Serial Input Flag 2. The IF2 bit is enabled only when the HCKR pin is defined as ESAI in the Port Control Register, SYN=1 and RHCKD=0, indicating that HCKR is an input flag and the synchronous mode is selected. Data present on the HCKR pin is latched during reception of the first received data bit after frame sync is detected. The IF2 bit is updated with this data when the receive shift registers are transferred into the receiver data registers. IF2 reads as a zero when it is not enabled. Hardware, software, ESAI individual reset clear IF2.                                                                                         |
| 1<br>IF1        | ESAI_SAISR Serial Inout Flag 1. The IF1 bit is enabled only when the FSR pin is defined as ESAI in the Port Control Register, SYN =1, RFSD=0 and TEBE=0, indicating that FSR is an input flag and the synchronous mode is selected. Data present on the FSR pin is latched during reception of the first received data bit after frame sync is detected. The IF1 bit is updated with this data when the receiver shift registers are transferred into the receiver data registers. IF1 reads as a zero when it is not enabled. Hardware, software, ESAI individual reset clear IF1.                                                                                   |
| 0<br>IF0        | ESAI_SAISR Serial Input Flag 0. The IF0 bit is enabled only when the SCKR pin is defined as ESAI in the Port Control Register, SYN=1 and RCKD=0, indicating that SCKR is an input flag and the synchronous mode is selected. Data present on the SCKR pin is latched during reception of the first received data bit after frame sync is detected. The IF0 bit is updated with this data when the receiver shift registers are transferred into the receiver data registers. IF0 reads as a zero when it is not enabled. Hardware, software, ESAI individual reset clear IF0.                                                                                         |

**25.6.13 Serial Audio Interface Control Register (ESAI\_SAICR)**

The read/write Common Control Register (ESAI\_SAICR) contains control bits for functions that affect both the receive and transmit sections of the ESAI.



**Figure 25-27. SAICR SYN Bit Operation**

## ESAI Memory Map/Register Definition

Address: 202\_4000h base + D0h offset = 202\_40D0h

|       |    |    |    |    |    |    |    |    |     |      |     |    |    |    |     |     |     |
|-------|----|----|----|----|----|----|----|----|-----|------|-----|----|----|----|-----|-----|-----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |     | 23   | 22  | 21 | 20 | 19 | 18  | 17  | 16  |
| R     |    |    |    |    |    |    |    |    | 0   |      |     |    |    |    |     |     |     |
| W     |    |    |    |    |    |    |    |    |     |      |     |    |    |    |     |     |     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |     | 0    | 0   | 0  | 0  | 0  | 0   | 0   | 0   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |     | 7    | 6   | 5  | 4  | 3  | 2   | 1   | 0   |
| R     |    |    |    |    | 0  |    |    |    | ALC | TEBE | SYN |    | 0  |    | OF2 | OF1 | OF0 |
| W     |    |    |    |    |    |    |    |    |     |      |     |    |    |    |     |     |     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |     | 0    | 0   | 0  | 0  | 0  | 0   | 0   | 0   |

### ESAI\_SAICR field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–9<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8<br>ALC         | ESAI_SAICR Alignment Control. The ESAI is designed for 24-bit fractional data, thus shorter data words are left aligned to the MSB (bit 23). Some applications use 16-bit fractional data. In those cases, shorter data words may be left aligned to bit 15. The Alignment Control (ALC) bit supports these applications.<br><br>If ALC is set, transmitted and received words are left aligned to bit 15 in the transmit and receive shift registers. If ALC is cleared, transmitted and received word are left aligned to bit 23 in the transmit and receive shift registers.<br><br>While ALC is set, 20-bit and 24-bit words may not be used, and word length control should specify 8-, 12-, or 16-bit words; otherwise, results are unpredictable.                                                                                                                                                                                                                          |
| 7<br>TEBE        | ESAI_SAICR Transmit External Buffer Enable. The Transmitter External Buffer Enable (TEBE) bit controls the function of the FSR pin when in the synchronous mode. If the ESAI is configured for operation in the synchronous mode (SYN=1), and TEBE is set while FSR pin is configured as an output (RFSD=1), the FSR pin functions as the transmitter external buffer enable control to enable the use of an external buffers on the transmitter outputs. If TEBE is cleared, the FSR pin functions as the serial I/O flag 1. See <a href="#">Port C Control Register</a> for a summary of the effects of TEBE on the FSR pin.                                                                                                                                                                                                                                                                                                                                                    |
| 6<br>SYN         | ESAI_SAICR Synchronous Mode Selection. The Synchronous Mode Selection (SYN) bit controls whether the receiver and transmitter sections of the ESAI operate synchronously or asynchronously with respect to each other (see <a href="#">Port C Control Register</a> ). When SYN is cleared, the asynchronous mode is chosen and independent clock and frame sync signals are used for the transmit and receive sections. When SYN is set, the synchronous mode is chosen and the transmit and receive sections use common clock and frame sync signals.<br><br>When in the synchronous mode (SYN=1), the transmit and receive sections use the transmitter section clock generator as the source of the clock and frame sync for both sections. Also, the receiver clock pins SCKR, FSR and HCKR now operate as I/O flags. Refer to <a href="#">Table 25-39</a> , <a href="#">Table 25-40</a> , and <a href="#">Table 25-41</a> for the effects of SYN on the receiver clock pins. |
| 5–3<br>Reserved  | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2<br>OF2         | ESAI_SAICR Serial Output Flag 2. The Serial Output Flag 2 (OF2) is a data bit used to hold data to be send to the OF2 pin. When the ESAI is in the synchronous clock mode (SYN=1), the HCKR pin is configured as the ESAI flag 2. If the receiver high frequency clock direction bit (RHCKD) is set, the HCKR pin is the output flag OF2, and data present in the OF2 bit is written to the OF2 pin at the beginning of the frame in normal mode or at the beginning of the next time slot in network mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1<br>OF1         | ESAI_SAICR Serial Output Flag 1. The Serial Output Flag 1 (OF1) is a data bit used to hold data to be send to the OF1 pin. When the ESAI is in the synchronous clock mode (SYN=1), the FSR pin is configured as the ESAI flag 1. If the receiver frame sync direction bit (RFSD) is set and the TEBE bit is cleared, the FSR pin is the output flag OF1, and data present in the OF1 bit is written to the OF1 pin at the beginning of the frame in normal mode or at the beginning of the next time slot in network mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

Table continues on the next page...

**ESAI\_SAICR field descriptions (continued)**

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>OF0 | ESAI_SAICR Serial Output Flag 0. The Serial Output Flag 0 (OF0) is a data bit used to hold data to be send to the OF0 pin. When the ESAI is in the synchronous clock mode (SYN=1), the SCKR pin is configured as the ESAI flag 0. If the receiver serial clock direction bit (RCKD) is set, the SCKR pin is the output flag OF0, and data present in the OF0 bit is written to the OF0 pin at the beginning of the frame in normal mode or at the beginning of the next time slot in network mode. |

**25.6.14 Transmit Control Register (ESAI\_TCR)**

The read/write Transmit Control Register (ESAI\_TCR) controls the ESAI transmitter section. Interrupt enable bits for the transmitter section are provided in this control register. Operating modes are also selected in this register.

**Table 25-30. Transmit Network Mode Selection**

| TMOD1 | TMOD0 | TDC4-TDC0 | Transmitter Network Mode |
|-------|-------|-----------|--------------------------|
| 0     | 0     | 0x0-0x1F  | Normal Mode              |
| 0     | 1     | 0x0       | On-Demand Mode           |
| 0     | 1     | 0x1-0x1F  | Network Mode             |
| 1     | 0     | X         | Reserved                 |
| 1     | 1     | 0x0C      | AC97                     |

**Figure 25-29. Normal and Network Operation****Table 25-31. ESAI Transmit Slot and Word Length Selection**

| TSWS4 | TSWS3 | TSWS2 | TSWS1 | TSWS0 | SLOT LENGTH | WORD LENGTH |
|-------|-------|-------|-------|-------|-------------|-------------|
| 0     | 0     | 0     | 0     | 0     | 8           | 8           |
| 0     | 0     | 1     | 0     | 0     | 12          | 8           |
| 0     | 0     | 0     | 0     | 1     |             | 12          |
| 0     | 1     | 0     | 0     | 0     | 16          | 8           |
| 0     | 0     | 1     | 0     | 1     |             | 12          |
| 0     | 0     | 0     | 1     | 0     |             | 16          |
| 0     | 1     | 1     | 0     | 0     | 20          | 8           |
| 0     | 1     | 0     | 0     | 1     |             | 12          |
| 0     | 0     | 1     | 1     | 0     |             | 16          |
| 0     | 0     | 0     | 1     | 1     |             | 20          |
| 1     | 0     | 0     | 0     | 0     | 24          | 8           |
| 0     | 1     | 1     | 0     | 1     |             | 12          |
| 0     | 1     | 0     | 1     | 0     |             | 16          |
| 0     | 0     | 1     | 1     | 1     |             | 20          |

*Table continues on the next page...*

**Table 25-31. ESAI Transmit Slot and Word Length Selection  
(continued)**

| TSWS4 | TSWS3 | TSWS2 | TSWS1 | TSWS0 | SLOT LENGTH | WORD LENGTH |
|-------|-------|-------|-------|-------|-------------|-------------|
| 1     | 1     | 1     | 1     | 0     |             | 24          |
| 1     | 1     | 0     | 0     | 0     | 32          | 8           |
| 1     | 0     | 1     | 0     | 1     |             | 12          |
| 1     | 0     | 0     | 1     | 0     |             | 16          |
| 0     | 1     | 1     | 1     | 1     |             | 20          |
| 1     | 1     | 1     | 1     | 1     |             | 24          |
| 0     | 1     | 0     | 1     | 1     | Reserved    |             |
| 0     | 1     | 1     | 1     | 0     |             |             |
| 1     | 0     | 0     | 0     | 1     |             |             |
| 1     | 0     | 0     | 1     | 1     |             |             |
| 1     | 0     | 1     | 0     | 0     |             |             |
| 1     | 0     | 1     | 1     | 0     |             |             |
| 1     | 0     | 1     | 1     | 1     |             |             |
| 1     | 1     | 0     | 0     | 1     |             |             |
| 1     | 1     | 0     | 1     | 0     |             |             |
| 1     | 1     | 0     | 1     | 1     |             |             |
| 1     | 1     | 1     | 0     | 0     |             |             |
| 1     | 1     | 1     | 1     | 1     |             |             |
|       |       |       |       |       |             |             |



Figure 25-30. Frame Length Selection

Address: 202\_4000h base + D4h offset = 202\_40D4h

| Bit   | 31   | 30 | 29 | 28          | 27 | 26 | 25        | 24 | 23   | 22    | 21    | 20   | 19  | 18   | 17  | 16   |
|-------|------|----|----|-------------|----|----|-----------|----|------|-------|-------|------|-----|------|-----|------|
| R     |      |    |    | 0           |    |    |           |    | TLIE | TIE   | TEDIE | TEIE | TPR | 0    |     |      |
| W     |      |    |    |             |    |    |           |    |      |       |       |      |     | PADC |     | TFSR |
| Reset | 0    | 0  | 0  | 0           | 0  | 0  | 0         | 0  | 0    | 0     | 0     | 0    | 0   | 0    | 0   | 0    |
| Bit   | 15   | 14 | 13 | 12          | 11 | 10 | 9         | 8  | 7    | 6     | 5     | 4    | 3   | 2    | 1   | 0    |
| R     | TFSL |    |    | TSWS[14:10] |    |    | TMOD[9:8] |    | TWA  | TSHFD | TE5   | TE4  | TE3 | TE2  | TE1 | TE0  |
| W     |      |    |    |             |    |    |           |    | 0    | 0     | 0     | 0    | 0   | 0    | 0   | 0    |
| Reset | 0    | 0  | 0  | 0           | 0  | 0  | 0         | 0  | 0    | 0     | 0     | 0    | 0   | 0    | 0   | 0    |

**ESAI\_TCR field descriptions**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 23<br>TLIE        | ESAI_TCR Transmit Last Slot Interrupt Enable. TLIE enables an interrupt at the beginning of last slot of a frame in network mode. When TLIE is set the Core is interrupted at the start of the last slot in a frame in network mode regardless of the transmit mask register setting. When TLIE is cleared the transmit last slot interrupt is disabled. TLIE is disabled when TDC[4:0]=0x00000 (on-demand mode). The use of the transmit last slot interrupt is described in <a href="#">ESAI Interrupt Requests</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 22<br>TIE         | ESAI_TCR Transmit Interrupt Enable. The Core is interrupted when TIE and the TDE flag in the ESAI_SAISR status register are set. When TIE is cleared, this interrupt is disabled. Writing data to all the data registers of the enabled transmitters or to ESAI_TSR clears TDE, thus clearing the interrupt.<br><br>Transmit interrupts with exception have higher priority than normal transmit data interrupts, therefore if exception occurs (TUE is set) and TEIE is set, the ESAI requests an ESAI transmit data with exception interrupt from the interrupt controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 21<br>TEDIE       | ESAI_TCR Transmit Even Slot Data Interrupt Enable. The TEDIE control bit is used to enable the transmit even slot data interrupts. If TEDIE is set, the transmit even slot data interrupts are enabled. If TEDIE is cleared, the transmit even slot data interrupts are disabled. A transmit even slot data interrupt request is generated if TEDIE is set and the TEDE status flag in the ESAI_SAISR status register is set. Even time slots are all even-numbered time slots (0, 2, 4, etc.) when operating in network mode. The zero time slot in the frame is marked by the frame sync signal and is considered to be even. Writing data to all the data registers of the enabled transmitters or to ESAI_TSR clears the TEDE flag, thus servicing the interrupt.<br><br>Transmit interrupts with exception have higher priority than transmit even slot data interrupts, therefore if exception occurs (TUE is set) and TEIE is set, the ESAI requests an ESAI transmit data with exception interrupt from the interrupt controller. |
| 20<br>TEIE        | ESAI_TCR Transmit Exception Interrupt Enable. When TEIE is set, the Core is interrupted when both TDE and TUE in the ESAI_SAISR status register are set. When TEIE is cleared, this interrupt is disabled. Reading the ESAI_SAISR status register followed by writing to all the data registers of the enabled transmitters clears TUE, thus clearing the pending interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 19<br>TPR         | ESAI_TCR Transmit Section Personal Reset. The TPR control bit is used to put the transmitter section of the ESAI in the personal reset state. The receiver section is not affected. When TPR is cleared, the transmitter section may operate normally. When TPR is set, the transmitter section enters the personal reset state immediately. When in the personal reset state, the status bits are reset to the same state as after hardware reset. The control bits are not affected by the personal reset state. The transmitter data pins are tri-stated while in the personal reset state; if a stable logic level is desired, the transmitter data pins should be defined as GPIO outputs, or external pull-up or pull-down resistors should be used. The                                                                                                                                                                                                                                                                            |

Table continues on the next page...

## ESAI\_TCR field descriptions (continued)

| Field                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | transmitter clock outputs drive zeroes while in the personal reset state. Note that to leave the personal reset state by clearing TPR, the procedure described in <a href="#">ESAI Initialization Examples</a> should be followed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 18<br>Reserved       | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17<br>PADC           | ESAI_TCR Transmit Zero Padding Control. When PADC is cleared, zero padding is disabled. When PADC is set, zero padding is enabled. PADC, in conjunction with the TWA control bit, determines the way that padding is done for operating modes where the word length is less than the slot length. See the TWA bit description in bit 7 for more details.<br><br>Because the data word is shorter than the slot length, the data word is extended until achieving the slot length, according to the following rule:<br><br>If the data word is left-aligned (TWA=0), and zero padding is disabled (PADC=0), the last data bit is repeated after the data word has been transmitted. If zero padding is enabled (PADC=1), zeroes are transmitted after the data word has been transmitted.<br><br>If the data word is right-aligned (TWA=1), and zero padding is disabled (PADC=0), the first data bit is repeated before the transmission of the data word. If zero padding is enabled (PADC=1), zeroes are transmitted before the transmission of the data word.                                                                      |
| 16<br>TFSR           | ESAI_TCR Transmit Frame Sync Relative Timing. TFSR determines the relative timing of the transmit frame sync signal as referred to the serial data lines, for a word length frame sync only (TFSL=0). When TFSR is cleared the word length frame sync occurs together with the first bit of the data word of the first slot. When TFSR is set the word length frame sync starts one serial clock cycle earlier, that is, together with the last bit of the previous data word.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15<br>TFSL           | ESAI_TCR Transmit Frame Sync Length. The TFSL bit selects the length of frame sync to be generated or recognized. If TFSL is cleared, a word-length frame sync is selected. If TFSL is set, a 1-bit clock period frame sync is selected. See Figure 1-21 for examples of frame length selection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 14–10<br>TSWS[14:10] | ESAI_TCR Tx Slot and Word Length Select (TSWS4-TSWS0). The TSWS4-TSWS0 bits are used to select the length of the slot and the length of the data words being transferred through the ESAI. The word length must be equal to or shorter than the slot length. The possible combinations are shown in <a href="#">Table 25-31</a> . See also the ESAI data path programming model in <a href="#">Figure 25-2</a> and <a href="#">Figure 25-3</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9–8<br>TMOD[9:8]     | ESAI_TCR Transmit Network Mode Control (TMOD1-TMOD0). The TMOD1 and TMOD0 bits are used to define the network mode of ESAI transmitters, as shown in <a href="#">Table 25-31</a> . In the normal mode, the frame rate divider determines the word transfer rate - one word is transferred per frame sync during the frame sync time slot, as shown in <a href="#">Figure 25-29</a> . In network mode, it is possible to transfer a word for every time slot, as shown in <a href="#">Figure 25-29</a> . For further details, refer to <a href="#">Modes of Operation</a><br><br>In order to comply with AC-97 specifications, TSWS4-TSWS0 should be set to 00011 (20-bit slot, 20-bit word length), TFSL and TFSR should be cleared, and TDC4-TDC0 should be set to 0x0C (13 words in frame). If TMOD[1:0]=0b11 and the above recommendations are followed, the first slot and word will be 16 bits long, and the next 12 slots and words will be 20 bits long, as required by the AC97 protocol.                                                                                                                                     |
| 7<br>TWA             | ESAI_TCR Transmit Word Alignment Control. The Transmitter Word Alignment Control (TWA) bit defines the alignment of the data word in relation to the slot. This is relevant for the cases where the word length is shorter than the slot length. If TWA is cleared, the data word is left-aligned in the slot frame during transmission. If TWA is set, the data word is right-aligned in the slot frame during transmission.<br><br>Because the data word is shorter than the slot length, the data word is extended until achieving the slot length, according to the following rule:<br><br>If the data word is left-aligned (TWA=0), and zero padding is disabled (PADC=0), the last data bit is repeated after the data word has been transmitted. If zero padding is enabled (PADC=1), zeroes are transmitted after the data word has been transmitted.<br><br>If the data word is right-aligned (TWA=1), and zero padding is disabled (PADC=0), the first data bit is repeated before the transmission of the data word. If zero padding is enabled (PADC=1), zeroes are transmitted before the transmission of the data word. |

*Table continues on the next page...*

**ESAI\_TCR field descriptions (continued)**

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>TSHFD | ESAI_TCR Transmit Shift Direction. The TSHFD bit causes the transmit shift registers to shift data out MSB first when TSHFD equals zero or LSB first when TSHFD equals one (see <a href="#">Figure 25-2</a> and <a href="#">Figure 25-3</a> ).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5<br>TE5   | <p>ESAI_TCR ESAI Transmit 5 Enable. TE5 enables the transfer of data from ESAI_TX5 to the transmit shift register #5. When TE5 is set and a frame sync is detected, the transmit #5 portion of the ESAI is enabled for that frame. When TE5 is cleared, the transmitter #5 is disabled after completing transmission of data currently in the ESAI transmit shift register. Data can be written to ESAI_TX5 when TE5 is cleared but the data is not transferred to the transmit shift register #5.</p> <p>The SDO5/SDI0 pin is the data input pin for ESAI_RX0 if TE5 is cleared and RE0 in the ESAI_RCR register is set. If both RE0 and TE5 are cleared, the transmitter and receiver are disabled, and the pin is tri-stated. Both RE0 and TE5 should not be set at the same time.</p> <p>The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.</p> <p>In the network mode, the operation of clearing TE5 and setting it again disables the transmitter #5 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO5/SDI0 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE5 can be left enabled.</p> |
| 4<br>TE4   | <p>ESAI_TCR ESAI Transmit 4 Enable. TE4 enables the transfer of data from ESAI_TX4 to the transmit shift register #4. When TE4 is set and a frame sync is detected, the transmit #4 portion of the ESAI is enabled for that frame. When TE4 is cleared, the transmitter #4 is disabled after completing transmission of data currently in the ESAI transmit shift register. Data can be written to ESAI_TX4 when TE4 is cleared but the data is not transferred to the transmit shift register #4.</p> <p>The SDO4/SDI1 pin is the data input pin for ESAI_RX1 if TE4 is cleared and RE1 in the RCR register is set. If both RE1 and TE4 are cleared, the transmitter and receiver are disabled, and the pin is tri-stated. Both RE1 and TE4 should not be set at the same time.</p> <p>The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.</p> <p>In the network mode, the operation of clearing TE4 and setting it again disables the transmitter #4 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO4/SDI1 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE4 can be left enabled.</p>      |
| 3<br>TE3   | <p>ESAI_TCR ESAI Transmit 3 Enable. TE3 enables the transfer of data from ESAI_TX3 to the transmit shift register #3. When TE3 is set and a frame sync is detected, the transmit #3 portion of the ESAI is enabled for that frame. When TE3 is cleared, the transmitter #3 is disabled after completing transmission of data currently in the ESAI transmit shift register. Data can be written to ESAI_TX3 when TE3 is cleared but the data is not transferred to the transmit shift register #3.</p> <p>The SDO3/SDI2 pin is the data input pin for ESAI_RX2 if TE3 is cleared and RE2 in the ESAI_RCR register is set. If both RE2 and TE3 are cleared, the transmitter and receiver are disabled, and the pin is tri-stated. Both RE2 and TE3 should not be set at the same time.</p> <p>The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.</p> <p>In the network mode, the operation of clearing TE3 and setting it again disables the transmitter #3 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO3/SDI2 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE3 can be left enabled.</p> |
| 2<br>TE2   | ESAI_TCR ESAI Transmit 2 Enable. TE2 enables the transfer of data from ESAI_TX2 to the transmit shift register #2. When TE2 is set and a frame sync is detected, the transmit #2 portion of the ESAI is enabled for that frame. When TE2 is cleared, the transmitter #2 is disabled after completing transmission of data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

*Table continues on the next page...*

**ESAI\_TCR field descriptions (continued)**

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | <p>currently in the ESAI transmit shift register. Data can be written to ESAI_TX2 when TE2 is cleared but the data is not transferred to the transmit shift register #2.</p> <p>The SDO2/SDI3 pin is the data input pin for ESAI_RX3 if TE2 is cleared and RE3 in the ESAI_RCR register is set. If both RE3 and TE2 are cleared, the transmitter and receiver are disabled, and the pin is tri-stated. Both RE3 and TE2 should not be set at the same time.</p> <p>The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.</p> <p>In the network mode, the operation of clearing TE2 and setting it again disables the transmitter #2 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO2/SDI3 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE2 can be left enabled.</p>                                                                                                                          |
| 1<br>TE1 | <p>ESAI_TCR ESAI Transmit 1 Enable. TE1 enables the transfer of data from TX1 to the transmit shift register #1. When TE1 is set and a frame sync is detected, the transmit #1 portion of the ESAI is enabled for that frame. When TE1 is cleared, the transmitter #1 is disabled after completing transmission of data currently in the ESAI transmit shift register. The SDO1 output is tri-stated, and any data present in TX1 is not transmitted, that is, data can be written to TX1 with TE1 cleared, but data is not transferred to the transmit shift register #1.</p> <p>The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.</p> <p>In the network mode, the operation of clearing TE1 and setting it again disables the transmitter #1 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO1 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE1 can be left enabled.</p>                |
| 0<br>TE0 | <p>ESAI_TCR ESAI Transmit 0 Enable. TE0 enables the transfer of data from ESAI_TX0 to the transmit shift register #0. When TE0 is set and a frame sync is detected, the transmit #0 portion of the ESAI is enabled for that frame. When TE0 is cleared, the transmitter #0 is disabled after completing transmission of data currently in the ESAI transmit shift register. The SDO0 output is tri-stated, and any data present in ESAI_TX0 is not transmitted, that is, data can be written to ESAI_TX0 with TE0 cleared, but data is not transferred to the transmit shift register #0.</p> <p>The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.</p> <p>In the network mode, the operation of clearing TE0 and setting it again disables the transmitter #0 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO0 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE0 can be left enabled.</p> |

**25.6.15 Transmit Clock Control Register (ESAI\_TCCR)**

The read/write Transmitter Clock Control Register (ESAI\_TCCR) controls the ESAI transmitter clock generator bit and frame sync rates, the bit clock and high frequency clock sources and the directions of the HCKT, FST and SCKT signals. In the synchronous mode (SYN=1), the bit clock defined for the transmitter determines the receiver bit clock as well. ESAI\_TCCR also controls the number of words per frame for the serial data. Hardware and software reset clear all the bits of the ESAI\_TCCR register.

Care should be taken in asynchronous mode whenever the frame sync clock (FSR, FST) is not sourced directly from its associated bit clock (SCKR, SCKT). Proper phase relationships must be maintained between these clocks in order to guarantee proper operation of the ESAI.

### NOTE

ARM Core clock is ipg\_clk\_esai in block ESAI which is from CCM's ahb\_clk\_root.



**Figure 25-32. ESAI Clock Generator Functional Block Diagram**

### NOTE

1. ETI, ETO, ERI and ERO bit descriptions are covered in [ESAI Control Register \(ESAI\\_ECR\)](#).
2. Fsys is the ESAI system 133 MHz clock.
3. EXTAL is the on-chip clock sources other than ESAI system 133MHz clock.

## ESAI Memory Map/Register Definition



**Figure 25-33. ESAI Frame Sync Generator Functional Block Diagram**

**Table 25-33. Transmitter High Frequency Clock Divider**

| TFP3-TFP0 | Divide Ratio |
|-----------|--------------|
| 0x0       | 1            |
| 0x1       | 2            |
| 0x2       | 3            |
| 0x3       | 4            |
| ...       | ...          |
| 0xF       | 16           |

Address: 202\_4000h base + D8h offset = 202\_40D8h

| Bit      | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23       | 22   | 21   | 20    | 19   | 18   | 17 | 16       |
|----------|----|----|----|----|----|----|----|----|----------|------|------|-------|------|------|----|----------|
| R        |    |    |    |    |    |    |    |    | THCKD    | TFSD | TCKD | THCKP | TFSP | TCKP |    |          |
| W        |    |    |    |    |    |    |    |    |          |      |      |       |      |      |    | TFP[3:0] |
| Reset    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0    | 0    | 0     | 0    | 0    | 0  | 0        |
| Bit      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7        | 6    | 5    | 4     | 3    | 2    | 1  | 0        |
| R        |    |    |    |    |    |    |    |    |          |      |      |       |      |      |    |          |
| TFP[3:0] |    |    |    |    |    |    |    |    | TDC[4:0] |      | TPSR |       |      |      |    | TPM[7:0] |
| W        |    |    |    |    |    |    |    |    |          |      |      |       |      |      |    |          |
| Reset    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0    | 0    | 0     | 0    | 0    | 0  | 0        |

### ESAI\_TCCR field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 23<br>THCKD       | ESAI_TCCR Transmit High Frequency Clock Direction. THCKD controls the direction of the HCKT pin. When THCKD is cleared, HCKT is an input; when THCKD is set, HCKT is an output (see <a href="#">Table 25-3</a> ).                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 22<br>TFSD        | ESAI_TCCR Transmit Frame Sync Signal Direction. TFSD controls the direction of the FST pin. When TFSD is cleared, FST is an input; when TFSD is set, FST is an output (see <a href="#">Table 25-3</a> ).                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 21<br>TCKD        | ESAI_TCCR Transmit Clock Source Direction. The Transmitter Clock Source Direction (TCKD) bit selects the source of the clock signal used to clock the transmit shift registers in the asynchronous mode (SYN=0) and the transmit shift registers and the receive shift registers in the synchronous mode (SYN=1). When TCKD is set, the internal clock source becomes the bit clock for the transmit shift registers and word length divider and is the output on the SCKT pin. When TCKD is cleared, the clock source is external; the internal clock generator is disconnected from the SCKT pin, and an external clock source may drive this pin (see <a href="#">Table 25-3</a> ). |
| 20<br>THCKP       | ESAI_TCCR Transmit High Frequency Clock Polarity<br>The Transmitter High Frequency Clock Polarity (THCKP) bit controls the polarity of the HCKT.<br>0 - Normal polarity<br>1 - Inverted polarity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 19<br>TFSP        | ESAI_TCCR Transmit Frame Sync Polarity. The Transmitter Frame Sync Polarity (TFSP) bit determines the polarity of the transmit frame sync signal. When TFSP is cleared, the frame sync signal polarity is positive, that is, the frame start is indicated by a high level on the frame sync pin. When TFSP is set, the frame sync signal polarity is negative, that is, the frame start is indicated by a low level on the frame sync pin.                                                                                                                                                                                                                                             |
| 18<br>TCKP        | ESAI_TCCR Transmit Clock Polarity. The Transmitter Clock Polarity (TCKP) bit controls on which bit clock edge data and frame sync are clocked out and latched in. If TCKP is cleared the data and the frame sync are clocked out on the rising edge of the transmit bit clock and latched in on the falling edge of the transmit bit clock. If TCKP is set the falling edge of the transmit clock is used to clock the data out and frame sync and the rising edge of the transmit clock is used to latch the data and frame sync in.                                                                                                                                                  |
| 17–14<br>TFP[3:0] | ESAI_TCCR Tx High Frequency Clock Divider. The TFP3-TFP0 bits control the divide ratio of the transmitter high frequency clock to the transmitter serial bit clock when the source of the high frequency clock and the bit clock is the internal ARM Core clock. When the HCKT input is being driven from an external high frequency clock, the TFP3-TFP0 bits specify an additional division ratio in the clock divider chain. <a href="#">Table 25-33</a> shows the specification for the divide ratio. <a href="#">Figure 25-32</a> shows the ESAI high frequency clock generator functional diagram.                                                                               |

Table continues on the next page...

**ESAI\_TCCR field descriptions (continued)**

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13–9<br>TDC[4:0] | <p>ESAI_TCCR Tx Frame Rate Divider Control. The TDC4-TDC0 bits control the divide ratio for the programmable frame rate dividers used to generate the transmitter frame clocks.</p> <p>In network mode, this ratio may be interpreted as the number of words per frame minus one. The divide ratio may range from 2 to 32 (TDC[4:0]=0x00001 to 0x11111) for network mode. A divide ratio of one (TDC[4:0]=0x00000) in network mode is a special case (on-demand mode).</p> <p>In normal mode, this ratio determines the word transfer rate. The divide ratio may range from 1 to 32 (TDC[4:0]=0x00000 to 0x11111) for normal mode. In normal mode, a divide ratio of 1 (TDC[4:0]=0x00000) provides continuous periodic data word transfers. A bit-length frame sync (TFSL=1) must be used in this case.</p> <p>The ESAI frame sync generator functional diagram is shown in <a href="#">Figure 25-33</a></p> |
| 8<br>TPSR        | ESAI_TCCR Transmit Prescaler Range. The TPSR bit controls a fixed divide-by-eight prescaler in series with the variable prescaler. This bit is used to extend the range of the prescaler for those cases where a slower bit clock is desired. When TPSR is set, the fixed prescaler is bypassed. When TPSR is cleared, the fixed divide-by-eight prescaler is operational (see <a href="#">Figure 25-32</a> ). The maximum internally generated bit clock frequency is Fsys/4; the minimum internally generated bit clock frequency is Fsys/(2 x 8 x 256 x 16)=Fsys/65536. (Do not use the combination TPSR=1, TPM7-TPM0=0x00, and TFP3-TFP0=0x0 which causes synchronization problems when using the internal ARM Core clock as source (TCKD=1 or THCKD=1))                                                                                                                                                 |
| TPM[7:0]         | ESAI_TCCR Transmit Prescale Modulus Select. The TPM7-TPM0 bits specify the divide ratio of the prescale divider in the ESAI transmitter clock generator. A divide ratio from 1 to 256 (TPM[7:0]=0x00 to 0xFF) may be selected. The bit clock output is available at the transmit serial bit clock (SCKT) pin. The bit clock output is also available internally for use as the bit clock to shift the transmit and receive shift registers. The ESAI transmit clock generator functional diagram is shown in <a href="#">Figure 25-32</a> .                                                                                                                                                                                                                                                                                                                                                                  |

**25.6.16 Receive Control Register (ESAI\_RCR)**

The read/write Receive Control Register (ESAI\_RCR) controls the ESAI receiver section. Interrupt enable bits for the receivers are provided in this control register. The receivers are enabled in this register (0,1,2 or 3 receivers can be enabled) if the input data pin is not used by a transmitter. Operating modes are also selected in this register.

**Table 25-35. ESAI Receive Network Mode Selection**

| RMOD1 | RMOD0 | RDC4-RDC0 | Receiver Network Mode |
|-------|-------|-----------|-----------------------|
| 0     | 0     | 0x0-0x1F  | Normal Mode           |
| 0     | 1     | 0x0       | On-Demand Mode        |
| 0     | 1     | 0x1-0x1F  | Network Mode          |
| 1     | 0     | X         | Reserved              |
| 1     | 1     | 0x0C      | AC97                  |

**Table 25-36. ESAI Receive Slot and Word Length Selection**

| RSWS4 | RSWS3 | RSWS2 | RSWS1 | RSWS0 | SLOT LENGTH | WORD LENGTH |
|-------|-------|-------|-------|-------|-------------|-------------|
| 0     | 0     | 0     | 0     | 0     | 8           | 8           |
| 0     | 0     | 1     | 0     | 0     | 12          | 8           |
| 0     | 0     | 0     | 0     | 1     |             | 12          |
| 0     | 1     | 0     | 0     | 0     | 16          | 8           |
| 0     | 0     | 1     | 0     | 1     |             | 12          |
| 0     | 0     | 0     | 1     | 0     |             | 16          |
| 0     | 1     | 1     | 0     | 0     | 20          | 8           |
| 0     | 1     | 0     | 0     | 1     |             | 12          |
| 0     | 0     | 1     | 1     | 0     |             | 16          |
| 0     | 0     | 0     | 1     | 1     | 24          | 20          |
| 1     | 0     | 0     | 0     | 0     |             | 8           |
| 0     | 1     | 1     | 0     | 1     |             | 12          |
| 0     | 1     | 0     | 1     | 0     |             | 16          |
| 0     | 0     | 1     | 1     | 1     |             | 20          |
| 1     | 1     | 1     | 1     | 0     | 32          | 24          |
| 1     | 1     | 0     | 0     | 0     |             | 8           |
| 1     | 0     | 1     | 0     | 1     |             | 12          |
| 1     | 0     | 0     | 1     | 0     |             | 16          |
| 0     | 1     | 1     | 1     | 1     |             | 20          |
| 1     | 1     | 1     | 1     | 1     | Reserved    | 24          |
| 0     | 1     | 0     | 1     | 1     |             |             |
| 0     | 1     | 1     | 1     | 0     |             |             |
| 1     | 0     | 0     | 0     | 1     |             |             |
| 1     | 0     | 0     | 1     | 1     |             |             |
| 1     | 0     | 1     | 0     | 0     |             |             |
| 1     | 0     | 1     | 1     | 0     |             |             |
| 1     | 0     | 1     | 1     | 1     |             |             |
| 1     | 1     | 0     | 0     | 1     |             |             |
| 1     | 1     | 0     | 1     | 0     |             |             |
| 1     | 1     | 1     | 0     | 0     |             |             |
| 1     | 1     | 1     | 0     | 1     |             |             |
| 1     | 1     | 1     | 1     | 0     |             |             |
| 1     | 1     | 1     | 1     | 1     |             |             |

## ESAI Memory Map/Register Definition

Address: 202\_4000h base + DCh offset = 202\_40DCh

| Bit   | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22    | 21    | 20   | 19  | 18  | 17    | 16  |
|-------|------|----|----|----|----|----|----|----|------|-------|-------|------|-----|-----|-------|-----|
| R     |      |    |    |    |    |    |    |    | RLIE | RIE   | REDIE | REIE | RPR | 0   |       |     |
| W     |      |    |    |    |    |    |    |    |      |       |       |      |     |     | RFSSR |     |
| Reset | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0     | 0    | 0   | 0   | 0     | 0   |
| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7    | 6     | 5     | 4    | 3   | 2   | 1     | 0   |
| R     | RFSL |    |    |    |    |    |    |    | RWA  | RSHFD | 0     |      | RE3 | RE2 | RE1   | RE0 |
| W     |      |    |    |    |    |    |    |    |      |       |       |      |     |     |       |     |
| Reset | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0     | 0    | 0   | 0   | 0     | 0   |

### ESAI\_RCR field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23<br>RLIE        | ESAI_RCR Receive Last Slot Interrupt Enable. RLIE enables an interrupt after the last slot of a frame ended in network mode only. When RLIE is set the Core is interrupted after the last slot in a frame ended regardless of the receive mask register setting. When RLIE is cleared the receive last slot interrupt is disabled. Hardware and software reset clear RLIE. RLIE is disabled when RDC[4:0]=00000 (on-demand mode). The use of the receive last slot interrupt is described in <a href="#">ESAI Interrupt Requests</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 22<br>RIE         | ESAI_RCR Receive Interrupt Enable. The Core is interrupted when RIE and the RDF flag in the ESAI_SAISR status register are set. When RIE is cleared, this interrupt is disabled. Reading the receive data registers of the enabled receivers clears RDF, thus clearing the interrupt.<br><br>Receive interrupts with exception have higher priority than normal receive data interrupts, therefore if exception occurs (ROE is set) and REIE is set, the ESAI requests an ESAI receive data with exception interrupt from the interrupt controller.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21<br>REDIE       | ESAI_RCR Receive Even Slot Data Interrupt Enable. The REDIE control bit is used to enable the receive even slot data interrupts. If REDIE is set, the receive even slot data interrupts are enabled. If REDIE is cleared, the receive even slot data interrupts are disabled. A receive even slot data interrupt request is generated if REDIE is set and the REDF status flag in the ESAI_SAISR status register is set. Even time slots are all even-numbered time slots (0, 2, 4, etc.) when operating in network mode. The zero time slot is marked by the frame sync signal and is considered to be even. Reading all the data registers of the enabled receivers clears the REDF flag, thus servicing the interrupt.<br><br>Receive interrupts with exception have higher priority than receive even slot data interrupts, therefore if exception occurs (ROE is set) and REIE is set, the ESAI requests an ESAI receive data with exception interrupt from the interrupt controller. |
| 20<br>REIE        | ESAI_RCR Receive Exception Interrupt Enable. When REIE is set, the Core is interrupted when both RDF and ROE in the ESAI_SAISR status register are set. When REIE is cleared, this interrupt is disabled. Reading the ESAI_SAISR status register followed by reading the enabled receivers data registers clears ROE, thus clearing the pending interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 19<br>RPR         | ESAI_RCR Receiver Section Personal Reset. The RPR control bit is used to put the receiver section of the ESAI in the personal reset state. The transmitter section is not affected. When RPR is cleared, the receiver section may operate normally. When RPR is set, the receiver section enters the personal reset state immediately. When in the personal reset state, the status bits are reset to the same state as after hardware reset. The control bits are not affected by the personal reset state. The receiver data pins are disconnected while in the personal reset state.                                                                                                                                                                                                                                                                                                                                                                                                    |

Table continues on the next page...

**ESAI\_RCR field descriptions (continued)**

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <b>NOTE:</b> To leave the personal reset state by clearing RPR, the procedure described in <a href="#">ESAI Initialization Examples</a> should be followed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 18–17<br>Reserved  | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16<br>RFSR         | ESAI_RCR Receiver Frame Sync Relative Timing. RFSR determines the relative timing of the receive frame sync signal as referred to the serial data lines, for a word length frame sync only. When RFSR is cleared the word length frame sync occurs together with the first bit of the data word of the first slot. When RFSR is set the word length frame sync starts one serial clock cycle earlier, that is, together with the last bit of the previous data word.                                                                                                                                                                                                                                                                                                  |
| 15<br>RFSL         | ESAI_RCR Receiver Frame Sync Length. The RFSL bit selects the length of the receive frame sync to be generated or recognized. If RFSL is cleared, a word-length frame sync is selected. If RFSL is set, a 1-bit clock period frame sync is selected. Refer to <a href="#">Figure 25-30</a> for examples of frame length selection.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 14–10<br>RSWS[4:0] | ESAI_RCR Receiver Slot and Word Select. The RSWS4-RSWS0 bits are used to select the length of the slot and the length of the data words being received through the ESAI. The word length must be equal to or shorter than the slot length. The possible combinations are shown in <a href="#">Table 25-36</a> . See also the ESAI data path programming model in <a href="#">Figure 25-2</a> and <a href="#">Figure 25-3</a> .                                                                                                                                                                                                                                                                                                                                        |
| 9–8<br>RMOD[1:0]   | ESAI_RCR Receiver Network Mode Control. The RMOD1 and RMOD0 bits are used to define the network mode of the ESAI receivers, as shown in <a href="#">Table 25-35</a> . In the normal mode, the frame rate divider determines the word transfer rate - one word is transferred per frame sync during the frame sync time slot, as shown in <a href="#">Figure 25-29</a> . In network mode, it is possible to transfer a word for every time slot, as shown in <a href="#">Figure 25-29</a> . For more details, see <a href="#">Modes of Operation</a> .<br><br>In order to comply with AC-97 specifications, RSWS4-RSWS0 should be set to 0x00011 (20-bit slot, 20-bit word); RFSL and RFSR should be cleared, and RDC4-RDC0 should be set to 0x0C (13 words in frame). |
| 7<br>RWA           | ESAI_RCR Receiver Word Alignment Control. The Receiver Word Alignment Control (RWA) bit defines the alignment of the data word in relation to the slot. This is relevant for the cases where the word length is shorter than the slot length. If RWA is cleared, the data word is assumed to be left-aligned in the slot frame. If RWA is set, the data word is assumed to be right-aligned in the slot frame.<br><br>If the data word is shorter than the slot length, the data bits which are not in the data word field are ignored.<br><br>For data word lengths of less than 24 bits, the data word is right-extended with zeroes before being stored in the receive data registers.                                                                             |
| 6<br>RSHFD         | ESAI_RCR Receiver Shift Direction. The RSHFD bit causes the receiver shift registers to shift data in MSB first when RSHFD is cleared or LSB first when RSHFD is set (see <a href="#">Figure 25-2</a> and <a href="#">Figure 25-3</a> ).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5–4<br>Reserved    | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3<br>RE3           | ESAI_RCR ESAI Receiver 3 Enable. When RE3 is set and TE2 is cleared, the ESAI receiver 3 is enabled and samples data at the SDO2/SDI3 pin. ESAI_TX2 and ESAI_RX3 should not be enabled at the same time (RE3=1 and TE2=1). When RE3 is cleared, receiver 3 is disabled by inhibiting data transfer into ESAI_RX3. If this bit is cleared while receiving a data word, the remainder of the word is shifted in and transferred to the ESAI_RX3 data register.<br><br>If RE3 is set while some of the other receivers are already in operation, the first data word received in ESAI_RX3 will be invalid and must be discarded.                                                                                                                                         |
| 2<br>RE2           | ESAI_RCR ESAI Receiver 2 Enable. When RE2 is set and TE3 is cleared, the ESAI receiver 2 is enabled and samples data at the SDO3/SDI2 pin. ESAI_TX3 and ESAI_RX2 should not be enabled at the same time (RE2=1 and TE3=1). When RE2 is cleared, receiver 2 is disabled by inhibiting data transfer into ESAI_RX2. If this bit is cleared while receiving a data word, the remainder of the word is shifted in and transferred to the ESAI_RX2 data register.<br><br>If RE2 is set while some of the other receivers are already in operation, the first data word received in ESAI_RX2 will be invalid and must be discarded.                                                                                                                                         |

*Table continues on the next page...*

**ESAI\_RCR field descriptions (continued)**

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>RE1 | ESAI_RCR ESAI Receiver 1 Enable. When RE1 is set and TE4 is cleared, the ESAI receiver 1 is enabled and samples data at the SDO4/SDI1 pin. ESAI_TX4 and ESAI_RX1 should not be enabled at the same time (RE1=1 and TE4=1). When RE1 is cleared, receiver 1 is disabled by inhibiting data transfer into ESAI_RX1. If this bit is cleared while receiving a data word, the remainder of the word is shifted in and transferred to the ESAI_RX1 data register.<br><br>If RE1 is set while some of the other receivers are already in operation, the first data word received in ESAI_RX1 will be invalid and must be discarded. |
| 0<br>RE0 | ESAI_RCR ESAI Receiver 0 Enable. When RE0 is set and TE5 is cleared, the ESAI receiver 0 is enabled and samples data at the SDO5/SDI0 pin. ESAI_TX5 and ESAI_RX0 should not be enabled at the same time (RE0=1 and TE5=1). When RE0 is cleared, receiver 0 is disabled by inhibiting data transfer into ESAI_RX0. If this bit is cleared while receiving a data word, the remainder of the word is shifted in and transferred to the ESAI_RX0 data register.<br><br>If RE0 is set while some of the other receivers are already in operation, the first data word received in ESAI_RX0 will be invalid and must be discarded. |

**25.6.17 Receive Clock Control Register (ESAI\_RCCR)**

The read/write Receiver Clock Control Register (ESAI\_RCCR) controls the ESAI receiver clock generator bit and frame sync rates, word length, and number of words per frame for the serial data. The ESAI\_RCCR control bits are described in the following paragraphs.

**NOTE**

ARM Core clock is ipg\_clk\_esai in block ESAI which is from CCM's ahb\_clk\_root.

**Table 25-38. Receiver High Frequency Clock Divider**

| RFP3-RFP0 | Divide Ratio |
|-----------|--------------|
| 0x0       | 1            |
| 0x1       | 2            |
| 0x2       | 3            |
| 0x3       | 4            |
| ...       | ...          |
| 0xF       | 16           |

**Table 25-39. SCKR Pin Definition Table**

| Control Bits |      | SCKR PIN   |
|--------------|------|------------|
| SYN          | RCKD |            |
| 0            | 0    | SCKR input |

*Table continues on the next page...*

**Table 25-39. SCKR Pin Definition Table (continued)**

| Control Bits |      | SCKR PIN    |
|--------------|------|-------------|
| SYN          | RCKD |             |
| 0            | 1    | SCKR output |
| 1            | 0    | IF0         |
| 1            | 1    | OF0         |

**Table 25-40. FSR Pin Definition Table**

| Control Bits |      |      | FSR Pin                   |
|--------------|------|------|---------------------------|
| SYN          | TEBE | RFSD |                           |
| 0            | X    | 0    | FSR input                 |
| 0            | X    | 1    | FSR output                |
| 1            | 0    | 0    | IF1                       |
| 1            | 0    | 1    | OF1                       |
| 1            | 1    | 0    | reserved                  |
| 1            | 1    | 1    | Transmitter Buffer Enable |

**Table 25-41. HCKR Pin Definition Table**

| Control Bits |       |  | HCKR PIN    |
|--------------|-------|--|-------------|
| SYN          | RHCKD |  |             |
| 0            | 0     |  | HCKR input  |
| 0            | 1     |  | HCKR output |
| 1            | 0     |  | IF2         |
| 1            | 1     |  | OF2         |

Address: 202\_4000h base + E0h offset = 202\_40E0h

| Bit   | 31       | 30 | 29       | 28 | 27 | 26 | 25   | 24       | 23    | 22   | 21   | 20    | 19   | 18   | 17       | 16 |
|-------|----------|----|----------|----|----|----|------|----------|-------|------|------|-------|------|------|----------|----|
| R     |          |    |          |    |    |    |      |          | RHCKD | RFSD | RCKD | RHCKP | RFSP | RCKP | RFP[3:0] |    |
| W     |          |    |          |    |    |    |      |          |       |      |      |       |      |      |          |    |
| Reset | 0        | 0  | 0        | 0  | 0  | 0  | 0    | 0        | 0     | 0    | 0    | 0     | 0    | 0    | 0        | 0  |
| Bit   | 15       | 14 | 13       | 12 | 11 | 10 | 9    | 8        | 7     | 6    | 5    | 4     | 3    | 2    | 1        | 0  |
| R     | RFP[3:0] |    | RDC[4:0] |    |    |    | RPSR | RPM[7:0] |       |      |      |       |      |      |          |    |
| W     |          |    |          |    |    |    |      |          |       |      |      |       |      |      |          |    |
| Reset | 0        | 0  | 0        | 0  | 0  | 0  | 0    | 0        | 0     | 0    | 0    | 0     | 0    | 0    | 0        | 0  |

**ESAI\_RCCR field descriptions**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 23<br>RHCKD       | ESAI_RCCR Receiver High Frequency Clock Direction. The Receiver High Frequency Clock Direction (RHCKD) bit selects the source of the receiver high frequency clock when in the asynchronous mode (SYN=0) and the IF2/OF2 flag direction in the synchronous mode (SYN=1).<br><br>In the asynchronous mode, when RHCKD is set, the internal clock generator becomes the source of the receiver high frequency clock and is the output on the HCKR pin. In the asynchronous mode, when RHCKD is cleared, the receiver high frequency clock source is external; the internal clock generator is disconnected from the HCKR pin, and an external clock source may drive this pin.<br><br>When RHCKD is cleared, HCKR is an input; when RHCKD is set, HCKR is an output.<br><br>In the synchronous mode when RHCKD is set, the HCKR pin becomes the OF2 output flag. If RHCKD is cleared, the HCKR pin becomes the IF2 input flag. Refer to <a href="#">Table 25-2</a> and <a href="#">Table 25-41</a> . |
| 22<br>RFSD        | ESAI_RCCR Receiver Frame Sync Signal Direction. The Receiver Frame Sync Signal Direction (RFSD) bit selects the source of the receiver frame sync signal when in the asynchronous mode (SYN=0) and the IF1/OF1/Transmitter Buffer Enable flag direction in the synchronous mode (SYN=1).<br><br>In the asynchronous mode, when RFSD is set, the internal clock generator becomes the source of the receiver frame sync and is the output on the FSR pin. In the asynchronous mode, when RFSD is cleared, the receiver frame sync source is external; the internal clock generator is disconnected from the FSR pin, and an external clock source may drive this pin.<br><br>In the synchronous mode when RFSD is set, the FSR pin becomes the OF1 output flag or the Transmitter Buffer Enable, according to the TEBE control bit. If RFSD is cleared, the FSR pin becomes the IF1 input flag. Refer to <a href="#">Table 25-2</a> and <a href="#">Table 25-40</a> .                               |
| 21<br>RCKD        | ESAI_RCCR Receiver Clock Source Direction. The Receiver Clock Source Direction (RCKD) bit selects the source of the clock signal used to clock the receive shift register in the asynchronous mode (SYN=0) and the IF0/OF0 flag direction in the synchronous mode (SYN=1).<br><br>In the asynchronous mode, when RCKD is set, the internal clock source becomes the bit clock for the receive shift registers and word length divider and is the output on the SCKR pin. In the asynchronous mode when RCKD is cleared, the clock source is external; the internal clock generator is disconnected from the SCKR pin, and an external clock source may drive this pin.<br><br>In the synchronous mode when RCKD is set, the SCKR pin becomes the OF0 output flag. If RCKD is cleared, the SCKR pin becomes the IF0 input flag. Refer to <a href="#">Table 25-2</a> and <a href="#">Table 25-39</a> .                                                                                               |
| 20<br>RHCKP       | ESAI_RCCR Receiver High Frequency Clock Polarity. The Receiver High Frequency Clock Polarity (RHCKP) bit controls on which bit clock edge data and frame sync are clocked out and latched in. If RHCKP is cleared the data and the frame sync are clocked out on the rising edge of the receive high frequency bit clock and the frame sync is latched in on the falling edge of the receive bit clock. If RHCKP is set the falling edge of the receive clock is used to clock the data and frame sync out and the rising edge of the receive clock is used to latch the frame sync in.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 19<br>RFSP        | ESAI_RCCR Receiver Frame Sync Polarity. The Receiver Frame Sync Polarity (RFSP) determines the polarity of the receive frame sync signal. When RFSP is cleared the frame sync signal polarity is positive, that is, the frame start is indicated by a high level on the frame sync pin. When RFSP is set the frame sync signal polarity is negative, that is, the frame start is indicated by a low level on the frame sync pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 18<br>RCKP        | The Receiver Clock Polarity (RCKP) bit controls on which bit clock edge data and frame sync are clocked out and latched in. If RCKP is cleared the data and the frame sync are clocked out on the rising edge of the receive bit clock and the frame sync is latched in on the falling edge of the receive bit clock. If RCKP is set the falling edge of the receive clock is used to clock the data and frame sync out and the rising edge of the receive clock is used to latch the frame sync in.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17–14<br>RFP[3:0] | ESAI_RCCR Rx High Frequency Clock Divider. The RFP3-RFP0 bits control the divide ratio of the receiver high frequency clock to the receiver serial bit clock when the source of the receiver high frequency clock and the bit clock is the internal Arm Core clock. When the HCKR input is being driven                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

*Table continues on the next page...*

**ESAI\_RCCR field descriptions (continued)**

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | from an external high frequency clock, the RFP3-RFP0 bits specify an additional division ration in the clock divider chain. <a href="#">Table 25-38</a> provides the specification of the divide ratio. <a href="#">Figure 25-32</a> shows the ESAI high frequency generator functional diagram.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13–9<br>RDC[4:0] | <p>ESAI_RCCR Rx Frame Rate Divider Control. The RDC4-RDC0 bits control the divide ratio for the programmable frame rate dividers used to generate the receiver frame clocks.</p> <p>In network mode, this ratio may be interpreted as the number of words per frame minus one. The divide ratio may range from 2 to 32 (RDC[4:0]=0x00001 to 0x11111) for network mode. A divide ratio of one (RDC[4:0]=0x00000) in network mode is a special case (on-demand mode).</p> <p>In normal mode, this ratio determines the word transfer rate. The divide ratio may range from 1 to 32 (RDC[4:0]=0x00000 to 0x11111) for normal mode. In normal mode, a divide ratio of one (RDC[4:0]=0x00000) provides continuous periodic data word transfers. A bit-length frame sync (RFSL=1) must be used in this case.</p> <p>The ESAI frame sync generator functional diagram is shown in <a href="#">Figure 25-33</a>.</p> |
| 8<br>RPSR        | ESAI_RCCR Receiver Prescaler Range. The RPSR controls a fixed divide-by-eight prescaler in series with the variable prescaler. This bit is used to extend the range of the prescaler for those cases where a slower bit clock is desired. When RPSR is set, the fixed prescaler is bypassed. When RPSR is cleared, the fixed divide-by-eight prescaler is operational (see <a href="#">Figure 25-32</a> ). The maximum internally generated bit clock frequency is Fsys/4, the minimum internally generated bit clock frequency is Fsys/(2 x 8 x 256 x 16)=Fsys/65536. (Do not use the combination RPSR=1 and RPM7-RPM0 =0x00, which causes synchronization problems when using the internal Core clock as source (RHCKD=1 or RCKD=1))                                                                                                                                                                       |
| RPM[7:0]         | ESAI_RCCR Receiver Prescale Modulus Select. The RPM7-RPM0 bits specify the divide ratio of the prescale divider in the ESAI receiver clock generator. A divide ratio from 1 to 256 (RPM[7:0]=0x00 to 0xFF) may be selected. The bit clock output is available at the receiver serial bit clock (SCKR) pin. The bit clock output is also available internally for use as the bit clock to shift the receive shift registers. The ESAI receive clock generator functional diagram is shown in <a href="#">Figure 25-32</a> .                                                                                                                                                                                                                                                                                                                                                                                   |

## 25.6.18 Transmit Slot Mask Register A (ESAI\_TSMA)

The Transmit Slot Mask Register A together with Transmit Slot Mask Register B (ESAI\_TSMA and ESAI\_TSMB) are two read/write registers used by the transmitters in network mode to determine for each slot whether to transmit a data word and generate a transmitter empty condition (TDE=1), or to tri-state the transmitter data pins. Fields ESAI\_TSMA [TS[15:0]] and ESAI\_TSMB [TS[31:16]] are concatenated to form the 32-bit field TS[31:0]. Bit number n in TS[31:0] is the enable/disable control bit for transmission in slot number n.

Address: 202\_4000h base + E4h offset = 202\_40E4h

| 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 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**ESAI\_TSMA field descriptions**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TS[15:0]          | <p>When bit number N in ESAI_TSMA is cleared, all the transmit data pins of the enabled transmitters are tri-stated during transmit time slot number N. The data is still transferred from the transmit data registers to the transmit shift registers but neither the TDE nor the TUE flags are set. This means that during a disabled slot, no transmitter empty interrupt is generated. The Core is interrupted only for enabled slots. Data that is written to the transmit data registers when servicing this request is transmitted in the next enabled transmit time slot.</p> <p>When bit number N in ESAI_TSMA register is set, the transmit sequence is as usual: data is transferred from the TX registers to the shift registers and transmitted during slot number N, and the TDE flag is set.</p> <p>Using the slot mask in ESAI_TSMA does not conflict with using TSR. Even if a slot is enabled in ESAI_TSMA, the user may choose to write to TSR instead of writing to the transmit data registers TXn. This causes all the transmit data pins of the enabled transmitters to be tri-stated during the next slot.</p> <p>Data written to the ESAI_TSMA affects the next frame transmission. The frame being transmitted is not affected by this data and would comply to the last ESAI_TSMA setting. Data read from ESAI_TSMA returns the last written data.</p> <p>After hardware or software reset, the ESAI_TSMA register is preset to 0x0000FFFF, which means that all 16 possible slots are enabled for data transmission.</p> <p>When operating in normal mode, bit 0 of the ESAI_TSMA register must be set, otherwise no output is generated.</p> |

**25.6.19 Transmit Slot Mask Register B (ESAI\_TSMB)**

The Transmit Slot Mask Register B together with Transmit Slot Mask Register A (ESAI\_TSMA and ESAI\_TSMB) are two read/write registers used by the transmitters in network mode to determine for each slot whether to transmit a data word and generate a transmitter empty condition (TDE=1), or to tri-state the transmitter data pins. Fields ESAI\_TSMA [TS[15:0]] and ESAI\_TSMB [TS[31:16]] are concatenated to form the 32-bit field TS[31:0]. Bit number n in TS[31:0] is the enable/disable control bit for transmission in slot number n.

Address: 202\_4000h base + E8h offset = 202\_40E8h

| 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 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |

**ESAI\_TSMB field descriptions**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| TS[31:16]         | When bit number N in ESAI_TSMB is cleared, all the transmit data pins of the enabled transmitters are tri-stated during transmit time slot number N. The data is still transferred from the transmit data registers to the transmit shift registers but neither the TDE nor the TUE flags are set. This means that during a disabled slot, no transmitter empty interrupt is generated. The Core is interrupted only for enabled slots. Data that is written to the transmit data registers when servicing this request is transmitted in the next enabled transmit time slot.<br><br>When bit number N in ESAI_TSMB register is set, the transmit sequence is as usual: data is transferred from the TX registers to the shift registers and transmitted during slot number N, and the TDE flag is set.<br><br>Using the slot mask in ESAI_TSMB does not conflict with using TSR. Even if a slot is enabled in TSMB, the user may chose to write to TSR instead of writing to the transmit data registers TXn. This causes all the transmit data pins of the enabled transmitters to be tri-stated during the next slot.<br><br>Data written to the ESAI_TSMB affects the next frame transmission. The frame being transmitted is not affected by this data and would comply to the last ESAI_TSMB setting. Data read from ESAI_TSMB returns the last written data.<br><br>After hardware or software reset, the ESAI_TSMB register is preset to 0x0000FFFF, which means that all 16 possible slots are enabled for data transmission. |

**25.6.20 Receive Slot Mask Register A (ESAI\_RSMA)**

The Receive Slot Mask Register A together with Receive Slot Mask Register B (ESAI\_RSMA and ESAI\_RSMB) are two read/write registers used by the receiver in network mode to determine for each slot whether to receive a data word and generate a receiver full condition (RDF=1), or to ignore the received data. Fields ESAI\_RSMA [RS[15:0]] and ESAI\_RSMB [RS31:16] are concatenated to form the 32-bit field RS[31:0]. Bit number n in RS[31:0] is an enable/disable control bit for receiving data in slot number n.

Address: 202\_4000h base + EC offset = 202\_40ECh

| 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 |  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |

**ESAI\_RSMA field descriptions**

| Field             | Description                                                                                                                                                                                                      |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                          |
| RS[15:0]          | When bit number N in the ESAI_RSMA register is cleared, the data from the enabled receivers input pins are shifted into their receive shift registers during slot number N. The data is not transferred from the |

*Table continues on the next page...*

**ESAI\_RSMA field descriptions (continued)**

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p>receive shift registers to the receive data registers, and neither the RDF nor the ROE flag is set. This means that during a disabled slot, no receiver full interrupt is generated. The Core is interrupted only for enabled slots.</p> <p>When bit number N in the ESAI_RSMA is set, the receive sequence is as usual: data which is shifted into the enabled receivers shift registers is transferred to the receive data registers and the RDF flag is set.</p> <p>Data written to the ESAI_RSMA affects the next received frame. The frame being received is not affected by this data and would comply to the last ESAI_RSMA setting. Data read from ESAI_RSMA returns the last written data.</p> <p>After hardware or software reset, the ESAI_RSMA register is preset to 0x0000FFFF, which means that all 16 possible slots are enabled for data reception.</p> <p>When operating in normal mode, bit 0 of the ESAI_RSMA register must be set to one, otherwise no input is received.</p> |

**25.6.21 Receive Slot Mask Register B (ESAI\_RSMB)**

The Receive Slot Mask Register B together with Receive Slot Mask Register A (ESAI\_RSMA and ESAI\_RSMB) are two read/write registers used by the receiver in network mode to determine for each slot whether to receive a data word and generate a receiver full condition (RDF=1), or to ignore the received data. Fields ESAI\_RSMA [RS[15:0]] and ESAI\_RSMB [RS31:16]] are concatenated to form the 32-bit field RS[31:0]. Bit number n in RS[31:0] is an enable/disable control bit for receiving data in slot number n.

Address: 202\_4000h base + F0h offset = 202\_40F0h

| 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 |  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |

**ESAI\_RSMB field descriptions**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| RS[31:16]         | <p>When bit number N in the ESAI_RSMB register is cleared, the data from the enabled receivers input pins are shifted into their receive shift registers during slot number N. The data is not transferred from the receive shift registers to the receive data registers, and neither the RDF nor the ROE flag is set. This means that during a disabled slot, no receiver full interrupt is generated. The Core is interrupted only for enabled slots.</p> <p>When bit number N in the ESAI_RSMB is set, the receive sequence is as usual: data which is shifted into the enabled receivers shift registers is transferred to the receive data registers and the RDF flag is set.</p> |

*Table continues on the next page...*

**ESAI\_RSMB field descriptions (continued)**

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Data written to the ESAI_RSMB affects the next received frame. The frame being received is not affected by this data and would comply to the last ESAI_RSMB setting. Data read from ESAI_RSMB returns the last written data.<br><br>After hardware or software reset, the ESAI_RSMB register is preset to 0x0000FFFF, which means that all 16 possible slots are enabled for data reception. |

**25.6.22 Port C Direction Register (ESAI\_PRRC)**

There are two registers to control the ESAI personal reset status: Port C Direction Register (ESAI\_PRRC) and Port C Control Register (ESAI\_PCRC).

The read/write 32-bit Port C Direction Register (ESAI\_PRRC) in conjunction with the Port C Control Register (ESAI\_PCRC) controls the functionality of the ESAI personal reset state. [Table 25-48](#) provides the port pin configurations. Hardware and software reset clear all ESAI\_PRRC bits.

Address: 202\_4000h base + F8h offset = 202\_40F8h

| 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 |   |   |  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|--|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |   |  |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |   |  |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

**ESAI\_PRRC field descriptions**

| Field             | Description                                                                             |
|-------------------|-----------------------------------------------------------------------------------------|
| 31–12<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0. |
| PDC[11:0]         | See <a href="#">Table 25-48</a> .                                                       |

**25.6.23 Port C Control Register (ESAI\_PCRC)**

The read/write 32-bit Port C Control Register (ESAI\_PCRC) in conjunction with the Port C Direction Register (ESAI\_PRRC) controls the functionality of the ESAI personal reset state. Each of the PC(11:0) bits controls the functionality of the corresponding port pin. [Table 25-48](#) provides the port pin configurations. Hardware and software reset clear all ESAI\_PCRC bits.

**Table 25-48. PCRC and PRRC Bits Functionality**

| PDC[i] | PC[i] | Port Pin[i] Function |
|--------|-------|----------------------|
| 0      | 0     | Disconnected         |
| 1      | 1     | ESAI                 |

Address: 202\_4000h base + FCh offset = 202\_40FCh



### ESAI\_PCRC field descriptions

| Field             | Description                                                                             |
|-------------------|-----------------------------------------------------------------------------------------|
| 31–12<br>Reserved | This field is reserved.<br>This read-only field is reserved and always has the value 0. |
| PC[11:0]          | See <a href="#">Table 25-48</a> .                                                       |