ticker instead of timer
This commit is contained in:
@@ -11,7 +11,7 @@ use embassy_stm32::usart::{Config, InterruptHandler, Uart, UartRx, UartTx};
|
|||||||
use embassy_sync::blocking_mutex::raw::CriticalSectionRawMutex;
|
use embassy_sync::blocking_mutex::raw::CriticalSectionRawMutex;
|
||||||
use embassy_sync::channel::Channel;
|
use embassy_sync::channel::Channel;
|
||||||
use embassy_sync::channel::Sender;
|
use embassy_sync::channel::Sender;
|
||||||
use embassy_time::{Duration, Timer};
|
use embassy_time::{Duration, Ticker, Timer};
|
||||||
use heapless::Vec;
|
use heapless::Vec;
|
||||||
|
|
||||||
use {defmt_rtt as _, panic_probe as _};
|
use {defmt_rtt as _, panic_probe as _};
|
||||||
@@ -108,6 +108,7 @@ async fn nrz(enkodovany: &Vec<u8, 38, u8>, sender: &Sender<'_, CriticalSectionRa
|
|||||||
|
|
||||||
#[embassy_executor::task]
|
#[embassy_executor::task]
|
||||||
async fn bit_send(mut pin: Output<'static>) {
|
async fn bit_send(mut pin: Output<'static>) {
|
||||||
|
let mut ticker = Ticker::every(Duration::from_millis(10));
|
||||||
let receiver = PIPE.receiver();
|
let receiver = PIPE.receiver();
|
||||||
loop {
|
loop {
|
||||||
let bit = receiver.receive().await;
|
let bit = receiver.receive().await;
|
||||||
@@ -117,6 +118,6 @@ async fn bit_send(mut pin: Output<'static>) {
|
|||||||
pin.set_low();
|
pin.set_low();
|
||||||
}
|
}
|
||||||
// bitrate
|
// bitrate
|
||||||
Timer::after(Duration::from_millis(10)).await;
|
ticker.next().await;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user