riot_wrappers::ztimer

Struct Clock

Source
pub struct Clock<const HZ: u32>(*mut ztimer_clock_t);
Available on riot_module_ztimer only.
Expand description

A clock that knows about its frequency. The pulse length is not given in core::time::Duration as that’s not yet supported by const generics, and because clock rates are often easier to express in Hertz than in multiples of 10^-n seconds.

Tuple Fields§

§0: *mut ztimer_clock_t

Implementations§

Source§

impl<const HZ: u32> ValueInThread<Clock<HZ>>

Source

pub fn sleep(&self, duration: Ticks<HZ>)

Pause the current thread for the duration of ticks in the timer’s time scale.

Wraps ztimer_sleep

Source

pub fn spin(&self, duration: Ticks<HZ>)

Keep the current thread in a busy loop until the duration of ticks in the timer’s tim scale has passed

Quoting the original documentation, “This blocks lower priority threads. Use only for very short delays.”.

Wraps ztimer_spin

Note that this would not technically require the self to be a ValueInThread (as spinning is doable in an ISR), but it’s so discouraged that the Rust wrapper takes the position that it’s best done using a ValueInThread.

Source

pub fn sleep_extended(&self, duration: Duration)

Pause the current thread for the given duration, possibly exceeding values expressible in Ticks<HZ>.

The duration is converted into ticks (rounding up), and overflows are caught by sleeping multiple times.

It is up to the caller to select the Clock suitable for efficiency. (Even sleeping for seconds on the microseconds timer would not overflow the timer’s interface’s u32, but the same multiple-sleeps trick may need to be employed by the implementation, and would keep the system from entering deeper sleep modes).

Source

pub fn set_during<I: FnOnce() + Send, M: FnOnce() -> R, R>( &self, callback: I, ticks: Ticks<HZ>, in_thread: M, ) -> R

Set the given callback to be executed in an interrupt some ticks in the future.

Then, start the in_thread function from in the thread this is called from (as a regular function call).

After the in_thread function terminates, the callback is dropped if it has not already triggered.

Further Development:

  • This could probably be done with some sort of pinning instead, thus avoiding the nested scope – but getting the Drop right is comparatively tricky, because when done naively it needs runtime state.

  • The callback could be passed something extra that enables it to set the timer again and again. Granted, there’s ztimer_periodic for these cases (and it has better drifting properties), but for something like exponential retransmission it could be convenient.

    (Might make sense to do this without an extra function variant: if the callback ignores the timer argument and always returns None, that’s all in the caller type and probebly inlined right away).

While (unless with sleep) nothing would break if this were called from an interrupt context, it would not work either: As RIOT uses flat interrupt priorities, any code executed in the in_thread handler would still be run in the original interrupt, and while the configured ZTimer would fire its interrupt during that time, the interrupt would not be serviced, and the timer would be removed already by the time the original interrupt completes and ZTimer is serviced (finding no actually pending callback).

Source§

impl<const HZ: u32> Clock<HZ>

Source

pub async fn sleep_async(&self, duration: Ticks<HZ>)

Similar to [.sleep()], but this does not block but creates a future to be .awaited.

Note that time starts running only when this is polled, for otherwise there’s no pinned Self around.

Source

fn now(&self) -> Timestamp<HZ>

A ztimer_now() wrapper that is not public because there needs to be a reason why the result makes sense, which can come for example from an acquisition.

Source

fn set_during<I: FnOnce() + Send, M: FnOnce() -> R, R>( &self, callback: I, ticks: Ticks<HZ>, in_thread: M, ) -> R

A version of ValueInThread<Clock>::set_during that relies on this module’s knowledge of the circumstances to state the validity of its use even without a ValueInThread

Source

pub fn acquire(&self) -> LockedClock<HZ>

Keep the clock being shut down or reset for low power modes

While the clock is locked, its LockedClock::now() method is available, and its values can be compared.

Source

pub fn time(&self, closure: impl FnOnce()) -> Option<Ticks<HZ>>

Run a closure and measure the time it takes.

If the time the closure took exceeded the 2³²-1 ticks (the maximum time measurable on that clock), None is returned.

Source

pub fn time_with_result<R>( &self, closure: impl FnOnce() -> R, ) -> (Option<Ticks<HZ>>, R)

Like Self::time(), but allowing the closure to return a value.

As an implementation note, this is not using ztimer_stopwatch because that can not detect overflows; if overflow detection is added to ztimer_stopwatch later, the implementation can change.

Source§

impl Clock<1>

Source

pub fn sec() -> ValueInThread<Self>

Available on riot_module_ztimer_sec only.

Get the global second ZTimer clock, ZTIMER_SEC.

This function verifies (at a small runtime cost) that the caller is in a thread context. This can be avoided by calling in_thread.promote(Clock::sec_unbound()) on an existing crate::thread::InThread token.

Source

pub fn sec_unbound() -> Self

Available on riot_module_ztimer_sec only.

Get the global second ZTimer clock, ZTIMER_SEC.

The clock is not packed in a ValueInThread, which makes the blocking sleep methods and delay implementations unavailable, but works even in interrupts contexts.

Source§

impl Clock<1000>

Source

pub fn msec() -> ValueInThread<Self>

Available on riot_module_ztimer_msec only.

Get the global milliseconds ZTimer clock, ZTIMER_MSEC.

This function verifies (at a small runtime cost) that the caller is in a thread context. This can be avoided by calling in_thread.promote(Clock::msec_unbound()) on an existing crate::thread::InThread token.

Source

pub fn msec_unbound() -> Self

Available on riot_module_ztimer_msec only.

Get the global milliseconds ZTimer clock, ZTIMER_MSEC.

The clock is not packed in a ValueInThread, which makes the blocking sleep methods and delay implementations unavailable, but works even in interrupts contexts.

Source§

impl Clock<1000000>

Source

pub fn usec() -> ValueInThread<Self>

Available on riot_module_ztimer_usec only.

Get the global microseconds ZTimer clock, ZTIMER_USEC.

This function verifies (at a small runtime cost) that the caller is in a thread context. This can be avoided by calling in_thread.promote(Clock::usec_unbound()) on an existing crate::thread::InThread token.

Source

pub fn usec_unbound() -> Self

Available on riot_module_ztimer_usec only.

Get the global microseconds ZTimer clock, ZTIMER_USEC.

The clock is not packed in a ValueInThread, which makes the blocking sleep methods and delay implementations unavailable, but works even in interrupts contexts.

Trait Implementations§

Source§

impl<const HZ: u32> Clone for Clock<HZ>

Source§

fn clone(&self) -> Clock<HZ>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<const F: u32> DelayNs for ValueInThread<Clock<F>>

Source§

fn delay_ns(&mut self, ns: u32)

Pauses execution for at minimum ns nanoseconds. Pause can be longer if the implementation requires it due to precision/timing issues.
Source§

fn delay_us(&mut self, us: u32)

Pauses execution for at minimum us microseconds. Pause can be longer if the implementation requires it due to precision/timing issues.
Source§

fn delay_ms(&mut self, ms: u32)

Pauses execution for at minimum ms milliseconds. Pause can be longer if the implementation requires it due to precision/timing issues.
Source§

impl<const HZ: u32> Copy for Clock<HZ>

Auto Trait Implementations§

§

impl<const HZ: u32> Freeze for Clock<HZ>

§

impl<const HZ: u32> RefUnwindSafe for Clock<HZ>

§

impl<const HZ: u32> !Send for Clock<HZ>

§

impl<const HZ: u32> !Sync for Clock<HZ>

§

impl<const HZ: u32> Unpin for Clock<HZ>

§

impl<const HZ: u32> UnwindSafe for Clock<HZ>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoSwitch for T

Source§

fn into_switch<ActiveLevel>(self) -> Switch<T, ActiveLevel>

Consumes the IoPin returning a Switch of the appropriate ActiveLevel. Read more
Source§

fn into_active_low_switch(self) -> Switch<Self, ActiveLow>
where Self: Sized,

Consumes the IoPin returning a Switch<IoPin, ActiveLow>. Read more
Source§

fn into_active_high_switch(self) -> Switch<Self, ActiveHigh>
where Self: Sized,

Consumes the IoPin returning a Switch<IoPin, ActiveHigh>. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 4 bytes