diff options
| author | Dario Nieuwenhuis <[email protected]> | 2023-11-29 17:23:48 +0100 |
|---|---|---|
| committer | Dario Nieuwenhuis <[email protected]> | 2023-11-29 17:26:33 +0100 |
| commit | c6989dfbca51787146f50270c671af9db434f577 (patch) | |
| tree | 5974a8ec41c108d5208e4f68027b918d424a2046 /embassy-time/src/delay.rs | |
| parent | 384bad7bfaa1f2415baf2cd3b69ebf36dc0a02d7 (diff) | |
Remove nightly and unstable-traits features in preparation for 1.75.
Diffstat (limited to 'embassy-time/src/delay.rs')
| -rw-r--r-- | embassy-time/src/delay.rs | 100 |
1 files changed, 42 insertions, 58 deletions
diff --git a/embassy-time/src/delay.rs b/embassy-time/src/delay.rs index aab56b1f1..7ef5961f0 100644 --- a/embassy-time/src/delay.rs +++ b/embassy-time/src/delay.rs | |||
| @@ -1,4 +1,5 @@ | |||
| 1 | use super::{Duration, Instant}; | 1 | use super::{Duration, Instant}; |
| 2 | use crate::Timer; | ||
| 2 | 3 | ||
| 3 | /// Blocks for at least `duration`. | 4 | /// Blocks for at least `duration`. |
| 4 | pub fn block_for(duration: Duration) { | 5 | pub fn block_for(duration: Duration) { |
| @@ -14,83 +15,66 @@ pub fn block_for(duration: Duration) { | |||
| 14 | /// active driver. | 15 | /// active driver. |
| 15 | pub struct Delay; | 16 | pub struct Delay; |
| 16 | 17 | ||
| 17 | #[cfg(feature = "unstable-traits")] | 18 | impl embedded_hal_1::delay::DelayNs for Delay { |
| 18 | mod eh1 { | 19 | fn delay_ns(&mut self, ns: u32) { |
| 19 | use super::*; | 20 | block_for(Duration::from_nanos(ns as u64)) |
| 20 | 21 | } | |
| 21 | impl embedded_hal_1::delay::DelayNs for Delay { | ||
| 22 | fn delay_ns(&mut self, ns: u32) { | ||
| 23 | block_for(Duration::from_nanos(ns as u64)) | ||
| 24 | } | ||
| 25 | 22 | ||
| 26 | fn delay_us(&mut self, us: u32) { | 23 | fn delay_us(&mut self, us: u32) { |
| 27 | block_for(Duration::from_micros(us as u64)) | 24 | block_for(Duration::from_micros(us as u64)) |
| 28 | } | 25 | } |
| 29 | 26 | ||
| 30 | fn delay_ms(&mut self, ms: u32) { | 27 | fn delay_ms(&mut self, ms: u32) { |
| 31 | block_for(Duration::from_millis(ms as u64)) | 28 | block_for(Duration::from_millis(ms as u64)) |
| 32 | } | ||
| 33 | } | 29 | } |
| 34 | } | 30 | } |
| 35 | 31 | ||
| 36 | #[cfg(all(feature = "unstable-traits", feature = "nightly"))] | 32 | impl embedded_hal_async::delay::DelayNs for Delay { |
| 37 | mod eha { | 33 | async fn delay_ns(&mut self, ns: u32) { |
| 38 | use super::*; | 34 | Timer::after_nanos(ns as _).await |
| 39 | use crate::Timer; | 35 | } |
| 40 | |||
| 41 | impl embedded_hal_async::delay::DelayNs for Delay { | ||
| 42 | async fn delay_ns(&mut self, ns: u32) { | ||
| 43 | Timer::after_nanos(ns as _).await | ||
| 44 | } | ||
| 45 | 36 | ||
| 46 | async fn delay_us(&mut self, us: u32) { | 37 | async fn delay_us(&mut self, us: u32) { |
| 47 | Timer::after_micros(us as _).await | 38 | Timer::after_micros(us as _).await |
| 48 | } | 39 | } |
| 49 | 40 | ||
| 50 | async fn delay_ms(&mut self, ms: u32) { | 41 | async fn delay_ms(&mut self, ms: u32) { |
| 51 | Timer::after_millis(ms as _).await | 42 | Timer::after_millis(ms as _).await |
| 52 | } | ||
| 53 | } | 43 | } |
| 54 | } | 44 | } |
| 55 | 45 | ||
| 56 | mod eh02 { | 46 | impl embedded_hal_02::blocking::delay::DelayMs<u8> for Delay { |
| 57 | use embedded_hal_02::blocking::delay::{DelayMs, DelayUs}; | 47 | fn delay_ms(&mut self, ms: u8) { |
| 58 | 48 | block_for(Duration::from_millis(ms as u64)) | |
| 59 | use super::*; | ||
| 60 | |||
| 61 | impl DelayMs<u8> for Delay { | ||
| 62 | fn delay_ms(&mut self, ms: u8) { | ||
| 63 | block_for(Duration::from_millis(ms as u64)) | ||
| 64 | } | ||
| 65 | } | 49 | } |
| 50 | } | ||
| 66 | 51 | ||
| 67 | impl DelayMs<u16> for Delay { | 52 | impl embedded_hal_02::blocking::delay::DelayMs<u16> for Delay { |
| 68 | fn delay_ms(&mut self, ms: u16) { | 53 | fn delay_ms(&mut self, ms: u16) { |
| 69 | block_for(Duration::from_millis(ms as u64)) | 54 | block_for(Duration::from_millis(ms as u64)) |
| 70 | } | ||
| 71 | } | 55 | } |
| 56 | } | ||
| 72 | 57 | ||
| 73 | impl DelayMs<u32> for Delay { | 58 | impl embedded_hal_02::blocking::delay::DelayMs<u32> for Delay { |
| 74 | fn delay_ms(&mut self, ms: u32) { | 59 | fn delay_ms(&mut self, ms: u32) { |
| 75 | block_for(Duration::from_millis(ms as u64)) | 60 | block_for(Duration::from_millis(ms as u64)) |
| 76 | } | ||
| 77 | } | 61 | } |
| 62 | } | ||
| 78 | 63 | ||
| 79 | impl DelayUs<u8> for Delay { | 64 | impl embedded_hal_02::blocking::delay::DelayUs<u8> for Delay { |
| 80 | fn delay_us(&mut self, us: u8) { | 65 | fn delay_us(&mut self, us: u8) { |
| 81 | block_for(Duration::from_micros(us as u64)) | 66 | block_for(Duration::from_micros(us as u64)) |
| 82 | } | ||
| 83 | } | 67 | } |
| 68 | } | ||
| 84 | 69 | ||
| 85 | impl DelayUs<u16> for Delay { | 70 | impl embedded_hal_02::blocking::delay::DelayUs<u16> for Delay { |
| 86 | fn delay_us(&mut self, us: u16) { | 71 | fn delay_us(&mut self, us: u16) { |
| 87 | block_for(Duration::from_micros(us as u64)) | 72 | block_for(Duration::from_micros(us as u64)) |
| 88 | } | ||
| 89 | } | 73 | } |
| 74 | } | ||
| 90 | 75 | ||
| 91 | impl DelayUs<u32> for Delay { | 76 | impl embedded_hal_02::blocking::delay::DelayUs<u32> for Delay { |
| 92 | fn delay_us(&mut self, us: u32) { | 77 | fn delay_us(&mut self, us: u32) { |
| 93 | block_for(Duration::from_micros(us as u64)) | 78 | block_for(Duration::from_micros(us as u64)) |
| 94 | } | ||
| 95 | } | 79 | } |
| 96 | } | 80 | } |
