embassy/time: round up by default in Duration::from_*
. Fixes #823
This commit is contained in:
parent
9721b2bf5b
commit
571e4f2b01
1 changed files with 31 additions and 4 deletions
|
@ -41,23 +41,45 @@ impl Duration {
|
||||||
Duration { ticks }
|
Duration { ticks }
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a duration from the specified number of seconds
|
/// Creates a duration from the specified number of seconds, rounding up.
|
||||||
pub const fn from_secs(secs: u64) -> Duration {
|
pub const fn from_secs(secs: u64) -> Duration {
|
||||||
Duration {
|
Duration {
|
||||||
ticks: secs * TICKS_PER_SECOND,
|
ticks: secs * TICKS_PER_SECOND,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a duration from the specified number of milliseconds
|
/// Creates a duration from the specified number of milliseconds, rounding up.
|
||||||
pub const fn from_millis(millis: u64) -> Duration {
|
pub const fn from_millis(millis: u64) -> Duration {
|
||||||
|
Duration {
|
||||||
|
ticks: div_ceil(millis * (TICKS_PER_SECOND / GCD_1K), 1000 / GCD_1K),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Creates a duration from the specified number of microseconds, rounding up.
|
||||||
|
/// NOTE: Delays this small may be inaccurate.
|
||||||
|
pub const fn from_micros(micros: u64) -> Duration {
|
||||||
|
Duration {
|
||||||
|
ticks: div_ceil(micros * (TICKS_PER_SECOND / GCD_1M), 1_000_000 / GCD_1M),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Creates a duration from the specified number of seconds, rounding down.
|
||||||
|
pub const fn from_secs_floor(secs: u64) -> Duration {
|
||||||
|
Duration {
|
||||||
|
ticks: secs * TICKS_PER_SECOND,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Creates a duration from the specified number of milliseconds, rounding down.
|
||||||
|
pub const fn from_millis_floor(millis: u64) -> Duration {
|
||||||
Duration {
|
Duration {
|
||||||
ticks: millis * (TICKS_PER_SECOND / GCD_1K) / (1000 / GCD_1K),
|
ticks: millis * (TICKS_PER_SECOND / GCD_1K) / (1000 / GCD_1K),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a duration from the specified number of microseconds
|
/// Creates a duration from the specified number of microseconds, rounding down.
|
||||||
/// NOTE: Delays this small may be inaccurate.
|
/// NOTE: Delays this small may be inaccurate.
|
||||||
pub const fn from_micros(micros: u64) -> Duration {
|
pub const fn from_micros_floor(micros: u64) -> Duration {
|
||||||
Duration {
|
Duration {
|
||||||
ticks: micros * (TICKS_PER_SECOND / GCD_1M) / (1_000_000 / GCD_1M),
|
ticks: micros * (TICKS_PER_SECOND / GCD_1M) / (1_000_000 / GCD_1M),
|
||||||
}
|
}
|
||||||
|
@ -155,3 +177,8 @@ impl<'a> fmt::Display for Duration {
|
||||||
write!(f, "{} ticks", self.ticks)
|
write!(f, "{} ticks", self.ticks)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
const fn div_ceil(num: u64, den: u64) -> u64 {
|
||||||
|
(num + den - 1) / den
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue