|  | // SPDX-License-Identifier: GPL-2.0 | 
|  |  | 
|  | //! Time related primitives. | 
|  | //! | 
|  | //! 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). | 
|  |  | 
|  | pub mod hrtimer; | 
|  |  | 
|  | /// 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 = crate::ffi::c_ulong; | 
|  |  | 
|  | /// The millisecond time unit. | 
|  | pub type Msecs = crate::ffi::c_uint; | 
|  |  | 
|  | /// Converts milliseconds to jiffies. | 
|  | #[inline] | 
|  | pub fn msecs_to_jiffies(msecs: Msecs) -> Jiffies { | 
|  | // SAFETY: The `__msecs_to_jiffies` function is always safe to call no | 
|  | // 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, | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | /// An identifier for a clock. Used when specifying clock sources. | 
|  | /// | 
|  | /// | 
|  | /// Selection of the clock depends on the use case. In some cases the usage of a | 
|  | /// particular clock is mandatory, e.g. in network protocols, filesystems.In other | 
|  | /// cases the user of the clock has to decide which clock is best suited for the | 
|  | /// purpose. In most scenarios clock [`ClockId::Monotonic`] is the best choice as it | 
|  | /// provides a accurate monotonic notion of time (leap second smearing ignored). | 
|  | #[derive(Clone, Copy, PartialEq, Eq, Debug)] | 
|  | #[repr(u32)] | 
|  | pub enum ClockId { | 
|  | /// A settable system-wide clock that measures real (i.e., wall-clock) time. | 
|  | /// | 
|  | /// Setting this clock requires appropriate privileges. This clock is | 
|  | /// affected by discontinuous jumps in the system time (e.g., if the system | 
|  | /// administrator manually changes the clock), and by frequency adjustments | 
|  | /// performed by NTP and similar applications via adjtime(3), adjtimex(2), | 
|  | /// clock_adjtime(2), and ntp_adjtime(3). This clock normally counts the | 
|  | /// number of seconds since 1970-01-01 00:00:00 Coordinated Universal Time | 
|  | /// (UTC) except that it ignores leap seconds; near a leap second it may be | 
|  | /// adjusted by leap second smearing to stay roughly in sync with UTC. Leap | 
|  | /// second smearing applies frequency adjustments to the clock to speed up | 
|  | /// or slow down the clock to account for the leap second without | 
|  | /// discontinuities in the clock. If leap second smearing is not applied, | 
|  | /// the clock will experience discontinuity around leap second adjustment. | 
|  | RealTime = bindings::CLOCK_REALTIME, | 
|  | /// A monotonically increasing clock. | 
|  | /// | 
|  | /// A nonsettable system-wide clock that represents monotonic time since—as | 
|  | /// described by POSIX—"some unspecified point in the past". On Linux, that | 
|  | /// point corresponds to the number of seconds that the system has been | 
|  | /// running since it was booted. | 
|  | /// | 
|  | /// The CLOCK_MONOTONIC clock is not affected by discontinuous jumps in the | 
|  | /// CLOCK_REAL (e.g., if the system administrator manually changes the | 
|  | /// clock), but is affected by frequency adjustments. This clock does not | 
|  | /// count time that the system is suspended. | 
|  | Monotonic = bindings::CLOCK_MONOTONIC, | 
|  | /// A monotonic that ticks while system is suspended. | 
|  | /// | 
|  | /// A nonsettable system-wide clock that is identical to CLOCK_MONOTONIC, | 
|  | /// except that it also includes any time that the system is suspended. This | 
|  | /// allows applications to get a suspend-aware monotonic clock without | 
|  | /// having to deal with the complications of CLOCK_REALTIME, which may have | 
|  | /// discontinuities if the time is changed using settimeofday(2) or similar. | 
|  | BootTime = bindings::CLOCK_BOOTTIME, | 
|  | /// International Atomic Time. | 
|  | /// | 
|  | /// A system-wide clock derived from wall-clock time but counting leap seconds. | 
|  | /// | 
|  | /// This clock is coupled to CLOCK_REALTIME and will be set when CLOCK_REALTIME is | 
|  | /// set, or when the offset to CLOCK_REALTIME is changed via adjtimex(2). This | 
|  | /// usually happens during boot and **should** not happen during normal operations. | 
|  | /// However, if NTP or another application adjusts CLOCK_REALTIME by leap second | 
|  | /// smearing, this clock will not be precise during leap second smearing. | 
|  | /// | 
|  | /// The acronym TAI refers to International Atomic Time. | 
|  | TAI = bindings::CLOCK_TAI, | 
|  | } | 
|  |  | 
|  | impl ClockId { | 
|  | fn into_c(self) -> bindings::clockid_t { | 
|  | self as bindings::clockid_t | 
|  | } | 
|  | } |