Struct SpiDma

Source
pub struct SpiDma<'d, Dm>
where Dm: DriverMode,
{ /* private fields */ }
Available on crate feature unstable only.
Expand description

A DMA capable SPI instance.

§Stability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Implementations§

Source§

impl<Dm> SpiDma<'_, Dm>
where Dm: DriverMode,

Source

pub fn write<'t, TXBUF>( &'t mut self, words: &'t TXBUF, ) -> Result<DmaTransferTx<'t, Self>, Error>
where TXBUF: ReadBuffer,

Register a buffer for a DMA write.

This will return a DmaTransferTx. The maximum amount of data to be sent is 32736 bytes.

The write is driven by the SPI master’s sclk signal and cs line.

§Stability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Source

pub fn read<'t, RXBUF>( &'t mut self, words: &'t mut RXBUF, ) -> Result<DmaTransferRx<'t, Self>, Error>
where RXBUF: WriteBuffer,

Register a buffer for a DMA read.

This will return a DmaTransferRx. The maximum amount of data to be received is 32736 bytes.

The read is driven by the SPI master’s sclk signal and cs line.

§Stability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Source

pub fn transfer<'t, RXBUF, TXBUF>( &'t mut self, read_buffer: &'t mut RXBUF, words: &'t TXBUF, ) -> Result<DmaTransferRxTx<'t, Self>, Error>
where RXBUF: WriteBuffer, TXBUF: ReadBuffer,

Register buffers for a DMA transfer.

This will return a DmaTransferRxTx. The maximum amount of data to be sent/received is 32736 bytes.

The data transfer is driven by the SPI master’s sclk signal and cs line.

§Stability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Trait Implementations§

Source§

impl<Dm> Debug for SpiDma<'_, Dm>
where Dm: DriverMode,

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'d, Dm> Freeze for SpiDma<'d, Dm>

§

impl<'d, Dm> RefUnwindSafe for SpiDma<'d, Dm>
where Dm: RefUnwindSafe,

§

impl<'d, Dm> Send for SpiDma<'d, Dm>
where Dm: Send,

§

impl<'d, Dm> !Sync for SpiDma<'d, Dm>

§

impl<'d, Dm> Unpin for SpiDma<'d, Dm>
where Dm: Unpin,

§

impl<'d, Dm> !UnwindSafe for SpiDma<'d, Dm>

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> 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, 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.