Struct SPI2

Source
pub struct SPI2 { /* private fields */ }
Expand description

Serial peripheral interface

See peripheral structure

Implementations§

Source§

impl SPI2

Source

pub const PTR: *const RegisterBlock = {0x40003800 as *const stm32f4_staging::stm32f429::spi1::RegisterBlock}

Pointer to the register block

Source

pub const fn ptr() -> *const RegisterBlock

Return the pointer to the register block

Source

pub unsafe fn steal() -> SPI2

Steal an instance of this peripheral

§Safety

Ensure that the new instance of the peripheral cannot be used in a way that may race with any existing instances, for example by only accessing read-only or write-only registers, or by consuming the original peripheral and using critical sections to coordinate access between multiple new instances.

Additionally, other software such as HALs may rely on only one peripheral instance existing to ensure memory safety; ensure no stolen instances are passed to such software.

Methods from Deref<Target = RegisterBlock>§

Source

pub fn cr1(&self) -> &Reg<CR1rs>

0x00 - control register 1

Source

pub fn cr2(&self) -> &Reg<CR2rs>

0x04 - control register 2

Source

pub fn sr(&self) -> &Reg<SRrs>

0x08 - status register

Source

pub fn dr8(&self) -> &Reg<DR8rs>

0x0c - Direct 8-bit access to data register

Source

pub fn dr(&self) -> &Reg<DRrs>

0x0c - data register

Source

pub fn crcpr(&self) -> &Reg<CRCPRrs>

0x10 - CRC polynomial register

Source

pub fn rxcrcr(&self) -> &Reg<RXCRCRrs>

0x14 - RX CRC register

Source

pub fn txcrcr(&self) -> &Reg<TXCRCRrs>

0x18 - TX CRC register

Source

pub fn i2scfgr(&self) -> &Reg<I2SCFGRrs>

0x1c - I2S configuration register

Source

pub fn i2spr(&self) -> &Reg<I2SPRrs>

0x20 - I2S prescaler register

Trait Implementations§

Source§

impl Debug for SPI2

Source§

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

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

impl Deref for SPI2

Source§

type Target = RegisterBlock

The resulting type after dereferencing.
Source§

fn deref(&self) -> &<SPI2 as Deref>::Target

Dereferences the value.
Source§

impl DualInstance for SPI2

Source§

type I2sExtPeripheral = I2S2EXT

The I2SEXT peripheral that extend the SPI peripheral
Source§

impl Enable for SPI2

Source§

fn enable(rcc: &RccRB)

Enables peripheral
Source§

fn disable(rcc: &RccRB)

Disables peripheral
Source§

fn is_enabled() -> bool

Check if peripheral enabled
Source§

fn is_disabled() -> bool

Check if peripheral disabled
Source§

unsafe fn enable_unchecked()

Safety Read more
Source§

unsafe fn disable_unchecked()

Safety Read more
Source§

impl I2sCommon for SPI2

Source§

type Ck = Ck

Source§

type Sd = Sd

Source§

type Ws = Ws

Source§

impl I2sExtPin for SPI2

Source§

impl I2sMaster for SPI2

Source§

impl LPEnable for SPI2

Source§

fn enable_in_low_power(rcc: &RccRB)

Enables peripheral in low power mode
Source§

fn disable_in_low_power(rcc: &RccRB)

Disables peripheral in low power mode
Source§

fn is_enabled_in_low_power() -> bool

Check if peripheral enabled in low power mode
Source§

fn is_disabled_in_low_power() -> bool

Check if peripheral disabled in low power mode
Source§

unsafe fn enable_in_low_power_unchecked()

Safety Read more
Source§

unsafe fn disable_in_low_power_unchecked()

Safety Read more
Source§

impl PeriAddress for SPI2

Source§

type MemSize = u8

Memory size of the peripheral.
Source§

fn address(&self) -> u32

Returns the address to be used by the DMA stream.
Source§

impl Ptr for SPI2

Source§

type RB = RegisterBlock

RegisterBlock structure
Source§

fn ptr() -> *const Self::RB

Return the pointer to the register block
Source§

impl RccBus for SPI2

Source§

type Bus = APB1

Bus type;
Source§

impl Reset for SPI2

Source§

fn reset(rcc: &RccRB)

Resets peripheral
Source§

unsafe fn reset_unchecked()

Safety Read more
Source§

impl SpiCommon for SPI2

Source§

impl DMASet<StreamX<DMA1, 3>, 0, PeripheralToMemory> for SPI2

Source§

impl DMASet<StreamX<DMA1, 4>, 0, MemoryToPeripheral> for SPI2

Source§

impl Instance for SPI2

Source§

impl Instance for SPI2

Source§

impl Send for SPI2

Auto Trait Implementations§

§

impl Freeze for SPI2

§

impl RefUnwindSafe for SPI2

§

impl !Sync for SPI2

§

impl Unpin for SPI2

§

impl UnwindSafe for SPI2

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> BusClock for T
where T: RccBus, <T as RccBus>::Bus: BusClock,

Source§

fn clock(clocks: &Clocks) -> Rate<u32, 1, 1>

Calculates frequency depending on Clock state
Source§

impl<T> BusTimerClock for T
where T: RccBus, <T as RccBus>::Bus: BusTimerClock,

Source§

fn timer_clock(clocks: &Clocks) -> Rate<u32, 1, 1>

Calculates base frequency of timer depending on Clock state
Source§

impl<SPI> DualI2sExt for SPI
where SPI: DualInstance,

Source§

fn dual_i2s( self, i2s_ext: <SPI as DualInstance>::I2sExtPeripheral, pins: (impl Into<<SPI as I2sCommon>::Ws>, impl Into<<SPI as I2sCommon>::Ck>, impl Into<<SPI as I2sMaster>::Mck>, impl Into<<SPI as I2sCommon>::Sd>, impl Into<<SPI as I2sExtPin>::ExtSd>), clocks: &Clocks, ) -> DualI2s<SPI>

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<SPI> I2sExt for SPI
where SPI: Instance,

Source§

fn i2s( self, pins: (impl Into<<SPI as I2sCommon>::Ws>, impl Into<<SPI as I2sCommon>::Ck>, impl Into<<SPI as I2sMaster>::Mck>, impl Into<<SPI as I2sCommon>::Sd>), clocks: &Clocks, ) -> I2s<SPI>

Source§

impl<T> I2sFreq for T
where T: RccBus, <T as RccBus>::Bus: I2sFreq,

Source§

fn try_i2s_freq(clocks: &Clocks) -> Option<Rate<u32, 1, 1>>

Source§

fn i2s_freq(clocks: &Clocks) -> Hertz

Source§

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

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<SPI> SpiExt for SPI
where SPI: Instance,

Source§

fn spi( self, pins: (impl Into<<SPI as SpiCommon>::Sck>, impl Into<<SPI as SpiCommon>::Miso>, impl Into<<SPI as SpiCommon>::Mosi>), mode: impl Into<Mode>, freq: Rate<u32, 1, 1>, clocks: &Clocks, ) -> Spi<SPI>

Enables the SPI clock, resets the peripheral, sets Alternate mode for pins and initialize the peripheral as SPI Master Normal mode.

§Note

Depending on freq you may need to set GPIO speed for pins (the Speed::Low is default for GPIO) before create Spi instance. Otherwise it may lead to the ‘wrong last bit in every received byte’ problem.

Source§

fn spi_bidi( self, pins: (impl Into<<SPI as SpiCommon>::Sck>, impl Into<<SPI as SpiCommon>::Mosi>), mode: impl Into<Mode>, freq: Rate<u32, 1, 1>, clocks: &Clocks, ) -> Spi<SPI, true>
where NoPin: Into<<SPI as SpiCommon>::Miso>,

Enables the SPI clock, resets the peripheral, sets Alternate mode for pins and initialize the peripheral as SPI Master BIDI mode.

§Note

Depending on freq you may need to set GPIO speed for pins (the Speed::Low is default for GPIO) before create Spi instance. Otherwise it may lead to the ‘wrong last bit in every received byte’ problem.

Source§

fn spi_slave( self, pins: (impl Into<<SPI as SpiCommon>::Sck>, impl Into<<SPI as SpiCommon>::Miso>, impl Into<<SPI as SpiCommon>::Mosi>, Option<<SPI as SpiCommon>::Nss>), mode: impl Into<Mode>, ) -> SpiSlave<SPI>

Enables the SPI clock, resets the peripheral, sets Alternate mode for pins and initialize the peripheral as SPI Slave Normal mode.

§Note

Depending on freq you may need to set GPIO speed for pins (the Speed::Low is default for GPIO) before create Spi instance. Otherwise it may lead to the ‘wrong last bit in every received byte’ problem.

Source§

fn spi_bidi_slave( self, pins: (impl Into<<SPI as SpiCommon>::Sck>, impl Into<<SPI as SpiCommon>::Miso>, Option<<SPI as SpiCommon>::Nss>), mode: impl Into<Mode>, ) -> SpiSlave<SPI, true>
where NoPin: Into<<SPI as SpiCommon>::Mosi>,

Enables the SPI clock, resets the peripheral, sets Alternate mode for pins and initialize the peripheral as SPI Slave BIDI mode.

§Note

Depending on freq you may need to set GPIO speed for pins (the Speed::Low is default for GPIO) before create Spi instance. Otherwise it may lead to the ‘wrong last bit in every received byte’ problem.

Source§

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

Source§

type Error = Infallible

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

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

Performs the conversion.
Source§

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

Source§

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

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

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

Performs the conversion.