Struct esp_idf_svc::hal::sys::spi_device_interface_config_t

source ·
#[repr(C)]
pub struct spi_device_interface_config_t {
Show 15 fields pub command_bits: u8, pub address_bits: u8, pub dummy_bits: u8, pub mode: u8, pub clock_source: u32, pub duty_cycle_pos: u16, pub cs_ena_pretrans: u16, pub cs_ena_posttrans: u8, pub clock_speed_hz: i32, pub input_delay_ns: i32, pub spics_io_num: i32, pub flags: u32, pub queue_size: i32, pub pre_cb: Option<unsafe extern "C" fn(_: *mut spi_transaction_t)>, pub post_cb: Option<unsafe extern "C" fn(_: *mut spi_transaction_t)>,
}
Expand description

@brief This is a configuration for a SPI slave device that is connected to one of the SPI buses.

Fields§

§command_bits: u8

< Default amount of bits in command phase (0-16), used when SPI_TRANS_VARIABLE_CMD is not used, otherwise ignored.

§address_bits: u8

< Default amount of bits in address phase (0-64), used when SPI_TRANS_VARIABLE_ADDR is not used, otherwise ignored.

§dummy_bits: u8

< Amount of dummy bits to insert between address and data phase

§mode: u8

< SPI mode, representing a pair of (CPOL, CPHA) configuration:

  • 0: (0, 0)
  • 1: (0, 1)
  • 2: (1, 0)
  • 3: (1, 1)
§clock_source: u32

< Select SPI clock source, SPI_CLK_SRC_DEFAULT by default.

§duty_cycle_pos: u16

< Duty cycle of positive clock, in 1/256th increments (128 = 50%/50% duty). Setting this to 0 (=not setting it) is equivalent to setting this to 128.

§cs_ena_pretrans: u16

< Amount of SPI bit-cycles the cs should be activated before the transmission (0-16). This only works on half-duplex transactions.

§cs_ena_posttrans: u8

< Amount of SPI bit-cycles the cs should stay active after the transmission (0-16)

§clock_speed_hz: i32

< SPI clock speed in Hz. Derived from clock_source.

§input_delay_ns: i32

< Maximum data valid time of slave. The time required between SCLK and MISO valid, including the possible clock delay from slave to master. The driver uses this value to give an extra delay before the MISO is ready on the line. Leave at 0 unless you know you need a delay. For better timing performance at high frequency (over 8MHz), it’s suggest to have the right value.

§spics_io_num: i32

< CS GPIO pin for this device, or -1 if not used

§flags: u32

< Bitwise OR of SPI_DEVICE_* flags

§queue_size: i32

< Transaction queue size. This sets how many transactions can be ‘in the air’ (queued using spi_device_queue_trans but not yet finished using spi_device_get_trans_result) at the same time

§pre_cb: Option<unsafe extern "C" fn(_: *mut spi_transaction_t)>

< Callback to be called before a transmission is started.

This callback is called within interrupt context should be in IRAM for best performance, see “Transferring Speed” section in the SPI Master documentation for full details. If not, the callback may crash during flash operation when the driver is initialized with ESP_INTR_FLAG_IRAM.

§post_cb: Option<unsafe extern "C" fn(_: *mut spi_transaction_t)>

< Callback to be called after a transmission has completed.

This callback is called within interrupt context should be in IRAM for best performance, see “Transferring Speed” section in the SPI Master documentation for full details. If not, the callback may crash during flash operation when the driver is initialized with ESP_INTR_FLAG_IRAM.

Trait Implementations§

source§

impl Clone for spi_device_interface_config_t

source§

fn clone(&self) -> spi_device_interface_config_t

Returns a copy of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for spi_device_interface_config_t

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl Default for spi_device_interface_config_t

source§

fn default() -> spi_device_interface_config_t

Returns the “default value” for a type. Read more
source§

impl Copy for spi_device_interface_config_t

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> CloneToUninit for T
where T: Clone,

§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
§

impl<T> CloneToUninit for T
where T: Copy,

§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of [From]<T> for U chooses to do.

§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.