19.8.2.1.2 Code
The following must be added to the user application source file, outside any functions:
A sample buffer to send via SPI.
Number of entries in the sample buffer.staticuint8_t buffer_expect[BUF_LENGTH] = {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09,0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13};staticuint8_t buffer_rx[BUF_LENGTH] = {0x00};
#define BUF_LENGTH 20
A globally available software device instance struct to store the SPI driver state while it is in use. A function for configuring the SPI.structspi_module spi_slave_instance;
Add to user application main().voidconfigure_spi_slave(void){structspi_config config_spi_slave;/* Configure, initialize and enable SERCOM SPI module */spi_get_config_defaults(&config_spi_slave);config_spi_slave.mode = SPI_MODE_SLAVE;config_spi_slave.mode_specific.slave.preload_enable =true;config_spi_slave.mode_specific.slave.frame_format = SPI_FRAME_FORMAT_SPI_FRAME;config_spi_slave.mux_setting = EXT1_SPI_SERCOM_MUX_SETTING;/* Configure pad 0 for data in */config_spi_slave.pinmux_pad0 = EXT1_SPI_SERCOM_PINMUX_PAD0;/* Configure pad 1 as unused */config_spi_slave.pinmux_pad1 = EXT1_SPI_SERCOM_PINMUX_PAD1;/* Configure pad 2 for data out */config_spi_slave.pinmux_pad2 = EXT1_SPI_SERCOM_PINMUX_PAD2;/* Configure pad 3 for SCK */config_spi_slave.pinmux_pad3 = EXT1_SPI_SERCOM_PINMUX_PAD3;spi_init(&spi_slave_instance, EXT1_SPI_MODULE, &config_spi_slave);spi_enable(&spi_slave_instance);}
uint8_t result = 0;/* Initialize system */system_init();configure_spi_slave();
