#![no_std] #![no_main] #![feature(type_alias_impl_trait)] #[path = "../example_common.rs"] mod example_common; use defmt::assert_eq; use embassy::executor::Spawner; use embassy_stm32::spi::{self, Spi}; use embassy_stm32::time::Hertz; use embassy_stm32::Peripherals; use example_common::*; #[embassy::main(config = "config()")] async fn main(_spawner: Spawner, p: Peripherals) { info!("Hello World!"); #[cfg(feature = "stm32f103c8")] let (sck, mosi, miso, tx_dma, rx_dma) = (p.PA5, p.PA7, p.PA6, p.DMA1_CH3, p.DMA1_CH2); #[cfg(feature = "stm32f429zi")] let (sck, mosi, miso, tx_dma, rx_dma) = (p.PA5, p.PA7, p.PA6, p.DMA2_CH3, p.DMA2_CH2); #[cfg(feature = "stm32h755zi")] let (sck, mosi, miso, tx_dma, rx_dma) = (p.PA5, p.PB5, p.PA6, p.DMA1_CH0, p.DMA1_CH1); #[cfg(feature = "stm32g491re")] let (sck, mosi, miso, tx_dma, rx_dma) = (p.PA5, p.PA7, p.PA6, p.DMA1_CH1, p.DMA1_CH2); #[cfg(feature = "stm32g071rb")] let (sck, mosi, miso, tx_dma, rx_dma) = (p.PA5, p.PA7, p.PA6, p.DMA1_CH1, p.DMA1_CH2); #[cfg(feature = "stm32wb55rg")] let (sck, mosi, miso, tx_dma, rx_dma) = (p.PA5, p.PA7, p.PA6, p.DMA1_CH1, p.DMA1_CH2); #[cfg(feature = "stm32u585ai")] let (sck, mosi, miso, tx_dma, rx_dma) = (p.PE13, p.PE15, p.PE14, p.GPDMA1_CH0, p.GPDMA1_CH1); let mut spi = Spi::new( p.SPI1, sck, // Arduino D13 mosi, // Arduino D11 miso, // Arduino D12 tx_dma, rx_dma, Hertz(1_000_000), spi::Config::default(), ); let data: [u8; 9] = [0x00, 0xFF, 0xAA, 0x55, 0xC0, 0xFF, 0xEE, 0xC0, 0xDE]; // Arduino pins D11 and D12 (MOSI-MISO) are connected together with a 1K resistor. // so we should get the data we sent back. let mut buf = [0; 9]; spi.transfer(&mut buf, &data).await.unwrap(); assert_eq!(buf, data); spi.transfer_in_place(&mut buf).await.unwrap(); assert_eq!(buf, data); // Check read/write don't hang. We can't check they transfer the right data // without fancier test mechanisms. spi.write(&buf).await.unwrap(); spi.read(&mut buf).await.unwrap(); spi.write(&buf).await.unwrap(); spi.read(&mut buf).await.unwrap(); spi.write(&buf).await.unwrap(); // Check transfer doesn't break after having done a write, due to garbage in the FIFO spi.transfer(&mut buf, &data).await.unwrap(); assert_eq!(buf, data); // Check zero-length operations, these should be noops. spi.transfer::(&mut [], &[]).await.unwrap(); spi.transfer_in_place::(&mut []).await.unwrap(); spi.read::(&mut []).await.unwrap(); spi.write::(&[]).await.unwrap(); // === Check mixing blocking with async. spi.blocking_transfer(&mut buf, &data).unwrap(); assert_eq!(buf, data); spi.transfer(&mut buf, &data).await.unwrap(); assert_eq!(buf, data); spi.blocking_write(&buf).unwrap(); spi.transfer(&mut buf, &data).await.unwrap(); assert_eq!(buf, data); spi.blocking_read(&mut buf).unwrap(); spi.blocking_write(&buf).unwrap(); spi.write(&buf).await.unwrap(); spi.read(&mut buf).await.unwrap(); spi.blocking_write(&buf).unwrap(); spi.blocking_read(&mut buf).unwrap(); spi.write(&buf).await.unwrap(); info!("Test OK"); cortex_m::asm::bkpt(); }