# 32-bit RISC Microcontroller

# TXZ+ Family

# Reference Manual Serial Peripheral Interface (TSPI-E)

**Revision 1.3** 

# 2023-03

# **TOSHIBA ELECTRONIC DEVICES & STORAGE CORPORATION**

TOSHIBA

# TOSHIBA

# Contents

| Preface                                                      | 7  |
|--------------------------------------------------------------|----|
| Related Document                                             | 7  |
| Conventions                                                  |    |
| Terms and Abbreviation                                       |    |
| 1. Outline                                                   |    |
| 2 Configuration                                              | 20 |
| 3 Operation Description                                      |    |
| 2.1. Papia Operation                                         | 22 |
|                                                              |    |
| 3.1.1. Clock Supply                                          |    |
| 3.1.2. Start and Stop Transfer                               |    |
| 3.2. Transfer Clock                                          |    |
| 3.2.1. Transfer Clock Frequency                              |    |
| 3.2.1.1. Master operation                                    |    |
| 3.2.1.2. Generating condition of the transfer clock          |    |
| 3.2. Communication Mode                                      |    |
|                                                              |    |
| 3.3.1. SPI / SIO Mode Selection                              |    |
| 3.3.2. Master / Slave Selection                              |    |
| 3.3.3. Frame / Sector selection                              |    |
| 3.4. Communication Operation Mode                            |    |
| 3.4.1. Transmit and receive (Full-Duplex) Communication Mode |    |
| 3.4.2. Transmit Mode                                         |    |
| 3.4.3. Receive Mode                                          | 31 |
| 3.5. Transfer Mode                                           |    |
| 3.5.1. Burst Transfer                                        |    |
| 3.5.2. Continuously Transfer                                 |    |
| 3.6. Data format                                             |    |
| 3.6.1. Frame mode                                            |    |
| 3.6.1.1. Buffer Structure and Operation                      | 35 |
| 3.6.1.2. Frame mode operation 1 (No parity, MSB first)       |    |
| 3.6.1.3. Frame mode operation 2 (No parity, LSB first)       |    |
| 3.6.1.4. Frame mode operation 3 (with parity, MSB first)     |    |
| 3.6.1.5. Frame mode operation 4 (with parity, LSB first)     |    |
| 3.6.1.6. Transfer cycle for master operations                | 40 |
| 3.6.2. Sector mode                                           | 41 |
| 3.6.2.1. Buffer Structure and Operation                      |    |
| 3.6.2.2. Sector mode operation 1 (No parity, MSB first)      |    |
| 3.6.2.3. Sector mode operation 2 (No parity, LSB first)      |    |
| 3.6.2.4. Sector mode operation 3 (with parity, MSB first)    |    |
| 3.6.2.5. Sector mode operation 4 (with parity, LSB first)    |    |
| 3.6.2.6. Transfer cycle for master operations                |    |
| 3.7. Interrupt Request                                       |    |

# TOSHIBA

|    | 3.7.1. Transmit Completion Interrupt / Receive Completion Interrupt   | 51 |
|----|-----------------------------------------------------------------------|----|
|    | 3.7.2. Transmit FIFO Interrupt / Receive FIFO Interrupt               | 51 |
|    | 3.7.3. Error Interrupt                                                | 51 |
|    | 3.8. DMA Request                                                      | 53 |
|    | 3.8.1. Transmit                                                       | 53 |
|    | 3.8.2. Receive                                                        | 53 |
| ;  | 3.9. Trigger Control                                                  | 54 |
|    | 3.9.1. Communication Start Trigger                                    | 54 |
|    | 3.9.2. Communication Complete Trigger                                 | 55 |
|    | 3.10. Special Control                                                 | 55 |
|    | 3.10.1. Polarity of Serial Clock                                      | 55 |
|    | 3.10.2. TSPIxTXD Output during Idle Period                            | 55 |
|    | 3.10.3. TXD last data hold period                                     | 57 |
|    | 3.10.4. RXD sampling timing                                           | 57 |
|    | 3.10.5. CS timing and polarity                                        | 61 |
|    | 3.10.6. Software Reset                                                | 61 |
| 4. | Registers                                                             | 62 |
| 4  | 4.1. Register List                                                    | 62 |
| 4  | 4.2. Detail of Register                                               | 63 |
|    | 4.2.1. [TSPIxCR0] (TSPI Control Register 0)                           | 63 |
|    | 4.2.2. [TSPIxCR1] (TSPI Control Register 1)                           | 64 |
|    | 4.2.3. [TSPIxCR2] (TSPI Control Register 2)                           | 65 |
|    | 4.2.4. [TSPIxCR3] (TSPI Control Register 3)                           | 66 |
|    | 4.2.5. [TSPIxBR] (TSPI Baud Rate Register)                            | 67 |
|    | 4.2.6. [TSPIxFMTR0] (TSPI Format Control Register 0)                  | 67 |
|    | 4.2.7. [TSPIxFMTR1] (TSPI Format Control Register 1)                  | 69 |
|    | 4.2.8. [TSPIxSECTCR0] (TSPI Sector Mode Control Register 0)           | 69 |
|    | 4.2.9. [TSPIxSECTCR1] (TSPI Sector Mode Control Register 1)           | 70 |
|    | 4.2.10. [TSPIxDR] (TSPI Data Register)                                | 70 |
|    | 4.2.11. [TSPIxSR] (TSPI Status Register)                              | 71 |
|    | 4.2.12. [TSPIxERR] (TSPI Error Flag Register)                         | 74 |
| 5. | Example for use                                                       | 76 |
| į  | 5.1. List of Available Operations for Each Mode                       | 76 |
| ļ  | 5.2. Starting / Stopping Transfer in Flame Mode                       | 77 |
|    | 5.2.1. Activating the Start Communication trigger in master operation | 77 |
|    | 5.2.2. Software activation in master operation                        | 78 |
|    | 5.2.3. Software activation in slave operation                         | 79 |
| ļ  | 5.3. Starting / Stopping Transfer in Sector Mode                      | 81 |
|    | 5.3.1. Activating the Start Communication trigger in master operation | 81 |
|    | 5.3.2. Software activation in master operation                        | 82 |
|    | 5.3.3. Software activation in slave operation                         | 83 |
| 6. | Precautions                                                           | 84 |
| 7. | Revision History                                                      | 85 |
|    |                                                                       |    |

| ESTRICTIONS ON PRODUCT USE | 36 |
|----------------------------|----|
|                            |    |

# List of Figures

| Figure 2.1  | Block diagram of TSPI                                                       | . 20 |
|-------------|-----------------------------------------------------------------------------|------|
| Figure 3.1  | Transfer clock generation circuit                                           | . 23 |
| Figure 3.2  | Operation example of transmit and receive(full-duplex) communication        | . 28 |
| Figure 3.3  | Operation example of transmit mode                                          | . 30 |
| Figure 3.4  | Operation example in receive mode                                           | . 31 |
| Figure 3.5  | Data format overview for the frame mode                                     | . 34 |
| Figure 3.6  | Buffer operation in Frame mode (No Parity / MSB first)                      | . 36 |
| Figure 3.7  | Buffer Operation in Frame mode (No Parity / LSB First)                      | . 37 |
| Figure 3.8  | Buffer operation in frame mode (with parity, MSB first)                     | . 38 |
| Figure 3.9  | Buffer operation of the frame mode (with parity, LSB first)                 | . 39 |
| Figure 3.10 | Data Format Overview for the Sector Mode                                    | . 41 |
| Figure 3.11 | Buffer operation of the sector mode (No parity, MSB first)                  | . 43 |
| Figure 3.12 | Buffer operation of the sector mode (No parity, LSB first)                  | . 44 |
| Figure 3.13 | Buffer operation of the sector mode (with parity, MSB first)                | . 45 |
| Figure 3.14 | Buffer operation of the sector mode (with parity, LSB first)                | . 46 |
| Figure 3.15 | Timing for cycle generation between sectors (sector mode, master operation) | . 47 |
| Figure 3.16 | Interrupt request Circuit                                                   | . 50 |
| Figure 3.17 | Overrun error and underrun error                                            | . 52 |
| Figure 3.18 | Idle period in SPI mode and the transmit pin status                         | . 56 |
| Figure 3.19 | Idle period in SIO mode and the transmit pin status                         | . 56 |
| Figure 3.20 | Data sampling timing of SPI mode (master)                                   | . 58 |
| Figure 3.21 | Data sampling timing SPI mode (slave)                                       | . 59 |
| Figure 3.22 | Data sampling timing of SIO mode (master)                                   | . 60 |
| Figure 3.23 | Data sampling timing of SIO mode (Slave)                                    | . 60 |
| Figure 3.24 | Transfer format and timing adjustment (Example for 2nd edge sampling)       | . 61 |
|             |                                                                             |      |

# List of Tables

| Table 1.1  | Functional outline (frame mode, sector mode)                                                 | . 11  |
|------------|----------------------------------------------------------------------------------------------|-------|
| Table 1.2  | Function outline (SPI mode, Master, Frame)                                                   | 12    |
| Table 1.3  | Function outline (SPI mode, Slave, Frame)                                                    | . 13  |
| Table 1.4  | Function outline (SIO mode, Master, Frame)                                                   | . 14  |
| Table 1.5  | Function outline (SIO mode, Slave, Frame)                                                    | . 15  |
| Table 1.6  | Functions Outline (SPI mode, Master, Sector)                                                 | . 16  |
| Table 1.7  | Functions Overview (SPI mode, Slave, Sector)                                                 | . 17  |
| Table 1.8  | Functions Overview (SIO mode, Master, Sector)                                                | . 18  |
| Table 1.9  | Functions Overview (SIO mode, Slave, Sector)                                                 | . 19  |
| Table 2.1  | List of Signals                                                                              | . 21  |
| Table 3.1  | Transfer clock generation example                                                            | . 24  |
| Table 3.2  | Condition for generating a transfer clock and the register configuration value               | . 25  |
| Table 3.3  | Conditions of a transfer clock for slave operation(2nd edge)                                 | . 26  |
| Table 3.4  | Communication modes and the specifications for the compatible operations                     | . 26  |
| Table 3.5  | Transfer mode compatibility                                                                  | . 32  |
| Table 3.6  | Frame mode settable fill level                                                               | 35    |
| Table 3.7  | Data format examples for the frame mode                                                      | . 35  |
| Table 3.8  | Example of transfer cycles for master operation (frame mode)                                 | . 40  |
| Table 3.9  | Settable fill level in Sector mode                                                           | 42    |
| Table 3 10 | Data format examples for the Sector mode                                                     | 42    |
| Table 3 11 | Operation specification following sector transfer during a master operation                  | 47    |
| Table 3 12 | Example of transfer cycles (sector mode, master operation)                                   | 48    |
| Table 3 13 | Interrupt factors and requests                                                               | 50    |
| Table 3.14 | Configurable modes for communication start trigger                                           | . 54  |
| Table 3 15 | TSPIxTXD Output during Idle Period                                                           | 55    |
| Table 3 16 | Communication modes and the availabilities of the RXD sampling timing                        | 57    |
| Table 3 17 | Data capture timing                                                                          | 57    |
| Table 4 1  | Initialized registers by software reset                                                      | 63    |
| Table 4.2  | Transfer state and setting enabled state flag at communication stop setting                  | 73    |
| Table 4.3  | Display range of Fill level status                                                           | 73    |
| Table 4.4  | Transmit FIFO and the transmit status                                                        | 73    |
| Table 4.5  | Receive FIFO and the receive status                                                          | 74    |
| Table 4.6  | Processing an underrun error                                                                 | 75    |
| Table 4 7  | Processing an overrun error                                                                  | 75    |
| Table 5.1  | List of available operations for each mode (Activation method, RXD data sampling)            | 76    |
| Table 52   | Starting / Stopping transfer in Frame mode (master operation activating the S                | Start |
| Comm       | unication trigger)                                                                           | 77    |
| Table 5.3  | Start/Stop transfer in the frame mode (master operation using software activation)           | 78    |
| Table 5.4  | Start/Stop transfer in the frame mode (slave operation, using software activation) (1)       | 79    |
| Table 5.5  | Start/Stop transfer in the frame mode (slave operation, using software activation) (2)       | 80    |
| Table 5.6  | Starting / Stopping transfer in the sector mode (master operation activate the S             | Start |
| Comm       | unication trigger)                                                                           | 81    |
| Table 5.7  | Starting / Stopping transfer in the sector mode (master operation using software activat     | ion)  |
|            |                                                                                              |       |
| Table 5.8  | Starting / Stopping transfer in the sector mode (slave operation, using software activation) | . 83  |
| Table 7.1  | Revision History                                                                             | . 85  |
|            |                                                                                              |       |

# Preface

## **Related Document**

| Document Name                    |  |
|----------------------------------|--|
| Clock Control and Operation Mode |  |

Exception

Input/Output Ports

Product Information

### Conventions

TOSHIBA

- Numeric formats follow the rules as shown below:
  - Hexadecimal: 0xABC

Decimal:123 or 0d123 – Only when it needs to be explicitly shown that they are decimal numbers.Binary:0b111 – It is possible to omit the "0b" when the number of bit can be distinctlyunderstood from a sentence.

- "\_N" is added to the end of signal names to indicate low active signals.
- It is called "assert" that a signal moves to its active level, "deassert" to its inactive level.
- When two or more signal names are referred, they are described like as [m: n]. Example: S[3: 0] shows four signal names S3, S2, S1 and S0 together.
- The characters surrounded by [] defines the register. Example: [ABCD]
- "n" substitutes suffix number of two or more same kind of registers, fields, and bit names. Example: [XYZ1], [XYZ2], [XYZ3] → [XYZn]
- "x" substitutes suffix number or character of units and channels in the Register List.
- In case of unit, "x" means A, B, and C... Example: [ADACR0], [ADBCR0], [ADCCR0]  $\rightarrow$  [ADxCR0] In case of channel, "x" means 0, 1, and 2... Example: [T32A0RUNA], [T32A1RUNA], [T32A2RUNA]  $\rightarrow$  [T32AxRUNA]
- The bit range of a register is written like as [m: n]. Example: Bit[3: 0] expresses the range of bit 3 to 0.
- The configuration value of a register is expressed by either the hexadecimal number or the binary number. Example: [ABCD]<EFG> = 0x01 (hexadecimal), [XYZn]<VW> = 1 (binary)
- Word and Byte represent the following bit length.

| Byte:        | 8 bits  |
|--------------|---------|
| Half word:   | 16 bits |
| Word:        | 32 bits |
| Double word: | 64 bits |

• Properties of each bit in a register are expressed as follows:

| R:   | Read only          |          |
|------|--------------------|----------|
| W:   | Write only         |          |
| R/W: | Read and Write are | oossible |

- Unless otherwise specified, register access supports only word access.
- The register defined as reserved must not be rewritten. Moreover, do not use the read value.
- The value read from the bit having default value of "-" is unknown.
- When a register containing both of writable bits and read-only bits is written, read-only bits should be written with their default value, In the cases that default is "-", follow the definition of each register.
- Reserved bits of the Write-only register should be written with their default value. In the cases that default is "-", follow the definition of each register.
- Do not use read-modified-write processing to the register of a definition which is different by writing and read out.

All other company names, product names, and service names mentioned herein may be trademarks of their respective companies.

# TOSHIBA

## **Terms and Abbreviation**

Some of abbreviations used in this document are as follows:

| ACK  | Acknowledgement             |
|------|-----------------------------|
| DMA  | Direct Memory Access        |
| FIFO | First-In First-Out          |
| LSB  | Least Significant Bit       |
| MSB  | Most Significant Bit        |
| SIO  | Serial Input/Output         |
| TSPI | Serial Peripheral Interface |

# 1. Outline

TSPI (serial peripheral interface) has a total of eight communication modes by allowing for the following choices; SPI mode/SIO mode, clock master/clock slave, and frame mode/sector mode. It operates as a one-channel circuit for transmit and receive. The sector mode combines a maximum of four types of data length and allows for transmit and receive in one frame, improving the processing efficiency for each data type. The list of the functional outline is shown in Table 1.1 and the functional outline of each communication mode is shown in Table 1.2 to Table 1.9.

| Function classification |                              |                                                               | Frame mode specification                                                                             | Sector mode specification            |
|-------------------------|------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--------------------------------------|
| Prescaler               |                              | (Master) The input clock can be divided by 1, 2, 4 up to 512. |                                                                                                      |                                      |
| I ransfer               | Baud rate generator          |                                                               | (Master) The prescaler output can be d                                                               | ivided by 1, 2,3 up to 16.           |
| CIOCK                   | Transfer clock of            | eneration                                                     | (Master) The baud rate generator output                                                              | It can be divided by 2.              |
|                         |                              |                                                               | SPI/SIÓ mode                                                                                         |                                      |
| Transmit and            | Communication                | modes                                                         | Master/Slave                                                                                         |                                      |
| Receive                 |                              |                                                               | Frame mode                                                                                           | Sector mode                          |
| Control                 | Communication operation mode |                                                               | Transmit and receive(Full-duplex comm                                                                | nunication)/Transmit/Receive         |
|                         | Transfer mode                |                                                               | Burst transfer/Continuous transfer                                                                   | Continuous transfer                  |
|                         | Sector count/Se              | ctor length                                                   | -                                                                                                    | 2 to 4 sectors / 1 to 32 bits        |
|                         | Frame length                 |                                                               | 8 to 32 bits                                                                                         | 8 to 128 bits (all sectors)          |
| Data format             | Number of FIFC               | ) stages                                                      | 16 bits x 8 stages / 32 bits x 4 stages                                                              | 32 bits x 4 stages                   |
|                         | Parity                       |                                                               | Following selections are available: no p                                                             | arity, even parity / odd parity.     |
|                         | Direction of data            | a transfer                                                    | Selection of LSB first / MSB first is prov                                                           | rided.                               |
|                         |                              | Transmission                                                  | Complete/FIFO                                                                                        |                                      |
|                         | Interruption                 | Reception                                                     | Complete/FIFO                                                                                        |                                      |
|                         | Interruption                 | Error                                                         | (Master) Vertical parity / Start Communication trigger                                               |                                      |
|                         |                              | EII0                                                          | (Slave) Vertical parity / Underrun / Overrun                                                         |                                      |
|                         |                              | Common                                                        | TSPI can be set up                                                                                   |                                      |
|                         |                              | Transmission                                                  | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO empty                                 |                                      |
| Ganged                  | Status flag                  | Reception                                                     | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO full                                  |                                      |
| control                 |                              | <b>F</b> 1110 1                                               | (Master) Vertical parity / Start Commun                                                              | ication trigger                      |
|                         |                              | EII0                                                          | (Slave) Vertical parity / Underrun / Overrun                                                         |                                      |
|                         | DMA request                  | Transmission                                                  | Single DMA request / Burst DMA reque                                                                 | st                                   |
|                         |                              | Reception                                                     | Single DMA request / Burst DMA request                                                               |                                      |
|                         | Trigger control<br>(Note 1)  | Trigger input                                                 | (Master) Start Communication trigger $\rightarrow$ Start communication                               |                                      |
|                         |                              | Trigger output                                                | Transmission complete $\rightarrow$ Transmission<br>complete $\rightarrow$ Reception Completed trigg | n Complete trigger, Reception<br>ler |
|                         | SCK: Polarity selection      |                                                               | High, Low: (Level during the idle period                                                             | )                                    |
|                         |                              |                                                               | During the idle period: High, Low, Last data, Hi-Z                                                   |                                      |
|                         | I XD level selec             | tion                                                          | (Slave) When an underrun error occurs: High, Low                                                     |                                      |
|                         | TXD timing                   |                                                               | (Slave) Last data hold time for the SIO mode: 2/fsys to 128/fsys                                     |                                      |
|                         |                              |                                                               | (Master) 1st edge / 2nd edge (timing for                                                             | r data sampling)                     |
| Special                 | RXD timing                   |                                                               | (Slave) 1st edge / 2nd edge (timing                                                                  | (Slave) 2nd edge (timing for data    |
| control (Note<br>2)     |                              |                                                               | for data sampling)                                                                                   | sampling)                            |
|                         | CS polarity selection        |                                                               | High, Low: (Level of the asserted period                                                             | d)                                   |
|                         | CS timing                    |                                                               | (Master) Cycle after CS assertion: 1/fsc                                                             | к to 16/fscк                         |
|                         |                              |                                                               | (Master) Cycle before CS deassertion: 1/fsck to 16/fsck                                              |                                      |
|                         | Frame interval period        |                                                               | (Master) Burst transfer: 0/fscк to 15/fscк -                                                         |                                      |
|                         | Idle period                  |                                                               | (Master) Continuous transfer: 1/fscк to 15/fscк                                                      |                                      |
|                         | Software reset               |                                                               | Reset by software                                                                                    |                                      |

| Table 1.1 | <b>Functional outline</b> | (frame mode,     | sector mode) |
|-----------|---------------------------|------------------|--------------|
|           |                           | (1141110 111040) |              |

Note 1: For the synced peripheral, refer to reference manual "Product Information".

Note 2: fsys: System clock frequency

f<sub>SCK</sub>: Transfer clock frequency

| Function classification |                       | ation            | A Functional Description or the range                                                                                          |
|-------------------------|-----------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------|
|                         | Prescaler             |                  | The input clock can be divided by 1,2,4 up to 512                                                                              |
| Transfer clock          | Baud rate ger         | erator           | The prescaler output can be divided by 1,2,3 up to 16                                                                          |
|                         | Transfer clock        | generation       | The baud rate generator output can be divided by 2                                                                             |
| Transmit and            | Communicatio          | on mode          | SPI mode, master, frame mode                                                                                                   |
| Receive                 | Communication mode    | on Operation     | Transmit and receive(Full-duplex communication) / transmit / receive                                                           |
| Control                 | Transfer mode         | e                | Burst transfer/Continuous transfer                                                                                             |
|                         | Frame length          |                  | 8 to 32 bits (adjustable in bit units))                                                                                        |
| Data                    | FIFO stage            |                  | 16 bits x 8 stages / 32 bits x 4 stages                                                                                        |
| Format                  | Parity                |                  | Following selections are available: no parity, even parity / odd parity.                                                       |
|                         | The direction         | of data transfer | Selection of the LSB first / MSB first is possible.                                                                            |
|                         |                       | Transmission     | Complete/FIFO                                                                                                                  |
|                         | Interruption          | Reception        | Complete/FIFO                                                                                                                  |
|                         |                       | Error            | Vertical parity / Start Communication trigger                                                                                  |
|                         |                       | Common           | TSPI can be set up                                                                                                             |
|                         | Status flag           | Transmission     | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO empty                                                           |
| Ganged                  |                       | Reception        | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO full                                                            |
| Control                 |                       | Error            | Vertical parity / Start Communication trigger                                                                                  |
|                         | DMA                   | Transmission     | Single DMA request / burst DMA request                                                                                         |
|                         | request               | Reception        | Single DMA request / burst DMA request                                                                                         |
|                         | Trigger               | Trigger input    | (Master) Start Communication trigger $\rightarrow$ Start communication                                                         |
|                         | control<br>(note1)    | Trigger output   | Transmission complete $\rightarrow$ Transmission complete trigger, Reception complete $\rightarrow$ Reception complete trigger |
|                         | SCK polarity s        | selection        | High, Low: (Level during the idle period)                                                                                      |
|                         | TXD level sele        | ection           | During the idle period: High, Low, Last data, Hi-Z                                                                             |
|                         | RXD timing            |                  | 1st edge / 2nd edge (timing for data sampling)                                                                                 |
| On a sigl as retral     | CS polarity selection |                  | High, Low: (Level of the asserted period)                                                                                      |
| Special control         | CS timing             |                  | Cycle after CS assertion: 1/fsck to 16/fsck                                                                                    |
| (10102)                 |                       |                  | Cycle before CS deassertion: 1/fsck to 16/fsck                                                                                 |
|                         | Frame interval period |                  | Burst transfer: 0/f <sub>SCK</sub> to 15/f <sub>SCK</sub>                                                                      |
|                         | Idle period           |                  | Continuous transfer: 1/f <sub>SCK</sub> to 15/f <sub>SCK</sub>                                                                 |
|                         | Software reset        |                  | Reset by software.                                                                                                             |

| Table 1.2 | Function outline (SPI mode, Master, F | <sup>;</sup> rame) |
|-----------|---------------------------------------|--------------------|
|           |                                       | . a                |

Note 2: f<sub>SCK</sub>: Transfer Clock frequency

| Function classification |                              | ation         | A Functional Description or the range                                                                                          |
|-------------------------|------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------|
| Troponit and            | Communicat                   | ion modes     | SPI mode, slave mode, frame mode                                                                                               |
| Receive                 | Communicat<br>mode           | ion Operation | Transmit and receive(Full-duplex communication), transmit, receive                                                             |
| Control                 | Transfer mod                 | de            | Burst transfer/Continuous transfer                                                                                             |
|                         | Frame length                 | า             | 8 to 32 bits (adjustable in bit units))                                                                                        |
| Data                    | FIFO stage                   |               | 16 bits x 8 stages / 32 bits x 4 stages                                                                                        |
| Format                  | Parity                       |               | Following selections are available: no parity, even parity / odd parity.                                                       |
| 1 offici                | The direction transfer       | of data       | Selection of the LSB first / MSB first is possible.                                                                            |
|                         |                              | Transmission  | Complete/FIFO                                                                                                                  |
|                         | Interruption                 | Reception     | Complete/FIFO                                                                                                                  |
|                         |                              | Error         | Vertical parity / Underrun / Overrun                                                                                           |
|                         | Status flag                  | Common        | TSPI Modify status                                                                                                             |
|                         |                              | Transmission  | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO empty                                                           |
| Ganged                  |                              | Reception     | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO full                                                            |
| Control                 |                              | Error         | Vertical parity / Underrun / Overrun                                                                                           |
|                         | DMA                          | Transmit      | Single DMA request / burst DMA request                                                                                         |
|                         | request                      | Receive       | Single DMA request / burst DMA request                                                                                         |
|                         | Trigger<br>control<br>(Note) |               | Transmission complete $\rightarrow$ Transmission complete trigger, Reception complete $\rightarrow$ Reception complete trigger |
|                         | SCK polarity                 | selection     | High, Low: (Level during the idle period)                                                                                      |
|                         |                              | laction       | During the idle period: High, Low, Last data, Hi-Z                                                                             |
| Special                 | I VD level se                | lection       | When an underrun error occurs: High, Low                                                                                       |
| Control                 | RXD timing                   |               | 1st edge / 2nd edge (timing for data sampling)                                                                                 |
|                         | CS polarity s                | election      | High, Low: (Level of the asserted period)                                                                                      |
|                         | Software res                 | et            | Reset by software                                                                                                              |

| Table 1.3 | Function outline | (SPI mode, | Slave, | Frame) |
|-----------|------------------|------------|--------|--------|
|-----------|------------------|------------|--------|--------|

| Function classification |                     | ation            | A Functional Description or the range                                                                                           |
|-------------------------|---------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------|
|                         | Prescaler           |                  | The input clock can be divided by 1,2,4 up to 512                                                                               |
| Transfer clock          | Baud rate ger       | nerator          | The prescaler output can be divided by 1,2,3 up to 16                                                                           |
|                         | Transfer clock      | generation       | The baud rate generator output can be divided by 2                                                                              |
| Transmittand            | Communicatio        | on modes         | SIO mode, master mode, frame mode                                                                                               |
| Receive                 | Communication mode  | on Operation     | Transmit and receive(Full-duplex communication), transmit, receive                                                              |
| Control                 | Transfer mode       | e                | Burst transfer / Continuous transfer                                                                                            |
|                         | Frame length        |                  | 8 to 32 bits (adjustable in bit units)                                                                                          |
| Data                    | FIFO stage          |                  | 16 bits x 8 stages / 32 bits x 4 stages                                                                                         |
| Format                  | Parity              |                  | Following selections are available: no parity, even parity / odd parity.                                                        |
|                         | The direction       | of data transfer | Selection of the LSB first / MSB first is possible.                                                                             |
|                         |                     | Transmission     | Complete/FIFO                                                                                                                   |
|                         | Interruption        | Reception        | Complete/FIFO                                                                                                                   |
|                         |                     | Error            | Vertical parity / Start Communication trigger                                                                                   |
|                         | Status flag         | Common           | TSPI modify status                                                                                                              |
|                         |                     | Transmission     | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO empty                                                            |
| Ganged                  |                     | Reception        | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO full                                                             |
| Control                 |                     | Error            | Vertical parity / Start Communication trigger                                                                                   |
|                         | DMA                 | Transmit         | Single DMA request / burst DMA request                                                                                          |
|                         | request             | Receive          | Single DMA request / burst DMA request                                                                                          |
|                         | Trigger             | Trigger input    | Start Communication trigger $\rightarrow$ Start communication                                                                   |
|                         | control<br>(Note 1) | Trigger output   | Transmission complete $\rightarrow$ Transmission complete trigger, Reception complete $\rightarrow$ Reception completed trigger |
|                         | SCK polarity s      | selection        | High, Low: (Level during the idle period)                                                                                       |
|                         | TXD level sele      | ection           | During the idle period: High, Low, Last data, Hi-Z                                                                              |
| Special                 | RXD timing          |                  | 1st edge / 2nd edge (timing for data sampling)                                                                                  |
| (Note2)                 | Frame interva       | l period         | Burst transfer: 0/fsck to 15/fsck                                                                                               |
|                         | Idle period         |                  | Continuous transfer: 1/fsck to 15/fsck                                                                                          |
|                         | Software rese       | t                | Reset by software                                                                                                               |

| Table 1.4 | Function | outline | (SIO mode | e, Master, | Frame) |
|-----------|----------|---------|-----------|------------|--------|
|-----------|----------|---------|-----------|------------|--------|

Note 2: f<sub>SCK</sub>: Transfer Clock frequency

| Function classification |                                | ation            | A Functional Description or the range                                                                                           |  |  |
|-------------------------|--------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|
| Transmit and            | Communication                  | on modes         | SIO mode, slave mode, frame mode                                                                                                |  |  |
| Receive                 | Communication mode             | on Operation     | Transmit and receive(Full-duplex communication), transmit, receive                                                              |  |  |
| Control                 | Transfer mod                   | е                | Burst transfer / Continuous transfer                                                                                            |  |  |
|                         | Frame length                   |                  | 8 to 32 bits (adjustable in bit units)                                                                                          |  |  |
| Data                    | FIFO stage                     |                  | 16 bits x 8 stages / 32 bits x 4 stages                                                                                         |  |  |
| Format                  | Parity                         |                  | Following selections are available: no parity, even parity / odd parity.                                                        |  |  |
|                         | The direction                  | of data transfer | Selection of the LSB first / MSB first is possible.                                                                             |  |  |
|                         |                                | Transmission     | Complete/FIFO                                                                                                                   |  |  |
|                         | Interruption                   | Reception        | Complete/FIFO                                                                                                                   |  |  |
|                         |                                | Error            | Vertical parity / Underrun / Overrun                                                                                            |  |  |
|                         | Status flag                    | Common           | TSPI modify status                                                                                                              |  |  |
|                         |                                | Transmission     | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO empty                                                            |  |  |
| Ganged                  |                                | Reception        | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO full                                                             |  |  |
| Control                 |                                | Error            | Vertical parity / Underrun / Overrun                                                                                            |  |  |
|                         | DMA<br>request                 | Transmit         | Single DMA request / burst DMA request                                                                                          |  |  |
|                         |                                | Receive          | Single DMA request / burst DMA request                                                                                          |  |  |
|                         | Trigger<br>control<br>(Note 1) | Trigger output   | Transmission complete $\rightarrow$ Transmission complete trigger, Reception complete $\rightarrow$ Reception completed trigger |  |  |
|                         | SCK polarity                   | selection        | High, Low: (Level during the idle period)                                                                                       |  |  |
|                         |                                | action           | During the idle period: High, Low, Last data, Hi-Z                                                                              |  |  |
| Special                 | I XD level sel                 | ection           | When an underrun error occurs: High, Low                                                                                        |  |  |
| Control                 | TXD timing (N                  | lote 2)          | Last data hold time: 2/fsys to 128/fsys                                                                                         |  |  |
|                         | RXD timing                     |                  | 1st edge / 2nd edge (timing for data sampling)                                                                                  |  |  |
|                         | Software rese                  | et               | Reset by software                                                                                                               |  |  |

| Table 1.5 | Function | outline | (SIO | mode, | Slave, | Frame) |
|-----------|----------|---------|------|-------|--------|--------|
|-----------|----------|---------|------|-------|--------|--------|

Note 2: fsys: System Clock frequency

| Func                     | tion Classific     | ation          | Function Description or the Range                                            |  |
|--------------------------|--------------------|----------------|------------------------------------------------------------------------------|--|
| Transfor                 | Prescaler          |                | The input clock can be divided by 1,2,4 up to 512                            |  |
| clock                    | Baud rate ge       | nerator        | The prescaler output can be divided by 1,2,3 up to 16                        |  |
| CIOCK                    | Transfer cloc      | k generation   | The baud rate generator output can be divided by 2                           |  |
| Transmit and             | Communicat         | ion modes      | SPI mode, master mode, sector mode                                           |  |
| Receive                  | Communicat<br>mode | ion operation  | Transmit and receive(Full-duplex communication), Transmit, Receive           |  |
| Control                  | Transfer mod       | de             | Continuous transfer                                                          |  |
|                          | Sector count       | /Sector length | 2 to 4 sectors / 1 to 32 bits (adjustable in bit units)                      |  |
|                          | Frame length       | า              | 8 to 128 bits (all sectors)                                                  |  |
| Data format              | Number of F        | IFO stages     | 32 bits x 4 stages                                                           |  |
|                          | Parity             |                | Following selections are available: no parity, even parity / odd parity.     |  |
|                          | Direction of o     | data transfer  | Selection of LSB first / MSB first is provided.                              |  |
|                          | Interruption       | Transmission   | Complete/FIFO                                                                |  |
|                          |                    | Reception      | Complete/FIFO                                                                |  |
|                          |                    | Error          | Vertical parity / Start Communication trigger                                |  |
|                          | Status flag        | Common         | TSPI modify status                                                           |  |
|                          |                    | Transmission   | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO empty         |  |
| Ganged                   |                    | Reception      | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO full          |  |
| control                  |                    | Error          | Vertical parity / Start Communication trigger                                |  |
|                          | DMA                | Transmission   | Single DMA request / Burst DMA request                                       |  |
|                          | request            | Reception      | Single DMA request / Burst DMA request                                       |  |
|                          | Trigger            | Trigger input  | Start Communication trigger $\rightarrow$ Start communication                |  |
|                          | control            | Trigger        | Transmission complete $\rightarrow$ Transmission Complete trigger, Reception |  |
|                          | (Note 1)           | output         | complete → Reception Completed trigger                                       |  |
|                          | SCK polarity       | selection      | High, Low: (Level during the idle period)                                    |  |
|                          | TXD level se       | lection        | During the idle period: High, Low, Last data, Hi-Z                           |  |
| Special                  | RXD timing         |                | 1st edge / 2nd edge (timing for data sampling)                               |  |
| Special<br>control (Note | CS polarity s      | election       | High, Low: (Level of the asserted period)                                    |  |
| 2)                       | CS timing          |                | Cycle after CS assertion: 1/fsck - 16/fsck                                   |  |
| -)                       | CS tiring          |                | Cycle before CS deassertion: 1/f <sub>SCK</sub> - 16/f <sub>SCK</sub>        |  |
|                          | Idle period        |                | Continuous transfer: 1/f <sub>SCK</sub> - 15/f <sub>SCK</sub>                |  |
|                          | Software res       | et             | Reset by software                                                            |  |

| Table 1.6 | <b>Functions Outline</b> | (SPI mode, | Master, Sector) |
|-----------|--------------------------|------------|-----------------|
|-----------|--------------------------|------------|-----------------|

Note 2: f<sub>SCK</sub>: Transfer clock frequency

| Func         | tion Classific               | ation          | Function Description or the Range                                                                                               |
|--------------|------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------|
| Transmit and | Communicat                   | ion modes      | SPI mode, slave mode, sector mode                                                                                               |
| Receive      | Communicat<br>mode           | ion operation  | Transmit and receive(Full-duplex communication), Transmit, Receive                                                              |
| Control      | Transfer mod                 | de             | Continuous transfer                                                                                                             |
|              | Sector count                 | /Sector length | 2 to 4 sectors / 2 to 32 bits (adjustable in bit units)                                                                         |
|              | Frame length                 | า              | 8 to 128 bits (all sectors)                                                                                                     |
| Data format  | Number of F                  | IFO stages     | 32 bits × 4 stages                                                                                                              |
|              | Parity                       |                | Following selections are available: no parity, even parity / odd parity.                                                        |
|              | Direction of o               | data transfer  | Selection of LSB first / MSB first is provided.                                                                                 |
|              |                              | Transmission   | Complete/FIFO                                                                                                                   |
|              | Interruption                 | Reception      | Complete/FIFO                                                                                                                   |
|              |                              | Error          | Vertical parity / Underrun / Overrun                                                                                            |
|              | Status flag                  | Common         | TSPI modify status                                                                                                              |
|              |                              | Transmission   | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO empty                                                            |
| Ganged       |                              | Reception      | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO full                                                             |
| control      |                              | Error          | Vertical parity / Underrun / Overrun                                                                                            |
|              | DMA                          | Transmission   | Single DMA request / Burst DMA request                                                                                          |
|              | request                      | Reception      | Single DMA request / Burst DMA request                                                                                          |
|              | Trigger<br>control<br>(Note) |                | Transmission complete $\rightarrow$ Transmission complete trigger, Reception complete $\rightarrow$ Reception completed trigger |
|              | SCK polarity                 | selection      | High, Low: (Level during the idle period)                                                                                       |
|              |                              | loction        | During the idle period: High, Low, Last data, Hi-Z                                                                              |
| Special      | I VD Ievel se                | lection        | When an underrun error occurs: High, Low                                                                                        |
| control      | RXD timing                   |                | 2nd edge (timing for data sampling)                                                                                             |
|              | CS polarity s                | election       | High, Low: (Level of the asserted period)                                                                                       |
|              | Software res                 | et             | Reset by software                                                                                                               |

| Table 1.7 | Functions Overview (SPI mode. | Slave. Sec | tor) |
|-----------|-------------------------------|------------|------|
|           |                               |            | ···· |

| Function Classification |                 | ation          | Function Description or the Range                                            |
|-------------------------|-----------------|----------------|------------------------------------------------------------------------------|
| Transfor                | Prescaler       |                | The input clock can be divided by 1,2,4 up to 512                            |
| ransier                 | Baud rate ge    | enerator       | The prescaler output can be divided by 1,2,3 up to 16                        |
| CIOCK                   | Transfer cloc   | k generation   | The baud rate generator output can be divided by 2                           |
| Transmit and            | Communicat      | ion modes      | SIO mode, master mode, sector mode                                           |
| Receive                 | Communicat mode | ion operation  | Transmit and receive(Full-duplex communication), Transmit, Receive           |
| Control                 | Transfer mod    | de             | Continuous transfer                                                          |
|                         | Sector count    | /Sector length | 2 to 4 sectors / 1 to 32 bits (adjustable in bit units)                      |
|                         | Frame length    | า              | 8 to 128 bits (all sectors)                                                  |
| Data format             | Number of F     | IFO stages     | 32 bits x 4 stages                                                           |
|                         | Parity          |                | Following selections are available: no parity, even parity / odd parity.     |
|                         | Direction of c  | data transfer  | Selection of LSB first / MSB first is provided.                              |
|                         | Interruption    | Transmission   | Complete/FIFO                                                                |
|                         |                 | Reception      | Complete/FIFO                                                                |
|                         |                 | Error          | Vertical parity / Start Communication trigger                                |
|                         | Status flag     | Common         | TSPI modify status                                                           |
|                         |                 | Transmission   | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO empty         |
| Ganged                  |                 | Reception      | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO full          |
| control                 |                 | Error          | Vertical parity / Start Communication trigger                                |
|                         | DMA             | Transmission   | Single DMA request / Burst DMA request                                       |
|                         | request         | Reception      | Single DMA request / Burst DMA request                                       |
|                         | Trigger         | Trigger input  | Start Communication trigger $\rightarrow$ Start communication                |
|                         | control         | Trigger        | Transmission complete $\rightarrow$ Transmission complete trigger, Reception |
|                         | (Note 1)        | output         | complete $\rightarrow$ Reception completed trigger                           |
|                         | SCK polarity    | selection      | High, Low: (Level during the idle period)                                    |
| Special                 | TXD level se    | lection        | During the idle period: High, Low, Last data, Hi-Z                           |
| control                 | RXD timing      |                | 1st edge / 2nd edge (timing for data sampling)                               |
| Control                 | Idle period (N  | Note 2)        | Continuous transfer: 1/fsck - 15/fsck                                        |
|                         | Software res    | et             | Reset by software                                                            |

| Table 1.8 | Functions | Overview | (SIO mode, | Master, | Sector) |
|-----------|-----------|----------|------------|---------|---------|
|-----------|-----------|----------|------------|---------|---------|

Note 2:  $f_{SCK}$ : Transfer clock frequency

| Function classification |                    | ation          | Function Description or the Range                                            |  |
|-------------------------|--------------------|----------------|------------------------------------------------------------------------------|--|
| Transmit and            | Communicat         | ion modes      | SIO mode, slave mode, sector mode                                            |  |
| Receive                 | Communicat<br>mode | ion operation  | Transmit and receive(Full-duplex communication), Transmit, Receive           |  |
| Control                 | Transfer mo        | de             | Continuous transfer                                                          |  |
|                         | Sector count       | /Sector length | 2 to 4 sectors / 2 to 32 bits (adjustable on a bit level)                    |  |
|                         | Frame lengt        | า              | 8 to 128 bits (all sectors)                                                  |  |
| Data format             | Number of F        | IFO stages     | 32 bits x 4 stages                                                           |  |
|                         | Parity             |                | Following selections are available: no parity, even parity / odd parity.     |  |
|                         | Direction of o     | data transfer  | Selection of LSB first / MSB first is provided.                              |  |
|                         |                    | Transmission   | Complete/FIFO                                                                |  |
|                         | Interrupt          | Reception      | Complete/FIFO                                                                |  |
|                         |                    | Error          | Vertical parity / Underrun / Overrun                                         |  |
|                         | Status flag        | Common         | TSPI modify status                                                           |  |
| Congod                  |                    | Transmission   | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO empty         |  |
| control                 |                    | Reception      | Operating / Complete / FIFO interrupt / FIFO fill level / FIFO full          |  |
| control                 |                    | Error          | Vertical parity / Underrun / Overrun                                         |  |
|                         | DMA                | Transmission   | Single DMA request / Burst DMA request                                       |  |
|                         | request            | Reception      | Single DMA request / Burst DMA request                                       |  |
|                         | Trigger            | Trigger        | Transmission complete $\rightarrow$ Transmission complete trigger, Reception |  |
|                         | control            | output         | complete $\rightarrow$ Reception completed trigger                           |  |
|                         | SCK polarity       | selection      | High, Low: (Level during the idle period)                                    |  |
|                         | TXD level se       |                | During the idle period: High, Low, Last data, Hi-Z                           |  |
| Special                 | TXD level 30       | accion         | When an underrun error occurs: High, Low                                     |  |
| control                 | TXD timing         |                | Last data hold time: 2/fsys to 128/fsys                                      |  |
|                         | RXD timing         |                | 2nd edge (timing for data sampling)                                          |  |
|                         | Software res       | et             | Reset by software                                                            |  |

| Table 1.9 | Functions | Overview | (SIO mode, | Slave, Sector) |
|-----------|-----------|----------|------------|----------------|
|-----------|-----------|----------|------------|----------------|

Note 2: fsys: System clock frequency

TOSHIBA

# 2. Configuration

The block diagram of the TSPI and the signal list are shown.



Figure 2.1 Block diagram of TSPI

| No | Signal symbol | Signal name                              | I/O          | Reference manual                    |
|----|---------------|------------------------------------------|--------------|-------------------------------------|
| 1  | fsys          | System clock                             | Input        | Clock Control and Operation<br>Mode |
| 2  | ФТ0           | Clock for prescaler                      | Input        | Clock Control and Operation<br>Mode |
| 3  | TSPIxSCK      | Serial clock output / Serial clock input | Input/Output | Input/Output Ports                  |
| 4  | TSPIxCS0      | Chip select 0                            | Output       | Input/Output Ports                  |
| 5  | TSPIxCS1      | Chip select 1                            | Output       | Input/Output Ports                  |
| 6  | TSPIxCS2      | Chip select 2                            | Output       | Input/Output Ports                  |
| 7  | TSPIxCS3      | Chip select 3                            | Output       | Input/Output Ports                  |
| 8  | TSPIxCSIN     | Chip select input for slave operation    | Input        | Input/Output Ports                  |
| 9  | TSPIxTXD      | Serial data of transmit                  | Output       | Input/Output Ports                  |
| 10 | TSPIxRXD      | Serial data of receive                   | Input        | Input/Output Ports                  |
| 11 | INTTxTX       | Transmit interrupt                       | Output       | Exception                           |
| 12 | INTTxRX       | Receive interrupt                        | Output       | Exception                           |
| 13 | INTTxERR      | Error interrupt                          | Output       | Exception                           |
| 14 | TSPIxTRG      | Trigger input for start communication    | Input        | Product Information                 |
| 15 | TSPIxTX_DMA   | Transmit DMA request                     | Output       | Product Information                 |
| 16 | TSPIxRX_DMA   | Receive DMA request                      | Output       | Product Information                 |
| 17 | TSPIxTXEND    | Transmit complete trigger                | Output       | Product Information                 |
| 18 | TSPIxRXEND    | Receive complete trigger                 | Output       | Product Information                 |

Table 2.1List of Signals

# 3. Operation Description

# 3.1. Basic Operation

# 3.1.1. Clock Supply

When TSPI is used, the corresponding clock enable bits should be set to "1" (Clock supply) in fsys supply stop register A (*[CGFSYSENA]* and *[CGFSYSMENA]*), fsys supply stop register B (*[CGFSYSENB]* and *[CGFSYSMENB]*), fsys supply stop register C (*[CGFSYSMENC]*), and fc supply stop register (*[CGFCEN]*). The corresponding registers and the bit locations depend on a product. Some products do not have all registers.

The corresponding registers and the bit locations depend on a product. Some products do not have all registers. For the details, refer to reference manual "Clock Control and Operation Mode".

When stopping the supply of a clock, please check that TSPI has stopped (*[TSPIxCR0]*<TSPIE>=0. Moreover, also when you change the operational mode to STOP1/STOP2, please check that TSPI has stopped.

## 3.1.2. Start and Stop Transfer

First, set **[TSPIxCR0]**<TSPIE>(operation control register) to "1". After verifying that it has stopped, conduct the necessary configurations including the communication mode, the transmit mode, and the transfer format.

Also, when modifying various settings or enabling communications and the Start communication trigger, make sure that it has stopped before changing the settings.

Stopped status: [TSPIxSR] <TSPISUE>=0 and [TSPIxCR1] <TRGEN>=0, <TRXE>=0

There are two methods for a transfer start in the case of transmit and receive(full-duplex communication)full-duplex communication mode and transmitting mode.

- 1. Write Data to data register [*TSPIxDR*], after wrote "1" to [*TSPIxCR1*] <TRXE> to enable communication.
- 2. Write "1" to [TSPIxCR1]<TRXE>, after wrote data to data register [TSPIxDR].

In the case of receiving mode, receive is started immediately after setting to [TSPIxCR1]<TRXE>=1.

To stop the transfer, set *[TSPIxCR1]*<TRXE>=0. For both burst transfer and continuous transfer, the transfer of a frame being transmitted is completed. For details, refer to "Table 4.2 Transfer state and setting enabled state flag at communication stop setting."

After stopped, TSPIxSCK, TSPIxCS0/1/2/3, and TSPIxTXD will be in an idle state. Refer to "3.10. Special Control".

When a transfer is enabled again after stopping a burst transfer, the operation starts from the first frame of the number of frames set in the *[TSPIxCR1]*<FC[7:0]> (configuration register for the transfer frame count).

# 3.2. Transfer Clock

"Clock for prescaler" ( $\Phi$ T0) is used as a general term that includes the clock for high speed prescaler ( $\Phi$ T0h) and the clock for middle speed prescaler ( $\Phi$ T0m).

A transfer clock used during master operation is generated from  $\Phi T0$  in a transfer clock generation circuit.

For more information on  $\Phi$ T0 on different products and channels, refer to reference manual "Product Information". For the maximum frequencies on  $f_{SCK}$  and  $f_{SCKi}$ , refer to the electrical characteristics in the data sheet of each product.

# 3.2.1. Transfer Clock Frequency

## 3.2.1.1. Master operation

The transfer clock generation circuit is shown in Figure 3.1.



Figure 3.1 Transfer clock generation circuit

The prescaler divides  $\Phi$ T0 by 1 to 512 ( $\Phi$ T0 to  $\Phi$ T256). The divided clock can be selected by *[TSPIxBR]*<BRCK[3:0]>.

Baud rate generator divides ΦTx by 1 to 16. The division ratio is selected in [TSPIxBR]<BRS[3:0]>.

The example of calculation of transfer clock frequency (hereinafter  $f_{SCK}$ ) is shown below, Table 3.1 shows examples.

```
 \begin{array}{l} f_{SCK} = \Phi T0 \times \textit{[TSPIxBR]} < & BRCK[3:0] > (1/x) \times \textit{[TSPIxBR]} < & BRS[3:0] > (1/N) \times 1/2 \\ & (x = 1, 2, 4, 8, 16 \dots 256, 512 \quad N = 1, 2, 3, 4, \dots 16) \end{array}
```

Note:  $\Phi TO$  should be set less than or equal to fsys (i.e. fsys $\geq \Phi TO$ ).

| (700/-001 | (7004-001 |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
|-----------|-----------|---------------|-----|-------|-----|------|------|-----|------|------|------|------|------|-----|-----|
|           |           | Ψ10<br>Divide | 40  | 50    | 60  |      |      | Ann |      |      | 400  | 400  | 200  |     |     |
|           |           | Divide        | 40  | 50    | 60  | 80   | 100  | 120 | 140  | 150  | 160  | 180  | 200  |     |     |
| 0000      | 0001      | 2             | 20  | 25    |     |      |      |     |      |      |      |      |      |     |     |
| 0000      | 0010      | 4             | 10  | 12.5  | 15  | 20   | 25   |     |      |      |      |      |      |     |     |
| 0001      | 0001      |               | 0.0 |       | 40  | 40.0 | 40.0 |     | 00.0 | 05   |      |      |      |     |     |
| 0000      | 0011      | 6             | 6.6 | 8.3   | 10  | 13.3 | 16.6 | 20  | 23.3 | 25   |      |      |      |     |     |
| 0000      | 0100      |               | _   |       | 7.5 | 40   | 10.5 | 45  | 475  | 40.7 |      | 00 F | 05   |     |     |
| 0001      | 0010      | 8             | 5   | 6.2   | 7.5 | 10   | 12.5 | 15  | 17.5 | 18.7 | 20   | 22.5 | 25   |     |     |
| 0010      | 0001      | 10            |     |       |     |      | 40   | 40  |      | 45   | 40   | 40   |      |     |     |
| 0000      | 0101      | 10            | 4   | 5     | 6   | 8    | 10   | 12  | 14   | 15   | 16   | 18   | 20   |     |     |
| 0000      | 0110      | 12            | 3.3 | 4.1   | 5   | 6.6  | 8.3  | 10  | 11.6 | 12.6 | 13.3 | 15   | 16.6 |     |     |
| 0001      | 0011      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0000      | 0111      | 14            | 2.8 | 3.5   | 4.2 | 5.7  | 7.1  | 8.5 | 10   | 10.7 | 11.4 | 12.8 | 14.2 |     |     |
| 0000      | 1000      | -             |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0001      | 0100      | 16            | 2.5 | 3.1   | 3.7 | 5    | 6.2  | 7.5 | 8.7  | 9.3  | 10   | 11.2 | 12.5 |     |     |
| 0010      | 0010      | -             |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0011      | 0001      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0000      | 1001      | 18            | 2.2 | 2.7   | 3.3 | 4.4  | 5.5  | 6.6 | 1.1  | 8.3  | 8.8  | 10   | 11.1 |     |     |
| 0000      | 1010      | 20            | 2   | 2.5   | 3   | 4    | 5    | 6   | 7    | 7.5  | 8    | 9    | 10   |     |     |
| 0001      | 0101      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0000      | 1011      | 22            | 1.8 | 2.2   | 2.7 | 3.6  | 4.5  | 5.4 | 6.3  | 6.8  | 7.2  | 8.1  | 9.0  |     |     |
| 0000      | 1100      |               |     | _     |     |      |      |     |      |      |      |      |      |     |     |
| 0001      | 0110      | 24            | 1.6 | 6 2.0 | 2.5 | 3.3  | 4.1  | 5   | 5.8  | 6.2  | 6.6  | 7.5  | 8.3  |     |     |
| 0010      | 0011      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0000      | 1101      | 26            | 1,5 | 1.9   | 2.3 | 3.0  | 3.8  | 4.6 | 5.3  | 5.7  | 6.1  | 6.9  | 7.6  |     |     |
| 0000      | 1110      | 28            | 28  | 28    | 1.4 | 1.7  | 2.1  | 2.8 | 3.5  | 4.2  | 5    | 5.3  | 5.7  | 6.4 | 7.1 |
| 0001      | 0111      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0000      | 1111      | 30            | 1.3 | 1.6   | 2   | 2.6  | 3.3  | 4   | 4.6  | 5    | 5.3  | 6    | 6.6  |     |     |
| 0000      | 0000      | -             |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0001      | 1000      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0010      | 0100      | 32            | 1.2 | 1.5   | 1.8 | 2.5  | 3.1  | 3.7 | 4.3  | 4.6  | 5    | 5.6  | 6.2  |     |     |
| 0011      | 0010      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0100      | 0001      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0001      | 1001      | 36            | 1.1 | 1.3   | 1.6 | 2.2  | 2.7  | 3.3 | 3.8  | 4.1  | 4.4  | 5    | 5.5  |     |     |
| 0001      | 1010      | 40            | 1   | 1.2   | 1.5 | 2    | 2.5  | 3   | 3.5  | 3.7  | 4    | 4.5  | 5    |     |     |
| 0010      | 0101      | -10           |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0001      | 1011      | 44            | 0.9 | 1.1   | 1.3 | 1.8  | 2.2  | 2.7 | 3.1  | 3.4  | 3.6  | 4.0  | 4.5  |     |     |
| 0001      | 1100      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0010      | 0110      | 48            | 0.8 | 1.0   | 1.2 | 1.6  | 2.0  | 2.5 | 2.9  | 3.1  | 3.3  | 3.7  | 4.1  |     |     |
| 0011      | 0011      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0001      | 1101      | 52            | 0.7 | 0.9   | 1.1 | 1.5  | 1.9  | 2.3 | 2.6  | 2.8  | 3.0  | 3.4  | 3.8  |     |     |
| 0001      | 1110      | 56            | 0.7 | 0.8   | 1.0 | 1.4  | 17   | 2.1 | 2.5  | 26   | 29   | 2.2  | 25   |     |     |
| 0010      | 0111      | 50            | 0.7 | 0.0   | 1.0 | 1.4  | 1.7  | 2.1 | 2.5  | 2.0  | 2.0  | 5.2  | 5.5  |     |     |
| 0001      | 1111      | 60            | 0.6 | 0.8   | 1   | 1.3  | 1.6  | 2   | 2.3  | 2.5  | 2.6  | 3    | 3.3  |     |     |
| 0001      | 0000      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0010      | 1000      |               |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0011      | 0100      | 64            | 0.6 | 0.7   | 0.9 | 1.2  | 1.5  | 1.8 | 2.1  | 2.3  | 2.5  | 2.8  | 3.1  |     |     |
| 0100      | 0010      | ]             |     |       |     |      |      |     |      |      |      |      |      |     |     |
| 0101      | 0001      | 1             |     |       |     |      |      |     |      |      |      |      |      |     |     |

Note: When setting conditions, the transfer clock cannot exceed 25 MHz (gray cells). It is also possible that some products have their maximum transfer clock set to less than 25 MHz. For more information on each product, refer to its datasheet and reference manual "Product Information".

## 3.2.1.2. Generating condition of the transfer clock

The condition for generating TSPI's transfer clock frequency (f<sub>SCK</sub>) can be configured.

The condition for generating  $f_{SCK}$  includes the frequency ratio of the system clock (fsys) and the clock for prescaler ( $\Phi T0$ ).

The relationships between each clock and the configurable range for its register are as follows.

### Condition for generating f<sub>SCK</sub>:

 $\begin{array}{l} fsys / f_{SCK} = 2^{A}L \times 2^{A}M \times 2N \\ (fsys / f_{SCK}: Ratio between the system clock (fsys) and the transfer clock (f_{SCK})) \\ fsys / \Phi T0 = 2^{A}L = 1/16, 1/8, 1/4, 1/2, 1, 2, 4, 8 \ to 512 \ L = -4 \ to 9 \\ (2^{A}L: Ratio between the system clock (fsys) and the clock for prescaler (\Phi T0)) \\ \Phi T0 / \Phi Tx = 2^{A}M = 1, 2, 4, 8, 16, 32, 64, 128, 256, 512 \ M = 0 \ to 9 \\ (2^{A}M: Division value for prescaler by the [$ *TSPIxBR]* $<BRCK[3:0]>) \\ \Phi Tx / f_{SCK} = 2N = 2, 4, 6, 8, 10, 12 \ to 22, 24, 26, 28, 30, 32 \ N = 1 \ to 16 \\ (N: Division value for baud rate generator by the [$ *TSPIxBR]* $<BRS[3:0]>) \\ \end{array}$ 

The combinations of the configuration of each register and the condition for generating  $f_{SCK}$  is shown in Table 3.2.

| fsys /<br>ФТ0         | <i>[TSPIxBR]</i> <brck[3:0]></brck[3:0]> | <i>[TSPIxBR]</i> <brs[3:0]></brs[3:0]> | fsys /<br>fscк | [TSPIxCR2] <rxdly[2:0]></rxdly[2:0]> |
|-----------------------|------------------------------------------|----------------------------------------|----------------|--------------------------------------|
| 1/16 to 1/2<br>(Note) | -                                        | -                                      | -              | -                                    |
| 1                     | 0000                                     | 0001                                   | 2              | 000                                  |
| 1                     | 0000                                     | 0010                                   | 4              | 000 to 001                           |
| 1                     | 0000                                     | 0011                                   | 6              | 000 to 010                           |
| 1                     | 0000                                     | 0100                                   | 8              | 000 to 011                           |
| 1                     | 0000                                     | 0101                                   | 10             | 000 to 100                           |
| 1                     | 0000                                     | 0110                                   | 12             | 000 to 101                           |
| 1                     | 0000                                     | 0111                                   | 14             | 000 to 110                           |
| 1                     | 0000                                     | 0000, 1000 to1111                      | 16 or more     | 000 to 111                           |
| 1                     | 0001                                     | 0001                                   | 4              | 000 to 001                           |
| 1                     | 0001                                     | 0010                                   | 8              | 000 to 011                           |
| 1                     | 0001                                     | 0011                                   | 12             | 000 to 101                           |
| 1                     | 0001                                     | 0000, 0100 to 1111                     | 16 or more     | 000 to 111                           |
| 1                     | 0010                                     | 0001                                   | 8              | 000 to 011                           |
| 1                     | 0010                                     | 0000, 0010 to 1111                     | 16 or more     | 000 to 111                           |
| 1                     | 0011 to 1001                             | 0000 to 1111                           | 16             | 000 to 111                           |
| 2                     | 0000                                     | 0001                                   | 4              | 000 to 001                           |
| 2                     | 0000                                     | 0010                                   | 8              | 000 to 011                           |
| 2                     | 0000                                     | 0011                                   | 12             | 000 to 101                           |
| 2                     | 0000                                     | 0000, 0100 to 1111                     | 16 or more     | 000 to 111                           |
| 2                     | 0001                                     | 0001                                   | 8              | 000 to 011                           |
| 2                     | 0001                                     | 0000, 0010 to 1111                     | 16 or more     | 000 to 111                           |
| 2                     | 0010 to 1001                             | 0000 to 1111                           | 16 or more     | 000 to 111                           |
| 4                     | 0000                                     | 0001                                   | 8              | 000 to 011                           |
| 4                     | 0000                                     | 0000, 0010 to 1111                     | 16 or more     | 000 to 111                           |
| 4                     | 0001 to 1001                             | 0000 to 1111                           | 16 or more     | 000 to 111                           |
| 8 to 512              | 0000 to 1001                             | 0000 to 1111                           | 16 or more     | 000 to 111                           |

 Table 3.2
 Condition for generating a transfer clock and the register configuration value

Note: The use of the 1/16 to 1/2 in fsys /  $\Phi$ T0 is prohibited.

## 3.2.1.3. Slave Operation

The input frequency (hereinafter  $f_{SCKi}$ ) of the transfer clock should be set to the following conditions. When using RXD sampling at the 1st edge, use under the condition of  $4 \le fsys / f_{SCKi}$ . When using RXD sampling at the 2nd edge, use under the conditions shown in Table 3.3.

| Condition for fsckiSector modefsys / fscki = NSector length |              | Frame mode<br>Frame length |
|-------------------------------------------------------------|--------------|----------------------------|
| N<2                                                         | -            | -                          |
| 2≤N                                                         | 4 to 32 bits | All range (9 to 22 hite)   |
| 4≤N                                                         | 2 to 32 bits | All lange (8 to 32 bits)   |

 Table 3.3
 Conditions of a transfer clock for slave operation(2nd edge)

# 3.3. Communication Mode

A communication mode is selected.

Specify the SPI or SIO mode in *[TSPIxCR1]*<TSPIMS> (communication mode selection register) Specify the master operation or slave operation in *[TSPIxCR1]*<MSTR> (master or slave selection register) Specify the frame or sector in *[TSPIxSECTCR0]*<SECT> (sector mode selection register)

Communication modes along with their compatible operation specifications are shown in Table 3.4.

## Table 3.4 Communication modes and the specifications for the compatible operations

| Transmit and Receive Control |             |        | Data format                           |                     |                          |                                | Spec                             | ial control                                                    |                                                           |                                                                        |
|------------------------------|-------------|--------|---------------------------------------|---------------------|--------------------------|--------------------------------|----------------------------------|----------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------------|
| Com                          | munication  | modes  | Communication operation mode          | Transfer<br>mode    | Frame<br>length<br>(bit) | FIFO<br>Bit<br>×<br>stage      | Common                           | Ganged control                                                 | Level selection                                           | Timing selection                                                       |
|                              | Master      | Frame  |                                       | Continuous<br>burst | 8 to<br>32               | 16 <b>×</b> 8<br>32 <b>×</b> 4 |                                  | Interrupt<br>DMA<br>Trigger<br>-Start                          | SCK<br>polarity                                           | RXD sampling<br>-1st edge                                              |
| SPI                          | operation   | Sector |                                       | Continuous          | 8 to<br>128              | 32 <b>×</b> 4                  |                                  | communication<br>-Complete<br>transmit<br>-Complete<br>receive | IXD<br>-Idle period<br>CS polarity                        | CS timing<br>Frame interval<br>Idle time                               |
|                              | Slave       | Frame  |                                       | Continuous<br>burst | 8 to<br>32               | 16 <b>×</b> 8<br>32 <b>×</b> 4 | Parity                           | Interrupt<br>DMA<br>Trigger                                    | SCK<br>polarity<br>TXD                                    | RXD sampling<br>-1st edge<br>-2nd edge                                 |
|                              | operation   | Sector | Transmit and                          | Continuous          | 8 to<br>128              | 32 <b>×</b> 4                  | -None<br>-Even<br>-Odd           | -Complete<br>receive                                           | -Underrun<br>error<br>CS polarity                         | RXD sampling<br>-2nd edge                                              |
|                              | Master      | Frame  | (Full-duplex)<br>Transmit,<br>Receive | Continuous<br>burst | 8 to<br>32               | 16 <b>×</b> 8<br>32 <b>×</b> 4 | Transfer                         | Interrupt<br>DMA<br>Trigger<br>-Start                          | SCK<br>polarity<br>TXD<br>-Idle period                    | RXD sampling<br>-1st edge                                              |
|                              | operation   | Sector |                                       | Continuous          | 8 to<br>128              | 32 <b>×</b> 4                  | -MSB<br>-LSB                     | -Complete<br>transmit<br>-Complete<br>receive                  |                                                           | Frame interval<br>Idle time                                            |
| SIO                          | Slave       | Frame  |                                       | Continuous<br>burst | 8 to<br>32               | 16 <b>×</b> 8<br>32 <b>×</b> 4 |                                  | Interrupt<br>DMA<br>Trigger<br>-Complete                       | SCK<br>polarity<br>TXD                                    | RXD sampling<br>-1st edge<br>-2nd edge<br>TXD last data<br>hold period |
|                              | operation - | Sector |                                       | Continuous 8 to 128 | 32 <b>×</b> 4            |                                | transmit<br>-Complete<br>receive | -Idle period<br>-Underrun<br>error                             | RXD sampling<br>-2nd edge<br>TXD last data<br>hold period |                                                                        |

# 3.3.1. SPI / SIO Mode Selection

The SPI mode or the SIO mode is selected. When *[TSPIxCR1]*<TSPIMS> (communication mode selection register) is set to "0", the SPI mode is selected. When it is set to "1", the SIO mode is selected.

(1) SPI mode

In SPI mode, you can communicate as a master or slave by using the terminals of TSPIxSCK(clock input/output), TSPIxCS0/1/2/3(Chip select output), TSPIxCSIN(Chip select input), TSPIxTXD(data transmit), and TSPIxRXD(data receive).

In addition, it has four built-in chip select signal outputs (TSPIxCS0 / 1/2/3), and can communicate with four external slave devices as a master device. Moreover, it has one built-in chip select signal input (TSPIxCSIN) and can communicate with one master device as a slave device.

Note: The number of chip select outputs(TSPIxCS0/1/2/3) are different product by product. Refer to the datasheet and reference manual "Product Information".

### (2) SIO mode

In SIO mode, you can use TSPIxSCK, TSPIxTXD, and TSPIxRXD to communicate as master or slave. Master and slave devices communicate one-to-one.

Note: When using SIO mode, do not select TSPIxCS0/1/2/3 and TSPIxCSIN in the port setting.

## 3.3.2. Master / Slave Selection

The master device operation (output clock) or the slave device operation (input clock) is selected. When *[TSPIxCR1]*<MSTR>(Master / Slave selection register) is set to "0", the TSPI operates as Slave. When *[TSPIxCR1]*<MSTR> is set to "1", the TSPI operates as Master.

• Master device operation

The TSPI outputs a clock from TSPIxSCK and operates synchronously with TSPIxSCK. In the SPI mode, the chip select signal is output from TSPIxCS0/1/2/3 to select the slave device.

• Slave device operation

The TSPI receives a clock from TSPIxSCK and operates synchronously with TSPIxSCK.

In the SPI mode, when not selected by the chip select signal input from TSPIxCSIN, the input to TSPIxSCK is ignored. However, from the start of TSPIxCSIN deassertion to the first edge of the serial clock during TSPIxCSIN deassertion, separate one cycle of the maximum speed of the TSPI slave mode used by the product.

## 3.3.3. Frame / Sector selection

The frame mode or the sector mode is selected. When *[TSPIxSECTCR0]*<SECT> (sector mode control register 0) is set to "0" (initial value), the frame mode is selected. When it is set to "1", the sector mode is selected. The sector mode is selected in case of a frame with 2 to 4 sectors with different lengths or a frame that exceeds 32 bits in length. For details of the sector mode, refer to "3.6.2 Sector mode".

# 3.4. Communication Operation Mode

# 3.4.1. Transmit and receive (Full-Duplex) Communication Mode

Figure 3.2 shows an example of operation for continuous transmit and receive (full-duplex) communication when master operation, frame length 32 bits, no parity, and one stage of FIFO is used.(*[TSPIxCR2]*<TIDLE[1:0]>=10)



### Figure 3.2 Operation example of transmit and receive(full-duplex) communication

- a) Write "1" to *[TSPIxCR1]*<TRXE> to enable communications.
- b) Write data to [TSPIxDR].
- c) When data is written to [TSPIxDR], it is buffered in order from the bottom of the internal transmit FIFO.
- d) Since one stage of data is buffered in the transmit FIFO, *[TSPIxSR]*<TLVL[3:0]> becomes "1".
- e) The data buffered to the transmit FIFO is moved to the shift register and *[TSPIxSR]*<TLVL[3:0]> is set to "0". After the cycle following the CS assertion configured with *[TSPIxFMTR0]*<CSSCKDL[3:0]> (cycle register following the CS assertion) has elapsed (ta), TSPIxSCK starts outputting a serial clock.
- f) Since [*TSPIxSR*]<TLVL[3:0]> changes to "0" from "1", a transmit FIFO interrupt or transmit DMA request occurs.
- g) All bits of the received data are loaded to the receive shift register and moved to the receive FIFO on the rising edge of the last serial clock. After the cycle preceding the CS assertion configured with *[TSPIxFMTR0]*<SCKCSDL[3:0]> (cycle register preceding the CS deassertion) has elapsed (tb),

SPIxCS0 is deasserted so that a transmit completion interrupt and a receive completion interrupt occur.

- h) [TSPIxSR] <RLVL [3: 0]> becomes "1" because the data for one stage is buffered in the receive FIFO.
- i) Since *[TSPIxSR]*<RLVL[3:0]> changes to "1" from "0", a receive FIFO interrupt or receive DMA request occurs.
- j) Until the idle period (td) specified by *[TSPIxFMTR0]*<CSINT[3:0]> has elapsed after TSPIxCS0 is deasserted, the serial transfer does not start and TSPIxCS0 remains deasserted. After the idle period (td) has elapsed, TSPIxCS0 is asserted and serial transfer starts.

## 3.4.2. Transmit Mode

Figure 3.3 shows an example of continuous transfer operation in transmit mode when master operation, frame length 32 bits, no parity, and one stage of FIFO is used. (*[TSPIxCR2]*<TIDLE[1:0]>=10)

|                                           | a)                  | 1          |             |
|-------------------------------------------|---------------------|------------|-------------|
| [TSPIxCR1] <trxe></trxe>                  | b)                  |            |             |
| [TSPIxDR]                                 | <u> </u>            |            | <u>(</u> ψ) |
| (Transmit FIFO)                           |                     |            |             |
| Transmit shift register                   |                     |            |             |
| TSPIxCS0(Negative logic)                  |                     | F          |             |
| TSPIxSCK                                  |                     |            |             |
| TSPIxTXD                                  | ulpdified TDn TDn-1 |            |             |
| TSPIxRXD                                  | Don't care          |            |             |
| (Receive FIFO)                            |                     |            |             |
| Receive shift register                    |                     |            |             |
| <b>[TSPIxSR]</b> <tlvl[3:0]></tlvl[3:0]>  |                     |            |             |
| [ <b>TSPIxSR]</b> <rlvl[3:0]></rlvl[3:0]> | 0                   | 0          |             |
| Trasnmit FIFO interrupt                   | ( ↓ f)              |            |             |
| Trasnmit completion interrupt             |                     | <b></b> g) |             |
| Receive FIFO interrupt                    |                     |            |             |
| Receive completion                        |                     |            |             |
| Trasnmit DMA request                      | f)                  |            | <u> </u>    |
| Receive DMA request                       |                     |            |             |

### Figure 3.3 Operation example of transmit mode

- a) Write "1" to *[TSPIxCR1]*<TRXE> to enable the communications.
- b) Write data to **[TSPIxDR]**.
- c) When the data is written to *[TSPIxDR]*, the buffer starts from the lower stage of the internal transmit FIFO.
- d) Since one stage of data is buffered to the transmit FIFO, *[TSPIxSR]*<TLVL[3:0]> becomes "1".
- e) The data buffered to the transmit FIFO is moved to the shift register, and [TSPIxSR]<TLVL[3:0]> becomes "0". After the CS assert cycle (ta) set in [TSPIxFMTR0]<CSSCKDL[3:0]> has elapsed, the serial clock output starts from TSPIxSCK.
- f) Since *[TSPIxSR]*<TLVL[3:0]> changed to "0" from "1", a transmit FIFO interrupt or transmit DMA request occurs.
- g) Until the idle period (td) specified by *[TSPIxFMTR0]*<CSINT[3:0]> has elapsed after TSPIxCS0 is deasserted, the serial transfer does not start and TSPIxCS0 remains deasserted. After the idle period (td) has elapsed, TSPIxCS0 is asserted and serial transfer starts.

## 3.4.3. Receive Mode

Figure 3.4 Figure 3.4 shows an example of continuous transfer operation in receive mode when master operation, frame length 32 bits, no parity, and one stage of FIFO is used. (*[TSPIxCR2]*<TIDLE[1:0]>=10).

| [TSPIxCR1] <trxe></trxe>                 | a)                                                                                                                                                                                                            |                                                                                                                       |                   |
|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-------------------|
| [TSPIxDR]                                |                                                                                                                                                                                                               | (R)                                                                                                                   |                   |
| (Transmit FIFO)                          |                                                                                                                                                                                                               |                                                                                                                       |                   |
| Transmit shift register                  |                                                                                                                                                                                                               |                                                                                                                       |                   |
| TSPIxCS0(Negative logic)                 | a) ¢                                                                                                                                                                                                          |                                                                                                                       | t <sub>d</sub> g) |
| TSPIxSCK                                 |                                                                                                                                                                                                               | $ \begin{array}{c} \hline \\ \hline $ |                   |
| TSPIxTXD                                 |                                                                                                                                                                                                               |                                                                                                                       |                   |
| TSPIxRXD                                 | $\left( \begin{array}{c} Rb_n \\ Rb_{n-1} \\ \end{array} \right) \left( \begin{array}{c} Rb_{n-1} \\ Rb_{n-1} \\ \end{array} \right) \left( \begin{array}{c} 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 $ |                                                                                                                       |                   |
| (Receive FIFO)                           |                                                                                                                                                                                                               |                                                                                                                       |                   |
| -<br>Receive shift register<br>-         | <u> </u>                                                                                                                                                                                                      |                                                                                                                       | <u> </u>          |
| <b>[TSPIxSR]</b> <tlvl[3:0]></tlvl[3:0]> | 0                                                                                                                                                                                                             |                                                                                                                       |                   |
| [TSPIxSR] <rlvl[3:0]></rlvl[3:0]>        | 0                                                                                                                                                                                                             |                                                                                                                       | 0                 |
| Trasnmit FIFO interrupt                  |                                                                                                                                                                                                               |                                                                                                                       |                   |
| Trasnmit completion interrupt            |                                                                                                                                                                                                               |                                                                                                                       |                   |
| Receive FIFO interrupt                   |                                                                                                                                                                                                               | e)                                                                                                                    |                   |
| Receive completion interrupt             |                                                                                                                                                                                                               |                                                                                                                       |                   |
| Trasnmit DMA request                     |                                                                                                                                                                                                               |                                                                                                                       |                   |
| Receive DMA request                      |                                                                                                                                                                                                               | e)                                                                                                                    |                   |

### Figure 3.4 Operation example in receive mode

- a) Write "1" to *[TSPIxCR1]*<TRXE> to enable the communications. Since receive FIFO is not full, TSPIxCS0 is immediately asserted and serial transfer starts.
- b) After the cycle following the CS assertion (ta) specified by *[TSPIxFMTR0]*<CSSCKDL[3:0]> has elapsed, the serial clock starts outputting from TSPIxSCK.
- c) On the last rising edge of the serial clock, all bits of receive data are captured in the receive shift register and moved to the receive FIFO.
- d) Since one stage of data is buffered to the receive FIFO, [TSPIxSR]<RLVL[3:0]> becomes "1".
- e) Since [*TSPIxSR*]<RLVL[3:0]> changed to "1" from "0", a receive FIFO interrupt or receive DMA request occurs.
- f) After the cycle preceding the CS deassertion (tb) specified by [TSPIxFMTR0]<SCKCSDL[3:0]> has elapsed after the last rising edge of the serial clock, TSPIxCS0 is deasserted and a receive completion interrupt occurs.
- g) Until the idle period (td) specified by *[TSPIxFMTR0]*<CSINT[3:0]> has elapsed after TSPIxCS0 is deasserted, the serial transfer does not start and TSPIxCS0 remains deasserted. After the idle period (td) has elapsed, TSPIxCS0 is asserted and serial transfer starts if the receive FIFO is not full.

# 3.5. Transfer Mode

There are two types of transfer mode; the burst transfer in which the transfer frame count (1 to 255) is specified for a transfer, and the continuous transfer where the transfer frame count is not specified.

The transfer mode and the frame count can be specified on *[TSPIxCR1]*<FC[7:0]> (transfer frame count configuration register)

| Frame / Sector selection | Transfer mode  |                     |  |  |
|--------------------------|----------------|---------------------|--|--|
|                          | Burst transfer | Continuous transfer |  |  |
| Frame mode               | $\checkmark$   | ✓                   |  |  |
| Sector mode              | ×              | ✓                   |  |  |

Table 3.5 Transfer mode compatibility

## 3.5.1. Burst Transfer

Burst transfer is a transfer mode where the frame count from 1 to 255, infinite times of transfer is specified. For master in SPI mode, TSPIxCS0/1/2/3 keeps asserted condition while specified frames are transferring. TSPIxCS0/1/2/3 is deasserted when the transfer of frame is completed.

Burst transfer can be used in the frame mode.

## 3.5.2. Continuously Transfer

It is the mode which repeats the burst transfer of one frame without specifying the number of transfer frames. In SPI mode, in the case of a master, TSPIxCSO/1/2/3 are certainly deasserted for every one-frame transfer, and TSPIxCSO/1/2/3 are asserted at the time of transfer of the following frame.

- Note1: At transmit in the Slave mode, when the serial transfer is performed with the setting data sampling on the 1st edge (*[TSPIxFMTR0]*<CKPHA>=0), the underrun flag is set to "1" (*[TSPIxERR]*<UDRERR>=1) just after the final data transmit.
- Note2: At receive in the Slave mode, when the serial transfer is performed with the setting data sampling on the 1st edge ([*TSPIxFMTR0*]<CKPHA>=0), and the receive is continued in the FIFO full state ([*TSPIxSR*]<RFFLL>=1), the overrun flag is set to "1" ([*TSPIxERR*]<OVERR>=1) just after the final data receive.

The following 2 modes are available for a continuous transfer.

Frame mode

• Transfer mode where a transfer is conducted with a frame unit with the length of 8 to 32 bits.

Sector mode

- Transfer mode where a transfer is conducted with a frame unit with the length of 8 to 128 bits.
- One frame consists of 2-4 sectors.
- The sector length for each sector can be configured in the following range. Master operation: 1 to 32 bits

# TOSHIBA

For details of the sector mode, refer to "3.6.2. Sector mode".

# 3.6. Data format

The frame mode and the sector mode are available as a data format. When choosing the sector mode, configure [*TSPIxSECTCR0*] (sector mode control register 0). To specify the sector length, configure [*TSPIxSECTCR1*] (sector mode control register 1). To choose the transfer direction (MSB first / LSB first), configure [*TSPIxFMTR0*] (format control register 0). To set the parity (with / no parity) and the type (even / odd), configure [*TSPIxFMTR1*] (format control register 1). Note that the data other than the received data are "0" when reading out the data register [*TSPIxDR*] (RD\_31 to RD\_0).

## 3.6.1. Frame mode

In the frame mode, the burst transfer or the continuous transfer is available when transferring a frame of length from 8 to 32 bits.

The data format for the frame mode is shown in Figure 3.5.

| ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Frame Length (8to16bits)         MSB           D15         D14         D9         D8         D7         D6         D1         D0         Pa           D14         D13         C         D8         D7         D6         D0         P         Pa       | First<br>No<br>arity<br>/ith                   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| Frame length           D31         D30         \(\screwtrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrightarrowtextrowtextrightarrowte | n (17to32bits)                                                                                                                                                                                                                                         | Arity<br>No<br>Irity<br>/ith<br>Arity          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Frame length (8to16bits)         LSE           D15         D14         D9         D8         D7         D6         D1         D0         Pairs           P         D14         D9         D8         D7         D6         D1         D0         Pairs | <b>3 First</b><br>No<br>arity<br>Vith<br>arity |
| Frame lengt           D31         D30         D25         D24         D23         D22         D17         D16           P         D30         D25         D24         D23         D22         D17         D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | h (17to32bits)<br>D15 D14 \(\sqrt{D9} D8 D7 D6 \(\sqrt{D1} D1 D0 Pa<br>D15 D14 \(\sqrt{D9} D8 D7 D6 \(\sqrt{D1} D1 D0 Pa<br>Pa<br>D15 D14 \(\sqrt{D9} D8 D7 D6 \(\sqrt{D1} D1 D0 Pa<br>Pa                                                              | No<br>arity<br>Vith<br>arity                   |

Figure 3.5 Data format overview for the frame mode

No parity

The frame length should be set to the same value as the data length. When the data length is 31 bits, configure *[TSPIxFMTR0]*<FL[5:0]> = 011111.

With parity

The frame length should be set to the same value as the data length plus 1 bit, which is a bit length for the parity. Since the frame length is from 8 to 32 bits, the data length is from 7 to 31 bits. When the data length is 31 bits, configure *[TSPIxFMTR0]*<FL[5:0]> = 100000. For transmit, the parity bit is added to the data in transmit FIFO and is moved to the transmit shift register. For receives, the parity bit is removed from the data in the receive shift register and is moved to the receive FIFO.

## 3.6.1.1. Buffer Structure and Operation

The transmit buffer and the receive buffer are independent of each other. Each buffer has a double buffer structure that consists of the FIFO and the shift register with the length of 32-bit and can be accessed in the data register *[TSPIxDR]*.

There are the transmit FIFO and receive FIFO. Each FIFO is 16-bit width and 8-stage or 32-bit width and 4-stage. Settable FIFO level varies depending on the Frame length.

The ranges for the configurable fill levels corresponding to various frame lengths are shown in Table 3.6.

|               | Settable Fill level                                       |                                                  |  |  |  |  |  |  |  |  |
|---------------|-----------------------------------------------------------|--------------------------------------------------|--|--|--|--|--|--|--|--|
| Frame length  | Transmit FIFO<br>[ <i>TSPIxCR2]</i> <til[3:0]></til[3:0]> | Receive FIFO<br>[TSPIxCR2] <ril[3:0]></ril[3:0]> |  |  |  |  |  |  |  |  |
| 8 to 16 bits  | 0 to 7                                                    | 1 to 8                                           |  |  |  |  |  |  |  |  |
| 17 to 32 bits | 0 to 3                                                    | 1 to 4                                           |  |  |  |  |  |  |  |  |

| Table 3.0 Frame mode settable milleve | Table 3.6 | Frame mode settable fill leve |
|---------------------------------------|-----------|-------------------------------|
|---------------------------------------|-----------|-------------------------------|

Note: Set a value within the settable fill level. If the value is outside of the settable fill level, the operation is not guaranteed.

| Condition                 | With / No parity | Transfer direction | Frame length |  |  |  |
|---------------------------|------------------|--------------------|--------------|--|--|--|
| Frame mode<br>operation 1 | No pority        | MSB first          | 32 bits      |  |  |  |
| Frame mode<br>operation 2 | No panty         | LSB first          | 8 bits       |  |  |  |
| Frame mode<br>operation 3 | With pority      | MSB first          | 16 bits      |  |  |  |
| Frame mode<br>operation 4 | with parity      | LSB first          | 24 bits      |  |  |  |

 Table 3.7
 Data format examples for the frame mode

The conditions for the operation 1 to 4 in "Table 3.7 Data format examples for the frame mode" are described.

The transmit operations are the process from writing to the data register of the transmit data to output the transmit shift register. The receive operations are the process from inputting the receive data to the receive shift register to read from the data register.

In the figure, the notation of each data is WR\_31 to WR\_0 for the write data of the data register *[TSPIxDR]*, RD\_31 to RD\_0 for the read data, TXD31 to TXD0 for the transmit shift register data, RXD31 to RXD0 for the receive shift register data, and FIFO.

The frame n data in the frame is represented by  $fn_31$  to  $fn_0$  (n = 0 to 3 for the FIFO fill level of 4, n = 0 to 7 for the FIFO fill level of 8), and the parity bit is shown as P.

# 3.6.1.2. Frame mode operation 1 (No parity, MSB first)

The following figure shows an example of transmit no parity, MSB first, frame length of 17 to 32 bits, FIFO fill level of 4 stages.

|              | <b>∢</b><br>MSB |          |                           |       |          |          | Fra                       | ame len  | gth (17    | to 32b     | its)                                    |       |            |       |                           |            | LSB      |                            |
|--------------|-----------------|----------|---------------------------|-------|----------|----------|---------------------------|----------|------------|------------|-----------------------------------------|-------|------------|-------|---------------------------|------------|----------|----------------------------|
|              | D31             | D30      | $\mathbb{S}$              | D24   | D23      | D22      | S                         | D16      | D15        | D14        | $\int$                                  | D8    | D7         | D6    | S                         | D1         | D0       |                            |
| <b>—</b> · - | <u> </u>        | · · —    | · ·                       | _ · _ | <u> </u> | · ·      | <u> </u>                  | <u> </u> | · — ·      | <u> </u>   | — · —                                   | · _ · | · ·        | _ · _ | ••• <b>—</b>              | · ·        | — · –    | - · ·                      |
|              | WR_31           | WR_30    |                           | WR_24 | WR_23    | WR_22    |                           | WR_16    | WR_15      | WR_14      |                                         | WR_8  | WR_7       | WR_6  |                           | WR_1       | WR_0     | Data Register              |
|              |                 |          |                           | ····  |          |          |                           |          |            | <u>-</u>   |                                         |       | ····       |       |                           | ···•       | <u> </u> |                            |
|              | f3_31           | f3_30    | $\mathbb{S}$              | f3_24 | f3_23    | f3_22    | S                         | f3_16    | f3_15      | f3_14      | S                                       | f3_8  | f3_7       | f3_6  | S                         | f3_1       | f3_0     | Stage4                     |
|              | f2_31           | f2_30    | $\int$                    | f2_24 | f2_23    | f2_22    | $\int$                    | f2_16    | f2_15      | f2_14      | $\int$                                  | f2_8  | f2_7       | f2_6  | S                         | f2_1       | f2_0     | Stage3<br>Transmit         |
|              | f1_31           | f1_30    | $\int$                    | f1_24 | f1_23    | f1_22    | $\int$                    | f1_16    | f1_15      | f1_14      | $\langle \rangle$                       | f1_8  | f1_7       | f1_6  | $\int$                    | f1_1       | f1_0     | FIFO<br>Stage2             |
|              | f0_31           | f0_30    | $\int$                    | f0_24 | f0_23    | f0_22    | $\mathbb{S}$              | f0_16    | f0_15      | f0_14      | $\int$                                  | f0_8  | f0_7       | f0_6  | $\mathbb{S}$              | f0_1       | f0_0     | Stgae1                     |
| L            |                 | <u>+</u> |                           |       |          | <u>+</u> |                           |          | · <u>-</u> |            |                                         |       | <u>+</u>   |       |                           | · <u>+</u> |          |                            |
| ←            | TXD31           | TXD30    | S                         | TXD24 | TXD23    | TXD22    | S                         | TXD16    | TXD15      | TXD14      | S                                       | TXD8  | TXD7       | TXD6  | S                         | TXD1       | TXD0     | Transmit<br>Shift Register |
| <u> </u>     | <u> </u>        | - ·      | · _ ·                     |       | _ ·      | · ·      | <u> </u>                  |          | · · ·      | . <u> </u> |                                         | · ·   | · ·        | _ · _ |                           |            | <u> </u> | _ · _ · _                  |
|              | RXD31           | RXD30    | $\langle \langle \rangle$ | RXD24 | RXD23    | RXD22    | $\langle \langle \rangle$ | RXD16    | RXD15      | RXD14      | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | RXD8  | RXD7       | RXD6  | $\langle \langle \rangle$ | RXD1       | RXD0     | Receive                    |
|              |                 |          |                           | ·     |          |          |                           |          |            |            |                                         |       | · <u>+</u> |       |                           |            |          | - Shirt Register           |
|              | f3_31           | f3_30    | S                         | f3_24 | f3_23    | f3_22    | S                         | f3_16    | f3_15      | f3_14      | $\mathbb{S}$                            | f3_8  | f3_7       | f3_6  | $\int$                    | f3_1       | f3_0     | Stage4                     |
|              | f2_31           | f2_30    | $\square$                 | f2_24 | f2_23    | f2_22    | S                         | f2_16    | f2_15      | f2_14      | $\square$                               | f2_8  | f2_7       | f2_6  | $\square$                 | f2_1       | f2_0     | Stage3<br>Receive          |
|              | f1_31           | f1_30    | $\mathbb{S}$              | f1_24 | f1_23    | f1_22    | S                         | f1_16    | f1_15      | f1_14      | S                                       | f1_8  | f1_7       | f1_6  | S                         | f1_1       | f1_0     | FIFO<br>Stage2             |
|              | f0_31           | f0_30    | S                         | f0_24 | f0_23    | f0_22    | S                         | f0_16    | f0_15      | f0_14      | S                                       | f0_8  | f0_7       | f0_6  | S                         | f0_1       | f0_0     | Stage1                     |
| L            |                 |          |                           |       |          |          |                           |          |            |            |                                         |       |            |       |                           |            |          |                            |
|              | RD_31           | RD_30    |                           | RD_24 | RD_23    | RD_22    |                           | RD_16    | RD_15      | RD_14      |                                         | RD_8  | RD_7       | RD_6  |                           | RD_1       | RD_0     | Data Register              |

Figure 3.6 Buffer operation in Frame mode (No Parity / MSB first)

Stop condition: *[TSPIxSR]* <TSPISUE> = 0 and *[TSPIxCR1]* <TRGEN> = 0, <TRXE> = 0

(1) Transmit buffer operation

The transmit data are written by the CPU or DMAC to the data register **[TSPIxDR]** when the operation is stopped or during communication, and are stacked to the first level when the transmit FIFO is empty. The data are stacked to the second level when the first level is already filled with data.

Also, when the transmit buffer is empty, the transmit data written after the communication is enabled are immediately transferred to the transmit shift register, and the transmit starts. For slave operations, make sure that an underrun error does not occur. (Refer to "3.7.3. Error Interrupt")

Figure 3.6 shows the transmit data from the frames f0 to f3 saved on the transmit FIFO level 1 to 4 stages. When the operation is enabled to start communications after being stopped or the transmit of a frame has been completed, the data on the first level of the transmit FIFO are moved to the transmit shift register and are transmitted. At the same time, the data on level 2 to 4 stages are moved to level 1 to 3 stages. The transmit data within the transmit shift register are transmitted for each serial clock, starting from MSB (f0\_31) in the frame f0.

(2) Receive buffer operation

For each frame received during communications, the data within the receive shift register are stacked to the first level stage when the receive FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data.

Figure 3.6 shows the receive data from the frames f0 to f3 saved on the receive FIFO level 1 to 4 stages. The received data are saved in the receive shift register for each serial clock, starting from MSB (f0\_31) in the frame f0, and are stacked to the lowest level of the receive FIFO whenever a frame is received. From the data register *[TSPIxDR]*, the CPU or DMAC reads out the data on the first level stage of the receive FIFO. At the same time, the data on level 2 to 4 stages are moved to level 1 to 3 stages.
# 3.6.1.3. Frame mode operation 2 (No parity, LSB first)

The following figure shows an example of transmit no parity, LSB first, frame length of 8 to 16 bits, FIFO fill level of 8 stages.



Figure 3.7 Buffer Operation in Frame mode (No Parity / LSB First)

(1) Transmit buffer operation

The transmit data are written by the CPU or DMAC to the data register **[TSPIxDR]** when the operation is stopped or during communication, and are stacked to the first level stage when the transmit FIFO is empty. The data are stacked to the second level stage when the first level is already filled with data.

Also, when the transmit buffer is empty, the transmit data written after the communication is enabled are immediately transferred to the transmit shift register, and the transmit starts. For slave operations, make sure that an underrun error does not occur. (Refer to "3.7.3. Error Interrupt")

Figure 3.7 Shows the transmit data in the frames f0 to f7 saved on level 1 to 8 stages of the transmit FIFO. When the operation is enabled to start communications after being stopped or the frames in the transmit have been transmitted, the data on the first level stage of the transmit FIFO are moved to the transmit shift register and are transmitted. At the same time, the data on level 2 to 4 are moved to level 1 to 3stages. The transmit data in the transmit shift register are transmitted for each serial clock, starting from LSB (f0\_0) in the frame f0.

(2) Receive buffer operation

For each frame received during communications, the data within the receive shift register are stacked to the first level stage when the receive FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data.

Figure 3.7 Shows the received data in the frames f0 to f7 saved on the level 1 to 8 stages of the receive FIFO. The received data are saved in the received shift register for each serial clock, starting from LSB (f0\_0) in the frame f0, and are stacked to the lowest level stage of the received FIFO whenever a frame is received. From the data register *[TSPIxDR]*, the CPU or DMAC are read out the data on the first level stage of the receive FIFO. At the same time, the data on level 2 to 4 stages are moved to level 1 to 3 stages.

## 3.6.1.4. Frame mode operation 3 (with parity, MSB first)

The following figure shows an example of transmit with parity, MSB first, frame length 8 to 16 bits, FIFO fill level of 8 stages.



Figure 3.8 Buffer operation in frame mode (with parity, MSB first)

(1) Transmit buffer operation

The transmit data are written by the CPU or DMAC to the data register *[TSPIxDR]* when the operation are stopped or during communication, and are stacked to the first level stage when the transmit FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data. Also, when the transmit buffer is empty, the transmit data written after the communication is enabled are immediately transferred to the transmit shift register, and the transmit starts. For slave operations, make sure that an underrun error does not occur. (Refer to "3.7.3. Error Interrupt")

Figure 3.8 shows the transmit data in the frames f0 to f7 saved on level 1 to 8 stages of the transmit FIFO. When the operation is enabled to start communications after being stopped or the frames in the transmit have been transmitted, the data on the first level stage of the transmit FIFO have the parity bit added to LSB, are moved to the transmit shift register and are transmitted. At the same time, the data on level 2 to 8 stages are moved to level 1 to 7stages.

The transmit data in the transmit shift register are transmitted for each serial clock, starting from MSB  $(f0_14)$  in the frame f0.

(2) Receive buffer operation

For each frame received during communications, the data in the receive shift register are stacked to the first level stage when the receive FIFO is empty. The data are stacked to the second level when the first level stage is already filled with data.

Figure 3.8 shows the received data in the frames f0 to f7 saved on level 1 to 8 stages of the receive FIFO. The received data are saved in the receive shift register for each serial clock, starting from MSB (f0\_14) in the frame f0. Every time a frame is received, the parity bit is removed from LSB and the received data are stacked to the lowest level stage of the receive FIFO.

From the data register **[TSPIxDR]**, the CPU or DMAC read out the data on the first level stage of the receive FIFO. At the same time, the data on level 2 to 8 stages are moved to level 1 to 7 stages.

# 3.6.1.5. Frame mode operation 4 (with parity, LSB first)

The following figure shows an example of transmit with parity, LSB first, frame length of 17 to 32 bits, FIFO fill level of 4 stages.

|       |       |                           |          | MSB   |            | Fra                       | ame ler | ngth (17   | ' to 32b | its)                      |       |       |                     |                           |           | LSB        | ł                 |
|-------|-------|---------------------------|----------|-------|------------|---------------------------|---------|------------|----------|---------------------------|-------|-------|---------------------|---------------------------|-----------|------------|-------------------|
| D31   | D30   | S                         | D24      | Ρ     | D22        | S                         | D16     | D15        | D14      | S                         | D8    | D7    | D6                  | $\int$                    | D1        | D0         | ]                 |
|       | · · · | _ · _                     | - ·      | · ·   | <u> </u>   | - ·                       | · — ·   | · -        | _ · _    | • —                       | · · · | _ · _ | · · —               | · <u> </u>                | _ · -     | - ·        | · _ · _ ·         |
| WR_31 | WR_30 |                           | WR_24    | WR_23 | WR_22      |                           | WR_16   | WR_15      | WR_14    |                           | WR_8  | WR_7  | WR_6                |                           | WR_1      | WR_0       | Data Register     |
| f3_31 | f3_30 |                           | f3_24    | f3_23 | ₩<br>f3_22 | $\langle \langle \rangle$ | f3_16   | f3_15      | f3_14    | $\langle \langle \rangle$ | f3_8  | f3_7  | f3_6                | $\langle \langle \rangle$ | ₩<br>f3_1 | ₩<br>f3_0  | Stage4            |
| f2_31 | f2_30 | $\langle \langle \rangle$ | f2_24    | f2_23 | f2_22      | $\langle \langle \rangle$ | f2_16   | f2_15      | f2_14    | $\langle \langle \rangle$ | f2_8  | f2_7  | f2_6                | $\langle \langle \rangle$ | f2_1      | f2_0       | Stage3 Transmit   |
| f1_31 | f1_30 |                           | f1_24    | f1_23 | f1_22      | S                         | f1_16   | f1_15      | f1_14    | S                         | f1_8  | f1_7  | f1_6                | S                         | f1_1      | f1_0       | FIFO<br>Stage2    |
| f0_31 | f0_30 |                           | f0_24    | f0_23 | f0_22      | $\int$                    | f0_16   | f0_15      | f0_14    | S                         | f0_8  | f0_7  | f0_6                | S                         | f0_1      | f0_0       | Stage1            |
|       |       |                           |          |       |            |                           | ····•   |            |          |                           | ·•    |       |                     |                           |           |            |                   |
| TXD31 | TXD30 |                           | TXD24    | Ρ     | TXD22      | S                         | TXD16   | TXD15      | TXD14    | S                         | TXD8  | TXD7  | TXD6                | S                         | TXD1      | TXD0       | Shift Regist      |
| - ·   | · — · | <u> </u>                  | <u> </u> | · — · |            | _ · _                     | - · —   | · <u> </u> | <u> </u> | · · —                     | · — · | — · – | <b>-</b> · <b>-</b> | · <u> </u>                | — · -     | - ·        | · · <u> </u>      |
| RXD31 | RXD30 | $\int$                    | RXD24    | Р     | RXD22      | $\langle \langle \rangle$ | RXD16   | RXD15      | RXD14    | $\int$                    | RXD8  | RXD7  | RXD6                | $\square$                 | RXD1      | RXD0       | Receive<br>Shift  |
|       |       |                           |          |       |            |                           |         |            |          |                           | ‡     |       |                     |                           |           | · <u>↓</u> | Register          |
| f3_31 | f3_30 | $\sum$                    | f3_24    | f3_23 | f3_22      | $\mathbb{S}$              | f3_16   | f3_15      | f3_14    | $\square$                 | f3_8  | f3_7  | f3_6                | S                         | f3_1      | f3_0       | Stage4            |
| f2_31 | f2_30 | $\sum$                    | f2_24    | f2_23 | f2_22      | $\mathbb{S}$              | f2_16   | f2_15      | f2_14    | $\mathbb{S}$              | f2_8  | f2_7  | f2_6                | S                         | f2_1      | f2_0       | Stage3<br>Receive |
| f1_31 | f1_30 | $\sum$                    | f1_24    | f1_23 | f1_22      | $\square$                 | f1_16   | f1_15      | f1_14    | $\square$                 | f1_8  | f1_7  | f1_6                | $\square$                 | f1_1      | f1_0       | FIFO<br>Stage2    |
| f0_31 | f0_30 | $\sum$                    | f0_24    | f0_23 | f0_22      | $\int$                    | f0_16   | f0_15      | f0_14    | $\int$                    | f0_8  | f0_7  | f0_6                |                           | f0_1      | f0_0       | Stage1            |
|       |       |                           |          |       |            |                           | ·ŧ      |            |          |                           | ·     |       | ·                   |                           | ···ŧ-··   | <u></u> ‡  |                   |
| RD_31 | RD_30 |                           | RD_24    | RD_23 | RD_22      |                           | RD_16   | RD_15      | RD_14    |                           | RD_8  | RD_7  | RD_6                |                           | RD_1      | RD_0       | Data Registe      |

Figure 3.9 Buffer operation of the frame mode (with parity, LSB first)

(1) Transmit buffer operation

The transmit data are written by the CPU or DMAC to the data register *[TSPIxDR]* when the operation is stopped or during communication, and are stacked to the first level when the transmit FIFO is empty. The data are stacked to the second level when the first level is already filled with data.

Also, when the transmit buffer is empty, the transmit data written after the communication is enabled are immediately transferred to the transmit shift register, and the transmit starts. For slave operations, make sure that an underrun error does not occur. (Refer to "3.7.3. Error Interrupt")

Figure 3.9 shows the transmit data from the frames f0 to f3 saved on the transmit FIFO level 1 to 4. When the state is changed from stopped to enabled communication or when frame transmit is completed, the parity bit is added to MSB of the data in the first level of the transmit FIFO, before it is moved to the transmit shift register and the transmit starts. At the same time, the data on level 2 to 4 are moved to level 1 to 3. The transmit data in the transmit shift register are transmitted for each serial clock, starting from LSB (f0\_0) in the frame f0.

(2) Receive buffer operation

For each frame received during communications, the data in the receive shift register are stacked to the first level when the receive FIFO is empty. The data are stacked to the second level when the first level is already filled with data.

Figure 3.9 shows the receive data from the frames f0 to f3 saved on the receive FIFO level 1 to 4. The received data are saved in the receive shift register for each serial clock, starting from LSB (f0\_0) in the frame f0. Every time a frame is received, the parity bit is removed from MSB and the received data are stacked to the lowest level of the receive FIFO.

From the data register *[TSPIxDR]*, the CPU or DMAC read out the data on the first level of the receive FIFO. At the same time, the data on level 2 to 4 are moved to level 1 to 3.

# 3.6.1.6. Transfer cycle for master operations

The number of cycles for frame transfer for master operation is as follows.

|     | Total cycles                                       | Transfer cycl                    | e (equivalent of the            | CS assertion    | period in the SPI | mode operation)       |                             |
|-----|----------------------------------------------------|----------------------------------|---------------------------------|-----------------|-------------------|-----------------------|-----------------------------|
|     | No.1.2: Burst transfer                             | Cycle                            | Cycle                           | Frame           | Burst t           | ransfer               | Continuous                  |
| No. | a+b+c×d+(d-1)×e<br>No.3, 4: Continuous<br>transfer | following<br>the CS<br>assertion | preceding the<br>CS deassertion | length<br>[bit] | Frame count       | Frame interval period | idle period<br>for transfer |
|     | a+b+c+g                                            | a:1 to 16                        | b: 1 to 16                      | c:8 to 32       | d:1 to 255        | e:0 to 15             | g:1 to 15                   |
| 1   | 10 to 34                                           | 1                                | 1                               | 8 to 32         | 1                 | 0                     | -                           |
| 2   | 5882 to 12002                                      | 16                               | 16                              | 8 to 32         | 255               | 15                    | -                           |
| 3   | 11 to 35                                           | 1                                | 1                               | 8 to 32         | -                 | -                     | 1                           |
| 4   | 55 to 79                                           | 16                               | 16                              | 8 to 32         | -                 | -                     | 15                          |

 Table 3.8
 Example of transfer cycles for master operation (frame mode)

The total cycles for burst transfer cycle can be expressed with the following formula.

Total cycles = cycles following CS assertion (a) + cycles preceding CS deassertion (b) + frame length (c)×frame count (d) + (frame count (d) - 1) × frame interval period (e)

For the example in No. 1, when the frame length is 32 bits, there are  $1+1+32\times1+(1-1)\times0=34$  transfer cycles in total.

For the example in No. 2, when the frame length is 8 bits, there are  $16+16+8\times255+(255-1)\times15=5882$  transfer cycles in total.

The total cycles for each frame of a continuous transfer can be expressed with the following formula.

Total cycles = cycle following CS assertion (a) + cycle preceding CS deassertion (b) + frame length (c) + idle period (g)

For the example in No. 3, when the frame length is 32 bits, there are 1+1+32+1 = 35 transfer cycles in total. For the example in No. 4, when the frame length is 8 bits, there are 16+16+8+15 = 55 transfer cycles in total.

Each transfer time can be expressed as follows.

Transfer time = transfer clock cycle  $(1/f_{SCK}) \times$  total cycles

Also, the cycles following the CS assertion and the ones preceding the CS deassertion are configured in *[TSPIxFMTR0]*<CSSCKDL[3:0]> <SCKCSDL[3:0]> and the frame interval period for burst transfers with 2 or more frames and the idle period for continuous transfer are specified with *[TSPIxFMTR0]*<FINT[3:0]> <CSINT[3:0]>. The period for the generation of each cycle is valid for both the SPI and SIO modes.

# TOSHIBA

### 3.6.2. Sector mode

In the sector mode, the transfer of a frame that consists of at most 4 sectors are conducted in the continuous transfer mode.

The sectors are called Sector 0 (S0), Sector 1 (S1), Sector 2 (S2), and Sector 3 (S3) in order of the data transfer. In an MSB-first transfer, the MSB side becomes S0. In an LSB-first transfer, the LSB side becomes S0.

The length of each sector is specified with *[TSPIxSECTCR1]* <SECTL0[5:0]>/<SECTL1[5:0]>/<SECTL2[5:0]> /<SECTL3[5:0]>.

The data format overview for the sector mode is shown in Figure 3.10.

| <b>←</b> 50                                                      |         |          |                                                   |                          | <b>S1</b>                                                                                                       |                               |                                | ┥──                                                                                                              | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 52                        |                                                       |                                                                                                                            | ←                                                                                                   |                                                         | <b>S</b> 3                |                                        |                                        | MSB First                                                                                                                                                                                       |
|------------------------------------------------------------------|---------|----------|---------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------|---------------------------|----------------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                  | - Frame | e length | n (8to64                                          | lbits) -                 |                                                                                                                 |                               |                                |                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |                                                       |                                                                                                                            |                                                                                                     |                                                         |                           |                                        |                                        |                                                                                                                                                                                                 |
| D31 D30 5                                                        | D1      | D0       | D31                                               | D30                      | S                                                                                                               | D1                            | D0                             |                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |                                                       |                                                                                                                            |                                                                                                     |                                                         |                           |                                        |                                        | No Parity                                                                                                                                                                                       |
| D31 D30 5                                                        | D1      | D0       | D30                                               | D29                      | $\mathbb{S}$                                                                                                    | D0                            | Р                              |                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |                                                       |                                                                                                                            |                                                                                                     |                                                         |                           |                                        |                                        | With Parity                                                                                                                                                                                     |
| •                                                                |         |          | Fr                                                | ame ler                  | ngth (8                                                                                                         | to96bit                       | s)                             |                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |                                                       |                                                                                                                            |                                                                                                     |                                                         |                           |                                        |                                        |                                                                                                                                                                                                 |
| D31 D30 ∬                                                        | D1      | D0       | D31                                               | D30                      | S                                                                                                               | D1                            | D0                             | D31                                                                                                              | D30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | $\mathbb{S}$              | D1                                                    | D0                                                                                                                         |                                                                                                     |                                                         |                           |                                        |                                        | No Parity                                                                                                                                                                                       |
| D31 D30 {}                                                       | D1      | D0       | D31                                               | D30                      | S                                                                                                               | D1                            | D0                             | D30                                                                                                              | D29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | $\mathbb{S}$              | D0                                                    | Ρ                                                                                                                          |                                                                                                     |                                                         |                           |                                        |                                        | With Parity                                                                                                                                                                                     |
|                                                                  |         |          |                                                   |                          |                                                                                                                 | Frame                         | length                         | (8to128                                                                                                          | Bbits)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | _                         |                                                       |                                                                                                                            |                                                                                                     |                                                         |                           |                                        |                                        | •                                                                                                                                                                                               |
| D31 D30 55                                                       | D1      | D0       | D31                                               | D30                      | $\langle \langle \rangle$                                                                                       | D1                            | DO                             | D31                                                                                                              | D30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | $\mathbb{S}$              | D1                                                    | D0                                                                                                                         | D31                                                                                                 | D30                                                     | $\mathbb{S}$              | D1                                     | D0                                     | No Parity                                                                                                                                                                                       |
| D31 D30 {\                                                       | D1      | D0       | D31                                               | D30                      | $\langle \langle \rangle$                                                                                       | D1                            | D0                             | D31                                                                                                              | D30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | $\langle \langle \rangle$ | D1                                                    | D0                                                                                                                         | D30                                                                                                 | D29                                                     | $\langle \langle \rangle$ | D0                                     | Р                                      | With Parity                                                                                                                                                                                     |
|                                                                  |         |          |                                                   |                          |                                                                                                                 |                               |                                |                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |                                                       |                                                                                                                            |                                                                                                     |                                                         |                           |                                        |                                        | -                                                                                                                                                                                               |
|                                                                  |         |          |                                                   |                          |                                                                                                                 |                               |                                |                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |                                                       |                                                                                                                            |                                                                                                     |                                                         |                           |                                        |                                        |                                                                                                                                                                                                 |
| <b>←</b> 53                                                      |         |          |                                                   |                          | S2                                                                                                              |                               | <b></b>                        | ┫                                                                                                                | :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | S1                        |                                                       |                                                                                                                            | ┥                                                                                                   |                                                         | SO                        |                                        |                                        | LSB First                                                                                                                                                                                       |
| <b>←</b> 53                                                      |         |          | ◀──                                               |                          | S2                                                                                                              |                               |                                | <b> </b> ∙                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | S1                        | Frame                                                 | ►<br>e lengtl                                                                                                              | <b> 4</b>                                                                                           | 4bits)                                                  | S0                        |                                        |                                        | LSB First                                                                                                                                                                                       |
| <b>←</b> S3                                                      |         | <b>→</b> | ◀                                                 |                          | S2                                                                                                              |                               |                                | <ul> <li>■</li> <li>D31</li> </ul>                                                                               | D30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | s1                        | Frame<br>D1                                           | e lengtl                                                                                                                   | <b>↓</b><br>1 (8to64<br>D31                                                                         | 4bits)<br>D30                                           | so                        | D1                                     |                                        | <ul> <li>LSB First</li> <li>No Parity</li> </ul>                                                                                                                                                |
| <b>←</b> 53                                                      |         | <b>→</b> | ◀                                                 |                          | S2                                                                                                              |                               |                                | <ul> <li>■</li> <li>■</li> <li>D31</li> <li>P</li> </ul>                                                         | D30 D30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | s1                        | Frame<br>D1<br>D1                                     | →<br>e lengtl<br>D0<br>D0                                                                                                  | <ul> <li>(8to6-</li> <li>D31</li> <li>D31</li> </ul>                                                | 4bits)<br>D30<br>D30                                    | so                        | D1<br>D1                               | <br>D0<br>D0                           | <ul> <li>LSB First</li> <li>No Parity</li> <li>With Parity</li> </ul>                                                                                                                           |
| <b>←</b> S3                                                      |         |          | ∙                                                 |                          | S2                                                                                                              |                               |                                | D31<br>P<br>Fra                                                                                                  | D30<br>D30<br>ame leng                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | S1                        | Frame<br>D1<br>D1                                     | e lengti<br>D0<br>D0                                                                                                       | <ul> <li>(8to6/<br/>D31</li> <li>D31</li> </ul>                                                     | 4bits)<br>D30<br>D30                                    | 50                        | D1<br>D1                               | D0<br>D0                               | <ul> <li>LSB First</li> <li>No Parity</li> <li>With Parity</li> </ul>                                                                                                                           |
| <b>∢</b> 53                                                      |         | <b>→</b> | •<br>D31                                          | D30                      | S2                                                                                                              | D1                            | <b>)</b>                       | <ul> <li>D31</li> <li>P</li> <li>Frain</li> <li>D31</li> </ul>                                                   | D30<br>D30<br>ame leng<br>D30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | S1                        | Frame<br>D1<br>D1<br>D96bits<br>D1                    | e lengti<br>D0<br>D0<br>s)<br>D0                                                                                           | <ul> <li>(8to6/<br/>D31</li> <li>D31</li> <li>D31</li> </ul>                                        | 4bits)<br>D30<br>D30<br>D30                             | 50                        | D1<br>D1<br>D1                         | <br>D0<br>                             | <ul> <li>LSB First</li> <li>No Parity</li> <li>With Parity</li> <li>No Parity</li> </ul>                                                                                                        |
| <b>←</b> 53                                                      |         |          | <ul> <li>D31</li> </ul>                           | D30                      | S2                                                                                                              | D1                            | DO                             | <ul> <li>D31</li> <li>P</li> <li>Frain D31</li> <li>D31</li> </ul>                                               | D30<br>D30<br>ame leng<br>D30<br>D30<br>D30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | S1                        | Frame<br>D1<br>D1<br>D96bits<br>D1<br>D1              | <ul> <li>lengtl</li> <li>D0</li> <li>D0</li> <li>s)</li> <li>D0</li> <li>D0</li> </ul>                                     | <ul> <li>(8to6-</li> <li>D31</li> <li>D31</li> <li>D31</li> <li>D31</li> </ul>                      | 4bits)<br>D30<br>D30<br>D30<br>D30                      | 50                        | D1<br>D1<br>D1<br>D1                   | <br>D0<br><br>D0<br>                   | <ul> <li>LSB First</li> <li>No Parity</li> <li>With Parity</li> <li>No Parity</li> <li>No Parity</li> <li>With Parity</li> </ul>                                                                |
| <b>←</b> 53                                                      |         |          | <ul> <li>D31</li> <li>P</li> </ul>                | D30                      | S2                                                                                                              | D1<br>D1<br>Frame             | D0                             | <ul> <li>D31</li> <li>P</li> <li>Fra</li> <li>D31</li> <li>D31</li> </ul>                                        | D30<br>D30<br>ame leng<br>D30<br>D30<br>Bhits)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | S1                        | Frame<br>D1<br>D1<br>D96bits<br>D1<br>D1              | <ul> <li>lengtl</li> <li>D0</li> <li>D0</li> <li>S)</li> <li>D0</li> <li>D0</li> </ul>                                     | <ul> <li>8to6</li> <li>D31</li> <li>D31</li> <li>D31</li> <li>D31</li> </ul>                        | 4bits)<br>D30<br>D30<br>D30<br>D30<br>D30               | 50                        | D1<br>D1<br>D1<br>D1                   | D0<br>D0<br>D0<br>D0<br>D0             | <ul> <li>LSB First</li> <li>No Parity</li> <li>With Parity</li> <li>No Parity</li> <li>With Parity</li> <li>With Parity</li> </ul>                                                              |
| <ul> <li>✓ S3</li> <li>✓ S3</li> </ul>                           | D1      | DO       | <ul> <li>D31</li> <li>D31</li> </ul>              | D30<br>D30<br>D30        | \$2<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$ | D1<br>D1<br>Frame<br>D1       | D0<br>D0<br>length<br>D0       | <ul> <li>D31</li> <li>P</li> <li>Fra</li> <li>D31</li> <li>D31</li> <li>0(8to12a)</li> <li>D31</li> </ul>        | D30<br>D30<br>ame leng<br>D30<br>D30<br>Bbits)<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30 | S1                        | Frame<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1       | <ul> <li>Lengtl</li> <li>D0</li> <li>D0</li> <li>S)</li> <li>D0</li> <li>D0</li> <li>D0</li> <li>D0</li> </ul>             | <ul> <li>(8to6-</li> <li>D31</li> <li>D31</li> <li>D31</li> <li>D31</li> </ul>                      | 4bits)<br>D30<br>D30<br>D30<br>D30<br>D30               | 50                        | D1<br>D1<br>D1<br>D1<br>D1             | D0<br>D0<br>D0<br>D0<br>D0             | <ul> <li>LSB First</li> <li>No Parity</li> <li>With Parity</li> <li>No Parity</li> <li>With Parity</li> <li>With Parity</li> <li>With Parity</li> </ul>                                         |
| <ul> <li>✓ S3</li> <li>✓ D31 D30 √</li> <li>✓ P D30 √</li> </ul> | D1      |          | <ul> <li>D31</li> <li>D31</li> <li>D31</li> </ul> | D30<br>D30<br>D30<br>D30 | 52<br>52<br>52<br>52<br>52<br>52<br>52<br>52<br>52<br>52<br>52<br>52<br>52<br>5                                 | D1<br>D1<br>Frame<br>D1<br>D1 | D0<br>D0<br>length<br>D0<br>D0 | <ul> <li>D31</li> <li>P</li> <li>D31</li> <li>D31</li> <li>031</li> <li>031</li> <li>031</li> <li>D31</li> </ul> | D30<br>D30<br>ame leng<br>D30<br>D30<br>8bits)<br>D30<br>D30<br>D30<br>D30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | S1                        | Frame<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1 | <ul> <li>Lengtl</li> <li>D0</li> <li>D0</li> <li>S)</li> <li>D0</li> <li>D0</li> <li>D0</li> <li>D0</li> <li>D0</li> </ul> | <ul> <li>(8to6/<br/>D31</li> <li>D31</li> <li>D31</li> <li>D31</li> <li>D31</li> <li>D31</li> </ul> | 4bits)<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30<br>D30 | 50                        | D1<br>D1<br>D1<br>D1<br>D1<br>D1<br>D1 | D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0 | <ul> <li>LSB First</li> <li>No Parity</li> <li>With Parity</li> <li>No Parity</li> <li>With Parity</li> <li>With Parity</li> <li>No Parity</li> <li>With Parity</li> <li>With Parity</li> </ul> |

Figure 3.10 Data Format Overview for the Sector Mode

#### No parity

The length of each sector is set to the same value as the sector's data length (1 to 32 bits). when the data length of the sector 0 is 31 bits, the sector length configuration register for Sector 0 is set as [TSPIxSECTCR1]<SECTL0[5:0]>= 011111.

#### With parity

The sector length of the sectors except the final sector are specified with same values as the data length from 1 to 32 bits. The sector length of the final sector is specified with the sector length from 2 to 32 bits (the data length from 1 to 31 bits and added 1 parity bit). Setting only one bit (only parity bit) of sector length is inhibited. For example, when the data length of the final sector 2 is 31 bits, *[TSPIxSECTCR1]*<SECTL2[5:0]>=100000 is set to the sector length setting register. Then, set the sector length setting register for unused sector 3 *[TSPIxSECTCR1]*<SECTL3[5:0]> to 000000.

For transmit, the parity bit is added to the data in transmit FIFO and is moved to the transmit shift register. For receives, the parity bit is removed from the data in the receive shift register and is moved to the receive FIFO.

### 3.6.2.1. Buffer Structure and Operation

The transmit buffer and the receive buffer are independent of each other. Each buffer has a double buffer structure that consists of the FIFO that is 32-bit wide and has 4 level stages and the shift register with the length of 32 bits and can be accessed in the data register *[TSPIxDR]*.

In the sector mode, the data are saved and moved with the maximum sector unit of 32 bits.

Table 3.9 shows the configurable ranges of the fill levels in the sector mode.

| Soctor longth | Settable                                          | Fill level                                       |
|---------------|---------------------------------------------------|--------------------------------------------------|
| (S0/S1/S2/S3) | Transmit FIFO<br>[TSPIxCR2] <til[3:0]></til[3:0]> | Receive FIFO<br>[TSPIxCR2] <ril[3:0]></ril[3:0]> |
| 1 to 32bit    | 0 to 3                                            | 1 to 4                                           |

#### Table 3.9 Settable fill level in Sector mode

Note1: Set a value within the settable fill level. If the value is outside of the settable fill level, the operation is not guaranteed.

Note2: Changing the sector length is inhibited when the receive FIFO is full.

| Condition                  | With / No parity | Transfer direction | Sector count / Sector length<br>(S0/S1/S2/S3) |
|----------------------------|------------------|--------------------|-----------------------------------------------|
| Sector mode<br>operation 1 | No pority        | MSB first          | 4 sectors (32/32/32)                          |
| Sector mode<br>operation 2 | но ранку         | LSB first          | 2 sectors (24/16/0/0)                         |
| Sector mode operation 3    | With parity      | MSB first          | 3 sectors (8/16/32/0)                         |
| Sector mode operation 4    | wiin panty       | LSB first          | 4 sectors (32/24/16/8)                        |

| Table 3.10 | Data format examples for the Sector mode |
|------------|------------------------------------------|
|            |                                          |

The conditions for the operation 1 to 4 in "Table 3.10 Data format examples for the Sector mode" are described.

For transmit operations, the process from writing to the data register of the transmit data to outputting the transmit shift register is described. For receive operations, the process from inputting the receive data to the receive shift register to reading out the data register is described.

In the figure, the notation of each data is WR\_31 to WR\_0 for the write data of the data register *[TSPIxDR]*, RD\_31 to RD\_0 for the read data, TXD31 to TXD0 for the transmit shift register data, RXD31 to RXD0 for the receive shift register data, and the frame. The configuration example and sector n data in the FIFO are represented as Sn\_31 to Sn\_0 (n= 0 to 3 and the maximum sector count is 4), and the parity bit is represented as P.

## 3.6.2.2. Sector mode operation 1 (No parity, MSB first)

The following figure shows a buffer operation for a transmit No parity, MSB first, 4 sectors (128 bits / frame).

|              |       |          |                           |        | Exam     | ole Fra  | me co                     | nfigura          | ation w       | ithout | Parity/                   | MSB f    | irst(12            | 8bits)-       |                           |          |              |                |                         |
|--------------|-------|----------|---------------------------|--------|----------|----------|---------------------------|------------------|---------------|--------|---------------------------|----------|--------------------|---------------|---------------------------|----------|--------------|----------------|-------------------------|
| -            | Sect  | or0 (32  | 2bits)                    |        | -        | Sect     | or1 (3                    | 2bits)           | $\rightarrow$ | -      | Secto                     | or2 (32  | 2bits)             | $\rightarrow$ | -                         | Sect     | or3 (3       | 2bits)         |                         |
| MSB<br>127   | 126   |          | 97                        | 96     | 95       | 94       |                           | 65               | 64            | 63     | 62                        |          | 33                 | 32            | 31                        | 30       |              | 1              | LSB<br>0                |
| <b>S0_31</b> | S0_30 | $\int$   | S0_1                      | S0_0   | S1_31    | S1_30    | S                         | \$1_1            | S1_0          | S2_31  | S2_30                     | $\int$   | \$2_1              | S2_0          | S3_31                     | S3_30    | SS           | S3_1           | S3_0                    |
| <u> </u>     | · — · | <u> </u> | <u> </u>                  | · · ·  | · · ·    | <u> </u> | · ·                       | · _ ·            | · _           | - ·    | · <u> </u>                | <u> </u> | - ·                | · _ ·         | <u> </u>                  | - ·      | · · —        | · — ·          | — · —                   |
|              | WR_31 | WR_30    |                           | WR_24  | WR_23    | WR_22    |                           | WR_16            | WR_15         | WR_14  |                           | WR_8     | WR_7               | WR_6          |                           | WR_1     | WR_0         | Data           | register                |
| Ē            | #     | ••••     |                           | ····   | ····     | ••••     |                           | ····             |               | ····   |                           | ••••     | ••••               | <u> </u>      |                           | <u> </u> | ···· <u></u> |                |                         |
|              | S3_31 | S3_30    |                           | S3_24  | S3_23    | S3_22    |                           | S3_16            | S3_15         | S3_14  | <u> </u>                  | S3_8     | S3_7               | S3_6          | $\mathcal{N}$             | S3_1     | S3_0         | Stage4         |                         |
|              | S2_31 | S2_30    | S                         | S2_24  | S2_23    | S2_22    | S                         | S2_16            | S2_15         | S2_14  | $\mathbb{S}$              | S2_8     | S2_7               | S2_6          | S                         | S2_1     | S2_0         | Stage3         | Transmit                |
|              | S1_31 | S1_30    | S                         | \$1_24 | S1_23    | \$1_22   | S                         | \$1_16           | \$1_15        | \$1_14 | $\mathbb{S}$              | S1_8     | \$1_7              | S1_6          | $\int$                    | \$1_1    | S1_0         | Stage2         | FIFO                    |
|              | S0_31 | S0_30    | $\langle \langle \rangle$ | S0_24  | S0_23    | S0_22    | $\mathbb{S}$              | S0_16            | S0_15         | S0_14  | $\mathbb{S}$              | S0_8     | S0_7               | S0_6          | $\langle \langle \rangle$ | S0_1     | S0_0         | Stage1         |                         |
| Ĺ.           |       |          |                           |        |          |          |                           |                  |               |        |                           |          |                    |               |                           |          |              |                |                         |
| -            | TXD31 | TXD30    | S                         | TXD24  | TXD23    | TXD22    | S                         | TXD16            | TXD15         | TXD14  | $\mathbb{S}$              | TXD8     | TXD7               | TXD6          | $\int$                    | TXD1     | TXD0         | Trans<br>Shift | mit<br>register         |
| — · —        | · — · | <u> </u> |                           | · ·    | <u> </u> | <u> </u> | · · <u> </u>              | <u> </u>         | <u> </u>      | - ·    | · _ ·                     | <u> </u> | <b>-</b> · <b></b> | · — ·         | <u> </u>                  | <u> </u> | · —          |                | <u> </u>                |
|              | RXD31 | RXD30    | 5                         | RXD24  | RXD23    | RXD22    | 5                         | RXD16            | RXD15         | RXD14  | $\mathbb{N}$              | RXD8     | RXD7               | RXD6          | $\mathbb{N}$              | RXD1     | RXD0         | Shif           | • Receive<br>t register |
| 5            |       | ····↓··· | ~~~~                      |        | ····     |          | ~~~~                      |                  | ·             |        | ~                         |          | ····↓···           |               | ~~~                       |          |              | 1              |                         |
|              | S3_31 | S3_30    | 5                         | S3_24  | S3_23    | S3_22    | <u> </u>                  | S3_16            | S3_15         | S3_14  | $\mathbb{N}$              | S3_8     | S3_7               | S3_6          | $\mathbb{N}$              | \$3_1    | S3_0         | Stage4         |                         |
|              | S2_31 | S2_30    | $\langle \rangle$         | S2_24  | S2_23    | S2_22    | $\sum$                    | S2_16            | \$2_15        | S2_14  | $\langle \rangle$         | S2_8     | S2_7               | S2_6          | $\langle \rangle$         | S2_1     | S2_0         | Stage 3        | Receive                 |
|              | S1_31 | S1_30    | $\langle \rangle$         | S1_24  | S1_23    | S1_22    | $\int$                    | S1_16            | S1_15         | \$1_14 | $\leq$                    | S1_8     | \$1_7              | S1_6          | $\mathcal{S}$             | \$1_1    | \$1_0        | Stage 2        | FIFO                    |
|              | S0_31 | S0_30    | $\langle \langle \rangle$ | S0_24  | S0_23    | S0_22    | $\langle \langle \rangle$ | S0_16            | S0_15         | S0_14  | $\langle \langle \rangle$ | S0_8     | S0_7               | S0_6          | $\langle \langle \rangle$ | S0_1     | S0_0         | Stage1         |                         |
| 11           | ···•  | ŧ        |                           | ••••   | ····↓··· |          |                           | ••• <b>•</b> ••• | ‡             |        |                           | ···‡···  | ŧ                  | ŧ             |                           | ···•     | ••••         |                |                         |
|              | RD_31 | RD_30    |                           | RD_24  | RD_23    | RD_22    |                           | RD_16            | RD_15         | RD_14  |                           | RD_8     | RD_7               | RD_6          |                           | RD_1     | RD_0         | Data           | register                |

Figure 3.11 Buffer operation of the sector mode (No parity, MSB first)

Stop condition: [TSPIxSR] <TSPISUE>= 0 and [TSPIxCR1] <TRGEN>= 0, <TRXE>= 0

(1) Transmit buffer operation

The transmit data are written by the CPU or DMAC to the data register **[TSPIxDR]** when the operation is stopped or during communication, and are stacked to the first level stage when the transmit FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data.

Also, when the transmit buffer is empty, the transmit data written after the communication is enabled are immediately transferred to the transmit shift register, and the transmit starts. For slave operations, make sure that an underrun error does not occur. (Refer to "3.7.3. Error Interrupt")

Figure 3.11 shows the transmit data in the sector 0 to 3 saved on level stages 1 to 4 on the transmit FIFO. When the operation is enabled to start communications after being stopped or the transmit of a frame has been completed, the data on the first level stage of the transmit FIFO is moved to the transmit shift register and are transmitted. At the same time, the data on level stages 2 to 4 are moved to level stages 1 to 3.

The transmit data in the transmit shift register are transmitted for each serial clock, starting from MSB (S0\_31) in the sector 0.

(2) Receive buffer operation

Each time a sector is received during communications, the data in the receive shift register are stacked to the first level stage when the receive FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data.

Figure 3.11 shows the data in the sector 0 to 3 saved on level stages 1 to 4 on the receive FIFO.

For each serial clock, the received data are saved in the receive shift register starting from MSB (S0\_31) in the sector 0 and are stacked to the lowest level stage on the receive FIFO each time a sector is received.

From the data register *[TSPIxDR]*, the CPU or DMAC read out the data on the first level stage of the receive FIFO. At the same time, the data on level stages 2 to 4 are moved to level stages 1 to 3.

# 3.6.2.3. Sector mode operation 2 (No parity, LSB first)

The following figure shows a buffer operation for a transmit No parity, LSB first, 2 sectors (40 bits / frame).

| •                   |                                       |          |                           |         | Exar     | nple Fi  | rame o                    | configu | iration       | withou    | ıt Parit                  | y/LSB   | first(4  | Obits) -      |                           |          |          |                |                         |
|---------------------|---------------------------------------|----------|---------------------------|---------|----------|----------|---------------------------|---------|---------------|-----------|---------------------------|---------|----------|---------------|---------------------------|----------|----------|----------------|-------------------------|
| -                   | Se                                    | ctor3(C  | )bit)                     | -       | -        | Sec      | tor2 (                    | Obit)   | $\rightarrow$ | MSB       | Secto                     | or1 (16 | 6bits)   | $\rightarrow$ | -                         | Secto    | or0 (2   | 4bits)         |                         |
|                     |                                       |          |                           |         |          |          |                           |         |               | 39        | 38                        |         | 25       | 24            | 23                        | 22       |          | 1              | 0                       |
| S3_31               | S3_30                                 |          | S3_1                      | S3_0    | \$2_31   | S2_30    | $\sum$                    | S2_1    | S2_0          | S1_15     | \$1_14                    | $\int$  | \$1_1    | S1_0          | S0_23                     | S0_22    | $\int$   | S0_1           | S0_0                    |
| _ · _               | · · — ·                               | · — · ·  | <u> </u>                  | • • —   | · — ·    | — · –    | - ·                       | · — ·   | — · -         | - ·       | · _ ·                     | - · ·   | <u> </u> | • — •         | <u> </u>                  |          |          | · — ·          |                         |
|                     | WR_31                                 | WR_30    |                           | WR_24   | WR_23    | WR_22    |                           | WR_16   | WR_15         | WR_14     | $\mathbb{N}$              | WR_8    | WR_7     | WR_6          |                           | WR_1     | WR_0     | Data           | register                |
|                     | · · · · · · · · · · · · · · · · · · · | <u>+</u> |                           | ···•    | ••••     |          |                           | ••••    | ••••          | ····↓···· |                           | •••     |          | ···•          |                           | ••••     | ···•     |                |                         |
|                     | S3_31                                 | S3_30    |                           | S3_24   | S3_23    | S3_22    |                           | S3_16   | \$3_15        | S3_14     |                           | S3_8    | S3_7     | S3_6          |                           | S3_1     | S3_0     | Stage4         |                         |
|                     | S2_31                                 | S2_30    | $\square$                 | S2_24   | S2_23    | S2_22    | $\square$                 | S2_16   | S2_15         | S2_14     | $\sum$                    | S2_8    | S2_7     | S2_6          | $\square$                 | \$2_1    | S2_0     | Stage 3        | Transmit                |
|                     | S1_31                                 | S1_30    | $\langle \langle \rangle$ | S1_24   | S1_23    | S1_22    | $\langle \langle \rangle$ | \$1_16  | \$1_15        | \$1_14    | $\langle \langle \rangle$ | S1_8    | \$1_7    | S1_6          | $\langle \langle \rangle$ | \$1_1    | \$1_0    | Stage 2        | FIFO                    |
|                     | S0_31                                 | S0_30    |                           | S0_24   | S0_23    | S0_22    | $\langle \langle \rangle$ | S0_16   | S0_15         | S0_14     | $\langle \langle \rangle$ | S0_8    | S0_7     | S0_6          |                           | S0_1     | S0_0     | Stage1         |                         |
| L                   | <u> </u>                              | Ţ        |                           | Ţ       | Ţ        | Ţ        |                           | t t     | ' <b>↓</b>    | Ţ         |                           | T.      | ·        |               |                           | Ţ        | <u> </u> | ·              | '                       |
|                     | TXD31                                 | TXD30    | $\langle \langle \rangle$ | TXD24   | TXD23    | TXD22    | $\langle \langle \rangle$ | TXD16   | TXD15         | TXD14     | $\langle \langle \rangle$ | TXD8    | TXD7     | TXD6          | $\langle \langle \rangle$ | TXD1     | TXD0     | Shi            | Transmit<br>ft register |
| <b>—</b> · <b>—</b> | · — ·                                 | - · ·    |                           | · —     | <u> </u> | <u> </u> |                           | · — ·   | <u> </u>      | <u> </u>  | · <u> </u>                | — · -   | <u> </u> | · — ·         |                           | <u> </u> | · _      | : <u> </u>     |                         |
| $\rightarrow$       | RXD31                                 | RXD30    | $\langle \langle \rangle$ | RXD24   | RXD23    | RXD22    | $\langle \langle \rangle$ | RXD16   | RXD15         | RXD14     | $\langle \langle \rangle$ | RXD8    | RXD7     | RXD6          | $\langle \langle \rangle$ | RXD1     | RXD0     | Recei<br>Shift | ve<br>register          |
|                     |                                       |          |                           |         |          |          |                           |         | ţ             |           |                           |         |          |               |                           |          |          |                |                         |
|                     | S3_31                                 | S3_30    | $\square$                 | S3_24   | S3_23    | S3_22    | $\langle \langle \rangle$ | S3_16   | S3_15         | S3_14     | $\langle \rangle$         | S3_8    | S3_7     | S3_6          | $\langle \langle \rangle$ | S3_1     | S3_0     | Stage4         |                         |
|                     | S2_31                                 | S2_30    | $\langle \langle \rangle$ | S2_24   | S2_23    | S2_22    | $\langle \langle \rangle$ | S2_16   | S2_15         | S2_14     | $\langle \langle \rangle$ | S2_8    | S2_7     | S2_6          | $\langle \langle \rangle$ | \$2_1    | S2_0     | Stage3         | Receive                 |
|                     | S1_31                                 | S1_30    | $\langle \langle \rangle$ | S1_24   | S1_23    | S1_22    | $\langle \langle \rangle$ | S1_16   | \$1_15        | \$1_14    | $\langle \langle \rangle$ | S1_8    | \$1_7    | \$1_6         | $\langle \langle \rangle$ | \$1_1    | \$1_0    | Stage2         | FIFO                    |
|                     | S0_31                                 | S0_30    |                           | S0_24   | S0_23    | S0_22    | $\langle \langle \rangle$ | S0_16   | S0_15         | S0_14     | $\langle \langle$         | S0_8    | S0_7     | S0_6          | $\langle \langle$         | S0_1     | S0_0     | Stage1         |                         |
| Ĺ                   |                                       | ·        |                           | ···‡··· |          | £        |                           |         |               |           |                           |         |          |               |                           | <u>+</u> |          |                | ł                       |
|                     | RD_31                                 | RD_30    |                           | RD_24   | RD_23    | RD_22    | $\langle \langle \rangle$ | RD_16   | RD_15         | RD_14     | $\langle \langle \rangle$ | RD_8    | RD_7     | RD_6          | ~~~                       | RD_1     | RD_0     | Data           | register                |

Figure 3.12 Buffer operation of the sector mode (No parity, LSB first)

(1) Transmit buffer operation

The transmit data are written by the CPU or DMAC to the data register *[TSPIxDR]* when the operation is stopped or during communication, and are stacked to the first level stage when the transmit FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data. Also, when the transmit buffer is empty, the transmit data written after the communication is allowed are immediately transferred to the transmit shift register, and the transmit starts. For slave operations, make sure that an underrun error does not occur. (Refer to "3.7.3. Error Interrupt")

Figure 3.12 shows the transmit data in the sector 0 to 1 saved on level stages 1 to 2 on the transmit FIFO. When the operation is allowed to start communications after being stopped or the transmit of a frame has been completed, the data on the first level stage of the transmit FIFO is moved to the transmit shift register and are transmitted. At the same time, the data on level stage 2 is moved to level stage 1. The transmit data within the transmit shift register are transmitted for each serial clock, starting from LSB

 $(S0_0)$  in the sector 0.

#### (2) Receive buffer operation

Each time a sector is received during communications, the data within the receive shift register are stacked to the first level stage if the receive FIFO is empty. The data are stacked to the second level stage if the first level stage is already filled with data.

Figure 3.12 shows the data within the sectors 0 to 1 saved on level stages 1 to 2 on the receive FIFO. For each serial clock, the received data are saved within the receive shift register, starting from LSB (S0\_0) in the sector 0 and are stacked to the lowest level stage on the receive FIFO each time a sector is received. From the data register *[TSPIxDR]*, the CPU or DMAC read out the data on the first level stage of the receive FIFO. At the same time, the data on level stage 2 is moved to level stage 1.

### 3.6.2.4. Sector mode operation 3 (with parity, MSB first)

The following figure shows a buffer operation for a transmit with parity, MSB first, 3 sectors (56 bits / frame).

| -        |          |                           |              |                     | - Exa  | mple F   | Frame               | config       | uratior | n with p | oarity/N                  | MSB fi                    | rst (56  | bits) -  |              |          |                     |                |                                                   |
|----------|----------|---------------------------|--------------|---------------------|--------|----------|---------------------|--------------|---------|----------|---------------------------|---------------------------|----------|----------|--------------|----------|---------------------|----------------|---------------------------------------------------|
| -        | Sect     | or0 (8                    | bits)        | $\rightarrow$       | -      | Secto    | or1 (1              | 6bits)       |         | -        | Secto                     | or2 (32                   | 2bits)   |          | -            | Sec      | tor3 (              | Obit)          |                                                   |
| 55       | 54       |                           | 49           | 48                  | 47     | 46       |                     | 33           | 32      | 31       | 30                        |                           | 1        | 0        |              |          |                     |                |                                                   |
| S0_7     | S0_6     | $\langle \langle \rangle$ | S0_1         | S0_0                | \$1_15 | \$1_14   | 5                   | \$1_1        | S1_0    | S2_30    | S2_29                     | $\langle \langle \rangle$ | S2_0     | Р        | S3_31        | S3_30    |                     | <b>S3_</b> 1   | L S3_0                                            |
| - • •    | <b>_</b> |                           | <u> </u>     | _ · _               | · · —  | · — ·    |                     |              | · _ ·   | _ · -    | <b>.</b> . <b>.</b>       | · _ ·                     |          | <u> </u> | · · _ ·      | _ · ·    |                     |                | · · _ · ·                                         |
|          | WR_31    | WR_30                     |              | WR_24               | WR_23  | WR_22    |                     | WR_16        | WR_15   | WR_14    | $\langle \langle \rangle$ | WR_8                      | WR_7     | WR_6     |              | WR_1     | WR_0                | Data           | register                                          |
| [7       |          |                           |              | ·‡                  | ·      |          |                     | ·            | ·       |          |                           |                           | ·        |          |              |          |                     |                | 1                                                 |
|          | S3_31    | S3_30                     |              | S3_24               | S3_23  | S3_22    |                     | <b>S3_16</b> | S3_15   | S3_14    |                           | S3_8                      | S3_7     | S3_6     |              | \$3_1    | S3_0                | Stage 4        |                                                   |
|          | S2_31    | S2_30                     | S            | S2_24               | S2_23  | S2_22    | $\int$              | S2_16        | \$2_15  | S2_14    | $\mathbb{S}$              | S2_8                      | S2_7     | S2_6     | $\int$       | \$2_1    | S2_0                | Stage3         | Transmit                                          |
|          | S1_31    | S1_30                     | S            | S1_24               | S1_23  | S1_22    | $\square$           | \$1_16       | \$1_15  | \$1_14   | $\mathbb{S}$              | S1_8                      | \$1_7    | \$1_6    | S            | \$1_1    | S1_0                | Stage2         | FIFO                                              |
|          | S0_31    | S0_30                     | $\sum$       | S0_24               | S0_23  | S0_22    | $\sum$              | S0_16        | S0_15   | S0_14    | $\sum$                    | S0_8                      | S0_7     | S0_6     | $\mathbb{S}$ | S0_1     | S0_0                | Stage1         |                                                   |
| Ĺ.       |          |                           |              |                     |        |          |                     |              |         |          |                           |                           |          |          |              |          |                     |                | i                                                 |
| -        | TXD31    | TXD30                     | S            | TXD24               | TXD23  | TXD22    | S                   | TXD16        | TXD15   | TXD14    | $\mathbb{S}$              | TXD8                      | TXD7     | TXD6     | S            | TXD1     | TXD0                | Trans<br>Shift | smit<br>register                                  |
| <u> </u> | - ·      | · — ·                     | <u> </u>     | <b>—</b> · <b>—</b> | · — ·  | <u> </u> | <b>—</b> · <b>—</b> | • • — •      | · — · · | — · —    | • · —                     | · <u> </u>                | <u> </u> | - ·      | · <u> </u>   | <u> </u> | <b>-</b> · <b>-</b> | · —            | · <u> </u>                                        |
|          | RXD31    | RXD30                     | $\square$    | RXD24               | RXD23  | RXD22    | $\mathbb{S}$        | RXD16        | RXD15   | RXD14    | $\langle \rangle$         | RXD8                      | RXD7     | RXD6     | $\mathbb{S}$ | RXD1     | RXD0                |                | <ul> <li>Receive</li> <li>ift register</li> </ul> |
| [-       |          |                           |              |                     |        |          |                     |              |         |          |                           |                           | ·        |          |              |          |                     |                |                                                   |
|          | S3_31    | S3_30                     |              | S3_24               | S3_23  | S3_22    |                     | S3_16        | \$3_15  | S3_14    |                           | S3_8                      | S3_7     | S3_6     |              | \$3_1    | S3_0                | Stage4         |                                                   |
|          | S2_31    | S2_30                     | S            | S2_24               | S2_23  | S2_22    | $\int$              | S2_16        | \$2_15  | S2_14    | $\mathbb{S}$              | S2_8                      | S2_7     | S2_6     | $\int$       | S2_1     | S2_0                | Stage3         | Receive                                           |
|          | S1_31    | S1_30                     | S            | S1_24               | S1_23  | S1_22    | $\square$           | S1_16        | \$1_15  | S1_14    | $\mathbb{S}$              | S1_8                      | S1_7     | \$1_6    | $\mathbb{S}$ | \$1_1    | S1_0                | Stage2         | FIFO                                              |
|          | S0_31    | S0_30                     | S            | S0_24               | S0_23  | S0_22    | S                   | S0_16        | S0_15   | S0_14    | S                         | S0_8                      | S0_7     | S0_6     | S            | S0_1     | S0_0                | Stage1         |                                                   |
| L_       |          |                           |              |                     |        |          |                     |              |         |          |                           |                           |          |          |              |          |                     |                |                                                   |
|          | RD_31    | RD_30                     | $\mathbb{Z}$ | RD_24               | RD_23  | RD_22    | 22                  | RD_16        | RD_15   | RD_14    | 22                        | RD_8                      | RD_7     | RD_6     | 22           | RD_1     | RD_0                | Data           | register                                          |

Figure 3.13 Buffer operation of the sector mode (with parity, MSB first)

(1) Transmit buffer operation

The transmit data are written by the CPU or DMAC to the data register *[TSPIxDR]* when the operation is stopped or during communication, and are stacked to the first level stage when the transmit FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data. Also, when the transmit buffer is empty, the transmit data written after the communication is allowed are immediately transferred to the transmit shift register, and the transmit starts. For slave operations, make sure that an underrun error does not occur. (Refer to "3.7.3. Error Interrupt")

Figure 3.13 shows the transmit data within the sector 0 to 2 saved on level stages 1 to 3 on the transmit FIFO. When the operation is allowed to start communications after being stopped or the transmit of a frame has been completed, the data on the first level stage of the transmit FIFO is moved to the transmit shift register and are transmitted. At the same time, the data on level stages 2 to 3 are moved to level stages 1 to 2. If the first level stage of the transmit FIFO corresponds to the last sector 2, the parity bit is attached to LSB before the data are moved to the transmit shift register and transmitted.

The transmit data within the transmit shift register are transmitted for each serial clock, starting from MSB  $(S0_7)$  in the sector 0.

(2) Receive buffer operation

Each time a sector is received during communications, the data within the receive shift register are stacked to the first level stage when the receive FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data.

Figure 3.13 shows the data within the sector 0 to 2 saved on level stages 1 to 3 on the receive FIFO. For each serial clock, the received data are saved within the receive shift register starting from MSB (S0\_7) in the sector 0 and are stacked to the lowest level stage on the receive FIFO each time a sector is received. When the last sector 2 is received, the parity bit is removed from LSB before the data are moved to the receive FIFO. From the data register *[TSPIxDR]*, the CPU or DMAC read out the data on the first level stage of the receive FIFO. At the same time, the data on level stages 2 to 3 is moved to level stages 1 to 2.

## 3.6.2.5. Sector mode operation 4 (with parity, LSB first)

The figure below shows a buffer operation for a transmit with parity, LSB first, 4 sectors (80 bits / frame).

|               |          |                           |                           |          | Exa                 | ample I    | Frame                                     | config | uratior | n with j | parity/l                  | LSB fir                   | st(80b   | oits) - |                                           |          |                           |         |                                               |
|---------------|----------|---------------------------|---------------------------|----------|---------------------|------------|-------------------------------------------|--------|---------|----------|---------------------------|---------------------------|----------|---------|-------------------------------------------|----------|---------------------------|---------|-----------------------------------------------|
| -             | Sect     | or3 (8                    | bits)                     |          | ◄                   | Secto      | or2 (16                                   | Sbits) |         | •        | Secto                     | or1 (24                   | 4bits)   |         | ◄                                         | Secto    | or0 (3                    | 2bits)  |                                               |
| 79            | 78       |                           | 73                        | 72       | 71                  | 70         |                                           | 57     | 56      | 55       | 54                        |                           | 33       | 32      | 31                                        | 30       |                           | 1       | 0                                             |
| Р             | S3_6     | $\langle \langle \rangle$ | S3_1                      | S3_0     | S2_15               | S2_14      | $\langle \langle \rangle$                 | \$2_1  | S2_0    | S1_23    | \$1_22                    | $\langle \langle \rangle$ | \$1_1    | \$1_0   | S0_31                                     | S0_30    | $\langle \langle \rangle$ | S0_1    | S0_0                                          |
| <u> </u>      |          | · _ ·                     | <u> </u>                  | _ · _    | - ·                 | · <u> </u> |                                           | - ·    | · — ·   | <u> </u> | <u> </u>                  | · — ·                     | <u> </u> |         | · _ ·                                     | <u> </u> | _ · _                     | - ·     | · · _ · ·                                     |
|               | WR_31    | WR_30                     | $\langle \langle \rangle$ | WR_24    | WR_23               | WR_22      | $\langle \langle \langle \rangle \rangle$ | WR_16  | WR_15   | WR_14    | $\langle \langle \rangle$ | WR_8                      | WR_7     | WR_6    | $\langle \langle \langle \rangle \rangle$ | WR_1     | WR_0                      | Data    | register                                      |
|               |          |                           |                           | <b>.</b> |                     |            |                                           | ·↓     |         |          |                           | <b>.</b>                  | ·        |         |                                           |          |                           |         |                                               |
|               | S3_31    | S3_30                     |                           | S3_24    | S3_23               | S3_22      |                                           | S3_16  | S3_15   | S3_14    |                           | S3_8                      | S3_7     | S3_6    | $\int$                                    | \$3_1    | S3_0                      | Stage4  |                                               |
|               | S2_31    | S2_30                     |                           | S2_24    | S2_23               | S2_22      | $\langle \rangle$                         | S2_16  | S2_15   | S2_14    | $\langle \langle \rangle$ | S2_8                      | S2_7     | S2_6    | $\mathbb{S}$                              | \$2_1    | S2_0                      | Stage3  | Transmit                                      |
|               | S1_31    | S1_30                     | $\langle \langle \rangle$ | S1_24    | S1_23               | S1_22      | $\langle \langle \rangle$                 | S1_16  | \$1_15  | S1_14    | $\langle \langle \rangle$ | S1_8                      | \$1_7    | S1_6    | $\langle \langle \rangle$                 | \$1_1    | \$1_0                     | Stage 2 | FIFO                                          |
|               | S0_31    | S0_30                     | $\langle \langle \rangle$ | S0_24    | S0_23               | S0_22      | $\langle \langle \rangle$                 | S0_16  | S0_15   | S0_14    | $\langle \langle \rangle$ | S0_8                      | S0_7     | S0_6    | $\langle \langle \rangle$                 | S0_1     | S0_0                      | Stage1  |                                               |
| L             |          |                           |                           | ·        |                     |            |                                           |        | ·       |          |                           |                           |          |         |                                           |          |                           |         |                                               |
|               | TXD31    | TXD30                     | S                         | TXD24    | TXD23               | TXD22      | $\mathbb{S}$                              | TXD16  | TXD15   | TXD14    | $\mathbb{S}$              | TXD8                      | TXD7     | TXD6    | $\mathbb{S}$                              | TXD1     | TXD0                      | Sh      | <ul> <li>Transmit<br/>ift register</li> </ul> |
| <b>—</b> ·    | <u> </u> | - ·                       | · — ·                     | — · -    | <b>-</b> · <b>-</b> | · — ·      | - • •                                     | _ · _  | · · — · | - · ·    | - • -                     | · · —                     | · — ·    | — · –   | - ·                                       | · _ ·    | — · -                     |         | - · - ·                                       |
| $\rightarrow$ | RXD31    | RXD30                     | $\square$                 | RXD24    | RXD23               | RXD22      | $\mathbb{S}$                              | RXD16  | RXD15   | RXD14    | $\mathbb{S}$              | RXD8                      | RXD7     | RXD6    | $\langle \rangle$                         | RXD1     | RXDO                      | Rece    | eive<br>register                              |
| ſ             | ·        |                           |                           |          | ····                |            |                                           |        |         |          |                           | <b>-</b>                  |          |         |                                           |          |                           |         | - ogietei                                     |
|               | S3_31    | S3_30                     |                           | S3_24    | S3_23               | S3_22      |                                           | S3_16  | S3_15   | S3_14    |                           | S3_8                      | S3_7     | S3_6    | S                                         | S3_1     | S3_0                      | Stage4  |                                               |
|               | S2_31    | S2_30                     | S                         | S2_24    | S2_23               | S2_22      | S                                         | S2_16  | \$2_15  | S2_14    | S                         | S2_8                      | S2_7     | S2_6    | S                                         | S2_1     | S2_0                      | Stage 3 | Receive                                       |
|               | S1_31    | S1_30                     | $\square$                 | S1_24    | S1_23               | S1_22      | $\langle \rangle$                         | \$1_16 | \$1_15  | \$1_14   | $\mathbb{S}$              | S1_8                      | \$1_7    | S1_6    | $\langle \rangle$                         | \$1_1    | S1_0                      | Stage2  | FIFO                                          |
|               | S0_31    | S0_30                     | $\mathbb{S}$              | S0_24    | S0_23               | S0_22      | $\mathbb{S}$                              | S0_16  | S0_15   | S0_14    | $\mathbb{S}$              | S0_8                      | S0_7     | S0_6    | $\int$                                    | S0_1     | S0_0                      | Stage1  |                                               |
| Ĺ.            |          |                           |                           |          |                     |            |                                           |        | ····    |          |                           |                           |          |         |                                           | ·        |                           |         |                                               |
|               | RD_31    | RD_30                     |                           | RD_24    | RD_23               | RD_22      |                                           | RD_16  | RD_15   | RD_14    |                           | RD_8                      | RD_7     | RD_6    |                                           | RD_1     | RD_0                      | Data    | register                                      |

Figure 3.14 Buffer operation of the sector mode (with parity, LSB first)

(1) Transmit buffer operation

The transmit data are written by the CPU or DMAC to the data register *[TSPIxDR]* when the operation is stopped or during communication, and is stacked to the first level stage when the transmit FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data. Also, when the transmit buffer is empty, the transmit data written after the communication is allowed are immediately transferred to the transmit shift register, and the transmit will start. Make sure that no underrun

errors occur during a slave operation. (Refer to "3.7.3. Error Interrupt")

Figure 3.14 shows the transmit data in the sector 0 to 3 saved on level stages 1 to 4 on the transmit FIFO. When the operation is allowed to start communications after being stopped or the transmit of a frame has been completed, the data on the first level stage of the transmit FIFO is moved to the transmit shift register and are transmitted. When the first level stage of the transmit FIFO corresponds to the last sector 3, the parity bit is attached to MSB before the data are moved to the transmit shift register and transmitted. At the same time, the data on level stages 2 to 4 is moved to level stages 1 to 3.

The transmit data within the transmit shift register are transmitted for each serial clock, starting from LSB  $(S0_0)$  in the sector 0.

(2) Receive buffer operation

Each time a sector is received during communications, the data within the receive shift register are stacked to the first level stage when the receive FIFO is empty. The data are stacked to the second level stage when the first level stage is already filled with data.

Figure 3.14 shows the data within the sector 0 to 3 saved on level stages 1 to 4 on the receive FIFO. For each serial clock, the received data are saved within the receive shift register, starting from LSB (S0\_0) in the sector 0 and are stacked to the lowest level stage on the receive FIFO each time a sector is received. When the last sector 3 is received, the parity bit is removed from MSB before the data are moved to the receive FIFO.

From the data register *[TSPIxDR]*, the CPU or DMAC will read out the data on the first level of the receive FIFO. At the same time, the data on level stages 2 to 4 is moved to level stages 1 to 3.

## **3.6.2.6.** Transfer cycle for master operations

The operation specification following sector transfer during a master operation is described. When the sector length of the sector except the final sector is 1 bit, a cycle between sectors occurs after the sector transfer.

| Order of sector<br>transfer | Sector<br>(note)<br>[bit]                                                                                                                              | Operation specificatior                 | n following sector transfer         |  |  |  |  |  |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------------------------------|--|--|--|--|--|
| Sectors other than the last | er 1 The cycle is generated between sectors and the next sector is transferred after one cycle of the transfer clock (1/f <sub>SCK</sub> ) has passed. |                                         |                                     |  |  |  |  |  |
| sector                      | 2 to 32                                                                                                                                                | No cycle is generated between sectors a | and the next sector is transferred. |  |  |  |  |  |
|                             | 1 to 32                                                                                                                                                |                                         | "Parity bit only" is prohibited.    |  |  |  |  |  |
| Loot oostor                 | 5 to 32                                                                                                                                                | Frame transfer complete                 |                                     |  |  |  |  |  |
| Last sector                 | 6 to 32                                                                                                                                                | (Parity bit included if available)      | -                                   |  |  |  |  |  |
|                             | 7 to 32                                                                                                                                                |                                         |                                     |  |  |  |  |  |

 Table 3.11
 Operation specification following sector transfer during a master operation

Note: Corresponds to the bit length of the sector 0/1/2/3 in the data transfer cycle in Table 3.12.

Figure 3.15 shows an example of when a cycle is generated between sectors (sector 1, sector length = 1). One cycle corresponds to the cycle of a transfer clock TSPIxSCK ( $1/f_{SCK}$ ).

[example Timing for cycle generation between sectors:



#### Figure 3.15 Timing for cycle generation between sectors (sector mode, master operation)

The above figure shows the cycle generation timing where the polarity of TSPIxCSn is negative *[TSPIxFMTR0]*<CSnPOL>= 0, the polarity of TSPIxSCK (levels during the idle period) is "Low" <CKPOL>= 0, the RXD sampling timing is configured to the 2nd edge <CKPHA>= 1, the cycle following the CS assertion and the cycle preceding the CS deassertion cycle is 1, the each sector length is 3 bits (Sector 0), 1 bit (Sector 1), 4 bits (Sector 2), and 1 bit (Sector 3).

Inter-sector cycle is generated after Sector 1 with the sector length of 1 bit is transferred. Although Sector 3 is 1 bit length, inter-sector cycle is not generated because it is the last sector.

TSPIxSCK will not be changed during inter-sector cycles and TSPIxTXD will continue to maintain the data from Sector 1.

(TSPIxRXD simulates the data received from TSPIxTXD in the slave mode)

# TOSHIBA

The transfer cycle count for each condition is shown along with sector counts and sector lengths.

|     | Total cycles | Transf                 | er cycle (corresp         | onding to t       | he CS asse             | rtion period           | d in the SPI           | mode operati | on)                |                           |
|-----|--------------|------------------------|---------------------------|-------------------|------------------------|------------------------|------------------------|--------------|--------------------|---------------------------|
|     |              | Cycle                  | Cycle                     | F                 | rame lengt             | h c: 8 to 12           | 8                      | 1            | Inter-             | Continuous<br>idle period |
| No. | Continuous   | following              | preceding the             |                   | Data transfe           | er cycle [bit          | []                     |              | sector             | for transfer              |
|     | a+b+c+f+g    | assertion<br>a:1 to 16 | deassertion<br>b: 1 to 16 | 0<br>0<br>1 to 32 | Sector<br>1<br>1 to 32 | Sector<br>2<br>1 to 32 | Sector<br>3<br>1 to 32 |              | cycle<br>f:0 to f3 | g:1 to g15                |
| 1   | 10 to 130    | 1                      | 1                         | 2 to 32           | 2 to 32                | 2 to 32                | 1 to 32                | 8 to 128     | 0                  | -                         |
|     |              |                        |                           | 2 to 32           | 2 to 32                | 1                      | 1 to 32                |              |                    |                           |
| 2   | 11 to 100    | 1                      | 1                         | 2 to 32           | 1                      | 2 to 32                | 1 to 32                | 8 to 97      | 1                  | -                         |
|     |              |                        |                           | 1                 | 2 to 32                | 2 to 32                | 1 to 32                |              |                    |                           |
|     |              |                        |                           | 2 to 32           | 1                      | 1                      | 1 to 32                |              |                    |                           |
| 3   | 12 to 70     | 1                      | 1                         | 1                 | 2 to 32                | 1                      | 1 to 32                | 8 to 66      | 2                  | -                         |
|     |              |                        |                           | 1                 | 1                      | 2 to 32                | 1 to 32                |              |                    |                           |
| 4   | 43 to 70     | 16                     | 16                        | 1                 | 1                      | 1                      | 5 to 32                | 8 to 35      | 3                  | -                         |
| 5   | 10 to 98     | 1                      | 1                         | 2 to 32           | 2 to 32                | 1 to 32                | 0                      | 8 to 96      | 0                  | -                         |
| 6   | 11 to 69     | 1                      | 1                         | 2 to 32           | 1                      | 1 to 32                | 0                      | 9 to 65      | 1                  |                           |
| 0   | 111000       | 1                      | 1                         | 1                 | 2 to 32                | 1 to 32                | 0                      | 0 10 05      | 1                  | -                         |
| 7   | 12 to 38     | 1                      | 1                         | 1                 | 1                      | 6 to 32                | 0                      | 8 to 34      | 2                  | -                         |
| 8   | 10 to 66     | 1                      | 1                         | 2 to 32           | 1 to 32                | 0                      | 0                      | 8 to 64      | 0                  | -                         |
| 9   | 11 to 36     | 1                      | 1                         | 1                 | 7 to 32                | 0                      | 0                      | 8 to 33      | 1                  | -                         |
| 10  | 11 to 67     | 1                      | 1                         | 2 to 32           | 1 to 32                | 0                      | 0                      | 8 to 64      | 0                  | 1                         |
| 11  | 58 to 85     | 16                     | 16                        | 1                 | 1                      | 1                      | 5 to 32                | 8 to 35      | 3                  | 15                        |

 Table 3.12
 Example of transfer cycles (sector mode, master operation)

Upon launching the software, the total cycles that occur from when the transfer is conducted to when the next frame starts can be expressed with the following formula.

Total cycles = cycles following CS assertion (a) + cycles preceding CS deassertion (b) + frame length (c) + intersector cycles (f) + idle period (g)

For the example in No. 10, when the frame length is 8 bits, there are 1+1+8+0+1 = 11 transfer cycles in total. For the example in No. 11, when the frame length is 35 bits, there are 16+16+35+3+15 = 85 transfer cycles in total.

Also, a frame can be transferred by continuously writing in Start  $\langle TRXE \rangle = 1$  and Stop  $\langle TRXE \rangle = 0$  within the register.

The total cycle for a single frame transfer is the same as when the Start Communication trigger is activated.

When the Start Communication trigger is activated, the total cycle for transferring one frame can be expressed with the following formula.

Total cycles = cycles following CS assertion (a) + cycles preceding CS deassertion (b) + frame length (c) + intersector cycles (f)

For the example in No. 8, when the frame length is 64 bits, there are 1+1+64+0 = 66 transfer cycles in total. For the example in No. 4, when the frame length is 8 bits, there are 16+16+8+3 = 43 transfer cycles in total. Each transfer time can be expressed as follows.

Transfer time = transfer clock cycle  $(1/f_{SCK}) \times$  total cycles

In addition, the cycles following the CS assertion and the ones preceding the CS deassertion are configured in *[TSPIxFMTR0]*<CSSCKDL[3:0]> <SCKCSDL[3:0]> and the idle period for continuous transfers of 2 or more frames is set in *[TSPIxFMTR0]*<CSINT[3:0]>. The period for the generation of each cycle is valid for both the SPI and SIO modes.

# 3.7. Interrupt Request

The TSPI has three types of interrupts: receive interrupt, transmit interrupt and error interrupt.

Each interrupt is an output consisting of some signals related to interrupts. Transmit interrupts and receive interrupts are enabled / disabled for each interrupt factor, and error interrupts can be set to be enabled / disabled at once.

| Interrupt request  | Interrupt factor                            | Enable register                      |  |
|--------------------|---------------------------------------------|--------------------------------------|--|
| Tropomit interrupt | Transmit completion interrupt               | [TSPIxCR2] <inttxwe></inttxwe>       |  |
| Transmit interrupt | Transmit FIFO interrupt                     | [TSPIxCR2] <inttxfe></inttxfe>       |  |
| Pagaiva interrupt  | Receive completion interrupt                | [TSPIxCR2] <intrxwe></intrxwe>       |  |
| Receive Interrupt  | Receive FIFO interrupt                      | [TSPIxCR2] <intrxfe></intrxfe>       |  |
|                    | Vertical parity error interrupt             |                                      |  |
| Error interrupt    | Overrun error interrupt                     | [ <b>TSPIxCR2]</b> <interr></interr> |  |
|                    | Underrun error interrupt                    |                                      |  |
|                    | Communication start trigger error interrupt |                                      |  |

Table 3.13 Interrupt factors and requests



Figure 3.16 Interrupt request Circuit

# 3.7.1. Transmit Completion Interrupt / Receive Completion Interrupt

• Master device operation

The transmit completion interrupt is generated with the burst transfer and continuous transfer at the timing of which TSPIxCS0/1/2/3 are deasserted at transmit or transmit and receive(full-duplex) communication. As well, the receive completion interrupt is generated with the burst transfer and continuous transfer at the timing of which TSPIxCS0/1/2/3 are deasserted at receive or transmit and receive(full-duplex) communication.

#### • Slave device operation

The transmit completion interrupt with the burst transfer is generated at the timing of the final frame transfer end at transmit or transmit and receive(full-duplex) communication.

And in the case of the continuous transfer, that is generated at the timing of one frame transfer end. As well, the receive end interrupt with the burst transfer is generated at the timing of the final frame transfer end at receive or transmit and receive(full-duplex) communication.

And in the case of the continuous transfer, that is generated at the timing of one frame transfer end.

## 3.7.2. Transmit FIFO Interrupt / Receive FIFO Interrupt

A transmit FIFO interrupt occurs when the following conditions are met.

- a) The data is transferred to the transmit shift register when [TSPIxSR]<TLVL[3:0]>(transmit FIFO fill level status register) is added by 1 to the transmit FIFO interrupt generation condition specified in [TSPIxCR2]<TIL[3:0]>(transmit FIFO Fill level setting register). Then, the transmit FIFO interrupt is generated when the fill level of transmit FIFO is reduced by 1, and <TLVL[3:0]> is changed to the same value of the transmit interrupt generation condition <TIL[3:0]>.
- b) In case of <TLVL[3:0]> = <TIL[3:0]>+1
   When the data in the FIFO is read into the shift register before transmit starts, then interrupt occurs.

Receive FIFO interrupt occurs when the following conditions are met.

a) The data is transferred to the receive shift register when [TSPIxSR]<RLVL[3:0]>(receive FIFO fill level status register) is reduced by 1 to the receive FIFO interrupt generation condition specified in [TSPIxCR2]<RIL[3:0]>(receive FIFO fill level setting register). Then, the receive FIFO interrupt is generated when the fill level of receive FIFO is added by 1, and <RLVL[3:0]> is changed to the same value of the receive interrupt generation condition <RIL[3:0]>.

## 3.7.3. Error Interrupt

The following error interrupt is generated. In case, please process appropriately.

(1) Parity error interrupt

The parity error interrupt is generated when the parity error occurs. When the parity is enabled, the parity is calculated automatically by the data received one bit before the final bit of the frame length.

The parity error interrupt is generated when the parity bit received as the final bit of the frame length is compared and not matched. Also, the interrupt generation timing is the time when the receive frame data are stored to the receive FIFO.

#### (2) Underrun error interrupt and overrun error interrupt

An underrun and overrun errors occur in slave mode.

An underrun error occurs if, after transmit the data in the transmit shift register, the next transfer clock is inputted while the transmit buffer is empty. For the transmitted data for frames where an underrun error has occurred, the output level configured on *[TSPIxCR2]* <TXDEMP> (output value control for underrun errors in TSPIxTXD) register is maintained until the end of the frames.

An overrun error occurs if, after receiving the data in the receive shift register, the next transfer clock is inputted while the receive buffer is full. Data in the frame where an overrun occurs is not received. Thus, the contents of the receive FIFO and receive shift register are not updated.



#### Figure 3.17 Overrun error and underrun error

Note1: It depends on *[TSPIxCR2]*<TIDLE[1:0]>. Note2: It depends on *[TSPIxCR2]*<TXDEMP>.

#### (3) Communication start trigger error interrupt

Communication start trigger error interrupt is generated in master mode if communication cannot be started with trigger while the start communication trigger is enabled (*[TSPIxCR1]*<TRGEN>= 1). For more information, refer to 3.9.1 " Communication Start Trigger".

# 3.8. DMA Request

The DMA request has the transmit and receive request. These requests have a single and burst request.

Supported DMA requests depend on the product. Refer to reference manual "Product Information" for details.

# 3.8.1. Transmit

The single DMA request of transmit and a burst DMA request of transmit will be enabled when *[TSPIxCR2]*<DMATE> is set to "1".

When FIFO has one or more empty stages, a single request occurs.

A burst transmit DMA request occurs when a value of *[TSPIxSR]*<TLVL[3:0]> indicating the current value of fill level is equal to or less than transmit interrupt generation condition (fill level) specified in *[TSPIxCR2]*<TIL[3:0]>. If *[TSPIxSR]*<TLVL[3:0]> is still equal to or less than the fill level after completion of DMA transfer, a burst transmit DMA request occurs again.

## 3.8.2. Receive

The single DMA request of receive and a burst DMA request of receiving will be enabled when [*TSPIxCR2*] <DMARE> is set to "1".

When FIFO has one or more data, a single request occurs.

A burst receive DMA request occurs when a value of *[TSPIxSR]*<RLVL[3:0]> indicating the current value of fill level is equal to or greater than receive interrupt generation condition (fill level) specified in *[TSPIxCR2]*<RIL[3:0]>. If *[TSPIxSR]*<RLVL[3:0]> is still equal to or greater than *[TSPIxCR2]*<RIL[3:0]> after completion of DMA transfer, a burst receive DMA request occurs again.

# 3.9. Trigger Control

## 3.9.1. Communication Start Trigger

The table below shows the configurable modes that allow for starting communication by activating triggers on peripherals.

| Cc               | onfigurable mode |                        | Operation specification for when communication start triggers are provided |
|------------------|------------------|------------------------|----------------------------------------------------------------------------|
| Master operation |                  | Burst transfer         | Starts transfer, ends after transferring 1 to 255 frame(s)                 |
|                  | Frame mode       | Continuous<br>transfer | - (Not available)                                                          |
|                  | Sector mode      |                        | Starts transfer, ends after transferring 1 frame                           |
| Slave operation  |                  |                        | - (Not available)                                                          |

| Table 3.14 | Configurable modes f | or communication | start trigger |
|------------|----------------------|------------------|---------------|
|------------|----------------------|------------------|---------------|

Stop condition: [TSPIxSR]<TSPISUE>= 0 and [TSPIxCR1]<TRGEN>= 0, <TRXE>= 0

Waiting for the communication start trigger: *[TSPIxSR]*<TSPISUE>= 0 and *[TSPIxCR1]*<TRGEN>= 1, <TRXE>= 0

Communication start trigger activating: [TSPIxSR]<TSPISUE>= 1 and [TSPIxCR1]<TRGEN>= 1, <TRXE>= 1

The peripherals that output Communication start trigger vary depending on the product to be used. For more information, refer to reference manual "Product Information".

The transmit and receive operations in the trigger control are conducted as follows.

(1) Receiving trigger

When the stop condition is confirmed and the condition [*TSPIxCR1*]<TRGEN>= 1 is configured, the state enters to the "Waiting for the Communication start trigger" state. When the trigger is input and communication is started, the state enters to the "Communication start trigger activating" state. Once the communication is terminated, the state is changed to "Waiting for the communication start trigger." Triggers that are input under the "Communication start trigger activating" state is ignored. Enter the next trigger after the communication is completed.

#### (2) Transmit operation

When a trigger is provided while the transmit FIFO contains data, the clock and the data are output, and the transmit starts.

In the frame mode, the clock output is stopped, and the transmit is terminated once the number of transfers specified in *[TSPIxCR1]*<FC[7:0]> has been conducted.

In the sector mode, the clock output is stopped, and the transmit is terminated for each frame that has been transmitted.

(3) Receive operation

When a trigger is provided while the receive FIFO is not full, the clock is output and the receive starts. In the frame mode, the clock output is stopped, and the receive is terminated once the number of transfers specified in *[TSPIxCR1]*<FC[7:0]> has been conducted.

In the sector mode, the clock output is stopped, and the receive is terminated for each frame that has been received.

(4) Error for the communication start trigger

When a trigger is provided while the transmit FIFO is empty, the trigger is ignored, the error interrupt is output, and the flag for the error on the Communication start trigger (*[TSPIxERR]*<TRGERR>) is set. When a trigger is provided while the receive FIFO is full, the trigger is ignored, the error interrupt is output, and the flag for the error on the Communication start trigger is set. Triggers that are provided while the flag for the arror on the Communication start trigger is set.

Triggers that are provided while the flag for the error on the Communication start trigger is set are ignored.

# 3.9.2. Communication Complete Trigger

Using the outputs of the Transmit Complete trigger (TSPIxTXEND) and the Receive Complete trigger (TSPIxRXEND) allows for syncing with other peripherals, such as triggering the timer counter. The synced peripherals vary depending on the product to be used. For more information, refer to reference manual "Product Information".

# 3.10. Special Control

# 3.10.1. Polarity of Serial Clock

The polarity of the serial clock TSPIxSCK (SCK) can be selected on *[TSPIxFMTR0]*<CKPOL> (the polarity register of the idle period for a serial clock).

When *[TSPIxFMTR0]*<CKPOL>= 0, TSPIxSCK outputs "Low" level signal during the idle period and the first clock edge is a rising edge.

When *[TSPIxFMTR0]*<CKPOL>= 1, TSPIxSCK outputs "High" level signal during the idle period and the first clock edge is a falling edge.

# 3.10.2. TSPIxTXD Output during Idle Period

The output level during idle period of the transmit data TSPIxTXD (hereinafter referred as TXD) is selected in *[TSPIxCR2]*<TIDLE[1:0]>.

| [TSPIxCR2] <tidle[1:0]></tidle[1:0]> | Output              |
|--------------------------------------|---------------------|
| 00                                   | Hi-Z                |
| 01                                   | Final transmit data |
| 10                                   | Low                 |
| 11                                   | High                |

Table 3.15 TSPIxTXD Output during Idle Period

The TXD output changes to the state shown in Table 3.15 at the timing of *[TSPIxCR2]*<TIDLE[1:0]> setting. The different conditions from the state shown in Table 3.15 are as follows.

- When the "final transmit data" is set before the first transmit execution, "High" is output.
- At Master operation, even if "final transmit data setting state" is changed from "High" setting or "Low" setting, each state of "High" or "Low" is held. And it moves to the idle period while the final data is held after the transmit completion.
- At Slave operation, when an underrun error occurs and the value specified in *[TSPIxCR2]*<TXDEMP> is output, the state is changed to the state shown in Table 3.15 after the transmit completion.
- The final transmit data are held in the frame interval period during the burst transfer.
- At Master operation in SIO mode, an unfixed value is output before one clock of SCK clock cycle of the transmit start.

#### [TSPIxCR2]<TIDLE[1:0]>= 10 ,[TSPIxFMTR0]<CKPHA>= 1: Example of outputting low at idle



Figure 3.18 Idle period in SPI mode and the transmit pin status

[TSPIxCR2]<TIDLE[1:0]>= 10, [TSPIxFMTR0]<CKPHA>= 1: Example of outputting Low at idle



## Figure 3.19 Idle period in SIO mode and the transmit pin status

# 3.10.3. TXD last data hold period

During a slave operation in the SIO mode, the last data hold period for the transmit data TSPIxTXD (TXD) is set to the system clock fsys cycle times  $2^n$  (n=1 to 7) in [TSPIxFMTR1] <EHOLD[2:0]>.

# 3.10.4. RXD sampling timing

The sampling timing for the received data TSPIxRXD (RXD) can be switched in *[TSPIxFMTR0]*<CKPHA>. The sampling is conducted in the 2nd edge and the 1st edge when *[TSPIxFMTR0]*<CKPHA>= 1 and *[TSPIxFMTR0]*<CKPHA>= 0, respectively.

Table 3.16 shows various communication modes along with the availabilities of RDX sampling timing. When the Slave operation / sector mode is selected, the sampling timing of 1st edge is inhibited using.

|                     | ammunication mode | RXD sampling timing |              |              |  |
|---------------------|-------------------|---------------------|--------------|--------------|--|
| Communication modes |                   |                     | 1st edge     | 2nd edge     |  |
|                     | Master operation  | Frame               | $\checkmark$ | $\checkmark$ |  |
| SPI mode            |                   | Sector              | $\checkmark$ | ~            |  |
|                     | Slave operation   | Frame               | ~            | ~            |  |
|                     |                   | Sector              | ×            | ~            |  |
| SIO mode            | Maatar aparation  | Frame               | ~            | ~            |  |
|                     | Master operation  | Sector              | ~            | ~            |  |
|                     | Slave operation   | Frame               | ~            | ~            |  |
|                     | Slave operation   | Sector              | ×            | ~            |  |

 Table 3.16
 Communication modes and the availabilities of the RXD sampling timing

 $\checkmark$ : Can be used  $\times$ : Can not be used

Table 3.17 shows the data capture timing

| Polarity of idle period of TSPIxSCK   | Data capture timing<br>[TSPIxFMTR0] <ckpha></ckpha> |                          |  |
|---------------------------------------|-----------------------------------------------------|--------------------------|--|
| <i>[TSPIxFMTR0]</i> <ckpol></ckpol>   | 0<br>(1st edge sampling)                            | 1<br>(2nd edge sampling) |  |
| 0 (Polarity of idle period is "Low")  | Rising edge                                         | Falling edge             |  |
| 1 (Polarity of idle period is "High") | Falling edge                                        | Rising edge              |  |

Table 3.17 Data capture timing

# TOSHIBA

[SPI mode(master) 2nd edge data sampling<CKPHA>=1]



[SPI mode(master) 1st edge data sampling<CKPHA>=0 Idle period output is Hi-Z<TIDLE[1:0]>=00]



Figure 3.20 Data sampling timing of SPI mode (master)



[SPI mode(slave) 1st edge data sampling<CKPHA>=0]



Figure 3.21 Data sampling timing SPI mode (slave)

[SIO mode(master)2nd edge data sampling<CKPHA>=1]



[SIO mode(slave)2nd edge data sampling<CKPHA>=1]





# 3.10.5. CS timing and polarity

The polarities of the chip select TSPIxCS0/1/2/3 (CS) is selectable with From [*TSPIxFMTR0*]<CSnPOL> for each pin.

In the case of *[TSPIxFMTR0]*<CSnPOL>= 0, it becomes negative logic and *[TSPIxFMTR0]*<CSnPOL>= 1, it becomes positive logic.

Moreover, the generating timing of CS in master mode can be set up as follows.

- 1. Cycle following the CS assertion (common across Frame / Sector mode and burst / continuous transfer) In the SPI mode operation, set the time interval from the CS assertion to the SCK 1st edge (ta) to n (n=1 to 16) times the SCK cycle in *[TSPIxFMTR0]*<CSSCKDL[3:0]>.
- 2. Cycle preceding the CS deassertion (Common across frame / sector and burst / continuous transfer) In the SPI mode operation, set the time interval from the end of the SCK cycle in the last data to the CS deassertion (tb) to n (n=1 to 16) times the SCK cycle in [TSPIxFMTR0]<SCKCSDL[3:0]>.
- Frame interval period (common across the SPI / SIO mode) In frame mode / burst transfers, set the frame interval period (tc) to n (n=1 to 15) times the SCK cycle in [TSPIxFMTR0]<FINT[3:0]>.
- Idle period (common across SPI / SIO mode, Frame / Sector mode) In continuous transfers, set the idle period (td) to n (n=1 to 15) times the SCK cycle in [TSPIxFMTR0]<CSINT[3:0]>. The idle period corresponds to the CS deassertion period in the SPI mode operation and can be configured in the SIO mode operation.



Figure 3.24 Transfer format and timing adjustment (Example for 2nd edge sampling)

### 3.10.6. Software Reset

TSPI can be reset by software and initialized. Refer to "4.2.1 [TSPIxCR0] (TSPI Control Register 0)" for details.

# 4. Registers

# 4.1. Register List

The following tables show the control registers and addresses.

| Peripheral Function        |      | Channel / Unit | Base address |            |            |  |
|----------------------------|------|----------------|--------------|------------|------------|--|
|                            |      | Channel / Unit | TYPE 1       | TYPE 2     | TYPE 3     |  |
|                            |      | ch0            | 0x40098000   | 0x400CA000 | 0x4006A000 |  |
|                            |      | ch1            | 0x40099000   | 0x400CA400 | 0x4006A400 |  |
|                            |      | ch2            | 0x4009A000   | 0x400CA800 | 0x4006A800 |  |
|                            | TSPI | ch3            | 0x4009B000   | 0x400CAC00 | 0x4006AC00 |  |
|                            |      | ch4            | 0x4009C000   | 0x400CB000 | 0x4006B000 |  |
| Sorial Darinhard Interface |      | ch5            | 0x4009D000   | 0x400CB400 | 0x4006B400 |  |
| Senai Fenpherai Interface  |      | ch6            | 0x4009E000   | 0x400CB800 | 0x4006B800 |  |
|                            |      | ch7            | 0x4009F000   | 0x400CBC00 | 0x4006BC00 |  |
|                            |      | ch8            | 0x40096000   | 0x400CC000 | 0x4006C000 |  |
|                            |      | ch9            | 0x40097000   | 0x400CC400 | 0x4006C400 |  |
|                            |      | ch10           | -            | 0x400CC800 | 0x4006C800 |  |
|                            |      | ch11           | -            | 0x400CCC00 | 0x4006CC00 |  |

Note: The channel / unit and base address type are different by products. Refer to reference manual "Product Information" for details.

| Register name                       | Address(Base+) |        |
|-------------------------------------|----------------|--------|
| TSPI Control Register 0             | [TSPIxCR0]     | 0x0000 |
| TSPI Control Register 1             | [TSPIxCR1]     | 0x0004 |
| TSPI Control Register 2             | [TSPIxCR2]     | 0x0008 |
| TSPI Control Register 3             | [TSPIxCR3]     | 0x000C |
| TSPI Baud Rate Register             | [TSPIxBR]      | 0x0010 |
| TSPI Format Control Register 0      | [TSPIxFMTR0]   | 0x0014 |
| TSPI Format Control Register 1      | [TSPIxFMTR1]   | 0x0018 |
| TSPI Sector Mode Control Register 0 | [TSPIxSECTCR0] | 0x001C |
| TSPI Sector Mode Control Register 1 | [TSPIxSECTCR1] | 0x0020 |
| TSPI Data Register                  | [TSPIxDR]      | 0x0100 |
| TSPI Status Register                | [TSPIxSR]      | 0x0200 |
| TSPI Error Flag Register            | [TSPIxERR]     | 0x0204 |

Note: Registers except [TSPIxCR0]<SWRST[1:0]>, [TSPIxCR1]<TRXE>, [TSPIxDR] and [TSPIxSR] cannot be set when [TSPIxSR]<TSPISUE> is "1".

# TOSHIBA

# 4.2. Detail of Register

# 4.2.1. [TSPIxCR0] (TSPI Control Register 0)

| Bit  | Bit Symbol | After<br>reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|------------|----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -          | 0              | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7:6  | SWRST[1:0] | 00             | W    | TSPI software reset (Note)<br>Software reset occurs by writing "10" and then "01".<br>By software reset, the transfer operation under execution is<br>forcibly terminated and the value of the control register other than<br>the transfer setting is initialized. (Table 4.1)                                                                                                                                    |
| 5:1  | -          | 0              | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0    | TSPIE      | 0              | R/W  | TSPI operation control<br>0: Stop<br>1: Operation<br><tspie> controls a whole operation of TSPI to start/stop (clock<br/>shutdown). When <tspie>=0 (stop) is set, a clock is not fed into<br/>the internal of the TSPI. Set <tspie>=1 (operation) to start<br/>operation first. Then perform initialization and communications.<br/><tspie> is not initialized by software reset.</tspie></tspie></tspie></tspie> |

Note: Completion of software reset takes two clocks after an instruction is executed. When TSPI setting is stopped (<TSPIE>= 0), software reset is not applied.

To perform a software reset, consecutively write "10" and then "01" to *[TSPIxCR0]*<SWRST[1:0]>(Software reset register). Software reset will become invalid if other TSPI control registers are accessed in between "10" and "01". Please redo from writing "10".

"Table 4.1 Initialized registers by software reset" shows the initialized register by software reset.

#### Table 4.1 Initialized registers by software reset

| Register name  | Symbol name                                                                                                                                                                                            |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [TSPIxCR0]     | No registers                                                                                                                                                                                           |
| [TSPIxCR1]     | <trxe></trxe>                                                                                                                                                                                          |
| [TSPIxCR2]     | <til[3:0]><ril[3:0]><inttxfe><inttxwe><intrxfe><br/><intrxwe><interr><dmate><dmare></dmare></dmate></interr></intrxwe></intrxfe></inttxwe></inttxfe></ril[3:0]></til[3:0]>                             |
| [TSPIxCR3]     | No registers                                                                                                                                                                                           |
| [TSPIxBR]      | No registers                                                                                                                                                                                           |
| [TSPIxFMTR0]   | No registers                                                                                                                                                                                           |
| [TSPIxFMTR1]   | No registers                                                                                                                                                                                           |
| [TSPIxSECTCR0] | No registers                                                                                                                                                                                           |
| [TSPIxSECTCR1] | No registers                                                                                                                                                                                           |
| [TSPIxDR]      | No registers                                                                                                                                                                                           |
| [TSPIxSR]      | <tspisue><txrun><txend><inttxwf><tfemp><br/><tlvl[3:0]><rxrun><rxend><intrxff><rffll><rlvl[3:0]></rlvl[3:0]></rffll></intrxff></rxend></rxrun></tlvl[3:0]></tfemp></inttxwf></txend></txrun></tspisue> |
| [TSPIxERR]     | <trgerr><udrerr><ovrerr><perr></perr></ovrerr></udrerr></trgerr>                                                                                                                                       |

# 4.2.2. [TSPIxCR1] (TSPI Control Register 1)

| Bit   | Bit Symbol | After<br>reset | Туре | Function                                                                                                                                                                                                                                                                                                          |
|-------|------------|----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | -          | 0              | R    | Read as "0".                                                                                                                                                                                                                                                                                                      |
| 16    | INF        | 0              | R/W  | Infinite times of transfer control for the burst transfer frames<br>(Note 1)<br>0: Infinite times of transfer control is disabled.<br>1: Infinite times of transfer control is enabled.                                                                                                                           |
| 15    | TRGEN      | 0              | R/W  | Trigger control (valid only in Master operation)<br>0: Not used<br>1: A trigger is valid                                                                                                                                                                                                                          |
| 14    | TRXE       | 0              | R/W  | Communication control (Note2)(Note3)(Note4) (Note5)(Note6)<br>(Note7)<br>0: Communication stops<br>1: Communication is enabled<br>Set TRXE to "1" after all the settings have been completed.                                                                                                                     |
| 13    | TSPIMS     | 0              | R/W  | Communication mode selection<br>0: SPI mode<br>1: SIO mode                                                                                                                                                                                                                                                        |
| 12    | MSTR       | 1              | R/W  | Master / slave selection<br>0: Slave operation<br>1: Master operation                                                                                                                                                                                                                                             |
| 11:10 | TMMD[1:0]  | 11             | R/W  | Transfer mode selection<br>00: Reserved<br>01: Transmit only<br>10: Receive only<br>11: Full-duplex mode (Transmit / receive)<br>When the mode "transmit only" is selected, the processing<br>circuit for TSPIxRXD stops. When the mode "receive only" is<br>selected, the processing circuit for TSPIxTXD stops. |
| 9:8   | CSSEL      | 0              | R/W  | Selection of TSPIxCS0/1/2/3 (Note8)<br>00: TSPIxCS0 is valid<br>01: TSPIxCS1 is valid<br>10: TSPIxCS2 is valid<br>11: TSPIxCS3 is valid                                                                                                                                                                           |
| 7:0   | FC[7:0]    | 0x01           | R/W  | Sets the number of transfer frames<br>0: continuous transfer (No limit of transfer times specification)<br>1 to 255: Burst transfer (1 to 255 times transfer(s))                                                                                                                                                  |

- Note 1: When INF=1, the infinite times of transfer frames for the burst transfer is enabled regardless of FC value. When the serial transfer and the burst transfer (frame count 1-255) are used, INF=0 should be set. \* In the sector mode, (SECT=1), the INF setting has no meaning.
- Note 2: In Transmit and receive(Full-duplex communication) / transmit mode, a transmit can be started either by configuring *[TSPIxCR1]*<TRXE>= 1 (enable communication) while the transmit shift register contains data or by writing the transmit data with <TRXE>= 1. When the configuration of <TRXE>= 0 (stop communication) is conducted during transmit, the configuration of <TRXE>= 0 is applied after the transmit of the frame has been completed.

In receive mode, the receive will start immediately when the configuration of  $\langle TRXE \rangle = 1$  is conducted. When the configuration of  $\langle TRXE \rangle = 0$  is conducted during the receive, the configuration is applied after the receive of the frame has been completed.

- Note 3: In a burst transmit, the configuration of <TRXE>= 0 is applied after the transfer is completed. When conducting another burst transmit, configure <TRXE>= 1 after verifying that the flag that signifies the configurable state of TSPI has been set as follows: *[TSPIxSR]*<TSPISUE>= 0 (configurable state). In continuous transmits, the configuration <TRXE>= 0 is not applied unless it is explicitly set.
- Note 4: During slave operation, to stop communication in such a way that the communications on the master side do not start after the configuration of  $\langle TRXE \rangle = 1$  has been conducted, configure the TSPI software reset option as follows: [*TSPIxCR0*]  $\langle SWRST[1:0] \rangle = 10 \rightarrow 01$  (reset).

# TOSHIBA

- Note 5: During slave operation, when the configuration of  $\langle TRXE \rangle = 0$  has been conducted while the transmit FIFO contained data during the transmit of the data within the transmit shift register, clear the transmit buffer per [*TSPIxCR3*] $\langle TFEMPCLR \rangle = 1$  (clear) or conduct the configuration again after setting  $\langle SWRST[1:0] \rangle = 10$  $\rightarrow 01$ .
- Note 6: The FIFO data should be written before starting to transmit ( $\langle TRXE \rangle = 1$ ) in SIO mode slave 1st edge setting. When  $\langle TRXE \rangle = 1$  is set without writing FIFO data, an underrun will occur.
- Note 7: If the transfer ends 1st edge transmit of slave transmit in the SIO mode by setting <TRXE>=0 during transfer, the reset should be performed after the software reset in *[TSPIxCR0]*<SWRST[1:0]>.
- Note 8: Available during master operation in SPI mode. For the SIO mode or during slave operation, do not choose TSPIxCS0/1/2/3 in the settings of the port's functional terminals.
- Note 9: When stop communication in slave 1st edge transmit operation, stop communication while the serial clock is inputting from the master device. If stop communication when no clock input from master device, execute software reset.

#### After Bit **Bit Symbol** Туре Function reset 31:24 0 R Read as "0". -Fixed output value function control when TSPIxTXD idles. (Note 1) 00: Hi-Z 23:22 TIDLE[1:0] 11 R/W 01: Last data in the previous transfer 10: Fixed to low 11: Fixed to high Fixed output value function control when TSPIxTXD underruns (Slave operation). R/W 21 TXDEMP 1 0: Fixed to low 1: Fixed to high 0 Read as "0". 20:19 R Conditions for transfer clock frequencies f<sub>SCK</sub> (master operation) 000: fsys / fsck ≥ 2 100: fsys / f<sub>SCK</sub> ≥ 10 001: fsys / $f_{SCK} \ge 4$ 101: fsys / f<sub>SCK</sub> ≥ 12 18:16 R/W RXDLY[2:0] 001 010: fsys / fsck ≥ 6 110: fsys / fsck ≥ 14 011: fsys / fsck ≥ 8 111: fsys / fsck ≥ 16 For more information, refer to "Table 3.2." (Note 2) Transmit fill level setting R/W 15:12 TIL[3:0] 0000 Transmit FIFO interrupt occurrence condition (Note3) Receive fill level setting R/W 11:8 RIL[3:0] 0001 Receive FIFO interrupt occurrence condition (Note3) Transmit FIFO interrupt control 0: Disabled 1: Enabled 7 INTTXFE 0 R/W This is enable bit for generating fill level interrupt of transmit FIFO. Fill level setting is by <TIL[3:0]>. Transmit completion interrupt control 0: Disabled 1: Enabled R/W 6 INTTXWE 0 An interrupt is generated at the deassertion timing of TSPIxCS 0/1/2/3 when one frame ends during continuous transfer and when burst transfer ends during burst transfer. Receive FIFO interrupt control 0: Disabled 1: Enabled R/W 5 0 INTRXFE This is enable bit for generating fill level interrupt of receive FIFO. Fill level setting is by <RIL[3:0]>.

# 4.2.3. [TSPIxCR2] (TSPI Control Register 2)

| 4 | INTRXWE | 0 | R/W | Receive completion interrupt control<br>0: Disabled<br>1: Enabled<br>An interrupt is generated at the deassertion timing of TSPIxCS<br>0/1/2/3 when one frame ends during continuous transfer and<br>when burst transfer ends during burst transfer.                                                                          |
|---|---------|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | -       | 0 | R   | Read as "0".                                                                                                                                                                                                                                                                                                                  |
| 2 | INTERR  | 0 | R/W | Error Interrupt control<br>0: Disabled<br>1: Enabled<br>Enables interrupt for a receive parity error, a trigger<br>communication error in master operation, and an overrun error<br>and an underrun error in slave operation.                                                                                                 |
| 1 | DMATE   | 0 | R/W | Transmit DMA control<br>0: Disabled<br>1: Enabled<br>When <dmate> is set to "0" while the transmit DMA request<br/>signal is asserted, the request signal is deasserted. It is<br/>reasserted if it satisfies the transmit DMA request signal<br/>generation requirement when <dmate> is set to enable again.</dmate></dmate> |
| 0 | DMARE   | 0 | R/W | Receive DMA control<br>0: Disabled<br>1: Enabled<br>When <dmare> is set to "0" while the receive DMA request<br/>signal is asserted, the request signal is deasserted. It is<br/>reasserted if it satisfies the receive DMA request signal<br/>generation requirement when <dmare> is set to enable again.</dmare></dmare>    |

Note1: When the continuous transfer is performed in the SPI mode Slave operation 1st edge data sampling, each setting is disabled. An unfixed value is output.

Note2: Recommended setting values may be determined depending on the product. Refer to the Serial Peripheral Interface chapter in the Reference Manual "Product Specific Information" and the AC Electrical Characteristics chapter for the Serial Peripheral Interface in the "Data Sheet".

Note3: Fill level: Refer to Table 3.6 and Table 3.9 for the frame mode and the sector mode, respectively.

# 4.2.4. [TSPIxCR3] (TSPI Control Register 3)

| Bit  | Bit Symbol | After<br>reset | Туре | Function                                                                                                                                    |
|------|------------|----------------|------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | -          | 0              | R    | Read as "0".                                                                                                                                |
| 1    | TFEMPCLR   | 0              | w    | Clears transmit buffer<br>0: Invalid<br>1: Clear<br>The transmit FIFO and the transmit shift register are reset to the<br>default settings. |
| 0    | RFFLLCLR   | 0              | W    | Clears receive buffer<br>0: Invalid<br>1: Clear<br>The receive FIFO and the receive shift register are reset to the<br>default settings.    |

# 4.2.5. [TSPIxBR] (TSPI Baud Rate Register)

| Bit  | Bit Symbol | After<br>reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | -          | 0              | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:4  | BRCK[3:0]  | 0000           | R/W  | Input clock selection for baud rate generator.           0000: ΦT0         0101: ΦT16(1/32 ΦT0)           0001: ΦT1(1/2 ΦT0)         0110: ΦT32(1/64 ΦT0)           0010: ΦT2(1/4 ΦT0)         0111: ΦT64(1/128 ΦT0)           0011: ΦT4(1/8 ΦT0)         1000: ΦT128(1/256 ΦT0)           0100: ΦT8(1/16 ΦT0)         1001: ΦT256(1/512 ΦT0)           1010 to 1111: Prohibited         1000 |
| 3:0  | BRS[3:0]   | 0000           | R/W  | Sets a division ratio "N" of baud rate generator.         0000: 16       0110: 6       1100: 12         0001: 1       0111: 7       1101: 13         0010: 2       1000: 8       1110: 14         0011: 3       1001: 9       1111: 15         0100: 4       1010: 10         0101: 5       1011: 11                                                                                          |

# 4.2.6. [TSPIxFMTR0] (TSPI Format Control Register 0)

| Bit   | Bit Symbol | After<br>reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | DIR        | 1              | R/W  | Transfer direction<br>0: LSB first<br>1: MSB first                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 30    | -          | 0              | R    | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 29:24 | FL[5:0]    | 001000         | R/W  | Sets a frame length. (Note1)<br>Sets a data length of one frame including a parity bit.<br>001000: 8 bits<br>001001: 9 bits<br>:<br>011111: 31 bits<br>100000: 32 bits<br>Available on the frame mode operation. The parity bit is included in<br>the frame length.<br>Frame length must be set to a value from 8 to 32 (bit).                                                                                                                                              |
| 23:20 | FINT[3:0]  | 0000           | R/W  | Interval time between frames in the burst transfer.<br>0000: 0 (No interval)<br>0001: 1 x TSPIxSCK cycle<br>0010: 2 x TSPIxSCK cycles<br>:<br>1110: 14 x TSPIxSCK cycles<br>1111: 15 x TSPIxSCK cycles<br>Settings of the frame interval period for a burst transfer during master<br>operation.<br>The frame interval period specified in <fint> will occur on the SIO<br/>mode operation. This setting is disabled at the serial transfer and<br/>slave operation.</fint> |
| 19    | CS3POL     | 0              | R/W  | Polarity of TSPIxCS3(Master operation)<br>0: Negative logic<br>1: Positive logic                                                                                                                                                                                                                                                                                                                                                                                            |
| 18    | CS2POL     | 0              | R/W  | Polarity of TSPIxCS2(Master operation)<br>0: Negative logic<br>1: Positive logic                                                                                                                                                                                                                                                                                                                                                                                            |

| 17    | CS1POL       | 0    | R/W | Polarity of TSPIxCS1(Master operation)<br>0: Negative logic<br>1: Positive logic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|--------------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | CS0POL       | 0    | R/W | Polarity of TSPIxCS0(Master operation)<br>Polarity of TSPIxCSIN(Slave operation)<br>0: Negative logic<br>1: Positive logic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15    | СКРНА        | 1    | R/W | Timing of data capture for serial clock<br>0: Data is sampled on the first edge.<br>1: Data is sampled on the second edge.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 14    | CKPOL        | 1    | R/W | Polarity of idle period of serial clock (Note 2) (Note3)<br>0: TSPIxSCK is "Low" level at idle.<br>1: TSPIxSCK is "High" level at idle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10.10 |              |      | DAA | Idle time (Note4)<br>TSPIxCS0/1/2/3 invalid→TSPIxCS0/1/2/3 valid time<br>0000: Prohibited<br>0001: 1 × TSPIxSCK cycle<br>0010: 2 × TSPIxSCK cycles<br>:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13:10 | CSINT[3:0]   | 0001 | R/W | 1110: 14 × TSPIxSCK cycles<br>1111: 15 × TSPIxSCK cycles<br>Settings of the CS deassertion period for a continuous transfer during<br>master operation.<br>The idle period specified in <csint> will occur in the SIO mode<br/>operation.</csint>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 9:8   | -            | 0    | R   | Read as "0"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7:4   | CSSCKDL[3:0] | 0000 | R/W | Cycle following the CS assertion<br>TSPIxCS0/1/2/3 valid→TSPIxSCK valid time<br>0000: 1 × TSPIxSCK 1000: 9 × TSPIxSCK<br>0001: 2 × TSPIxSCK 1001: 10 × TSPIxSCK<br>0010: 3 × TSPIxSCK 1010: 11 × TSPIxSCK<br>0011: 4 × TSPIxSCK 1011: 12 × TSPIxSCK<br>0100: 5 × TSPIxSCK 1100: 13 × TSPIxSCK<br>0101: 6 × TSPIxSCK 1101: 14 × TSPIxSCK<br>0110: 7 × TSPIxSCK 1110: 15 × TSPIxSCK<br>0111: 8 × TSPIxSCK 1111: 16 × TSPIxSCK<br>1111: 8 × TSPIxSCK 1111: 16 × TSPIxSCK<br>In master operations, the time period between the assertion of the<br>TSPIxCS0/1/2/3 terminals and the change in the TSPIxSCK terminal<br>is set with the serial clock cycle used as a unit. In the SIO mode<br>operation, <cssckdl[3:0]> should be set to '0000'.</cssckdl[3:0]> |
| 3:0   | SCKCSDL[3:0] | 0000 | R/W | Cycle preceding the CS deassertion<br>0000: 1 × TSPIxSCK 1000: 9 × TSPIxSCK<br>0001: 2 × TSPIxSCK 1001: 10 × TSPIxSCK<br>0010: 3 × TSPIxSCK 1010: 11 × TSPIxSCK<br>0011: 4 × TSPIxSCK 1011: 12 × TSPIxSCK<br>0100: 5 × TSPIxSCK 1100: 13 × TSPIxSCK<br>0101: 6 × TSPIxSCK 1101: 14 × TSPIxSCK<br>0110: 7 × TSPIxSCK 1110: 15 × TSPIxSCK<br>0111: 8 × TSPIxSCK 1111: 16 × TSPIxSCK<br>In master operations, the time period required for the deassertion of<br>the TSPIxCS0/1/2/3 terminals from the location of the last data is set<br>with the serial clock cycle used as a unit.<br>In the SIO mode operation, <cssckdl[3:0]> should be set to '0000'.</cssckdl[3:0]>                                                                                   |

Note1: All data in the FIFO are discarded if <FL[5:0]> is changed remaining data in the FIFO even if [TSPIxSR]<TSPISUE> is "0".

Note2: Please perform a <CKPOL> setup when transmit / receive is disabled (*[TSPIxCR2]*<TRXE>= 0) at the time of slave operation.

Note3: At the Slave operation in the SIO mode, in the case of using at 1st edge, CS0POL=1 should be set surely.

Note4: When use 1st edge data sampling of master operation,

"Setting value (Integer multiple of TSPIxSCK) +  $0.5 \times$  TSPIxSCK".

# 4.2.7. [TSPIxFMTR1] (TSPI Format Control Register 1)

| Bit  | Bit Symbol | After<br>reset | Туре | Function                                                                                                                                                                                             |
|------|------------|----------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | -          | 0              | R    | Read as "0".                                                                                                                                                                                         |
| 6:4  | EHOLD[2:0] | 000            | R/W  | Sets a last bit holding time of TSPIxTXD pin in SIO mode slave<br>operation.(Note1)<br>000: 2/fc<br>001: 4/fc<br>010: 8/fc<br>011: 16/fc<br>100: 32/fc<br>101: 64/fc<br>110: 128/fc<br>111: Reserved |
| 3:2  | -          | 0              | R    | Read as "0".                                                                                                                                                                                         |
| 1    | VPE        | 0              | R/W  | Vertical parity function (Note2)<br>0: Disabled<br>1: Enabled                                                                                                                                        |
| 0    | VPM        | 0              | R/W  | Vertical parity selection (Note2)<br>0: Even parity<br>1: Odd parity                                                                                                                                 |

Note1: When the transmit is performed in the SIO mode Slave operation 1st clock edge sampling, and next data is written to the transmit buffer within the final bit hold time, the written data is output to TSPIxTXD.

Note2: Do not write <VPE> and <VPM> when transfer data remain in the shift register.

# 4.2.8. [TSPIxSECTCR0] (TSPI Sector Mode Control Register 0)

| Bit  | Bit Symbol | After<br>reset | Туре | Function                                                                                                                                                                                                      |
|------|------------|----------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | -          | 0              | R    | Read as "0".                                                                                                                                                                                                  |
| 0    | SECT       | 0              | R/W  | Sector / Frame mode selection<br>0: Frame mode<br>1: Sector mode<br>Select the sector mode under one of the following conditions.<br>- Frame length of 33 to 128 bits<br>- Frame consisting of 2 to 4 sectors |

# 4.2.9. [TSPIxSECTCR1] (TSPI Sector Mode Control Register 1)

| Bit   | Bit Symbol  | After<br>reset | Туре | Function                                                                                                                                                                                                                                                                                        |
|-------|-------------|----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | -           | 0              | R    | Read as "0".                                                                                                                                                                                                                                                                                    |
| 29:24 | SECTL3[5:0] | 000000         | R/W  | Sector length configuration for sector 3 (Setting prohibited<br>except 0 to 32.)<br>000000: sector 3 not used<br>000001 1 bit<br>:<br>011111: 31 bits<br>100000: 32 bits<br>when the sector 3 is the last sector and there is a parity bit, add<br>1 to the data length.                        |
| 23:22 | -           | 0              | R    | Read as "0".                                                                                                                                                                                                                                                                                    |
| 21:16 | SECTL2[5:0] | 000000         | R/W  | Sector length configuration for sector 2 (Setting prohibited<br>except 0 to 32.)<br>000000: sector 2 and sector 3 not used (Note 1)<br>000001: 1 bit<br>:<br>011111: 31 bits<br>100000: 32 bits<br>when the sector 2 is the last sector and there is a parity bit, add<br>1 to the data length. |
| 15:14 | -           | 0              | R    | Read as "0".                                                                                                                                                                                                                                                                                    |
| 13:8  | SECTL1[5:0] | 000001         | R/W  | Sector length configuration for sector 1 (Setting prohibited<br>except 1 to 32.)<br>000001: 1 bit<br>:<br>011111: 31 bits<br>100000: 32 bits<br>when the sector 1 is the last sector and there is a parity bit, add<br>1 to the data length.                                                    |
| 7:6   | -           | 0              | R    | Read as "0".                                                                                                                                                                                                                                                                                    |
| 5:0   | SECTL0[5:0] | 000001         | R/W  | Sector length configuration for sector 0 (Setting prohibited<br>except 1 to 32.)<br>000001: 1 bit<br>:<br>011111: 31 bits<br>100000: 32 bits                                                                                                                                                    |

Note1: The configuration of *<*SECTL3[5:0]*>* is not available,

Note2: Should be used with the frame length (the total sector length) in the range of 8 to 128 bits.

Note3: 1-bit sector length communication in slave mode cannot be set.

Note4: Change the sector length after reading all the received data.

# 4.2.10. [TSPIxDR] (TSPI Data Register)

| Bit  | Bit Symbol | After<br>reset | Туре | Function                   |
|------|------------|----------------|------|----------------------------|
| 31:0 |            | 0x0000000      | R    | Read from the receive FIFO |
|      |            |                | W    | Write to the transmit FIFO |

Note1: Do not write data to this register when the transmit FIFO is full.

Note2: Do not read data from this register when the receive FIFO is empty.

# 4.2.11. [TSPIxSR] (TSPI Status Register)

| Bit   | Bit Symbol | After<br>reset | Туре | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------------|----------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | TSPISUE    | 0              | R    | <ul> <li>TSPI modify status flag</li> <li>0: Modification is enabled.</li> <li>1: Modification is disabled.</li> <li>When <tspisue> is "0", the TSPI is not transmitting or receiving, thus the register setting can be modified.</tspisue></li> <li><tspisue> is "0" in the following conditions:</tspisue></li> <li>1. Reset is input.</li> <li>2. Software reset occurs.</li> <li>3. In the continuous transfer mode operation, the communication stop setting (<i>[TSPIxCR1]</i><trxe>=0) is set. And when there is a frame under the transfer, the frame transfer ends.</trxe></li> <li>4. In the burst mode operation, the timing when the specified number of transfers are finished.</li> <li>5. The current transferring frame is finished by setting <i>[TSPIxCR1]</i><trxe>=0 during burst transfer. (refer to the Table 4.2)</trxe></li> <li>However, even if the above conditions are satisfied, <tspisue> does not become "0" when the receive FIFO or receive shift register is full.</tspisue></li> </ul> |
| 20:24 |            | 0              | P    | value in the receive shift register to the receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 30:24 | -          | 0              | ĸ    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 23    | TXRUN      | 0              | R    | Transmit operation flag<br>0: Stop<br>1: Operation<br>A status flag indicates the transmit operation is ongoing.<br><txrun> is set when data exists in the transmit shift register even if<br/>data does not exist in the transmit FIFO.<br/>The state associated with <txend><tfemp> is shown in "Table 4.4."</tfemp></txend></txrun>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 22    | TXEND      | 0              | R    | Transmit completion flag<br>A flag that is set at the time when the transmit is complete.<br>0: -<br>1: Transmit is complete.<br>TSPIxCS0/1/2/3 of the last frame transfer during continuous transfer<br>and burst transfer is set when it is deasserted. The state associated<br>with <txrun><tfemp> is shown in Table 4.4.</tfemp></txrun>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |            |                | W    | Flag can be cleared by writing "1".<br>0: Don't care<br>1: Flag is cleared.<br>When the setting by transmit completion and clearing by writing "1"<br>occur simultaneously, the setting by transmit has higher priority.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 21    | INTTXWF    | 0              | R    | Transmit FIFO interrupt flag<br>This bit is set when remaining data in the transmit FIFO reaches a TIL<br>value from a fill level setting value (TIL) + 1.<br>0: No interrupt<br>1: Interrupt occurs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       |            |                | W    | Flag can be cleared by writing "1".<br>0: Don't care<br>1: Flag is cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| 20    | TFEMP     | 1    | R | Transmit FIFO empty flag<br>0: Data exists in the FIFO<br>1: Empty<br>When the transmit FIFO is empty, this bit is set to "1".<br>This is cleared to "0" once the transmit data is written to the data<br>register.<br>The state associated with cTXRLIN                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------|------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16 | TLVL[3:0] | 0000 | R | Transmit FIFO fill level status<br>Indicates the current value of the transmit FIFO fill level (number of<br>data). Stages of the FIFO vary depending on the length of frame.<br>"Table 4.3" shows the display range.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:8  | -         | 0    | R | Read as "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7     | RXRUN     | 0    | R | Receive operation flag<br>0: Stop<br>1: Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6     | RXEND     | 0    | R | The state associated with <rxend><rffll> is shown in "Table 4.5".         Receive completion flag         A flag that is set at the time when receive is complete.         0: -         1: Receiving is complete.         TSPIxCS0/1/2/3 of the last frame transfer during continuous transfer and burst transfer is set when it is deasserted. The state associated with <rxrun><rffll> is shown in "Table 4.5."         Flag can be cleared by writing "1".         0: Don't care         1: Flag is cleared.         When setting by receive completion and clearing by writing "1" occur simultaneously, setting has higher priority.</rffll></rxrun></rffll></rxend> |
| 5     | INTRXFF   | 0    | R | Receive FIFO interrupt flag<br>0: No interrupt<br>1: Interrupt occurs<br>This bit is set when remaining data in the receive FIFO reaches a<br><ril[3:0]> value from a fill level setting value <ril[3:0]> - 1.<br/>0: Don't care<br/>1: Flag is cleared.<br/>This bit is cleared by writing "1".</ril[3:0]></ril[3:0]>                                                                                                                                                                                                                                                                                                                                                    |
| 4     | RFFLL     | 0    | R | Receive FIFO full flag<br>0: Not Full<br>1: Full<br>Indicates that the receive FIFO is full.<br>It is automatically cleared once the data is read out from the data<br>register. (Note)<br>The state associated with <rxrun><rxend> is shown in "Table 4.5."</rxend></rxrun>                                                                                                                                                                                                                                                                                                                                                                                              |
| 3:0   | RLVL[3:0] | 0000 | R | Receive FIFO fill level status<br>Indicates that the current value of the receive FIFO fill level (number of data).<br>Stages of the FIFO varies depending on the length of the frame. "Table 4.3" shows the display range on cRL VLI3:01>                                                                                                                                                                                                                                                                                                                                                                                                                                |

 Note: When there is data in the receive shift register, it will be cleared once the data register is read twice.
| Transfer state of<br>communication stop<br><i>[TSPIxCR1]</i> <trxe>=0<br/>setting</trxe> |             | TSPI setting enabled state flag [TSPIxSR] <tspisue></tspisue>                         |                                                                                                                   |  |  |
|------------------------------------------------------------------------------------------|-------------|---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|
|                                                                                          |             | Master operation                                                                      | Slave operation                                                                                                   |  |  |
| Before transfer                                                                          |             | "0" Setting enabled state                                                             | "1" Setting disabled state (stop instruction is disabled.)<br>Software reset should be performed.                 |  |  |
| During transfer                                                                          |             | After the frame during transfer ends, "0" is set.                                     |                                                                                                                   |  |  |
| Transfer<br>break                                                                        | Frame mode  | "0" Setting enabled state                                                             | "1" Setting disabled state (transfer break state continues.)<br>After the frame ends during transfer, "0" is set. |  |  |
| (Note)                                                                                   | Sector mode | "1" Setting disabled state (transfer br<br>transfer, "0" is set.                      | break continues). After the frame ends during                                                                     |  |  |
| After transfer                                                                           |             | "0" Setting enabled state (communication stop state, stop instruction is not needed.) |                                                                                                                   |  |  |

#### Table 4.2 Transfer state and setting enabled state flag at communication stop setting

Note: Transfer break due to unprocessed transmit / receive data in Master operation, and due to Master in Slave operation.

| Mada   | Frame length    |            | FIFO fill level status range        |                                      |  |
|--------|-----------------|------------|-------------------------------------|--------------------------------------|--|
| wode   | / Sector length | FIFO stage | For receive <rlvl[3:0]></rlvl[3:0]> | For transmit <tlvl[3:0]></tlvl[3:0]> |  |
| Frame  | 8 to 16bits     | 8 stages   | 0 to 8                              | 0 to 8                               |  |
|        | 17 to 32bits    | 4 stages   | 0 to 4                              | 0 to 4                               |  |
| Sector | 1 to 32bits     | 4 stages   | 0 to 4                              | 0 to 4                               |  |

#### Table 4.3 Display range of Fill level status

| l able 4.4 | Transmit FIFO and the transmit status |  |
|------------|---------------------------------------|--|
|            |                                       |  |

| <txrun></txrun> | <txend></txend> | <tfemp></tfemp> |                                                                                                                                                                                                            | Status                                                                                           |
|-----------------|-----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
|                 | 0               | 1               | (1)                                                                                                                                                                                                        | The initial status or the transmit completion flag in (3) cleared                                |
|                 | 0               | 0               | (2)                                                                                                                                                                                                        | The transmit data are written, or the transmit completion flag in (4) cleared                    |
| 0               | 1               | 1               | (3)                                                                                                                                                                                                        | Stopped, transmit completed, no transmit FIFO data available (separate shift register available) |
|                 |                 | 0               | (4)                                                                                                                                                                                                        | Stopped, transmit completed, transmit FIFO data available                                        |
| 1               | 0               | 1               | <ul> <li>Transmit in progress, no transmit FIFO data available, transmit of the<br/>transmit shift register in progress<br/>or, transmit buffer paused due to its empty during master operation</li> </ul> |                                                                                                  |
|                 |                 | 0               | (6)                                                                                                                                                                                                        | Transmit in progress, transmit FIFO data available                                               |
|                 | 1               | 1/0             | -                                                                                                                                                                                                          | Transmit completion flag not cleared (not used properly)                                         |

| <rxrun></rxrun> | <rxend></rxend> | <rffll></rffll>                                                   |      | Status                                                                                                                                                                 |  |  |
|-----------------|-----------------|-------------------------------------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                 | 0               | 0                                                                 | (7)  | The initial status or the receive completion flag in (9) cleared                                                                                                       |  |  |
| 0               | U               | 1                                                                 | (8)  | The receive completion flag in (10) cleared                                                                                                                            |  |  |
| 0               | 1               | 0 (9) Stopped, receive completed, space in receive FIFO available |      | Stopped, receive completed, space in receive FIFO available                                                                                                            |  |  |
|                 |                 | 1                                                                 | (10) | Stopped, receive completed, space in receive FIFO unavailable                                                                                                          |  |  |
|                 |                 | 0                                                                 | (11) | Receive in progress, space in receive FIFO available                                                                                                                   |  |  |
| 1               | 0               | 1                                                                 | (12) | Receive in progress, space in receive FIFO unavailable, receive shift register being received Or, receive buffer paused due to its full during master operation (Note) |  |  |
|                 | 1               | 0/1                                                               | -    | - Receive completion flag not cleared (not used properly)                                                                                                              |  |  |

Note: While the operation is paused because of the receive buffer is full, it can be resumed by reading the data register twice.

## 4.2.12. [TSPIxERR] (TSPI Error Flag Register)

| Bit  | Bit Symbol | After<br>reset | Туре | Function                                                                                                                                                              |   |                                                                            |
|------|------------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------------------------------------------------------|
| 31:4 | -          | 0              | R    | Read as "0".                                                                                                                                                          |   |                                                                            |
| 3    | TRGERR     | 0              | R    | Communication Start trigger error Flag (master operation)<br>This bit is set when communication cannot be started by the trigger input.<br>0: No error<br>1: Error    |   |                                                                            |
|      |            |                | W    | Flag can be cleared by writing "1".<br>0: Don't care<br>1: Flag is cleared                                                                                            |   |                                                                            |
| 2    | UDRERR     | UDRERR 0       | R    | Underrun error Flag (Slave operation)<br>This bit is set when an underrun error occurs.<br>0: No error<br>1: Error ("Table 4.6" shows the error processing procedure) |   |                                                                            |
|      |            |                | W    | Flag can be cleared by writing "1".<br>0: Don't care<br>1: Flag is cleared                                                                                            |   |                                                                            |
| 1    | OVRERR     | 0              | R    | Overrun error Flag (Slave operation)<br>This bit is set when an overrun error occurs.<br>0: No error<br>1: Error ("Table 4.7" shows the error processing procedure)   |   |                                                                            |
|      |            |                |      |                                                                                                                                                                       | W | Flag can be cleared by writing "1".<br>0: Don't care<br>1: Flag is cleared |
| 0    | PERR       | ERP            | R    | Vertical parity error flag<br>This bit is set when a vertical parity error occurs.<br>0: No error<br>1: Error                                                         |   |                                                                            |
|      |            |                | W    | Flag can be cleared by writing "1".<br>0: Don't care<br>1: Flag is cleared                                                                                            |   |                                                                            |

Note: during communication, do not clear all flag bits.

#### Table 4.6 Processing an underrun error

| Mode   | Processing an underrun error                                                                                                                                                                                                                                                                                                                                                                         |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Frame  | To resume transmit after an error has occurred, conduct a reconfiguration and re-transmit after the frame with invalid data has been transmitted and the error has been processed. When the data written in the data register after the error has occurred is not used, clear the transmit buffer.                                                                                                   |
| Sector | To resume transmit after an error has occurred, clear the transmit buffer, reconfigure and re-transmit from the frame's sector 0 after the frame with invalid data has been transmitted and the error has been processed. When the master operation stops and the frame transmit cannot be completed after the error, conduct a software reset, before proceeding with reconfiguration and transmit. |

Note: When in slave 1st edge operation, stop TSPI after error recovery processing. After that, re-setting and restart to transmit or receive.

| Table 4.7 | Processing an overrun error |
|-----------|-----------------------------|
|-----------|-----------------------------|

| Mode   | Processing an overrun error                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Frame  | To resume a receive after an error has occurred, conduct a reconfiguration and re-receive after the frame with invalid data has been received and the error has been processed. Note that the error processing includes reading out the data register (2 or more frames need to be read out to resume the receive). To reset the status of the receive FIFO and the receive shift register, clear the receive buffer.                                         |
| Sector | To resume a receive after an error has occurred, clear the receive buffer, reconfigure and receive data from the frame's sector 0 after the frame with invalid data has been received and the error has been processed. The error processing includes reading out the data register.<br>If the master operation stops and the frame receive cannot be completed after the error, conduct a software reset before proceeding with reconfiguration and receive. |

Note: When in slave 1st edge operation, stop TSPI after error recovery processing. After that, re-setting and restart to transmit or receive.

# 5. Example for use

## 5.1. List of Available Operations for Each Mode

The following table shows the list of operations available for each mode.

Also, the reference table of the specifications on starting / stopping transfer for each mode is shown on the "Operation specification" column.

| Table 5.1 | List of available operations | for each mode (Activation | method, RXD data sampling) |
|-----------|------------------------------|---------------------------|----------------------------|
|-----------|------------------------------|---------------------------|----------------------------|

| Communication modes |                     |                              | Communication operation mode                                                | Transfer<br>mode | Activation<br>method                                 | RXD data sampling    | Operation<br>specification |
|---------------------|---------------------|------------------------------|-----------------------------------------------------------------------------|------------------|------------------------------------------------------|----------------------|----------------------------|
|                     |                     |                              |                                                                             | Continuous       | Activate by Software                                 |                      | Table 5.3                  |
| SPI<br>SIO          |                     | Master<br>peration<br>Sector | Transmit and<br>receive(full-duplex<br>communication),<br>Transmit, Receive | Burst            | Activate by Software                                 | 1st edge<br>2nd edge |                            |
|                     | Master<br>operation |                              |                                                                             | Burst            | Activate by<br>the Start<br>Communication<br>trigger |                      | Table 5.2                  |
|                     |                     |                              |                                                                             | Continuous       |                                                      |                      | Table 5.5                  |
|                     |                     |                              |                                                                             |                  | Activate by Software                                 |                      | Table 5.6                  |
|                     | Slave<br>operation  | Frame<br>ve<br>ation         |                                                                             | Continuous       |                                                      | 1st edge<br>2nd edge | Table 5.4                  |
|                     |                     |                              |                                                                             | Burst            |                                                      |                      |                            |
|                     |                     | Sector                       |                                                                             | Continuous       |                                                      | 2nd edge             | Table 5.7                  |

Note: The following notations are used when describing the operation specifications starting / stopping transfer on the frame mode operation and the sector mode operation.

Stopped:[TSPIxSR] <TSPISUE>= 0 and [TSPIxCR1] <TRGEN>= 0, <TRXE>= 0Software activation:[TSPIxSR] <TSPISUE>= 1 and [TSPIxCR1] <TRGEN>= 0, <TRXE>= 1Waiting for the Start Communication trigger:[TSPIxSR] <TSPISUE>= 0 and [TSPIxCR1] <TRGEN>= 1, <TRXE>= 0

The Start Communication trigger activated:

| 1311301/(1311302) = 1 and $1311301/(1311302) = 1, (131132) = 1$ |
|-----------------------------------------------------------------|
|-----------------------------------------------------------------|

| (Master operation)        | SCK output: TSPIxSCK output    | CS output: TSPIxCS0/1/2/3 output |
|---------------------------|--------------------------------|----------------------------------|
| (Slave operation)         | SCK input: TSPIxSCK input      | CS input: TSPIxCSIinput          |
| Transmit buffer: Transmit | shift register + Transmit FIFO |                                  |

Receive buffer: Receive shift register + Receive FIFO

When the state is in "Modification is disabled (<TSPISUE>=1)", a read of each register and register setting in the following is possible. The configurations of other registers need to be conducted in "Modification is enabled (<TSPISUE>=0)".

[TSPIxCR0] <SWRST[1:0]> (software reset): Writing "10" and then "01".

[*TSPIxCR1*] <TRXE> (communication control register):

Writing "0" (stop communication) after reading out "1" (verify if the communication is enabled)

[TSPIxDR] <TSPIDR[31:0]> (data register): Writing transmit data

# 5.2. Starting / Stopping Transfer in Flame Mode

The operation specifications for starting / stopping transfer in the frame mode operation are as follows.

### 5.2.1. Activating the Start Communication trigger in master operation

| Table 5.2 | Starting / Stopping transfer in Frame mode (master operation, activating the Start |
|-----------|------------------------------------------------------------------------------------|
|           | Communication trigger)                                                             |

| Transfer<br>mode  | Communication operations                                          | Timing for starting / stopping transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | Transmit and<br>receive(Full-<br>duplex<br>communication)<br>mode | <ul> <li>With the configuration ([TSPIxCR1]<trgen>=1) for the stopped state, the operation moves to the Waiting for the Start Communication Trigger state.</trgen></li> <li>When the transmit FIFO has data with 1 or more frames and the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS output and the SCK output with the trigger, and the transfer starts. (Activate the Start Communication trigger)</li> <li>When the transmit buffer becomes empty after completing a frame transfer, the transfer of the next frame does not start, and the assert state is maintained in the CS output. The transfer is resumed once the data register is written in.</li> <li>When the receive buffer becomes full after completing a frame transfer, the transfer of the next frame does not start, and the assert state is maintained in the CS output. The transfer is resumed once 2 frames from the data register are read out. The operation moves to the waiting for the Start Communication Trigger state once the configured number of frames is transferred.</li> </ul> |
| Burst<br>transfer | Transmit mode                                                     | <ul> <li>With the configuration (<i>[TSPIxCR1]</i><trgen>=1) for the stopped state, the operation moves to the Waiting for the Start Communication Trigger state.</trgen></li> <li>When the transmit FIFO has data with 1 or more frames, the operation is synchronized to the CS output and the SCK output with the trigger, and the transmit starts. (Activate the Start Communication trigger)</li> <li>When the transmit buffer becomes empty after completing a frame transmit, the transmit of the next frame does not start, and the assert state is maintained in the CS output. The transmit is resumed once the data register is written in. The operation will move to the Waiting for the Start Communication Trigger state once the configured number of frames is transmitted.</li> </ul>                                                                                                                                                                                                                                                                                                                    |
|                   | Receive mode                                                      | <ul> <li>With the configuration (<i>[TSPIxCR1]</i><trgen>=1) for the stopped state, the operation moves to the Waiting for the Start Communication Trigger state.</trgen></li> <li>When the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS output and the SCK output with the trigger and the receive starts. (Activate the Start Communication trigger)</li> <li>When the receive buffer becomes full after completing a frame receive, the receive of the next frame does not start, and the assert state is maintained in the CS output. The receive is resumed once 2 frames from the data register are read out. The operation moves to the Waiting for the Start Communication Trigger state once the configured number of frames is received.</li> </ul>                                                                                                                                                                                                                                                                                                            |
|                   | Stop                                                              | <ul> <li>The operation will move to the Waiting for the Start Communication Trigger state once the currently transferred frame is completed with the Start Communication trigger activated (<i>[TSPIxCR1]</i><trxe>=0).</trxe></li> <li>With <trgen>=0, the Waiting for the Start Communication Trigger state is released and the state changes to Stopped.</trgen></li> <li>When configuring <trgen>=0, make sure that the state is in Waiting for the Start Communication trigger (i.e. Before providing the next trigger following a completed transfer, or after stopping the features for activating triggers and providing the external trigger).</trgen></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | Resume                                                            | Providing the next trigger is invalid (communication cannot be started) unless the configured number of frames have been transferred.<br>The trigger activated after completing the transfer (Stopped state) can be used as a trigger to enable for starting communication.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### 5.2.2. Software activation in master operation

| Table 5.3 | Start/Sto | p transfer in | h the fram | e mode (    | (master o | peration. | usind | a software | activation) |
|-----------|-----------|---------------|------------|-------------|-----------|-----------|-------|------------|-------------|
|           | 01010010  |               |            | 0 1110 40 1 |           | poration  | aonie | ,          | aouvation   |

| Transfer               | Communication                                                     | Timing for starting / stopping transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mode                   | operations                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                        | Transmit and<br>receive(Full-<br>duplex<br>communication)<br>mode | <ul> <li>When the transmit FIFO has data with 1 or more frames and the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS output and the SCK output after setting <i>[TSPIxCR1]</i></li> <li>TRXE&gt; to "1" at the Stopped state, and the transfer starts. (Software activation)</li> <li>When the transmit buffer becomes empty after completing a frame transfer, the transfer of the next frame does not start, and the assert state is maintained in the CS output. The transfer is resumed once the data register is written in.</li> <li>When the receive buffer becomes full after completing a frame transfer, the transfer of the next frame does not start, and the assert state is maintained in the CS output. The transfer is resumed once 2 frames from the data register are read out.</li> <li>The state changes to Stopped once the configured number of frames has been transferred.</li> </ul> |
| Burst<br>transfer      | Transmit mode                                                     | <ul> <li>When the transmit FIFO has data with 1 or more frames, the operation is synchronized to the CS output and the SCK output after setting [TSPIxCR1]<trxe> to "1" at the Stopped state, and the transmit starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing a frame transmit, the transmit of the next frame does not start, and the assert state is maintained in the CS output. The transmit is resumed once the data register is written in. The state changes to Stopped once the configured number of frames has been transmitted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                    |
|                        | Receive mode                                                      | <ul> <li>When the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS output and the SCK output after setting <i>[TSPIxCR1]</i><trxe> to "1" at the Stopped state and the receive starts. (Software activation)</trxe></li> <li>When the receive buffer becomes full after completing a frame receive, the receive of the next frame does not start, and the assert state is maintained in the CS output. The receive is resumed once 2 frames from the data register are read out. The state changes to Stopped once the configured number of frames has been received.</li> </ul>                                                                                                                                                                                                                                                                                                                                 |
|                        | Transmit and<br>receive(Full-<br>duplex<br>communication)<br>mode | <ul> <li>When the transmit FIFO has data with 1 or more frames and the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS output and the SCK output after setting [TSPIxCR1]<trxe> to "1" at the Stopped state and the transfer starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing a frame transfer, the transfer of the next frame does not start, and the deassert state is maintained in the CS output. The transfer is resumed once the data register is written in.</li> <li>When the receive buffer becomes full after completing a frame transfer, the transfer of the next frame does not start, and the deassert state is maintained in the CS output. The transfer is resumed once 2 frames from the data register are read out.</li> </ul>                                                                                                           |
| Continuous<br>transfer | Transmit mode                                                     | <ul> <li>When the transmit FIFO has data with 1 or more frames, the operation is synchronized to the CS output and the SCK output after setting <i>[TSPIxCR1]</i><trxe> to "1" at the Stopped state, and the transmit starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing a frame transmit, the transfer of the next frame does not start, and the deassert state is maintained in the CS output. The transmit is resumed once the data register is written in.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                        | Receive mode                                                      | <ul> <li>When the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS output and the SCK output after setting <i>[TSPIxCR1]</i><trxe> to "1" at the Stopped state and the receive starts. (Software activation)</trxe></li> <li>When the receive buffer becomes full after completing a frame receive, the receive of the next frame does not start, and the deassert state is maintained in the CS output. The receive is resumed once 2 frames from the data register are read out.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Common                 | Stop                                                              | The state changes to Stopped once the frame being transmitted has been completed after setting <b>[TSPIxCR1]</b> <trxe> to "0" at the Software Activation state.</trxe>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

Apart from the methods described in the above tables, the following conditions are also available when starting a transfer.

- Writing to the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the transmit buffer is empty.
- Reading out 2 frames from the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the receive buffer is full.
- Reading out one frame from the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the receive FIFO is full (the shift register is empty).

## 5.2.3. Software activation in slave operation

| Table 5.4 | Start/Stor | transfer in | h the frame | e mode (slave o | operation, u   | using software | activation) (1) | ) |
|-----------|------------|-------------|-------------|-----------------|----------------|----------------|-----------------|---|
|           |            |             |             |                 | - p o . a o, c | aoing contait  |                 | , |

| Transfer<br>mode  | Communication<br>operations                                       | Timing for starting / stopping transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mode              | Transmit and<br>receive(Full-<br>duplex<br>communication)<br>mode | <ul> <li>When the transmit FIFO has data with 1 or more frames and the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS input and the SCK input after setting [TSPIxCR1]<trxe> to "1" at the stopped state, and the transfer starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing a frame transfer, starting the transfer of the next frame will result in an underrun error and the configured output (Low/High) is maintained in TXD. The data written to the data register after the transfer of the next frame has been started are transmitted when the frame following the next frame is transferred.</li> <li>When the receive buffer becomes full after completing a frame transfer, starting the transfer of the next frame will result in an overrun error, and the received data become invalid. When the data register is read out after starting the transfer of the next frame, the data are received in the frame following the next frame. The state changes to Stopped once the configured number of frames has been transferred.</li> </ul> |
| Burst<br>transfer | Transmit mode                                                     | <ul> <li>When the transmit FIFO has data with 1 or more frames, the operation is synchronized to the CS input and the SCK input after setting [TSPIxCR1]<trxe> to "1" at the stopped state, and the transmit starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing a frame transmit, starting the transmit of the next frame will result in an underrun error, and the configured output (Low/High) is maintained in TXD. The data written to the data register after the transmit of the next frame has been started are transmitted when the frame following the next frame is transmitted. The state changes to Stopped once the configured number of frames has been transmitted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                             |
|                   | Receive mode                                                      | <ul> <li>When the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS input and the SCK input after setting [TSPIxCR1]<trxe> to "1" at the stopped state and the receive starts. (Software activation)</trxe></li> <li>When the receive buffer becomes full after completing a frame receive, starting the receive of the next frame results in an overrun error, and the received data become invalid. When the data register is read out after starting the receive of the next frame, the data are received in the frame following the next frame. The state changes to Stopped once the configured number of frames has been received.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### Table 5.5 Start/Stop transfer in the frame mode (slave operation, using software activation) (2)

| Transfer<br>mode       | Communication<br>operations                                       | Timing for starting / stopping transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Continuous<br>transfer | Transmit and<br>receive(Full-<br>duplex<br>communication)<br>mode | <ul> <li>When the transmit FIFO has data with 1 or more frames and the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS input and the SCK input after setting <i>[TSPIxCR1]</i><trxe> to "1" at the stopped state, and the transfer starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing a frame transfer, starting the transfer of the next frame will result in an underrun error, and the configured output (Low/High) is maintained in TXD. The data written to the data register after the transfer of the next frame has been started is transmitted when the frame following the next frame is transferred.</li> <li>When the receive buffer becomes full after completing a frame transfer, starting the transfer of the next frame will result in an overrun error, and the received data becomes invalid. When the data register is read out after starting the transfer of the next frame, the data is received in the frame following the next frame.</li> </ul> |
|                        | Transmit mode                                                     | <ul> <li>When the transmit FIFO has data with 1 or more frames, the operation is synchronized to the CS input and the SCK input after setting [TSPIxCR1]<trxe> to "1" at the stopped state, and the transmit starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing a frame transmit, starting the transmit of the next frame will result in an underrun error, and the configured output (Low/High) is maintained in TXD.</li> <li>The data written to the data register after the transmit of the next frame has been started is transmitted when the frame following the next frame is transmitted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                            |
|                        | Receive mode                                                      | <ul> <li>When the receive FIFO has an empty space with 1 or more frames, the operation is synchronized to the CS input and the SCK input after setting [TSPIxCR1]<trxe> to "1" at the stopped state, and the receive starts. (Software activation)</trxe></li> <li>When the receive buffer becomes full after completing a frame receive, starting the receive of the next frame will result in an overrun error, and the received data becomes invalid. When the data register is read out after starting the receive of the next frame, the data is received in the frame following the next frame.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Common                 | Stop                                                              | The state changes to Stopped once the frame being transmitted has been completed after setting <b>[TSPIxCR1]</b> <trxe> to "0" at the Software Activation state.</trxe>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Apart from the methods described in the above tables, the following conditions are also available when starting a transfer. However, care should be taken when using the following methods as they could result in an underrun / overrun error.

- Writing to the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the transmit buffer is empty.
- Reading out 2 frames from the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the receive buffer is full.
- Reading out one frame from the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the receive FIFO is full (the shift register is empty).

# 5.3. Starting / Stopping Transfer in Sector Mode

This section describes the operation specifications for starting / stopping a transfer in the sector mode operation.

#### 5.3.1. Activating the Start Communication trigger in master operation

# Table 5.6Starting / Stopping transfer in the sector mode (master operation, activate the StartCommunication trigger)

| Transfer<br>mode       | Communication operations                                          | Timing for starting / stopping transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | Transmit and<br>receive(Full-<br>duplex<br>communication)<br>mode | <ul> <li>With the configuration for setting [TSPIxCR1]<trgen> to "1" at the stopped state, the operation moves to the Waiting for the Start Communication Trigger state.</trgen></li> <li>When the transmit FIFO has data with 1 or more sectors and the receive FIFO has an empty space, the operation is synchronized to the CS output and the SCK output with the trigger, and the transfer starts. (Activate the Start Communication trigger)</li> <li>When the transmit buffer becomes empty after completing the transfer of the sectors other than the last sector, the transfer of the next sector does not start, and the assert state is maintained in the CS output. The transfer is resumed once data is written to the data register.</li> <li>When the receive buffer becomes full after completing the transfer of the sectors other than the last sector, the transfer of the next sector does not start, and the assert state is maintained in the CS output. The transfer is resumed once data is read from the data register.</li> <li>When the receive buffer becomes full after completing the transfer of the sectors other than the last sector, the transfer of the next sector does not start, and the assert state is maintained in the CS output. The transfer is resumed once data is read from the data register.</li> <li>The state changes to Waiting for the Start Communication Trigger once one frame is transferred.</li> </ul> |
| Continuous<br>transfer | Transmit mode                                                     | <ul> <li>The state changes to Waiting for the Start Communication Trigger with [TSPIxCR1]<trgen>=1 at the Stopped state.</trgen></li> <li>When the transmit FIFO has data with 1 or more sectors, the operation is synchronized to the CS output and the SCK output with the trigger, and the transfer starts. (Activate the Start Communication trigger)</li> <li>When the transmit buffer becomes empty after completing the transmit of the sectors other than the last sector, the transmit of the next sector does not start, and the assert state is maintained in the CS output. The transmit is resumed once data is written to the data register.</li> <li>The state changes to Waiting for the Start Communication Trigger once one frame is transmitted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                        | Receive mode                                                      | <ul> <li>The state changes to Waiting for the Start Communication Trigger with [TSPIxCR1]<trgen>=1 at the Stopped state.</trgen></li> <li>When the receive FIFO has an empty space, the operation is synchronized to the CS output and the SCK output with the trigger, and the transmit starts. (Activate the Start Communication trigger) <ul> <li>When the receive buffer becomes full after completing the receive of the sectors other than the last sector, the receive of the next sector does not start, and the assert state is maintained in the CS output. The receive is resumed once data is read from the data register.</li> <li>The state changes to Waiting for the Start Communication Trigger once one frame is received.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Common                 | Stop                                                              | <ul> <li>The state changes to Waiting for the Start Communication Trigger once one frame for activating the Start Communication trigger has been transferred.</li> <li>It does not make sense to stop while the Start Communication trigger is activated for a transfer of only one frame.</li> <li>With the configuration of <i>[TSPIxCR1]</i><trgen>=0, the Waiting for the Start Communication Trigger state is released and the state changes to Stopped.</trgen></li> <li>When configuring <i>[TSPIxCR1]</i><trgen>=0, make sure that the state is in waiting for the Start Communication trigger (Before providing the next trigger following a completed transfer, or after stopping the function for activating triggers and providing the external trigger).</trgen></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                        | Resume                                                            | Providing the next trigger is invalid (communication cannot be started) before a transfer is completed (while a frame is transferred).<br>The trigger activated after completing the transfer (Stopped state) can be used as a trigger to enable for starting communication.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

#### 5.3.2. Software activation in master operation

| Table 5.7 | Starting / Stopping transfer in the sector mode (master operation, using software |
|-----------|-----------------------------------------------------------------------------------|
|           | activation)                                                                       |

| Transfer<br>mode       | Communication operations                                          | Timing for starting / stopping transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | Transmit and<br>receive(Full-<br>duplex<br>communication)<br>mode | <ul> <li>When the transmit FIFO has data with 1 or more sectors, and the receive FIFO has an empty space with 1 or more sector, the operation is synchronized to the CS output and the SCK output after setting [TSPIxCR1]<trxe> to "1" at the Stopped state, and the transfer starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing the transfer of the sectors other than the last sector, the transfer of the next sector does not start, and the assert state is maintained in the CS output. The transfer is resumed once data is written to the data register.</li> <li>When the transmit buffer becomes empty after completing the transfer of the sectors of the last sector, the transfer of the next frame does not start, and the assert state is maintained in the CS output. The transfer is resumed once data is written to the data register.</li> <li>When the receive buffer becomes full after completing the transfer of the sectors other than the last sector, the transfer of the next sector does not start, and the assert state is maintained in the CS output. The transfer is resumed once data is written to the data register.</li> <li>When the receive buffer becomes full after completing the transfer of the sectors other than the last sector, the transfer of the next sector does not start, and the assert state is maintained in the CS output. The transfer is resumed once data is read from the data register.</li> <li>When the receive buffer becomes full after completing the transfer of the last sector, the transfer of the next frame does not start, and the assert state is maintained in the CS output. The transfer is resumed once data is read from the data register.</li> <li>When the receive buffer becomes full after completing the transfer of the last sector, the transfer of the next frame does not start, and the assert state is maintained in the CS output. The transfer is resumed once data is read from the data register.</li> </ul> |
| Continuous<br>transfer | Transmit mode                                                     | <ul> <li>When the transmit FIFO has data with 1 or more sectors, the operation is synchronized to the CS output and the SCK output with <i>[TSPIxCR1]</i><trxe>=1 at the Stopped state, and the transmit starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing the transmit of the sectors other than the last sector, the transmit of the next sector does not start, and the assert state is maintained in the CS output. The transmit is resumed once data is written to the data register.</li> <li>When the transmit buffer becomes empty after completing the transmit of the last sector, the transmit of the next frame does not start, and the deassert state is maintained in the CS output. The transmit of the data register.</li> <li>When the transmit of the next frame does not start, and the deassert state is maintained in the CS output.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                        | Receive mode                                                      | <ul> <li>When the receive FIFO has an empty space with 1 or more sectors, the operation is synchronized to the CS output and the SCK output with <i>[TSPIxCR1]</i><trxe>=1 at the Stopped state, and the receive starts. (Software activation)</trxe></li> <li>When the receive buffer becomes full after completing the receive of the sectors other than the last sector, the receive of the next sector does not start, and the assert state is maintained in the CS output. The receive is resumed once data is read from the data sector, the receive buffer becomes full after completing the receive of the last sector, the receive of the next sector does not start, and the assert state is maintained in the CS output. The receive is resumed once data is read from the CS output. The receive of the next frame does not start, and the deassert state is maintained in the CS output. The receive is resumed once data is read from the data register.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Common                 | Stop                                                              | The state changes to Stopped once the frame being transmitted has been completed after setting <b>[TSPIxCR1]</b> <trxe> to "0" at the Software Activation state.</trxe>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Apart from the methods described in the above tables, the following conditions are also available when starting a transfer.

- Writing to the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the transmit buffer is empty.
- Reading out 2 sectors from the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the receive buffer is full.
- Reading out one sector from the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the receive FIFO is full (the shift register is empty).

#### 5.3.3. Software activation in slave operation

#### Table 5.8 Starting / Stopping transfer in the sector mode (slave operation, using software activation)

| Transfer<br>mode       | Communication<br>operations                                       | Timing for starting / stopping transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Continuous<br>transfer | Transmit and<br>receive(Full-<br>duplex<br>communication)<br>mode | <ul> <li>When the transmit FIFO has data with 1 or more sectors and the receive FIFO has an empty space with 1 or more sectors, the operation is synchronized to the CS input and the SCK input with [TSPIxCR1]<trxe>=1 at the Stopped state, and the transfer starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing a sector transfer, starting the transfer of the next sector will result in an underrun error and the configured output (Low/High) is maintained in TXD until the transfer of the frame is completed. The data written to the data register after an underrun error has occurred is invalid. Please clear the FIFO after the frame transfer is completed.</li> <li>When the receive buffer becomes full after completing a sector transfer, starting the transfer of the next sector will result in an overrun error, and the received data becomes invalid. When the data register is read after the transfer of the next sector has begun, the data is received in the sector following the next sector.</li> </ul> |
|                        | Transmit mode                                                     | <ul> <li>When the transmit FIFO has data with 1 or more sectors, the operation is synchronized to the CS input and the SCK input with <i>[TSPIxCR1]</i><trxe>=1 at the Stopped state, and the transmit starts. (Software activation)</trxe></li> <li>When the transmit buffer becomes empty after completing a sector transfer, starting the transfer of the next sector will result in an underrun error, and the configured output (Low/High) is maintained in TXD.</li> <li>The data written to the data register after the transfer of the next sector has started is transmitted in the sector following the next sector.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                        | Receive mode                                                      | <ul> <li>When the receive FIFO has an empty space with 1 or more sectors, the operation is synchronized to the CS input and the SCK input with <i>[TSPIxCR1]</i><trxe>=1 at the Stopped state and the receive starts. (Software activation)</trxe></li> <li>When the receive buffer becomes full after completing a sector transfer, starting the transfer of the next sector will result in an overrun error, and the received data becomes invalid.</li> <li>When the data register is read after the transfer of the next sector has begun, the data is received in the sector following the next sector.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Common                 | Stop                                                              | The state changes to Stopped once the frame being transmitted has been completed after setting <b>[TSPIxCR1]</b> <trxe> to "0" at the Software Activation state.</trxe>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

Apart from the methods described in the above tables, the following conditions are also available when starting a transfer. However, care should be taken when using the following methods as they could result in an underrun / overrun error.

- Writing to the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the transmit buffer is empty.
- Reading out 2 sectors from the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the receive buffer is full.
- Reading out one sector from the data register after setting *[TSPIxCR1]*<TRXE> to "1" at the Stopped state while the receive FIFO is full (the shift register is empty).

# 6. Precautions

- In case of the product which does not have TSPIxCS0/1/2/3 pins or TSPIxCSIN pin, please use SIO mode that is not using these pins.
- Do not access the address that is not assigned register.

# 7. Revision History

| Revision | Date       | Description                                                                                                                                                                                                                                                                                                                                  |
|----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0      | 2020-11-16 | First release                                                                                                                                                                                                                                                                                                                                |
| 1.1      | 2021-07-16 | Corrected book marks.                                                                                                                                                                                                                                                                                                                        |
| 1.2      | 2021-10-15 | <ul> <li>3.2.1.3. Slave Operation Added description.</li> <li>3.9.1. Communication Start Trigger (1) Receiving trigger Added description.</li> <li>4.2.2. Changed explanations in Note7 and Note8 of <i>[TSPIxCR1]</i>.</li> <li>4.2.6. In function description of <i>[TSPIxFMTR0]</i> FINT[3:0] and CSINT[3:0], corrected typos.</li> </ul> |
| 1.3      | 2023-03-31 | - 3.7.2. Transmit FIFO Interrupt / Receive FIFO Interrupt<br>Changed description                                                                                                                                                                                                                                                             |

#### Table 7.1 Revision History

#### **RESTRICTIONS ON PRODUCT USE**

Toshiba Corporation and its subsidiaries and affiliates are collectively referred to as "TOSHIBA". Hardware, software and systems described in this document are collectively referred to as "Product".

- TOSHIBA reserves the right to make changes to the information in this document and related Product without notice.
- This document and any information herein may not be reproduced without prior written permission from TOSHIBA. Even with TOSHIBA's written permission, reproduction is permissible only if reproduction is without alteration/omission.
- Though TOSHIBA works continually to improve Product's quality and reliability, Product can malfunction or fail. Customers are responsible for complying with safety standards and for providing adequate designs and safeguards for their hardware, software and systems which minimize risk and avoid situations in which a malfunction or failure of Product could cause loss of human life, bodily injury or damage to property, including data loss or corruption. Before customers use the Product, create designs including the Product, or incorporate the Product into their own applications, customers must also refer to and comply with (a) the latest versions of all relevant TOSHIBA information, including without limitation, this document, the specifications, the data sheets and application notes for Product and the precautions and conditions set forth in the "TOSHIBA Semiconductor Reliability Handbook" and (b) the instructions for the application with which the Product will be used with or for. Customers are solely responsible for all aspects of their own product design or applications, including but not limited to (a) determining the appropriateness of the use of this Product in such design or applications; (b) evaluating and determining the applicability of any information contained in this document, or in charts, diagrams, programs, algorithms, sample application circuits, or any other referenced documents; and (c) validating all operating parameters for such designs and applications. TOSHIBA ASSUMES NO LIABILITY FOR CUSTOMERS' PRODUCT DESIGN OR APPLICATIONS.
- PRODUCT IS NEITHER INTENDED NOR WARRANTED FOR USE IN EQUIPMENTS OR SYSTEMS THAT REQUIRE EXTRAORDINARILY HIGH LEVELS OF QUALITY AND/OR RELIABILITY, AND/OR A MALFUNCTION OR FAILURE OF WHICH MAY CAUSE LOSS OF HUMAN LIFE, BODILY INJURY, SERIOUS PROPERTY DAMAGE AND/OR SERIOUS PUBLIC IMPACT ("UNINTENDED USE"). Except for specific applications as expressly stated in this document, Unintended Use includes, without limitation, equipment used in nuclear facilities, equipment used in the aerospace industry, lifesaving and/or life supporting medical equipment, equipment used for automobiles, trains, ships and other transportation, traffic signaling equipment, equipment used to control combustions or explosions, safety devices, elevators and escalators, and devices related to power plant. IF YOU USE PRODUCT FOR UNINTENDED USE, TOSHIBA ASSUMES NO LIABILITY FOR PRODUCT. For details, please contact your TOSHIBA sales representative or contact us via our website.
- Do not disassemble, analyze, reverse-engineer, alter, modify, translate or copy Product, whether in whole or in part.
- Product shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any
  applicable laws or regulations.
- The information contained herein is presented only as guidance for Product use. No responsibility is assumed by TOSHIBA for any infringement of patents or any other intellectual property rights of third parties that may result from the use of Product. No license to any intellectual property right is granted by this document, whether express or implied, by estoppel or otherwise.
- ABSENT A WRITTEN SIGNED AGREEMENT, EXCEPT AS PROVIDED IN THE RELEVANT TERMS AND CONDITIONS OF SALE FOR PRODUCT, AND TO THE MAXIMUM EXTENT ALLOWABLE BY LAW, TOSHIBA (1) ASSUMES NO LIABILITY WHATSOEVER, INCLUDING WITHOUT LIMITATION, INDIRECT, CONSEQUENTIAL, SPECIAL, OR INCIDENTAL DAMAGES OR LOSS, INCLUDING WITHOUT LIMITATION, LOSS OF PROFITS, LOSS OF OPPORTUNITIES, BUSINESS INTERRUPTION AND LOSS OF DATA, AND (2) DISCLAIMS ANY AND ALL EXPRESS OR IMPLIED WARRANTIES AND CONDITIONS RELATED TO SALE, USE OF PRODUCT, OR INFORMATION, INCLUDING WARRANTIES OR CONDITIONS OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, ACCURACY OF INFORMATION, OR NONINFRINGEMENT.
- Do not use or otherwise make available Product or related software or technology for any military purposes, including without limitation, for the design, development, use, stockpiling or manufacturing of nuclear, chemical, or biological weapons or missile technology products (mass destruction weapons). Product and related software and technology may be controlled under the applicable export laws and regulations including, without limitation, the Japanese Foreign Exchange and Foreign Trade Law and the U.S. Export Administration Regulations. Export and re-export of Product or related software or technology are strictly prohibited except in compliance with all applicable export laws and regulations.
- Please contact your TOSHIBA sales representative for details as to environmental matters such as the RoHS compatibility of Product. Please
  use Product in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including
  without limitation, the EU RoHS Directive. TOSHIBA ASSUMES NO LIABILITY FOR DAMAGES OR LOSSES OCCURRING AS A RESULT
  OF NONCOMPLIANCE WITH APPLICABLE LAWS AND REGULATIONS.

# **TOSHIBA ELECTRONIC DEVICES & STORAGE CORPORATION**

https://toshiba.semicon-storage.com/