

## 21.6 Applications



Figure 21-14. Flowchart of the ECSPI Operation

## 21.7 ECSPI Memory Map/Register Definition

This section includes the block memory map and detailed descriptions of all registers. For the base address of a particular block instantiation, see the system memory map.

**ECSPI memory map**

| Absolute address (hex) | Register name                                     | Width (in bits) | Access | Reset value | Section/ page                |
|------------------------|---------------------------------------------------|-----------------|--------|-------------|------------------------------|
| 200_8000               | Receive Data Register (ECSPI1_RXDATA)             | 32              | R      | 0000_0000h  | <a href="#">21.7.1/990</a>   |
| 200_8004               | Transmit Data Register (ECSPI1_TXDATA)            | 32              | W      | 0000_0000h  | <a href="#">21.7.2/991</a>   |
| 200_8008               | Control Register (ECSPI1_CONREG)                  | 32              | R/W    | 0000_0000h  | <a href="#">21.7.3/991</a>   |
| 200_800C               | Config Register (ECSPI1_CONFIGREG)                | 32              | R/W    | 0000_0000h  | <a href="#">21.7.4/994</a>   |
| 200_8010               | Interrupt Control Register (ECSPI1_INTREG)        | 32              | R/W    | 0000_0000h  | <a href="#">21.7.5/996</a>   |
| 200_8014               | DMA Control Register (ECSPI1_DMAREG)              | 32              | R/W    | 0000_0000h  | <a href="#">21.7.6/997</a>   |
| 200_8018               | Status Register (ECSPI1_STATREG)                  | 32              | R/W    | 0000_0003h  | <a href="#">21.7.7/999</a>   |
| 200_801C               | Sample Period Control Register (ECSPI1_PERIODREG) | 32              | R/W    | 0000_0000h  | <a href="#">21.7.8/1000</a>  |
| 200_8020               | Test Control Register (ECSPI1_TESTREG)            | 32              | R/W    | 0000_0000h  | <a href="#">21.7.9/1002</a>  |
| 200_8040               | Message Data Register (ECSPI1_MSGDATA)            | 32              | W      | 0000_0000h  | <a href="#">21.7.10/1003</a> |
| 200_C000               | Receive Data Register (ECSPI2_RXDATA)             | 32              | R      | 0000_0000h  | <a href="#">21.7.1/990</a>   |
| 200_C004               | Transmit Data Register (ECSPI2_TXDATA)            | 32              | W      | 0000_0000h  | <a href="#">21.7.2/991</a>   |
| 200_C008               | Control Register (ECSPI2_CONREG)                  | 32              | R/W    | 0000_0000h  | <a href="#">21.7.3/991</a>   |
| 200_C00C               | Config Register (ECSPI2_CONFIGREG)                | 32              | R/W    | 0000_0000h  | <a href="#">21.7.4/994</a>   |
| 200_C010               | Interrupt Control Register (ECSPI2_INTREG)        | 32              | R/W    | 0000_0000h  | <a href="#">21.7.5/996</a>   |
| 200_C014               | DMA Control Register (ECSPI2_DMAREG)              | 32              | R/W    | 0000_0000h  | <a href="#">21.7.6/997</a>   |
| 200_C018               | Status Register (ECSPI2_STATREG)                  | 32              | R/W    | 0000_0003h  | <a href="#">21.7.7/999</a>   |
| 200_C01C               | Sample Period Control Register (ECSPI2_PERIODREG) | 32              | R/W    | 0000_0000h  | <a href="#">21.7.8/1000</a>  |
| 200_C020               | Test Control Register (ECSPI2_TESTREG)            | 32              | R/W    | 0000_0000h  | <a href="#">21.7.9/1002</a>  |
| 200_C040               | Message Data Register (ECSPI2_MSGDATA)            | 32              | W      | 0000_0000h  | <a href="#">21.7.10/1003</a> |
| 201_0000               | Receive Data Register (ECSPI3_RXDATA)             | 32              | R      | 0000_0000h  | <a href="#">21.7.1/990</a>   |
| 201_0004               | Transmit Data Register (ECSPI3_TXDATA)            | 32              | W      | 0000_0000h  | <a href="#">21.7.2/991</a>   |
| 201_0008               | Control Register (ECSPI3_CONREG)                  | 32              | R/W    | 0000_0000h  | <a href="#">21.7.3/991</a>   |
| 201_000C               | Config Register (ECSPI3_CONFIGREG)                | 32              | R/W    | 0000_0000h  | <a href="#">21.7.4/994</a>   |
| 201_0010               | Interrupt Control Register (ECSPI3_INTREG)        | 32              | R/W    | 0000_0000h  | <a href="#">21.7.5/996</a>   |
| 201_0014               | DMA Control Register (ECSPI3_DMAREG)              | 32              | R/W    | 0000_0000h  | <a href="#">21.7.6/997</a>   |
| 201_0018               | Status Register (ECSPI3_STATREG)                  | 32              | R/W    | 0000_0003h  | <a href="#">21.7.7/999</a>   |
| 201_001C               | Sample Period Control Register (ECSPI3_PERIODREG) | 32              | R/W    | 0000_0000h  | <a href="#">21.7.8/1000</a>  |
| 201_0020               | Test Control Register (ECSPI3_TESTREG)            | 32              | R/W    | 0000_0000h  | <a href="#">21.7.9/1002</a>  |
| 201_0040               | Message Data Register (ECSPI3_MSGDATA)            | 32              | W      | 0000_0000h  | <a href="#">21.7.10/1003</a> |
| 201_4000               | Receive Data Register (ECSPI4_RXDATA)             | 32              | R      | 0000_0000h  | <a href="#">21.7.1/990</a>   |
| 201_4004               | Transmit Data Register (ECSPI4_TXDATA)            | 32              | W      | 0000_0000h  | <a href="#">21.7.2/991</a>   |
| 201_4008               | Control Register (ECSPI4_CONREG)                  | 32              | R/W    | 0000_0000h  | <a href="#">21.7.3/991</a>   |
| 201_400C               | Config Register (ECSPI4_CONFIGREG)                | 32              | R/W    | 0000_0000h  | <a href="#">21.7.4/994</a>   |
| 201_4010               | Interrupt Control Register (ECSPI4_INTREG)        | 32              | R/W    | 0000_0000h  | <a href="#">21.7.5/996</a>   |
| 201_4014               | DMA Control Register (ECSPI4_DMAREG)              | 32              | R/W    | 0000_0000h  | <a href="#">21.7.6/997</a>   |

Table continues on the next page...

## ECSPI memory map (continued)

| Absolute address (hex) | Register name                                     | Width (in bits) | Access | Reset value | Section/page |
|------------------------|---------------------------------------------------|-----------------|--------|-------------|--------------|
| 201_4018               | Status Register (ECSPI4_STATREG)                  | 32              | R/W    | 0000_0003h  | 21.7.7/999   |
| 201_401C               | Sample Period Control Register (ECSPI4_PERIODREG) | 32              | R/W    | 0000_0000h  | 21.7.8/1000  |
| 201_4020               | Test Control Register (ECSPI4_TESTREG)            | 32              | R/W    | 0000_0000h  | 21.7.9/1002  |
| 201_4040               | Message Data Register (ECSPI4_MSGDATA)            | 32              | W      | 0000_0000h  | 21.7.10/1003 |
| 201_8000               | Receive Data Register (ECSPI5_RXDATA)             | 32              | R      | 0000_0000h  | 21.7.1/990   |
| 201_8004               | Transmit Data Register (ECSPI5_TXDATA)            | 32              | W      | 0000_0000h  | 21.7.2/991   |
| 201_8008               | Control Register (ECSPI5_CONREG)                  | 32              | R/W    | 0000_0000h  | 21.7.3/991   |
| 201_800C               | Config Register (ECSPI5_CONFIGREG)                | 32              | R/W    | 0000_0000h  | 21.7.4/994   |
| 201_8010               | Interrupt Control Register (ECSPI5_INTREG)        | 32              | R/W    | 0000_0000h  | 21.7.5/996   |
| 201_8014               | DMA Control Register (ECSPI5_DMAREG)              | 32              | R/W    | 0000_0000h  | 21.7.6/997   |
| 201_8018               | Status Register (ECSPI5_STATREG)                  | 32              | R/W    | 0000_0003h  | 21.7.7/999   |
| 201_801C               | Sample Period Control Register (ECSPI5_PERIODREG) | 32              | R/W    | 0000_0000h  | 21.7.8/1000  |
| 201_8020               | Test Control Register (ECSPI5_TESTREG)            | 32              | R/W    | 0000_0000h  | 21.7.9/1002  |
| 201_8040               | Message Data Register (ECSPI5_MSGDATA)            | 32              | W      | 0000_0000h  | 21.7.10/1003 |

## 21.7.1 Receive Data Register (ECSPIx\_RXDATA)

The Receive Data register (ECSPI\_RXDATA) is a read-only register that forms the top word of the 64 x 32 receive FIFO. This register holds the data received from an external SPI device during a data transaction. Only word-sized read operations are allowed.

Address: Base address + 0h offset



### ECSPIx\_RXDATA field descriptions

| Field        | Description                                                                                                                                                                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ECSPI_RXDATA | Receive Data. This register holds the top word of the receive data FIFO. The FIFO is advanced for each read of this register. The data read is undefined when the Receive Data Ready (RR) bit in the Interrupt Control/Status register is cleared. Zeros are read when ECSPI is disabled. |

## 21.7.2 Transmit Data Register (ECSPIx\_TXDATA)

The Transmit Data (ECSPI\_TXDATA) register is a write-only data register that forms the bottom word of the 64 x 32 TXFIFO. The TXFIFO can be written to as long as it is not full, even when the SPI Exchange bit (XCH) in ECSPI\_CONREG is set. This allows software to write to the TXFIFO during a SPI data exchange process. Writes to this register are ignored when the ECSPI is disabled (ECSPI\_CONREG[EN] bit is cleared).

Address: Base address + 4h offset

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

### ECSPIx\_TXDATA field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ECSPI_TXDATA | Transmit Data. This register holds the top word of data loaded into the FIFO. Data written to this register must be a word operation. The number of bits actually transmitted is determined by the BIT_COUNT field of the corresponding SPI Control register. If this field contains more bits than the number specified by BIT_COUNT, the extra bits are ignored. For example, to transfer 10 bits of data, a 32-bit word must be written to this register. Bits 9-0 are shifted out and bits 31-10 are ignored. When the ECSPI is operating in Slave mode, zeros are shifted out when the FIFO is empty. Zeros are read when ECSPI is disabled. |

## 21.7.3 Control Register (ECSPIx\_CONREG)

The Control Register (ECSPI\_CONREG) allows software to enable the ECSPI , configure its operating modes, specify the divider value, and SPI\_RDY control signal, and define the transfer length.

Address: Base address + 8h offset

| Bit          | 31 | 30 | 29 | 28           | 27 | 26 | 25 | 24           | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 |
|--------------|----|----|----|--------------|----|----|----|--------------|----|----|----|-----|-----|----|----|----|
| R            |    |    |    |              |    |    |    |              |    |    |    |     |     |    |    |    |
| BURST_LENGTH |    |    |    |              |    |    |    |              |    |    |    |     |     |    |    |    |
| 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            |    |    |    |              |    |    |    |              |    |    |    |     |     |    |    |    |
| PRE_DIVIDER  |    |    |    | POST_DIVIDER |    |    |    | CHANNEL_MODE |    |    |    | SMC | XCH | HT | EN |    |
| W            |    |    |    |              |    |    |    |              |    |    |    |     |     |    |    |    |
| Reset        | 0  | 0  | 0  | 0            | 0  | 0  | 0  | 0            | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  |

**ECSPIx\_CONREG field descriptions**

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–20<br>BURST_LENGTH   | <p>Burst Length. This field defines the length of a SPI burst to be transferred. The Chip Select (SS) will remain asserted until all bits in a SPI burst are shifted out. A maximum of <math>2^{12}</math> bits can be transferred in a single SPI burst.</p> <p>In master mode, it controls the number of bits per SPI burst. Since the shift register always loads 32-bit data from transmit FIFO, only the n least-significant (<math>n = \text{BURST LENGTH} + 1</math>) will be shifted out. The remaining bits will be ignored.</p> <p>In slave mode, only when SS_CTL is cleared, this field will take effect in the transfer.</p> <p>Number of Valid Bits in a SPI burst.</p> <ul style="list-style-type: none"> <li>0x000 A SPI burst contains the 1 LSB in a word.</li> <li>0x001 A SPI burst contains the 2 LSB in a word.</li> <li>0x002 A SPI burst contains the 3 LSB in a word.</li> <li>...</li> <li>0x01F A SPI burst contains all 32 bits in a word.</li> <li>0x020 A SPI burst contains the 1 LSB in first word and all 32 bits in second word.</li> <li>0x021 A SPI burst contains the 2 LSB in first word and all 32 bits in second word.</li> <li>...</li> <li>0xFFE A SPI burst contains the 31 LSB in first word and <math>2^{7}-1</math> words.</li> <li>0xFFFF A SPI burst contains <math>2^7</math> words.</li> </ul> |
| 19–18<br>CHANNEL_SELECT | <p>SPI CHANNEL SELECT bits. Select one of four external SPI Master/Slave Devices. In master mode, these two bits select the external slave devices by asserting the Chip Select (SSn) outputs. Only the selected Chip Select (SSn) signal can be active at a given time; the remaining three signals will be negated.</p> <ul style="list-style-type: none"> <li>00 Channel 0 is selected. Chip Select 0 (SS0) will be asserted.</li> <li>01 Channel 1 is selected. Chip Select 1 (SS1) will be asserted.</li> <li>10 Channel 2 is selected. Chip Select 2 (SS2) will be asserted.</li> <li>11 Channel 3 is selected. Chip Select 3 (SS3) will be asserted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 17–16<br>DRCTL          | <p>SPI Data Ready Control. This field selects the utilization of the SPI_RDY signal in master mode. ECSPI checks this field before it starts an SPI burst.</p> <ul style="list-style-type: none"> <li>00 The SPI_RDY signal is a don't care.</li> <li>01 Burst will be triggered by the falling edge of the SPI_RDY signal (edge-triggered).</li> <li>10 Burst will be triggered by a low level of the SPI_RDY signal (level-triggered).</li> <li>11 Reserved.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15–12<br>PRE_DIVIDER    | <p>SPI Pre Divider. ECSPI uses a two-stage divider to generate the SPI clock. This field defines the pre-divider of the reference clock.</p> <ul style="list-style-type: none"> <li>0000 Divide by 1.</li> <li>0001 Divide by 2.</li> <li>0010 Divide by 3.</li> <li>...</li> <li>1101 Divide by 14.</li> <li>1110 Divide by 15.</li> <li>1111 Divide by 16.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 11–8<br>POST_DIVIDER    | <p>SPI Post Divider. ECSPI uses a two-stage divider to generate the SPI clock. This field defines the post-divider of the reference clock using the equation: <math>2^n</math>.</p> <ul style="list-style-type: none"> <li>0000 Divide by 1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

**ECSPIx\_CONREG field descriptions (continued)**

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>0001 Divide by 2.<br/>     0010 Divide by 4.<br/>     ...<br/>     1110 Divide by <math>2^{14}</math>.<br/>     1111 Divide by <math>2^{15}</math>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7–4 CHANNEL_MODE | <p>SPI CHANNEL MODE selects the mode for each SPI channel.<br/>     CHANNEL MODE[3] is for SPI channel 3.<br/>     CHANNEL MODE[2] is for SPI channel 2.<br/>     CHANNEL MODE[1] is for SPI channel 1.<br/>     CHANNEL MODE[0] is for SPI channel 0.</p> <p>0 Slave mode.<br/>     1 Master mode.</p>                                                                                                                                                                                                                                                                                                                     |
| 3 SMC            | <p>Start Mode Control. This bit applies only to channels configured in Master mode (CHANNEL MODE = 1). It controls how the ECSPI starts a SPI burst, either through the SPI exchange bit, or immediately when the TXFIFO is written to.</p> <p>0 SPI Exchange Bit (XCH) controls when a SPI burst can start. Setting the XCH bit will start a SPI burst or multiple bursts. This is controlled by the SPI SS Wave Form Select (SS_CTL). Refer to XCH and SS_CTL descriptions.<br/>     1 Immediately starts a SPI burst when data is written in TXFIFO.</p>                                                                 |
| 2 XCH            | <p>SPI Exchange Bit. This bit applies only to channels configured in Master mode (CHANNEL MODE = 1). If the Start Mode Control (SMC) bit is cleared, writing a 1 to this bit starts one SPI burst or multiple SPI bursts according to the SPI SS Wave Form Select (SS_CTL). The XCH bit remains set while either the data exchange is in progress, or when the ECSPI is waiting for an active input if SPIRDY is enabled through DRCTL. This bit is cleared automatically when all data in the TXFIFO and the shift register has been shifted out.</p> <p>0 Idle.<br/>     1 Initiates exchange (write) or busy (read).</p> |
| 1 HT             | <p>Hardware Trigger Enable. This bit is used in master mode only. It enables hardware trigger (HT) mode. Note, HT mode is not supported by this product.</p> <p>0 Disable HT mode.<br/>     1 Enable HT mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0 EN             | <p>SPI Block Enable Control. This bit enables the ECSPI. This bit must be set before writing to other registers or initiating an exchange. Writing zero to this bit disables the block and resets the internal logic with the exception of the ECSPI_CONREG. The block's internal clocks are gated off whenever the block is disabled.</p> <p>0 Disable the block.<br/>     1 Enable the block.</p>                                                                                                                                                                                                                         |

## 21.7.4 Config Register (ECSPIx\_CONFIGREG)

The Config Register (ECSPI\_CONFIGREG) allows software to configure each SPI channel, configure its operating modes, specify the phase and polarity of the clock, configure the Chip Select (SS), and define the HT transfer length. Note, HT mode is not supported by this product.

Address: Base address + Ch offset

| 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   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SS_POL |    | SS_CTL |    | SCLK_POL |    | SCLK_PHA |   |   |   |   |   |   |   |   |   |
| 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 |   |

### ECSPIx\_CONFIGREG field descriptions

| Field              | Description                                                                                                                                                                                                                                                                    |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–29<br>-         | This field is reserved.<br>Reserved                                                                                                                                                                                                                                            |
| 28–24<br>HT_LENGTH | HT LENGTH. This field defines the message length in HT Mode. Note, HT mode is not supported by this product.<br><br>The length in bits of one message is (HT LENGTH + 1).                                                                                                      |
| 23–20<br>SCLK_CTL  | SCLK CTL. This field controls the inactive state of SCLK for each SPI channel.<br><br>SCLK CTL[3] is for SPI channel 3.<br>SCLK CTL[2] is for SPI channel 2.<br>SCLK CTL[1] is for SPI channel 1.<br>SCLK CTL[0] is for SPI channel 0.<br><br>0 Stay low.<br>1 Stay high.      |
| 19–16<br>DATA_CTL  | DATA CTL. This field controls inactive state of the data line for each SPI channel.<br><br>DATA CTL[3] is for SPI channel 3.<br>DATA CTL[2] is for SPI channel 2.<br>DATA CTL[1] is for SPI channel 1.<br>DATA CTL[0] is for SPI channel 0.<br><br>0 Stay high.<br>1 Stay low. |
| 15–12<br>SS_POL    | SPI SS Polarity Select. In both Master and Slave modes, this field selects the polarity of the Chip Select (SS) signal.<br><br>SS POL[3] is for SPI channel 3.<br>SS POL[2] is for SPI channel 2.<br>SS POL[1] is for SPI channel 1.<br>SS POL[0] is for SPI channel 0.        |

Table continues on the next page...

**ECSPIx\_CONFIGREG field descriptions (continued)**

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | <p>0 Active low.<br/>1 Active high.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11–8 SS_CTL  | <p>SPI SS Wave Form Select. In master mode, this field controls the output wave form of the Chip Select (SS) signal when the SMC (Start Mode Control) bit is cleared. The SS_CTL are ignored if the SMC bit is set.</p> <p>SS CTL[3] is for SPI channel 3.<br/>SS CTL[2] is for SPI channel 2.<br/>SS CTL[1] is for SPI channel 1.<br/>SS CTL[0] is for SPI channel 0.</p> <p>In slave mode, this bit controls when the SPI burst is completed.</p> <p>An SPI burst is completed by the Chip Select (SS) signal edges. (SSPOL = 0: rising edge; SSPOL = 1: falling edge) The RXFIFO is advanced whenever a Chip Select (SS) signal edge is detected or the shift register contains 32-bits of valid data.</p> <ul style="list-style-type: none"> <li>0 In master mode - only one SPI burst will be transmitted.</li> <li>1 In master mode - Negate Chip Select (SS) signal between SPI bursts. Multiple SPI bursts will be transmitted. The SPI transfer will automatically stop when the TXFIFO is empty.</li> <li>0 In slave mode - an SPI burst is completed when the number of bits received in the shift register is equal to (BURST LENGTH + 1). Only the n least-significant bits (n = BURST LENGTH[4:0] + 1) of the first received word are valid. All bits subsequent to the first received word in RXFIFO are valid.</li> <li>1 In slave mode - an SPI burst is completed by the Chip Select (SS) signal edges. (SSPOL = 0: rising edge; SSPOL = 1: falling edge) The RXFIFO is advanced whenever a Chip Select (SS) signal edge is detected or the shift register contains 32-bits of valid data.</li> </ul> |
| 7–4 SCLK_POL | <p>SPI Clock Polarity Control. This field controls the polarity of the SCLK signal. See <a href="#">Figure 21-10</a> for more information.</p> <p>SCLK_POL[3] is for SPI channel 3.<br/>SCLK_POL[2] is for SPI channel 2.<br/>SCLK_POL[1] is for SPI channel 1.<br/>SCLK_POL[0] is for SPI channel 0.</p> <ul style="list-style-type: none"> <li>0 Active high polarity (0 = Idle).</li> <li>1 Active low polarity (1 = Idle).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| SCLK_PHA     | <p>SPI Clock/Data Phase Control. This field controls the clock/data phase relationship. See <a href="#">Figure 21-10</a> for more information.</p> <p>SCLK PHA[3] is for SPI channel 3.<br/>SCLK PHA[2] is for SPI channel 2.<br/>SCLK PHA[1] is for SPI channel 1.<br/>SCLK PHA[0] is for SPI channel 0.</p> <ul style="list-style-type: none"> <li>0 Phase 0 operation.</li> <li>1 Phase 1 operation.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

## 21.7.5 Interrupt Control Register (ECSPIx\_INTREG)

The Interrupt Control Register (ECSPI\_INTREG) enables the generation of interrupts to the host processor. If the ECSPI is disabled, this register reads zero.

Address: Base address + 10h offset



**ECSPIx\_INTREG field descriptions**

| Field      | Description                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8<br>-  | This field is reserved.<br>Reserved                                                                                                                                                               |
| 7<br>TCEN  | Transfer Completed Interrupt enable. This bit enables the Transfer Completed Interrupt.<br><br>0 Disable<br>1 Enable                                                                              |
| 6<br>ROEN  | RXFIFO Overflow Interrupt enable. This bit enables the RXFIFO Overflow Interrupt.<br><br>0 Disable<br>1 Enable                                                                                    |
| 5<br>RFEN  | RXFIFO Full Interrupt enable. This bit enables the RXFIFO Full Interrupt.<br><br>0 Disable<br>1 Enable                                                                                            |
| 4<br>RDREN | RXFIFO Data Request Interrupt enable. This bit enables the RXFIFO Data Request Interrupt when the number of data entries in the RXFIFO is greater than RX_THRESHOLD.<br><br>0 Disable<br>1 Enable |
| 3<br>RREN  | RXFIFO Ready Interrupt enable. This bit enables the RXFIFO Ready Interrupt.<br><br>0 Disable<br>1 Enable                                                                                          |

*Table continues on the next page...*

**ECSPIx\_INTREG field descriptions (continued)**

| Field      | Description                                                                                                                                                                                                |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>TFEN  | TXFIFO Full Interrupt enable. This bit enables the TXFIFO Full Interrupt.<br><br>0 Disable<br>1 Enable                                                                                                     |
| 1<br>TDREN | TXFIFO Data Request Interrupt enable. This bit enables the TXFIFO Data Request Interrupt when the number of data entries in the TXFIFO is less than or equal to TX_THRESHOLD.<br><br>0 Disable<br>1 Enable |
| 0<br>TEEN  | TXFIFO Empty Interrupt enable. This bit enables the TXFIFO Empty Interrupt.<br><br>0 Disable<br>1 Enable                                                                                                   |

**21.7.6 DMA Control Register (ECSPIx\_DMAREG)**

The Direct Memory Access Control Register (ECSPI\_DMAREG) provides software a way to use an on-chip DMA controller for ECSPI data. Internal DMA request signals enable direct data transfers between the ECSPI FIFOs and system memory. The ECSPI sends out DMA requests when the appropriate FIFO conditions are matched.

If the ECSPI is disabled, this register is read as 0.

Address: Base address + 14h offset

| Bit   | 31     | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------|----------|----|----|----|----|----|----|-------|----------|----|----|----|----|----|----|
| R     |        |          |    |    |    |    |    |    |       |          |    |    |    |    |    |    |
|       | RXTDEN | Reserved |    |    |    |    |    |    | RXDEN | Reserved |    |    |    |    |    |    |
| 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     |        |          |    |    |    |    |    |    |       |          |    |    |    |    |    |    |
|       |        |          |    |    |    |    |    |    | TEDEN | Reserved |    |    |    |    |    |    |
| W     |        |          |    |    |    |    |    |    |       |          |    |    |    |    |    |    |
| Reset | 0      | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0        | 0  | 0  | 0  | 0  | 0  | 0  |

**ECSPIx\_DMAREG field descriptions**

| Field                  | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>RXTDEN           | RXFIFO TAIL DMA Request Enable. This bit enables an internal counter that is increased at each read of the RXFIFO. This counter is cleared automatically when it reaches RX DMA LENGTH. If the number of words remaining in the RXFIFO is greater than or equal to RX DMA LENGTH, a DMA request is generated even if it is less than or equal to RX_THRESHOLD.<br><br>0 Disable<br>1 Enable |
| 30<br>-                | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                         |
| 29–24<br>RX_DMA_LENGTH | RX DMA LENGTH. This field defines the burst length of a DMA operation. Applies only when RXTDEN is set.                                                                                                                                                                                                                                                                                     |
| 23<br>RXDEN            | RXFIFO DMA Request Enable. This bit enables/disables the RXFIFO DMA Request.<br><br>0 Disable<br>1 Enable                                                                                                                                                                                                                                                                                   |
| 22<br>-                | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                         |
| 21–16<br>RX_THRESHOLD  | RX THRESHOLD. This field defines the FIFO threshold that triggers a RX DMA/INT request.<br><br>A RX DMA/INT request is issued when the number of data entries in the RXFIFO is greater than RX_THRESHOLD.                                                                                                                                                                                   |
| 15–8<br>-              | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                         |
| 7<br>TEDEN             | TXFIFO Empty DMA Request Enable. This bit enables/disables the TXFIFO Empty DMA Request.<br><br>0 Disable<br>1 Enable                                                                                                                                                                                                                                                                       |
| 6<br>-                 | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                         |
| TX_THRESHOLD           | TX THRESHOLD. This field defines the FIFO threshold that triggers a TX DMA/INT request.<br><br>A TX DMA/INT request is issued when the number of data entries in the TXFIFO is greater than TX_THRESHOLD.                                                                                                                                                                                   |

## 21.7.7 Status Register (ECSPIx\_STATREG)

The ECSPI Status Register (ECSPI\_STATREG) reflects the status of the ECSPI's operating condition. If the ECSPI is disabled, this register reads 0x0000\_0003.

Address: Base address + 18h offset

| 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     |    |    |    |    |    |    |    |    | TC  | RO  | RF | RDR | RR | TF | TDR | TE |
| W     |    |    |    |    |    |    |    |    | w1c | w1c |    |     |    |    |     |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0   | 0  | 0  | 1   | 1  |

### ECSPIx\_STATREG field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8<br>- | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7<br>TC   | Transfer Completed Status bit. Writing 1 to this bit clears it.<br><br>0 Transfer in progress.<br>1 Transfer completed.                                                                                                                                                                                                                                                                                                                                     |
| 6<br>RO   | RXFIFO Overflow. When set, this bit indicates that RXFIFO has overflowed. Writing 1 to this bit clears it.<br><br>0 RXFIFO has no overflow.<br>1 RXFIFO has overflowed.                                                                                                                                                                                                                                                                                     |
| 5<br>RF   | RXFIFO Full. This bit is set when the RXFIFO is full.<br><br>0 Not Full.<br>1 Full.                                                                                                                                                                                                                                                                                                                                                                         |
| 4<br>RDR  | RXFIFO Data Request.<br><br>0 When RXTDE is set - Number of data entries in the RXFIFO is not greater than RX_THRESHOLD.<br>1 When RXTDE is set - Number of data entries in the RXFIFO is greater than RX_THRESHOLD or a DMA TAIL DMA condition exists.<br><br>0 When RXTDE is clear - Number of data entries in the RXFIFO is not greater than RX_THRESHOLD.<br>1 When RXTDE is clear - Number of data entries in the RXFIFO is greater than RX_THRESHOLD. |
| 3<br>RR   | RXFIFO Ready. This bit is set when one or more words are stored in the RXFIFO.<br><br>0 No valid data in RXFIFO.<br>1 More than 1 word in RXFIFO.                                                                                                                                                                                                                                                                                                           |
| 2<br>TF   | TXFIFO Full. This bit is set when if the TXFIFO is full.                                                                                                                                                                                                                                                                                                                                                                                                    |

Table continues on the next page...

**ECSPIx\_STATREG field descriptions (continued)**

| Field | Description                                                                                                                                                    |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 0 TXFIFO is not Full.<br>1 TXFIFO is Full.                                                                                                                     |
| 1 TDR | TXFIFO Data Request.<br>0 Number of empty slots in TXFIFO is greater than TX_THRESHOLD.<br>1 Number of empty slots in TXFIFO is not greater than TX_THRESHOLD. |
| 0 TE  | TXFIFO Empty. This bit is set if the TXFIFO is empty.<br>0 TXFIFO contains one or more words.<br>1 TXFIFO is empty.                                            |

**21.7.8 Sample Period Control Register (ECSPIx\_PERIODREG)**

The Sample Period Control Register (ECSPI\_PERIODREG) provides software a way to insert delays (wait states) between consecutive SPI transfers. Control bits in this register select the clock source for the sample period counter and the delay count indicating the number of wait states to be inserted between data transfers.

The delay counts apply only when the current channel is operating in Master mode (ECSPI\_CONREG[CHANNEL MODE] = 1). ECSPI\_PERIODREG also contains the CSD CTRL field used to insert a delay between the Chip Select's active edge and the first SPI Clock edge.

Address: Base address + 1Ch offset

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

**ECSPIx\_PERIODREG field descriptions**

| Field      | Description                         |
|------------|-------------------------------------|
| 31–22<br>- | This field is reserved.<br>Reserved |

*Table continues on the next page...*

**ECSPIx\_PERIODREG field descriptions (continued)**

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21–16<br>CSD_CTL | Chip Select Delay Control bits. This field defines how many SPI clocks will be inserted between the chip select's active edge and the first SPI clock edge. The range is from 0 to 63.                                                                                                                                                                                                              |
| 15<br>CSRC       | Clock Source Control. This bit selects the clock source for the sample period counter.<br>0 SPI Clock (SCLK)<br>1 Low-Frequency Reference Clock (32.768 KHz)                                                                                                                                                                                                                                        |
| SAMPLE_PERIOD    | Sample Period Control. These bits control the number of wait states to be inserted in data transfers. During the idle clocks, the state of the SS output will operate according to the SS_CTL control field in the ECSPI_CONREG register.<br><br>0x0000 0 wait states inserted<br>0x0001 1 wait state inserted<br>... ...<br>0x7FFE 32766 wait states inserted<br>0x7FFF 32767 wait states inserted |

## 21.7.9 Test Control Register (ECSPIx\_TESTREG)

The Test Control Register (ECSPI\_TESTREG) provides software a mechanism to internally connect the receive and transmit devices of the ECSPI, and monitor the contents of the receive and transmit FIFOs.

Address: Base address + 20h offset



**ECSPIx\_TESTREG field descriptions**

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LBC     | Loop Back Control. This bit is used in Master mode only. When this bit is set, the ECSPI connects the transmitter and receiver sections internally, and the data shifted out from the most-significant bit of the shift register is looped back into the least-significant bit of the Shift register. In this way, a self-test of the complete transmit/receive path can be made. The output pins are not affected, and the input pins are ignored.<br><br>0 Not connected.<br>1 Transmitter and receiver sections internally connected for Loopback. |
| 30–28<br>-    | This field is reserved.<br>Reserved, all bits should be ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 27–15<br>-    | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 14–8<br>RXCNT | RXFIFO Counter. This field indicates the number of words in the RXFIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

*Table continues on the next page...*

**ECSPIx\_TESTREG field descriptions (continued)**

| Field  | Description                                                             |
|--------|-------------------------------------------------------------------------|
| 7<br>- | This field is reserved.<br>Reserved                                     |
| TXCNT  | TXFIFO Counter. This field indicates the number of words in the TXFIFO. |

**21.7.10 Message Data Register (ECSPIx\_MSGDATA)**

The Message Data Register (ECSPI\_MSGDATA) forms the top word of the 16 x 32 MSG Data FIFO. Only word-size accesses are allowed for this register. Reads to this register return zero, and writes to this register store data in the MSG Data FIFO.

Address: Base address + 40h offset

**ECSPIx\_MSGDATA field descriptions**

| Field         | Description                                                                                                                                                                                                |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ECSPI_MSGDATA | ECSPI_MSGDATA holds the top word of MSG Data FIFO. The MSG Data FIFO is advanced for each write of this register. The data read is zero. The data written to this register is stored in the MSG Data FIFO. |

