This section specifies how SPI is implemented on the device, what the SPI signals are, and how full duplex operations work.

SPI communications

The XBee 3 BLU supports SPI communications in slave mode. Slave mode receives the clock signal and data from the master and returns data to the master. The following table shows the signals that the SPI port uses on the device.

Signal Direction Function

SPI_MOSI (Master Out, Slave In)

Input

Inputs serial data from the master

SPI_MISO (Master In, Slave Out)

Output

Outputs serial data to the master

SPI_SCLK (Serial Clock)

Input

Clocks data transfers on MOSI and MISO

SPI_SSEL (Slave Select)

Input

Enables serial communication with the slave

SPI_ATTN (Attention)

Output

Alerts the master that slave has data queued to send. The XBee 3 BLU asserts this pin as soon as data is available to send to the SPI master and it remains asserted until the SPI master has clocked out all available data.

In this mode:

  • SPI clock rates up to 5 MHz (burst) are possible.

  • Data transmission format is most significant bit (MSB) first; bit 7 is the first bit of a byte sent over the interface.

  • Frame Format mode 0 is used. This means CPOL= 0 (idle clock is low) and CPHA = 0 (data is sampled on the clock’s leading edge).

  • The SPI port only supports API Mode (AP = 1).

The following diagram shows frame format mode 0 for SPI communications.

SPI frame format

SPI mode is chip to chip communication.

Full duplex operation

As a full-duplex protocol, SPI allows simultaneous transmission and reception of data, even if data is only available in one direction at a given time. This means that when the device receives data, it also transmits, although the received data is usually invalid. Likewise, when transmitting data, the device may receive invalid data. To manage this, the firmware encapsulates received data in API packets to identify its validity.

SPI enables valid data transmission from the slave device to begin at any point relative to when valid data is sent from the master. If the master sends data to the slave while the slave also has data to send, a full-duplex operation occurs, where both sides transmit and receive valid data simultaneously for a brief period. Both the master and slave must be capable of handling full-duplex operations and must adhere to the protocol for reliable communication.

When using SPI on the XBee 3 BLU, the device operates in API mode without escaped characters to organize data into packets. The AP configuration is ignored since SPI can only function in this particular mode.

The following figure illustrates the SPI interface while valid data is being sent in both directions.

SPI full duplex operation

Low power operation

Sleep modes generally work the same on SPI as they do on UART. However, the addition of SPI mode provides an option to configure another pin as a sleep pin.

By default, Digi configures D8 (DIO8/DTR/SLP_Request Configuration) as a peripheral and during pin sleep it wakes the device and puts it to sleep. This applies to both the UART and SPI serial interfaces.

If SLEEP_REQUEST is not configured as a peripheral and SPI_SSEL is configured as a peripheral, then pin sleep is controlled by SPI_SSEL rather than by SLEEP_REQUEST. Asserting SPI_SSEL by driving it low either wakes the device or keeps it awake. Negating SPI_SSEL by driving it high puts the device to sleep.

SPI_SSEL can be configured to both control sleep and to indicate that the SPI master has selected a particular slave device. This configuration provides an advantage where the pin sleep implementation on SPI mode requires one less physical pin. It does have the disadvantage that it puts the device to sleep whenever the SPI master unintentionally negates SPI_SSEL.

To effectively use the pin sharing configuration, the user/design must have control of the SPI_SSEL pin to the extent that it can control pin sleep. This makes the SLEEP_REQUEST pin available for a different purpose. Without control of SPI_SSEL while using it for sleep request, the device may go to sleep at inopportune times.

If the device is one of multiple slaves on the SPI, then the device sleeps while the SPI master talks to the other slave, but this is acceptable in most cases. If you do not configure either pin as a peripheral, then the device stays awake, being unable to sleep in SM 1 mode.

Select the SPI port

To force SPI mode on through-hole devices, hold DOUT/DIO13 low while resetting the device until SPI_ATTN asserts. This causes the device to disable the UART and go straight into SPI communication mode. Once configuration is complete, the device queues a modem status frame to the SPI port, which causes the SPI_ATTN line to assert. The host can use this to determine that the SPI port is configured properly.

On surface-mount devices, forcing DOUT low at the time of reset has no effect. To use SPI mode on the SMT modules, assert the SPI_SSEL low after reset and before any UART data is input.

Forcing DOUT low on TH devices forces the device to enable SPI support by setting the following configuration values to 1 (peripheral):

Through-hole Micro and Surface-mount SPI signal

D1 (DIO1/ADC1/TH_SPI_ATTN Configuration)

P9 (DIO19/SPI_ATTN Configuration)

ATTN

D2 (DIO2/ADC2/TH_SPI_CLK Configuration)

P8 (DIO18/SPI_CLK Configuration)

SCLK

D3 (DIO3/ADC3/TH_SPI_SSEL Configuration)

P7 (DIO17/SPI_SSEL Configuration)

SSEL

D4 (DIO4/TH_SPI_MOSI Configuration)

P6 (DIO16/SPI_MOSI Configuration)

MOSI

P2 (DIO12/TH_SPI_MISO Configuration)

P5 (DIO15/SPI_MISO Configuration)

MISO

The ATTN signal is optional—you can still use SPI mode if you disable the SPI_ATTN pin (D1 on through-hole or P9 on surface-mount devices).

As long as the host does not issue a WR command, these configuration values revert to previous values after a power-on reset. If the host issues a WR command while in SPI mode, these same parameters are written to flash, and after a reset the device continues to operate in SPI mode.

If the UART is disabled and the SPI is enabled in the written configuration, then the device comes up in SPI mode without forcing it by holding DOUT low. If both the UART and the SPI are configured (P3 (DIO13/UART_DOUT Configuration) through P9 (DIO19/SPI_ATTN Configuration) are set to 1) at the time of reset, then output goes to the UART until the host sends the first input to the SPI interface. As soon as the first input comes on the SPI port, then all subsequent output goes to the SPI port and the UART is disabled.

After the first input arrives on the SPI port, all subsequent output goes to the SPI port and the UART is disabled.

When the master asserts the slave select (SPI_SSEL) signal, SPI transmit data is driven to the output pin SPI_MISO, and SPI data is received from the input pin SPI_MOSI. The SPI_SSEL pin has to be asserted to enable the transmit serializer to drive data to the output signal SPI_MISO. A rising edge on SPI_SSEL causes the SPI_MISO line to be tri-stated such that another slave device can drive it, if so desired.

If the output buffer is empty, the SPI serializer transmits the last valid bit repeatedly, which may be either high or low. Otherwise, the device formats all output in API mode 1 format, as described in the API mode section of the Operating mode page. The attached host is expected to ignore all data that is not part of a formatted API frame.

Force UART operation

If you configure a device with only the SPI enabled and no SPI master is available to access the SPI slave port, you can recover the device to UART operation by holding DIN / CONFIG low at reset time.

DIN/CONFIG forces a default configuration on the UART at 9600 baud and brings up the device in Command mode on the UART port. You can then send the appropriate commands to the device to configure it for UART operation.

If you write those parameters, the device comes up with the UART enabled on the next reset.