

- (2) Set RB\_SPI\_MODE\_SLAVE in R8\_SPI\_CTRL\_MOD to 0, to configure SPI to master mode;
- (3) Set RB\_SPI\_MST\_SCK\_MOD in R8\_SPI\_CTRL\_MOD, to select clock idle mode0 or mode3;
- (4) Set the RB\_SPI\_FIFO\_DIR in R8\_SPI\_CTRL\_MOD to configure the FIFO direction. If it is 1, FIFO is used to receive. If it is 0, FIFO is used to transmit;
- (5) Set RB\_SPI\_MOSI\_OE and RB\_SPI\_SCK\_OE in R8\_SPI\_CTRL\_MOD to 1, and set RB\_SPI\_MISO\_OE to 0, and set GPIO direction configuration register (R32\_PA/PB\_DIR), to set the MOSI pin and SCK pin as output, and MISO pin as input;
- (6) In 2-wire mode, SCK is unchanged, RB\_SPI\_MOSI\_OE = 0, and MISO is not needed. In 3-wire mode, input (RB\_SPI\_MOSI\_OE = 0 and pin set as input) and output (RB\_SPI\_MOSI\_OE = 1 and pin set as output) are realized by MOSI half-duplex, and the direction is manually switched.
- (7) Optional. If DMA is enabled, it is needed to write the start address of transceiver buffer to R16\_SPI\_DMA\_BEG and write the end address (not included) to R16\_SPI\_DMA\_END. It is recommended to set RB\_SPI\_DMA\_ENABLE after setting RB\_SPI\_FIFO\_DIR. If R16\_SPI\_TOTAL\_CNT is confirmed as 0, RB\_SPI\_DMA\_ENABLE can be first set to 1 to enable DMA function.

Data transmission:

- (1) Set RB\_SPI\_FIFO\_DIR to 0, and the current FIFO direction is output;
- (2) Write to the R16\_SPI\_TOTAL\_CNT register, and set the length of the data to be sent;
- (3) Write to the R8\_SPI\_FIFO register and write the data to be transmitted to FIFO. If R8\_SPI\_FIFO\_COUNT is less than FIFO capacity, continue to write FIFO. If DMA is enabled, DMA will automatically load FIFO to complete this step;
- (4) As long as R16\_SPI\_TOTAL\_CNT is not 0 and there is data in FIFO, SPI master will automatically transmit data, otherwise, it will pause;
- (5) Wait until R16\_SPI\_TOTAL\_CNT register becomes 0, indicating that the data transmission is completed. If only one byte is sent, you can also query and wait for RB\_SPI\_FREE to be idle or wait for R8\_SPI\_FIFO\_COUNT to be 0.

Data reception:

- (1) Set RB\_SPI\_FIFO\_DIR to 1, to set the current FIFO direction to input;
- (2) Write to the R16\_SPI\_TOTAL\_CNT register, to set the length of the data to be received;
- (3) As long as R16\_SPI\_TOTAL\_CNT is not 0 and FIFO is not full, SPI master will automatically receive data, otherwise, it will pause;
- (4) Wait until R8\_SPI\_FIFO\_COUNT register is not 0, indicating that the return data is received, the value read in R8\_SPI0\_FIFO is the received data. If DMA is enabled, DMA will automatically read FIFO to complete this step.

### 10.4.2 Slave Mode

SPI supports the slave mode. In the slave mode, SCK pin is used to receive the serial clock of SPI master connected to the external.

Configuration procedure: