1.8 FLEXCOM SPI Slave Read Write
This example application demonstrates how to use the FLEXCOM SPI peripheral in slave mode.
Description
This example uses the FLEXCOM SPI peripheral library in slave mode and allows reading and writing data from/to its internal buffer by a SPI master.
The SPI master writes data by sending a write command followed by two bytes of memory address followed by the data to be written.
< WR_CMD > < ADDR_MSB > < ADDR_LSB > < DATA0 > … < DATA n >
The SPI slave asserts the Busy line to indicate to the SPI master that it is busy. Once ready, the SPI slave de-asserts the Busy line. Once the SPI slave is ready, the SPI master reads the data by sending read command followed by two bytes of memory address and the number of bytes to read.
< RD_CMD > < ADDR_MSB > < ADDR_LSB > < NUM_BYTES >
The SPI slave responds by sending the data at the requested memory address. The SPI master compares the sent data with the received data and repeats the test if it matches.
Downloading and Building the Application
To clone or download this application from Github, go to the main page of this repository and then click Clone button to clone this repository or download as zip file. This content can also be downloaded using content manager by following these instructions.
Path of the application within the repository is apps/flexcom/spi/slave/flexcom_spi_write_read/firmware.
To build the application, refer to the following table and open the project using its IDE.
Project Name | Description |
---|---|
sam_a5d29_curiosity.X | MPLABX project for SAMA5D29 Curiosity Development Board Kit |
Setting Up AT91Bootstrap Loader
To load the application binary onto the target device, we need to use at91bootstrap loader. Refer to the at91bootstrap loader documentation for details on how to configure, build and run bootstrap loader project and use it to bootstrap the application binaries.
Setting Up the Hardware
The following table shows the target hardware for the application projects.
Project Name | Description |
---|---|
sam_a5d29_curiosity.X | SAMA5D29 Curiosity Development Board Kit |
Setting Up SAMA5D29 Curiosity Development Board
- To run this demo two SAMA5D29 Curiosity Development Board Kit are required. One will be programmed as SPI master and other will be programmed as SPI slave.
- Connect Pin 19, 21, 23, 24 on RPi 40-pin connector (J25) of SPI slave to
Pin 19, 21, 23, 24 on RPi 40-pin connector (J25) of SPI master
- Pin 24 - SPI Chip Select
- Pin 23 - SCK
- Pin 19 - MOSI
- Pin 21 - MISO
- Connect Pin 16 on 40-pin connector (J25) of SPI slave to Pin 16 on 40-pin connector (J25) of SPI master. Pin 16 is configured as GPIO and serves as the slave busy pin.
- Connect the Debug USB port on the board to the computer using a Type-C USB cable
Running the Application
- Build the SPI master application using its IDE. Path of the SPI Master application within the repository is apps/flexcom/spi/master/flexcom_spi_write_read_test_app/firmware
- Build the SPI slave application using its IDE.
- On the SPI master board, press switch to start reading and writing data
- LED on SPI master board indicates
the success or failure:
- LED is turned ON when the data read from the SPI slave matches with the data written
- LED is turned OFF when the data read from the SPI slave does not match with the data written
Board | Switch Name | LED Name |
---|---|---|
SAMA5D29 Curiosity Development Board | USER | RGB_LED (Green) |