diff options
| author | Bob McWhirter <[email protected]> | 2021-07-14 15:07:36 -0400 |
|---|---|---|
| committer | GitHub <[email protected]> | 2021-07-14 15:07:36 -0400 |
| commit | e4325cb8fe9028f9c45719dfd5a8e6281df8ddab (patch) | |
| tree | c3d80abed014bef0360734259e01faf64e1221dc /examples | |
| parent | 667b259d538b9c7c1f1e3ae636d8b0ca48e34234 (diff) | |
| parent | 21e94972dc5f19f6a8620b9ef9cb98c84aa4a963 (diff) | |
Merge pull request #290 from bobmcwhirter/async-usart
First shot at async dma usart for stm32.
Diffstat (limited to 'examples')
| -rw-r--r-- | examples/stm32h7/src/bin/usart.rs | 3 | ||||
| -rw-r--r-- | examples/stm32l4/src/bin/usart.rs | 3 | ||||
| -rw-r--r-- | examples/stm32l4/src/bin/usart_dma.rs | 12 |
3 files changed, 10 insertions, 8 deletions
diff --git a/examples/stm32h7/src/bin/usart.rs b/examples/stm32h7/src/bin/usart.rs index b44d712b5..d8e60158b 100644 --- a/examples/stm32h7/src/bin/usart.rs +++ b/examples/stm32h7/src/bin/usart.rs | |||
| @@ -14,6 +14,7 @@ use embassy::executor::Executor; | |||
| 14 | use embassy::time::Clock; | 14 | use embassy::time::Clock; |
| 15 | use embassy::util::Forever; | 15 | use embassy::util::Forever; |
| 16 | use embassy_stm32::usart::{Config, Uart}; | 16 | use embassy_stm32::usart::{Config, Uart}; |
| 17 | use embassy_stm32::dma_traits::NoDma; | ||
| 17 | use example_common::*; | 18 | use example_common::*; |
| 18 | 19 | ||
| 19 | use stm32h7xx_hal as hal; | 20 | use stm32h7xx_hal as hal; |
| @@ -27,7 +28,7 @@ async fn main_task() { | |||
| 27 | let p = embassy_stm32::init(Default::default()); | 28 | let p = embassy_stm32::init(Default::default()); |
| 28 | 29 | ||
| 29 | let config = Config::default(); | 30 | let config = Config::default(); |
| 30 | let mut usart = Uart::new(p.UART7, p.PF6, p.PF7, config); | 31 | let mut usart = Uart::new(p.UART7, p.PF6, p.PF7, NoDma, NoDma, config); |
| 31 | 32 | ||
| 32 | usart.bwrite_all(b"Hello Embassy World!\r\n").unwrap(); | 33 | usart.bwrite_all(b"Hello Embassy World!\r\n").unwrap(); |
| 33 | info!("wrote Hello, starting echo"); | 34 | info!("wrote Hello, starting echo"); |
diff --git a/examples/stm32l4/src/bin/usart.rs b/examples/stm32l4/src/bin/usart.rs index 0b14eeb59..dc0f649b7 100644 --- a/examples/stm32l4/src/bin/usart.rs +++ b/examples/stm32l4/src/bin/usart.rs | |||
| @@ -18,13 +18,14 @@ use example_common::*; | |||
| 18 | 18 | ||
| 19 | use cortex_m_rt::entry; | 19 | use cortex_m_rt::entry; |
| 20 | use stm32l4::stm32l4x5 as pac; | 20 | use stm32l4::stm32l4x5 as pac; |
| 21 | use embassy_stm32::dma_traits::NoDma; | ||
| 21 | 22 | ||
| 22 | #[embassy::task] | 23 | #[embassy::task] |
| 23 | async fn main_task() { | 24 | async fn main_task() { |
| 24 | let p = embassy_stm32::init(Default::default()); | 25 | let p = embassy_stm32::init(Default::default()); |
| 25 | 26 | ||
| 26 | let config = Config::default(); | 27 | let config = Config::default(); |
| 27 | let mut usart = Uart::new(p.UART4, p.PA1, p.PA0, config); | 28 | let mut usart = Uart::new(p.UART4, p.PA1, p.PA0, NoDma, NoDma, config); |
| 28 | 29 | ||
| 29 | usart.bwrite_all(b"Hello Embassy World!\r\n").unwrap(); | 30 | usart.bwrite_all(b"Hello Embassy World!\r\n").unwrap(); |
| 30 | info!("wrote Hello, starting echo"); | 31 | info!("wrote Hello, starting echo"); |
diff --git a/examples/stm32l4/src/bin/usart_dma.rs b/examples/stm32l4/src/bin/usart_dma.rs index cc630e0df..6a2341859 100644 --- a/examples/stm32l4/src/bin/usart_dma.rs +++ b/examples/stm32l4/src/bin/usart_dma.rs | |||
| @@ -17,22 +17,22 @@ use embassy_stm32::usart::{Config, Uart}; | |||
| 17 | use example_common::*; | 17 | use example_common::*; |
| 18 | use heapless::String; | 18 | use heapless::String; |
| 19 | use stm32l4::stm32l4x5 as pac; | 19 | use stm32l4::stm32l4x5 as pac; |
| 20 | use embassy_stm32::dma_traits::NoDma; | ||
| 21 | use embassy_traits::uart::Write as AsyncWrite; | ||
| 20 | 22 | ||
| 21 | #[embassy::task] | 23 | #[embassy::task] |
| 22 | async fn main_task() { | 24 | async fn main_task() { |
| 23 | let mut p = embassy_stm32::init(Default::default()); | 25 | let p = embassy_stm32::init(Default::default()); |
| 24 | 26 | ||
| 25 | let config = Config::default(); | 27 | let config = Config::default(); |
| 26 | let mut usart = Uart::new(p.UART4, p.PA1, p.PA0, config); | 28 | let mut usart = Uart::new(p.UART4, p.PA1, p.PA0, p.DMA1_3, NoDma, config); |
| 27 | 29 | ||
| 28 | for n in 0u32.. { | 30 | for n in 0u32.. { |
| 29 | let mut s: String<128> = String::new(); | 31 | let mut s: String<128> = String::new(); |
| 30 | core::write!(&mut s, "Hello DMA World {}!\r\n", n).unwrap(); | 32 | core::write!(&mut s, "Hello DMA World {}!\r\n", n).unwrap(); |
| 31 | 33 | ||
| 32 | usart | 34 | usart.write( s.as_bytes() ).await.ok(); |
| 33 | .write_dma(&mut p.DMA1_3, s.as_bytes()) | 35 | |
| 34 | .await | ||
| 35 | .unwrap(); | ||
| 36 | info!("wrote DMA"); | 36 | info!("wrote DMA"); |
| 37 | } | 37 | } |
| 38 | } | 38 | } |
