//! Delay devices and providers use crate::register::mcycle; use embedded_hal::delay::DelayUs; /// Machine mode cycle counter (`mcycle`) as a delay provider #[derive(Copy, Clone)] #[repr(transparent)] pub struct McycleDelay { /// The clock speed of the core, in Hertz ticks_second: u32, } impl McycleDelay { /// Constructs the delay provider. /// `ticks_second` should be the clock speed of the core, in Hertz #[inline] pub const fn new(ticks_second: u32) -> Self { Self { ticks_second } } } impl DelayUs for McycleDelay { #[inline] fn delay_us(&mut self, us: u32) { let t0 = mcycle::read64(); let us_64: u64 = us.into(); let clock = (us_64 * (self.ticks_second as u64)) / 1_000_000u64; while mcycle::read64().wrapping_sub(t0) <= clock {} } }