Add uart::Read DMA-based implementation

* Rename existing read() to bread() (blocking)
This commit is contained in:
Ulf Lilleengen
2021-08-03 15:17:04 +02:00
parent ad62900a40
commit 6ff0614cb6
6 changed files with 103 additions and 5 deletions

View File

@ -33,7 +33,7 @@ fn main() -> ! {
let mut buf = [0u8; 1];
loop {
usart.read(&mut buf).unwrap();
usart.bread(&mut buf).unwrap();
usart.bwrite_all(&buf).unwrap();
}
}

View File

@ -34,7 +34,7 @@ async fn main_task() {
let mut buf = [0u8; 1];
loop {
usart.read(&mut buf).unwrap();
usart.bread(&mut buf).unwrap();
usart.bwrite_all(&buf).unwrap();
}
}

View File

@ -0,0 +1,42 @@
#![no_std]
#![no_main]
#![feature(trait_alias)]
#![feature(min_type_alias_impl_trait)]
#![feature(impl_trait_in_bindings)]
#![feature(type_alias_impl_trait)]
#![allow(incomplete_features)]
#[path = "../example_common.rs"]
mod example_common;
use example_common::*;
use defmt::panic;
use embassy::executor::Spawner;
use embassy_stm32::usart::{Config, Uart};
use embassy_stm32::{rcc, Peripherals};
use embassy_traits::uart::{Read, Write};
#[embassy::main]
async fn main(_spawner: Spawner, mut p: Peripherals) {
let mut rcc = rcc::Rcc::new(p.RCC);
rcc.enable_debug_wfe(&mut p.DBGMCU, true);
let mut usart = Uart::new(
p.USART1,
p.PB7,
p.PB6,
p.DMA1_CH2,
p.DMA1_CH3,
Config::default(),
);
usart.write(b"Hello Embassy World!\r\n").await.unwrap();
info!("wrote Hello, starting echo");
let mut buf = [0; 1];
loop {
usart.read(&mut buf[..]).await.unwrap();
usart.write(&buf[..]).await.unwrap();
}
}

View File

@ -33,7 +33,7 @@ fn main() -> ! {
let mut buf = [0u8; 1];
loop {
usart.read(&mut buf).unwrap();
usart.bread(&mut buf).unwrap();
usart.bwrite_all(&buf).unwrap();
}
}