diff options
Diffstat (limited to 'rust/kernel/time.rs')
| -rw-r--r-- | rust/kernel/time.rs | 63 | 
1 files changed, 63 insertions, 0 deletions
| diff --git a/rust/kernel/time.rs b/rust/kernel/time.rs index 25a896eed468..e3bb5e89f88d 100644 --- a/rust/kernel/time.rs +++ b/rust/kernel/time.rs @@ -4,6 +4,12 @@  //!  //! This module contains the kernel APIs related to time and timers that  //! have been ported or wrapped for usage by Rust code in the kernel. +//! +//! C header: [`include/linux/jiffies.h`](srctree/include/linux/jiffies.h). +//! C header: [`include/linux/ktime.h`](srctree/include/linux/ktime.h). + +/// The number of nanoseconds per millisecond. +pub const NSEC_PER_MSEC: i64 = bindings::NSEC_PER_MSEC as i64;  /// The time unit of Linux kernel. One jiffy equals (1/HZ) second.  pub type Jiffies = core::ffi::c_ulong; @@ -18,3 +24,60 @@ pub fn msecs_to_jiffies(msecs: Msecs) -> Jiffies {      // matter what the argument is.      unsafe { bindings::__msecs_to_jiffies(msecs) }  } + +/// A Rust wrapper around a `ktime_t`. +#[repr(transparent)] +#[derive(Copy, Clone)] +pub struct Ktime { +    inner: bindings::ktime_t, +} + +impl Ktime { +    /// Create a `Ktime` from a raw `ktime_t`. +    #[inline] +    pub fn from_raw(inner: bindings::ktime_t) -> Self { +        Self { inner } +    } + +    /// Get the current time using `CLOCK_MONOTONIC`. +    #[inline] +    pub fn ktime_get() -> Self { +        // SAFETY: It is always safe to call `ktime_get` outside of NMI context. +        Self::from_raw(unsafe { bindings::ktime_get() }) +    } + +    /// Divide the number of nanoseconds by a compile-time constant. +    #[inline] +    fn divns_constant<const DIV: i64>(self) -> i64 { +        self.to_ns() / DIV +    } + +    /// Returns the number of nanoseconds. +    #[inline] +    pub fn to_ns(self) -> i64 { +        self.inner +    } + +    /// Returns the number of milliseconds. +    #[inline] +    pub fn to_ms(self) -> i64 { +        self.divns_constant::<NSEC_PER_MSEC>() +    } +} + +/// Returns the number of milliseconds between two ktimes. +#[inline] +pub fn ktime_ms_delta(later: Ktime, earlier: Ktime) -> i64 { +    (later - earlier).to_ms() +} + +impl core::ops::Sub for Ktime { +    type Output = Ktime; + +    #[inline] +    fn sub(self, other: Ktime) -> Ktime { +        Self { +            inner: self.inner - other.inner, +        } +    } +} |