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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
//! no_std implementation of DelayMs and DelayUs for cortex-m

#![deny(missing_docs)]
#![no_std]

use bitrate::*;
use cortex_m::asm::delay;
use embedded_hal::blocking::delay::DelayMs;
use embedded_hal::blocking::delay::DelayUs;

/// asm::delay based Timer
pub struct AsmDelay {
    freq_base_ms: u32,
    freq_base_us: u32,
}

impl AsmDelay {
    /// Consturct new delay timer of CPU frequency (Hertz)
    pub fn new<F>(freq: F) -> Self
    where
        F: Into<Hertz<u32>>,
    {
        let freq_hz = freq.into().0;
        AsmDelay {
            freq_base_ms: (freq_hz / 1_000) / 2,
            freq_base_us: (freq_hz / 1_000_000) / 2,
        }
    }
}

impl<U> DelayMs<U> for AsmDelay
where
    U: Into<u32>,
{
    fn delay_ms(&mut self, ms: U) {
        delay(self.freq_base_ms * ms.into())
    }
}
impl<U> DelayUs<U> for AsmDelay
where
    U: Into<u32>,
{
    fn delay_us(&mut self, us: U) {
        delay(self.freq_base_us * us.into())
    }
}

/// Convert cycles back to time
pub struct CyclesToTime {
    freq_base_ms: f32,
    freq_base_us: f32,
}

impl CyclesToTime {
    /// Consturct new cycles to time converter of CPU frequency (Hertz)
    pub fn new<F>(freq: F) -> Self
    where
        F: Into<Hertz<u32>>,
    {
        let freq_hz = freq.into().0;
        CyclesToTime {
            freq_base_ms: (freq_hz / 1_000) as f32,
            freq_base_us: (freq_hz / 1_000_000) as f32,
        }
    }

    /// Converts cycles to ms
    pub fn to_ms<U>(&self, cycles: U) -> f32
    where
        U: Into<u32>,
    {
        (cycles.into() as f32) / self.freq_base_ms
    }

    /// Converts cycles to us
    pub fn to_us<U>(&self, cycles: U) -> f32
    where
        U: Into<u32>,
    {
        (cycles.into() as f32) / self.freq_base_us
    }
}