-
Notifications
You must be signed in to change notification settings - Fork 13
SPI Module
This module contains functions for accessing the CPU's SPI module.
SPI units are encoded into a byte and are platform-dependent. For this reason the SPI module define a numeric constant for each available SPI unit. For example in ESP32 SPI1 is defined by the constant spi.SPI1. Please refer to your platform or board documentation to know which SPI units are available. If you refer to an inexistent SPI, a nil value is returned.
SPI module can work in master or slave mode, each of then identified by spi.MASTER and spi.SLAVE constants. For now only spi.MASTER is allowed.
The Serial Peripheral Interface (SPI) bus is a synchronous serial communication interface specification used for short distance communication, primarily in embedded systems. The interface was developed by Motorola in the late eighties and has become a de facto standard.
SPI devices communicate in full duplex mode using a master-slave architecture with a single master. The master device originates the frame for reading and writing.
SPI use 4 signals:
- SCLK / SCK: Serial Clock (output from master).
- MOSI / SDO: Master Output, Slave Input (output from master).
- MISO / SDI: Master Input, Slave Output (output from slave).
- SS / CS : Slave Select (active low, output from master).
Multiple slave devices can share the same SPI bus (SCK, SDO and SDI lines), and each of them are selected through individual CS lines per device, when the master needs to communicate with one device; in addition each device can work at different speeds, clock polarity, etc ...
To use this module you must take into consideration the following:
- Create a SPI instance device, using the spi.setup function, and store the instance into a variable.
device = spi.setup(.....)
-
Use the device instance for select the device. This selects the device trough the CS pin connected to the device and configures the bus (speed, polarity, etc ...):
device:select()
-
Use the device instance for read from / write to the device:
device:write(...)
-
Use the device instance for deselect the device. This deselects the device trough the CS pin connected to the device and disconnects the device from the bus:
instance:deselect()
Complete wiki will be available soon