mirror of
https://github.com/rust-embedded/rust-raspberrypi-OS-tutorials.git
synced 2024-11-03 15:40:21 +00:00
36 lines
1.0 KiB
Rust
36 lines
1.0 KiB
Rust
|
// SPDX-License-Identifier: MIT OR Apache-2.0
|
||
|
//
|
||
|
// Copyright (c) 2020 Andre Richter <andre.o.richter@gmail.com>
|
||
|
|
||
|
//! Timer primitives.
|
||
|
|
||
|
#[cfg(target_arch = "aarch64")]
|
||
|
#[path = "_arch/aarch64/time.rs"]
|
||
|
mod arch_time;
|
||
|
pub use arch_time::*;
|
||
|
|
||
|
//--------------------------------------------------------------------------------------------------
|
||
|
// Public Definitions
|
||
|
//--------------------------------------------------------------------------------------------------
|
||
|
|
||
|
/// Timekeeping interfaces.
|
||
|
pub mod interface {
|
||
|
use core::time::Duration;
|
||
|
|
||
|
/// Time management functions.
|
||
|
///
|
||
|
/// The `BSP` is supposed to supply one global instance.
|
||
|
pub trait TimeManager {
|
||
|
/// The timer's resolution.
|
||
|
fn resolution(&self) -> Duration;
|
||
|
|
||
|
/// The uptime since power-on of the device.
|
||
|
///
|
||
|
/// This includes time consumed by firmware and bootloaders.
|
||
|
fn uptime(&self) -> Duration;
|
||
|
|
||
|
/// Spin for a given duration.
|
||
|
fn spin_for(&self, duration: Duration);
|
||
|
}
|
||
|
}
|