12#ifndef ZEPHYR_INCLUDE_DRIVERS_SPI_H_
13#define ZEPHYR_INCLUDE_DRIVERS_SPI_H_
40#define SPI_OP_MODE_MASTER 0U
41#define SPI_OP_MODE_SLAVE BIT(0)
42#define SPI_OP_MODE_MASK 0x1U
43#define SPI_OP_MODE_GET(_operation_) ((_operation_) & SPI_OP_MODE_MASK)
56#define SPI_MODE_CPOL BIT(1)
65#define SPI_MODE_CPHA BIT(2)
72#define SPI_MODE_LOOP BIT(3)
74#define SPI_MODE_MASK (0xEU)
75#define SPI_MODE_GET(_mode_) \
76 ((_mode_) & SPI_MODE_MASK)
84#define SPI_TRANSFER_MSB (0U)
85#define SPI_TRANSFER_LSB BIT(4)
92#define SPI_WORD_SIZE_SHIFT (5U)
93#define SPI_WORD_SIZE_MASK (0x3FU << SPI_WORD_SIZE_SHIFT)
94#define SPI_WORD_SIZE_GET(_operation_) \
95 (((_operation_) & SPI_WORD_SIZE_MASK) >> SPI_WORD_SIZE_SHIFT)
97#define SPI_WORD_SET(_word_size_) \
98 ((_word_size_) << SPI_WORD_SIZE_SHIFT)
106#define SPI_HOLD_ON_CS BIT(12)
112#define SPI_LOCK_ON BIT(13)
121#define SPI_CS_ACTIVE_HIGH BIT(14)
133#define SPI_LINES_SINGLE (0U << 16)
134#define SPI_LINES_DUAL (1U << 16)
135#define SPI_LINES_QUAD (2U << 16)
136#define SPI_LINES_OCTAL (3U << 16)
138#define SPI_LINES_MASK (0x3U << 16)
201#define SPI_CS_GPIOS_DT_SPEC_GET(spi_dev) \
202 GPIO_DT_SPEC_GET_BY_IDX_OR(DT_BUS(spi_dev), cs_gpios, \
203 DT_REG_ADDR(spi_dev), {})
214#define SPI_CS_GPIOS_DT_SPEC_INST_GET(inst) \
215 SPI_CS_GPIOS_DT_SPEC_GET(DT_DRV_INST(inst))
249#define SPI_CS_CONTROL_INIT(node_id, delay_) \
251 .gpio = SPI_CS_GPIOS_DT_SPEC_GET(node_id), \
268#define SPI_CS_CONTROL_INIT_INST(inst, delay_) \
269 SPI_CS_CONTROL_INIT(DT_DRV_INST(inst), delay_)
275#if defined(CONFIG_SPI_EXTENDED_MODES)
330#define SPI_CONFIG_DT(node_id, operation_, delay_) \
332 .frequency = DT_PROP(node_id, spi_max_frequency), \
333 .operation = (operation_) | \
334 DT_PROP(node_id, duplex) | \
335 DT_PROP(node_id, frame_format), \
336 .slave = DT_REG_ADDR(node_id), \
337 .cs = SPI_CS_CONTROL_INIT(node_id, delay_), \
351#define SPI_CONFIG_DT_INST(inst, operation_, delay_) \
352 SPI_CONFIG_DT(DT_DRV_INST(inst), operation_, delay_)
383#define SPI_DT_SPEC_GET(node_id, operation_, delay_) \
385 .bus = DEVICE_DT_GET(DT_BUS(node_id)), \
386 .config = SPI_CONFIG_DT(node_id, operation_, delay_) \
400#define SPI_DT_SPEC_INST_GET(inst, operation_, delay_) \
401 SPI_DT_SPEC_GET(DT_DRV_INST(inst), operation_, delay_)
427#if defined(CONFIG_SPI_STATS)
443struct spi_device_state {
445 struct stats_spi stats;
451#define Z_SPI_GET_STATS(dev_) \
452 CONTAINER_OF(dev_->state, struct spi_device_state, devstate)->stats
459#define SPI_STATS_RX_BYTES_INCN(dev_, n) \
460 STATS_INCN(Z_SPI_GET_STATS(dev_), rx_bytes, n)
467#define SPI_STATS_TX_BYTES_INCN(dev_, n) \
468 STATS_INCN(Z_SPI_GET_STATS(dev_), tx_bytes, n)
477#define SPI_STATS_TRANSFER_ERROR_INC(dev_) \
478 STATS_INC(Z_SPI_GET_STATS(dev_), transfer_error)
483#define Z_SPI_DEVICE_STATE_DEFINE(dev_id) \
484 static struct spi_device_state Z_DEVICE_STATE_NAME(dev_id) \
485 __attribute__((__section__(".z_devstate")));
493#define Z_SPI_INIT_FN(dev_id, init_fn) \
494 static inline int UTIL_CAT(dev_id, _init)(const struct device *dev) \
496 struct spi_device_state *state = \
497 CONTAINER_OF(dev->state, struct spi_device_state, devstate); \
498 stats_init(&state->stats.s_hdr, STATS_SIZE_32, 3, \
499 STATS_NAME_INIT_PARMS(spi)); \
500 stats_register(dev->name, &(state->stats.s_hdr)); \
501 return init_fn(dev); \
523#define SPI_DEVICE_DT_DEFINE(node_id, init_fn, pm_device, \
524 data_ptr, cfg_ptr, level, prio, \
526 Z_SPI_DEVICE_STATE_DEFINE(Z_DEVICE_DT_DEV_ID(node_id)); \
527 Z_SPI_INIT_FN(Z_DEVICE_DT_DEV_ID(node_id), init_fn) \
528 Z_DEVICE_DEFINE(node_id, Z_DEVICE_DT_DEV_ID(node_id), \
529 DEVICE_DT_NAME(node_id), \
530 &UTIL_CAT(Z_DEVICE_DT_DEV_ID(node_id), _init), \
532 data_ptr, cfg_ptr, level, prio, \
534 &(Z_DEVICE_STATE_NAME(Z_DEVICE_DT_DEV_ID(node_id)).devstate), \
550 SPI_STATS_TX_BYTES_INCN(dev, tx_bytes);
555 SPI_STATS_RX_BYTES_INCN(dev, rx_bytes);
561#define SPI_DEVICE_DT_DEFINE(node_id, init_fn, pm, \
562 data, config, level, prio, \
564 Z_DEVICE_STATE_DEFINE(Z_DEVICE_DT_DEV_ID(node_id)); \
565 Z_DEVICE_DEFINE(node_id, Z_DEVICE_DT_DEV_ID(node_id), \
566 DEVICE_DT_NAME(node_id), init_fn, pm, data, config, \
568 &Z_DEVICE_STATE_NAME(Z_DEVICE_DT_DEV_ID(node_id)), \
571#define SPI_STATS_RX_BYTES_INC(dev_)
572#define SPI_STATS_TX_BYTES_INC(dev_)
573#define SPI_STATS_TRANSFER_ERROR_INC(dev_)
575#define spi_transceive_stats(dev, error, tx_bufs, rx_bufs)
610#if defined(CONFIG_SPI_RTIO) || defined(DOXYGEN)
616typedef void (*spi_api_iodev_submit)(
const struct device *dev,
635#ifdef CONFIG_SPI_ASYNC
638#ifdef CONFIG_SPI_RTIO
639 spi_api_iodev_submit iodev_submit;
736static inline int z_impl_spi_transceive(
const struct device *dev,
745 ret = api->
transceive(dev, config, tx_bufs, rx_bufs);
855#if defined(CONFIG_SPI_ASYNC) || defined(__DOXYGEN__)
893 return api->transceive_async(dev, config, tx_bufs, rx_bufs, callback, userdata);
896#if defined(CONFIG_POLL) || defined(__DOXYGEN__)
899void z_spi_transfer_signal_cb(
const struct device *dev,
int result,
void *userdata);
935 spi_callback_t cb = (sig == NULL) ? NULL : z_spi_transfer_signal_cb;
937 return api->transceive_async(dev, config, tx_bufs, rx_bufs, cb, sig);
1047#if defined(CONFIG_SPI_RTIO) || defined(__DOXYGEN__)
1059 const struct device *dev = dt_spec->
bus;
1062 api->iodev_submit(dt_spec->
bus, iodev_sqe);
1078#define SPI_DT_IODEV_DEFINE(name, node_id, operation_, delay_) \
1079 const struct spi_dt_spec _spi_dt_spec_##name = \
1080 SPI_DT_SPEC_GET(node_id, operation_, delay_); \
1081 RTIO_IODEV_DEFINE(name, &spi_iodev_api, (void *)&_spi_dt_spec_##name)
1117 size_t tx_count = tx_bufs ? tx_bufs->
count : 0;
1118 size_t rx_count = rx_bufs ? rx_bufs->
count : 0;
1126 if (tx < tx_count) {
1134 if (rx < rx_count) {
1143 while ((tx < tx_count || rx < rx_count) && (tx_len > 0 || rx_len > 0)) {
1155 if (tx_len == rx_len) {
1159 }
else if (
rx_buf == NULL) {
1168 if (rx < rx_count) {
1175 if (tx < tx_count) {
1182 }
else if (tx_len == 0) {
1188 if (rx < rx_count) {
1195 }
else if (rx_len == 0) {
1201 if (tx < tx_count) {
1208 }
else if (tx_len > rx_len) {
1217 if (rx < rx_count) {
1224 }
else if (rx_len > tx_len) {
1233 if (tx < tx_count) {
1241 __ASSERT_NO_MSG(
"Invalid spi_rtio_copy state");
1281static inline int z_impl_spi_release(
const struct device *dev,
1287 return api->
release(dev, config);
1314#include <syscalls/spi.h>
workaround assembler barfing for ST r
Definition: asm-macro-32-bit-gnu.h:24
Public APIs for GPIO drivers.
bool device_is_ready(const struct device *dev)
Verify that a device is ready for use.
static bool gpio_is_ready_dt(const struct gpio_dt_spec *spec)
Validate that GPIO port is ready.
Definition: gpio.h:831
#define RTIO_SQE_TRANSACTION
The next request in the queue is part of a transaction.
Definition: rtio.h:106
#define RTIO_PRIO_NORM
Normal priority.
Definition: rtio.h:68
static void rtio_sqe_prep_transceive(struct rtio_sqe *sqe, const struct rtio_iodev *iodev, int8_t prio, uint8_t *tx_buf, uint8_t *rx_buf, uint32_t buf_len, void *userdata)
Prepare a transceive op submission.
Definition: rtio.h:599
static void rtio_sqe_prep_read(struct rtio_sqe *sqe, const struct rtio_iodev *iodev, int8_t prio, uint8_t *buf, uint32_t len, void *userdata)
Prepare a read op submission.
Definition: rtio.h:490
static struct rtio_sqe * rtio_sqe_acquire(struct rtio *r)
Acquire a single submission queue event if available.
Definition: rtio.h:884
static void rtio_sqe_drop_all(struct rtio *r)
Drop all previously acquired sqe.
Definition: rtio.h:902
static void rtio_sqe_prep_write(struct rtio_sqe *sqe, const struct rtio_iodev *iodev, int8_t prio, uint8_t *buf, uint32_t len, void *userdata)
Prepare a write op submission.
Definition: rtio.h:530
int(* spi_api_io_async)(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *tx_bufs, const struct spi_buf_set *rx_bufs, spi_callback_t cb, void *userdata)
Definition: spi.h:603
uint16_t spi_operation_t
Opaque type to hold the SPI operation flags.
Definition: spi.h:278
int spi_release(const struct device *dev, const struct spi_config *config)
Release the SPI device locked on and/or the CS by the current config.
void(* spi_callback_t)(const struct device *dev, int result, void *data)
SPI callback for asynchronous transfer requests.
Definition: spi.h:596
static int spi_write_dt(const struct spi_dt_spec *spec, const struct spi_buf_set *tx_bufs)
Write data to a SPI bus specified in spi_dt_spec.
Definition: spi.h:849
static bool spi_is_ready_dt(const struct spi_dt_spec *spec)
Validate that SPI bus (and CS gpio if defined) is ready.
Definition: spi.h:699
static int spi_write_async(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *tx_bufs, struct k_poll_signal *sig)
Alias for spi_write_signal for backwards compatibility.
Definition: spi.h:1034
static int spi_transceive_signal(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *tx_bufs, const struct spi_buf_set *rx_bufs, struct k_poll_signal *sig)
Read/write the specified amount of data from the SPI driver.
Definition: spi.h:927
static int spi_read(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *rx_bufs)
Read the specified amount of data from the SPI driver.
Definition: spi.h:789
static int spi_read_async(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *rx_bufs, struct k_poll_signal *sig)
Alias for spi_read_signal for backwards compatibility.
Definition: spi.h:990
static int spi_transceive_dt(const struct spi_dt_spec *spec, const struct spi_buf_set *tx_bufs, const struct spi_buf_set *rx_bufs)
Read/write data from an SPI bus specified in spi_dt_spec.
Definition: spi.h:766
static int spi_transceive_cb(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *tx_bufs, const struct spi_buf_set *rx_bufs, spi_callback_t callback, void *userdata)
Read/write the specified amount of data from the SPI driver.
Definition: spi.h:883
#define SPI_STATS_TRANSFER_ERROR_INC(dev_)
Definition: spi.h:573
static int spi_read_dt(const struct spi_dt_spec *spec, const struct spi_buf_set *rx_bufs)
Read data from a SPI bus specified in spi_dt_spec.
Definition: spi.h:808
static bool spi_is_ready(const struct spi_dt_spec *spec)
Validate that SPI bus is ready.
Definition: spi.h:677
static int spi_write(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *tx_bufs)
Write the specified amount of data from the SPI driver.
Definition: spi.h:830
static int spi_rtio_copy(struct rtio *r, struct rtio_iodev *iodev, const struct spi_buf_set *tx_bufs, const struct spi_buf_set *rx_bufs, struct rtio_sqe **last_sqe)
Copy the tx_bufs and rx_bufs into a set of RTIO requests.
Definition: spi.h:1110
static int spi_release_dt(const struct spi_dt_spec *spec)
Release the SPI device specified in spi_dt_spec.
Definition: spi.h:1301
int(* spi_api_release)(const struct device *dev, const struct spi_config *config)
Callback API for unlocking SPI device.
Definition: spi.h:625
static void spi_iodev_submit(struct rtio_iodev_sqe *iodev_sqe)
Submit a SPI device with a request.
Definition: spi.h:1056
static int spi_read_signal(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *rx_bufs, struct k_poll_signal *sig)
Read the specified amount of data from the SPI driver.
Definition: spi.h:977
int(* spi_api_io)(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *tx_bufs, const struct spi_buf_set *rx_bufs)
Callback API for I/O See spi_transceive() for argument descriptions.
Definition: spi.h:584
static bool spi_cs_is_gpio_dt(const struct spi_dt_spec *spec)
Check if SPI CS in spi_dt_spec is controlled using a GPIO.
Definition: spi.h:663
static int spi_transceive_async(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *tx_bufs, const struct spi_buf_set *rx_bufs, struct k_poll_signal *sig)
Alias for spi_transceive_signal for backwards compatibility.
Definition: spi.h:945
const struct rtio_iodev_api spi_iodev_api
int spi_transceive(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *tx_bufs, const struct spi_buf_set *rx_bufs)
Read/write the specified amount of data from the SPI driver.
#define spi_transceive_stats(dev, error, tx_bufs, rx_bufs)
Definition: spi.h:575
static int spi_write_signal(const struct device *dev, const struct spi_config *config, const struct spi_buf_set *tx_bufs, struct k_poll_signal *sig)
Write the specified amount of data from the SPI driver.
Definition: spi.h:1021
static bool spi_cs_is_gpio(const struct spi_config *config)
Check if SPI CS is controlled using a GPIO.
Definition: spi.h:651
static bool spi_is_ready_iodev(const struct rtio_iodev *spi_iodev)
Validate that SPI bus (and CS gpio if defined) is ready.
Definition: spi.h:1091
#define ENOMEM
Not enough core.
Definition: errno.h:51
Real-Time IO device API for moving bytes with low effort.
#define STATS_NAME_END(name__)
Definition: stats.h:391
#define STATS_NAME(name__, entry__)
Definition: stats.h:390
#define STATS_SECT_END
Ends a stats group struct definition.
Definition: stats.h:89
#define STATS_SECT_ENTRY32(var__)
Definition: stats.h:359
#define STATS_NAME_START(name__)
Definition: stats.h:389
#define STATS_SECT_START(group__)
Definition: stats.h:354
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
__UINT16_TYPE__ uint16_t
Definition: stdint.h:89
Runtime device dynamic structure (in RAM) per driver instance.
Definition: device.h:354
Runtime device structure (in ROM) per driver instance.
Definition: device.h:381
void * data
Address of the device instance private data.
Definition: device.h:391
const void * api
Address of the API structure exposed by the device instance.
Definition: device.h:387
Container for GPIO pin information specified in devicetree.
Definition: gpio.h:286
const struct device * port
GPIO device controlling the pin.
Definition: gpio.h:288
Definition: kernel.h:5627
API that an RTIO IO device should implement.
Definition: rtio.h:429
Compute the mempool block index for a given pointer.
Definition: rtio.h:419
struct rtio_sqe sqe
Definition: rtio.h:420
An IO device with a function table for submitting requests.
Definition: rtio.h:444
void * data
Definition: rtio.h:452
A submission queue event.
Definition: rtio.h:230
uint8_t * tx_buf
Definition: rtio.h:275
uint8_t * rx_buf
Definition: rtio.h:276
const struct rtio_iodev * iodev
Device to operation on.
Definition: rtio.h:241
uint16_t flags
Op Flags.
Definition: rtio.h:235
An RTIO context containing what can be viewed as a pair of queues.
Definition: rtio.h:323
SPI buffer array structure.
Definition: spi.h:422
const struct spi_buf * buffers
Definition: spi.h:423
size_t count
Definition: spi.h:424
SPI buffer structure.
Definition: spi.h:411
size_t len
Definition: spi.h:413
void * buf
Definition: spi.h:412
SPI controller configuration structure.
Definition: spi.h:284
uint16_t slave
Slave number from 0 to host controller slave limit.
Definition: spi.h:309
struct spi_cs_control cs
GPIO chip-select line (optional, must be initialized to zero if not used).
Definition: spi.h:314
spi_operation_t operation
Operation flags.
Definition: spi.h:307
uint32_t frequency
Bus frequency in Hertz.
Definition: spi.h:286
SPI Chip Select control structure.
Definition: spi.h:148
uint32_t delay
Delay in microseconds to wait before starting the transmission and before releasing the CS line.
Definition: spi.h:161
struct gpio_dt_spec gpio
GPIO devicetree specification of CS GPIO.
Definition: spi.h:156
SPI driver API This is the mandatory API any SPI driver needs to expose.
Definition: spi.h:633
spi_api_io transceive
Definition: spi.h:634
spi_api_release release
Definition: spi.h:641
Complete SPI DT information.
Definition: spi.h:360
const struct device * bus
Definition: spi.h:361
struct spi_config config
Definition: spi.h:362