# Summary of the SPI Protocol

#### ROCKSAVAGE

### 1 Introduction

The Serial Peripheral Interface (SPI) is a synchronous, full-duplex communication protocol widely used to interface microcontrollers with peripheral devices such as sensors, ADCs, DACs, and memory devices. This document summarizes the operational behavior of the SPI protocol, including data transmission mechanisms, clock configurations, and multi-subnode communication methods.

### 2 Data Transmission

To initiate SPI communication, the master device (main) must generate the clock signal and select the slave device (subnode) by asserting the Chip Select (CS) signal. The CS signal is typically active low, requiring the main to send a logic 0 to select the subnode. During data transmission, both the main and the subnode can send and receive data simultaneously through the Master Out Slave In (MOSI) and Master In Slave Out (MISO) lines.

The SPI protocol allows data to be transmitted serially on the MOSI line while simultaneously receiving data from the MISO line. The transmission and reception are synchronized to the clock signal, with the edge of the clock determining when data is shifted and sampled. The user can configure the clock edge for sampling and shifting as per the device requirements.

## 3 Clock Polarity and Clock Phase

The clock configuration in SPI can be defined by two parameters:

- Clock Polarity (CPOL): Defines the idle state of the clock signal (high or low).
- Clock Phase (CPHA): Determines which clock edge (rising or falling) is used for data sampling and shifting.

Based on the combinations of CPOL and CPHA, four SPI modes can be established, as shown in Table ??.

Table 1: SPI Modes with CPOL and CPHA

| CPOL | CPHA             |
|------|------------------|
| 0    | 0                |
| 0    | 1                |
| 1    | 0                |
| 1    | 1                |
|      | 0<br>0<br>1<br>1 |

# 4 Timing Diagrams

Figures ??, ??, and ?? illustrate the timing diagrams for SPI modes 0, 1, 2, and 3, respectively, showing how data is sampled and shifted according to the selected clock configuration.



Figure 1: SPI Mode 0: Data sampled on rising edge, shifted on falling edge.



Figure 2: SPI Mode 1: Data sampled on falling edge, shifted on rising edge.

## 5 Multi-Subnode Configuration

SPI supports configurations with multiple subnodes connected to a single main device. This can be achieved in two ways: regular mode and daisy-chain mode.

### 5.1 Regular Mode

In regular mode, the main device requires an individual Chip Select (CS) signal for each subnode. When the CS signal is asserted (pulled low), the clock and data lines become active for the selected subnode. If multiple CS signals are active simultaneously, the data received on the MISO line may become corrupted.

### 5.2 Daisy-Chain Mode

In daisy-chain mode, all subnodes are connected such that they share a common CS signal. Data is transmitted from the main device to the first subnode, which forwards the data to the next subnode, and so forth. This configuration allows multiple subnodes to be addressed with fewer control lines.



Figure 3: SPI Mode 2: Data sampled on rising edge, shifted on falling edge.

## 6 Conclusion

SPI is a versatile and efficient protocol for serial communication between a master and one or more slave devices. Its ability to support high clock frequencies and full-duplex communication makes it suitable for various applications in embedded systems. For specific device implementations and timing specifications, users should refer to the corresponding product data sheets.



Figure 4: SPI Mode 3: Data sampled on falling edge, shifted on rising edge.