blob: aa56f7c423eb800d6974911c58de6da3f48c1201 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
#![no_std]
#![no_main]
use defmt::info;
use embassy_executor::Spawner;
use embassy_imxrt::bind_interrupts;
use embassy_imxrt::flexcomm::spi::{InterruptHandler, Spi};
use embassy_imxrt::peripherals::FLEXCOMM5;
use {defmt_rtt as _, embassy_imxrt_examples as _, panic_probe as _};
bind_interrupts!(struct Irqs {
FLEXCOMM5 => InterruptHandler<FLEXCOMM5>;
});
const BUFLEN: usize = 1024;
#[embassy_executor::main]
async fn main(_spawner: Spawner) {
let p = embassy_imxrt::init(Default::default());
info!("Initializing SPI");
let mut spi = Spi::new_async(p.FLEXCOMM5, p.PIO1_3, p.PIO1_5, p.PIO1_4, Irqs, Default::default());
let mut rxbuf = [0x55; BUFLEN];
let txbuf = [0xaa; BUFLEN];
for _ in 0..10 {
spi.async_transfer(&mut rxbuf, &txbuf).await.unwrap();
assert!(rxbuf.iter().all(|b| *b == 0xaa));
rxbuf.fill(0x55);
}
info!("SPI transfers succeeded");
}
|