Software implemented Serial Peripheral Interface bus. More...
Software implemented Serial Peripheral Interface bus.
This module provides a software implemented Serial Peripheral Interface bus. It is intended to be used in situation where hardware spi is not available. The signatures of the functions are similar to the functions declared in spi.h The clock speed is approximated by using xtimer_usleep. Currently only the use of MOSI in master mode is implemented. Therefore receiving data from a slave is currently not possible.
Modules | |
Software SPI driver compile configuration | |
Files | |
file | soft_spi.h |
Software SPI port descriptor definition. | |
file | soft_spi_params.h |
Software SPI configuration. | |
Data Structures | |
struct | soft_spi_conf_t |
Software SPI port descriptor. More... | |
Typedefs | |
typedef unsigned int | soft_spi_t |
Default type for SPI devices. | |
typedef gpio_t | soft_spi_cs_t |
Chip select pin type overlaps with gpio_t so it can be casted to this. | |
Enumerations | |
enum | { SOFT_SPI_OK = 0 , SOFT_SPI_NODEV = -1 , SOFT_SPI_NOCS = -2 , SOFT_SPI_NOMODE = -3 , SOFT_SPI_NOCLK = -4 } |
Status codes used by the SPI driver interface. More... | |
enum | soft_spi_mode_t { SOFT_SPI_MODE_0 = 0 , SOFT_SPI_MODE_1 , SOFT_SPI_MODE_2 , SOFT_SPI_MODE_3 } |
Available SPI modes, defining the configuration of clock polarity and clock phase. More... | |
enum | soft_spi_clk_t { SOFT_SPI_CLK_100KHZ = 5 , SOFT_SPI_CLK_1MHZ = 1 , SOFT_SPI_CLK_DEFAULT = 0 } |
Available SPI clock speeds. More... | |
Functions | |
void | soft_spi_init (soft_spi_t bus) |
Basic initialization of the given SPI bus. | |
void | soft_spi_init_pins (soft_spi_t bus) |
Initialize the used SPI bus pins, i.e. | |
int | soft_spi_init_cs (soft_spi_t bus, soft_spi_cs_t cs) |
Initialize the given chip select pin. | |
void | soft_spi_acquire (soft_spi_t bus, soft_spi_cs_t cs, soft_spi_mode_t mode, soft_spi_clk_t clk) |
Start a new SPI transaction. | |
void | soft_spi_release (soft_spi_t bus) |
Finish an ongoing SPI transaction by releasing the given SPI bus. | |
uint8_t | soft_spi_transfer_byte (soft_spi_t bus, soft_spi_cs_t cs, bool cont, uint8_t out) |
Transfer one byte on the given SPI bus Currently only the use of MOSI in master mode is implemented. | |
void | soft_spi_transfer_bytes (soft_spi_t bus, soft_spi_cs_t cs, bool cont, const void *out, void *in, size_t len) |
Transfer a number bytes using the given SPI bus. | |
uint8_t | soft_spi_transfer_reg (soft_spi_t bus, soft_spi_cs_t cs, uint8_t reg, uint8_t out) |
Transfer one byte to/from a given register address. | |
void | soft_spi_transfer_regs (soft_spi_t bus, soft_spi_cs_t cs, uint8_t reg, const void *out, void *in, size_t len) |
Transfer a number of bytes to/from a given register address. | |
typedef gpio_t soft_spi_cs_t |
Chip select pin type overlaps with gpio_t so it can be casted to this.
Definition at line 75 of file soft_spi.h.
typedef unsigned int soft_spi_t |
Default type for SPI devices.
Definition at line 69 of file soft_spi.h.
anonymous enum |
Status codes used by the SPI driver interface.
Definition at line 80 of file soft_spi.h.
enum soft_spi_clk_t |
Available SPI clock speeds.
The actual speed of the bus varies between CPUs and depends on the speed of the processing. The values of the enum entries represent the approximate delay between two clock edges.
Enumerator | |
---|---|
SOFT_SPI_CLK_100KHZ | drive the SPI bus with less than 100kHz |
SOFT_SPI_CLK_1MHZ | drive the SPI bus with less than 1MHz |
SOFT_SPI_CLK_DEFAULT | drive the SPI bus with maximum speed possible |
Definition at line 118 of file soft_spi.h.
enum soft_spi_mode_t |
Available SPI modes, defining the configuration of clock polarity and clock phase.
RIOT is using the mode numbers as commonly defined by most vendors (https://en.wikipedia.org/wiki/Serial_Peripheral_Interface_Bus#Mode_numbers):
Enumerator | |
---|---|
SOFT_SPI_MODE_0 | CPOL=0, CPHA=0. |
SOFT_SPI_MODE_1 | CPOL=0, CPHA=1. |
SOFT_SPI_MODE_2 | CPOL=1, CPHA=0. |
SOFT_SPI_MODE_3 | CPOL=1, CPHA=1. |
Definition at line 104 of file soft_spi.h.
void soft_spi_acquire | ( | soft_spi_t | bus, |
soft_spi_cs_t | cs, | ||
soft_spi_mode_t | mode, | ||
soft_spi_clk_t | clk | ||
) |
Start a new SPI transaction.
Starting a new SPI transaction will get exclusive access to the SPI bus and configure it according to the given values. If another SPI transaction is active when this function is called, this function will block until the other transaction is complete (soft_spi_relase was called).
bus
and the cs
parameters to be valid (they are checked in soft_spi_init and soft_spi_init_cs before)[in] | bus | SPI device to access |
[in] | cs | chip select pin/line to use |
[in] | mode | mode to use for the new transaction |
[in] | clk | bus clock speed to use for the transaction |
void soft_spi_init | ( | soft_spi_t | bus | ) |
Basic initialization of the given SPI bus.
This function does the basic initialization including pin configuration for MISO, MOSI, and CLK pins.
Errors (e.g. invalid bus
parameter) are not signaled through a return value, but should be signaled using the assert() function internally.
[in] | bus | SPI device to initialize |
int soft_spi_init_cs | ( | soft_spi_t | bus, |
soft_spi_cs_t | cs | ||
) |
Initialize the given chip select pin.
The chip select must be any generic GPIO pin (e.g. GPIO_PIN(x,y)). It must be called once before the use of the chip select pin in transaction.
[in] | bus | SPI device that is used with the given CS line |
[in] | cs | chip select pin to initialize |
void soft_spi_init_pins | ( | soft_spi_t | bus | ) |
Initialize the used SPI bus pins, i.e.
MISO, MOSI, and CLK
After calling soft_spi_init, the pins must be initialized. In normal cases, this function will not be used.
The pins used are configured in the board's periph_conf.h.
[in] | bus | SPI device the pins are configure for |
void soft_spi_release | ( | soft_spi_t | bus | ) |
Finish an ongoing SPI transaction by releasing the given SPI bus.
After release, the given SPI bus should be fully powered down until acquired again.
[in] | bus | SPI device to release |
uint8_t soft_spi_transfer_byte | ( | soft_spi_t | bus, |
soft_spi_cs_t | cs, | ||
bool | cont, | ||
uint8_t | out | ||
) |
Transfer one byte on the given SPI bus Currently only the use of MOSI in master mode is implemented.
Therefore receiving data from a slave is currently not possible.
[in] | bus | SPI device to use |
[in] | cs | chip select pin/line to use |
[in] | cont | if true, keep device selected after transfer |
[in] | out | byte to send out, set NULL if only receiving |
void soft_spi_transfer_bytes | ( | soft_spi_t | bus, |
soft_spi_cs_t | cs, | ||
bool | cont, | ||
const void * | out, | ||
void * | in, | ||
size_t | len | ||
) |
Transfer a number bytes using the given SPI bus.
[in] | bus | SPI device to use |
[in] | cs | chip select pin/line to use |
[in] | cont | if true, keep device selected after transfer |
[in] | out | buffer to send data from, set NULL if only receiving |
[out] | in | buffer to read into, set NULL if only sending |
[in] | len | number of bytes to transfer |
uint8_t soft_spi_transfer_reg | ( | soft_spi_t | bus, |
soft_spi_cs_t | cs, | ||
uint8_t | reg, | ||
uint8_t | out | ||
) |
Transfer one byte to/from a given register address.
This function is a shortcut function for easier handling of SPI devices that implement a register based access scheme.
[in] | bus | SPI device to use |
[in] | cs | chip select pin/line to use |
[in] | reg | register address to transfer data to/from |
[in] | out | byte to send, set NULL if only receiving data |
void soft_spi_transfer_regs | ( | soft_spi_t | bus, |
soft_spi_cs_t | cs, | ||
uint8_t | reg, | ||
const void * | out, | ||
void * | in, | ||
size_t | len | ||
) |
Transfer a number of bytes to/from a given register address.
This function is a shortcut function for easier handling of SPI devices that implement a register based access scheme.
[in] | bus | SPI device to use |
[in] | cs | chip select pin/line to use |
[in] | reg | register address to transfer data to/from |
[in] | out | buffer to send data from, set NULL if only receiving |
[out] | in | buffer to read into, set NULL if only sending |
[in] | len | number of bytes to transfer |