Skip to main content

Timer

Struct Timer 

Source
pub struct Timer {
    pub handle: TimerHandle,
    /* private fields */
}
Expand description

A software timer that executes a callback at regular intervals.

Timers can be configured as:

  • One-shot: Executes once after the specified period
  • Auto-reload: Executes repeatedly at the specified interval

Timer callbacks execute in the context of the timer daemon task, not in interrupt context. This means they can call most RTOS functions safely.

§Important Notes

  • Timer callbacks should complete quickly to avoid delaying other timers
  • Callbacks must not block indefinitely
  • Requires configUSE_TIMERS = 1 in FreeRTOSConfig.h

§Examples

§One-shot timer

use osal_rs::os::{Timer, TimerFn};
use core::time::Duration;
 
let timer = Timer::new_with_to_tick(
    "oneshot",
    Duration::from_secs(1),
    false,  // Not auto-reload (one-shot)
    None,
    |timer, param| {
        println!("Timer fired once!");
        Ok(param)
    }
).unwrap();
 
timer.start_with_to_tick(Duration::from_millis(10)).unwrap();

§Periodic timer

use osal_rs::os::{Timer, TimerFn};
use core::time::Duration;
 
let timer = Timer::new_with_to_tick(
    "periodic",
    Duration::from_millis(500),
    true,  // Auto-reload (periodic)
    None,
    |timer, param| {
        println!("Tick every 500ms");
        Ok(param)
    }
).unwrap();
 
timer.start_with_to_tick(Duration::from_millis(10)).unwrap();
 
// Stop after some time
Duration::from_secs(5).sleep();
timer.stop_with_to_tick(Duration::from_millis(10));

§Timer with custom parameters

use osal_rs::os::{Timer, TimerFn, TimerParam};
use alloc::sync::Arc;
use core::time::Duration;
 
struct CounterData {
    count: u32,
}
 
let data = Arc::new(CounterData { count: 0 });
let param: TimerParam = data.clone();
 
let timer = Timer::new_with_to_tick(
    "counter",
    Duration::from_secs(1),
    true,
    Some(param),
    |timer, param| {
        if let Some(param_arc) = param {
            if let Some(data) = param_arc.downcast_ref::<CounterData>() {
                println!("Counter: {}", data.count);
            }
        }
        Ok(None)
    }
).unwrap();
 
timer.start_with_to_tick(Duration::from_millis(10));

§Changing timer period

use osal_rs::os::{Timer, TimerFn};
use core::time::Duration;
 
let timer = Timer::new_with_to_tick(
    "adjustable",
    Duration::from_millis(100),
    true,
    None,
    |_, _| { println!("Tick"); Ok(None) }
).unwrap();
 
timer.start_with_to_tick(Duration::from_millis(10));
 
// Change period to 500ms
Duration::from_secs(2).sleep();
timer.change_period_with_to_tick(
    Duration::from_millis(500),
    Duration::from_millis(10)
);

§Resetting a timer

use osal_rs::os::{Timer, TimerFn};
use core::time::Duration;
 
let timer = Timer::new_with_to_tick(
    "watchdog",
    Duration::from_secs(5),
    false,
    None,
    |_, _| { println!("Timeout!"); Ok(None) }
).unwrap();
 
timer.start_with_to_tick(Duration::from_millis(10));
 
// Reset timer before it expires (like a watchdog)
Duration::from_secs(2).sleep();
timer.reset_with_to_tick(Duration::from_millis(10));  // Restart the 5s countdown

Fields§

§handle: TimerHandle

FreeRTOS timer handle

Implementations§

Source§

impl Timer

Source

pub fn new_with_to_tick<F>( name: &str, timer_period_in_ticks: impl ToTick, auto_reload: bool, param: Option<TimerParam>, callback: F, ) -> Result<Self>
where F: Fn(Box<dyn TimerFn>, Option<TimerParam>) -> Result<TimerParam> + Send + Sync + Clone + 'static,

Source

pub fn start_with_to_tick(&self, ticks_to_wait: impl ToTick) -> OsalRsBool

Source

pub fn stop_with_to_tick(&self, ticks_to_wait: impl ToTick) -> OsalRsBool

Source

pub fn reset_with_to_tick(&self, ticks_to_wait: impl ToTick) -> OsalRsBool

Source

pub fn change_period_with_to_tick( &self, new_period_in_ticks: impl ToTick, new_period_ticks: impl ToTick, ) -> OsalRsBool

Source

pub fn delete_with_to_tick(&mut self, ticks_to_wait: impl ToTick) -> OsalRsBool

Source§

impl Timer

Source

pub fn new<F>( name: &str, timer_period_in_ticks: TickType, auto_reload: bool, param: Option<TimerParam>, callback: F, ) -> Result<Self>
where F: Fn(Box<dyn TimerFn>, Option<TimerParam>) -> Result<TimerParam> + Send + Sync + Clone + 'static,

Creates a new software timer.

§Parameters
  • name - Timer name for debugging
  • timer_period_in_ticks - Timer period in ticks
  • auto_reload - true for periodic, false for one-shot
  • param - Optional parameter passed to callback
  • callback - Function called when timer expires
§Returns
  • Ok(Self) - Successfully created timer
  • Err(Error) - Creation failed
§Examples
use osal_rs::os::{Timer, TimerFn};
 
let timer = Timer::new(
    "my_timer",
    1000,
    false,
    None,
    |_timer, _param| Ok(None)
).unwrap();
``

Trait Implementations§

Source§

impl Clone for Timer

Source§

fn clone(&self) -> Timer

Returns a duplicate 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 Debug for Timer

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Deref for Timer

Source§

type Target = *const c_void

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl Display for Timer

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Drop for Timer

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl Timer for Timer

Source§

fn start(&self, ticks_to_wait: TickType) -> OsalRsBool

Starts or restarts the timer. Read more
Source§

fn stop(&self, ticks_to_wait: TickType) -> OsalRsBool

Stops the timer. Read more
Source§

fn reset(&self, ticks_to_wait: TickType) -> OsalRsBool

Resets the timer to its full period. Read more
Source§

fn change_period( &self, new_period_in_ticks: TickType, new_period_ticks: TickType, ) -> OsalRsBool

Changes the timer period. Read more
Source§

fn delete(&mut self, ticks_to_wait: TickType) -> OsalRsBool

Deletes the timer and frees its resources. Read more
Source§

impl Send for Timer

Source§

impl Sync for Timer

Auto Trait Implementations§

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, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

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

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.