mirror of
https://github.com/embassy-rs/embassy.git
synced 2024-11-21 22:32:29 +00:00
enhanced docs for time driver
This commit is contained in:
parent
fcbbef01cd
commit
1434d2f97a
@ -109,12 +109,20 @@ pub trait Driver: Send + Sync + 'static {
|
|||||||
/// Try allocating an alarm handle. Returns None if no alarms left.
|
/// Try allocating an alarm handle. Returns None if no alarms left.
|
||||||
/// Initially the alarm has no callback set, and a null `ctx` pointer.
|
/// Initially the alarm has no callback set, and a null `ctx` pointer.
|
||||||
///
|
///
|
||||||
|
/// The allocated alarm is a reusable resource and can be used multiple times.
|
||||||
|
/// Once the alarm has fired, it remains allocated and can be set again without needing
|
||||||
|
/// to be reallocated.
|
||||||
|
///
|
||||||
/// # Safety
|
/// # Safety
|
||||||
/// It is UB to make the alarm fire before setting a callback.
|
/// It is UB to make the alarm fire before setting a callback.
|
||||||
unsafe fn allocate_alarm(&self) -> Option<AlarmHandle>;
|
unsafe fn allocate_alarm(&self) -> Option<AlarmHandle>;
|
||||||
|
|
||||||
/// Set the callback function to be called when the alarm triggers.
|
/// Set the callback function to be called when the alarm triggers.
|
||||||
/// The callback may be called from any context (interrupt or thread mode).
|
/// The callback may be called from any context (interrupt or thread mode).
|
||||||
|
///
|
||||||
|
/// The callback is maintained after the alarm has fired. Callers do not need
|
||||||
|
/// to set a callback again before setting another alarm, unless they want to
|
||||||
|
/// change the callback function or context.
|
||||||
fn set_alarm_callback(&self, alarm: AlarmHandle, callback: fn(*mut ()), ctx: *mut ());
|
fn set_alarm_callback(&self, alarm: AlarmHandle, callback: fn(*mut ()), ctx: *mut ());
|
||||||
|
|
||||||
/// Set an alarm at the given timestamp.
|
/// Set an alarm at the given timestamp.
|
||||||
|
Loading…
Reference in New Issue
Block a user