33 #ifndef PARAM_ASSERTIONS_ENABLED_TIME 34 #define PARAM_ASSERTIONS_ENABLED_TIME 0 38 #ifndef PICO_TIME_SLEEP_OVERHEAD_ADJUST_US 39 #define PICO_TIME_SLEEP_OVERHEAD_ADJUST_US 6 67 static inline uint32_t us_to_ms(uint64_t us) {
69 return (uint32_t)(us / 1000u);
71 return ((uint32_t)us) / 1000u;
97 uint64_t delayed = base + us;
98 if ((int64_t)delayed < 0) {
116 uint64_t delayed = base + ms * 1000ull;
117 if ((int64_t)delayed < 0) {
307 #ifndef PICO_TIME_DEFAULT_ALARM_POOL_DISABLED 320 #define PICO_TIME_DEFAULT_ALARM_POOL_DISABLED 0 324 #ifndef PICO_TIME_DEFAULT_ALARM_POOL_HARDWARE_ALARM_NUM 330 #define PICO_TIME_DEFAULT_ALARM_POOL_HARDWARE_ALARM_NUM 3 334 #ifndef PICO_TIME_DEFAULT_ALARM_POOL_MAX_TIMERS 343 #define PICO_TIME_DEFAULT_ALARM_POOL_MAX_TIMERS 16 380 #if !PICO_TIME_DEFAULT_ALARM_POOL_DISABLED 562 #if !PICO_TIME_DEFAULT_ALARM_POOL_DISABLED 728 #if !PICO_TIME_DEFAULT_ALARM_POOL_DISABLED bool alarm_pool_add_repeating_timer_us(alarm_pool_t *pool, int64_t delay_us, repeating_timer_callback_t callback, void *user_data, repeating_timer_t *out)
Add a repeating timer that is called repeatedly at the specified interval in microsecondsGenerally th...
Definition: time.c:345
alarm_pool_t * alarm_pool_create(uint hardware_alarm_num, uint max_timers)
Create an alarm pool.
Definition: time.c:180
uint alarm_pool_core_num(alarm_pool_t *pool)
Return the core number the alarm pool was initialized on (and hence callbacks are called on) ...
Definition: time.c:321
bool(* repeating_timer_callback_t)(repeating_timer_t *rt)
Callback for a repeating timer.
Definition: time.h:671
void sleep_until(absolute_time_t target)
Wait until after the given timestamp to return.
Definition: time.c:381
static bool cancel_alarm(alarm_id_t alarm_id)
Cancel an alarm from the default alarm pool.
Definition: time.h:647
static bool add_repeating_timer_ms(int32_t delay_ms, repeating_timer_callback_t callback, void *user_data, repeating_timer_t *out)
Add a repeating timer that is called repeatedly at the specified interval in millisecondsGenerally th...
Definition: time.h:767
bool cancel_repeating_timer(repeating_timer_t *timer)
Cancel a repeating timer.
Definition: time.c:358
static alarm_id_t alarm_pool_add_alarm_in_ms(alarm_pool_t *pool, uint32_t ms, alarm_callback_t callback, void *user_data, bool fire_if_past)
Add an alarm callback to be called after a delay specified in millisecondsGenerally the callback is c...
Definition: time.h:548
static bool add_repeating_timer_us(int64_t delay_us, repeating_timer_callback_t callback, void *user_data, repeating_timer_t *out)
Add a repeating timer that is called repeatedly at the specified interval in microsecondsGenerally th...
Definition: time.h:746
bool best_effort_wfe_or_timeout(absolute_time_t timeout_timestamp)
Helper method for blocking on a timeoutThis method will return in response to an event (as per __wfe)...
Definition: time.c:432
static absolute_time_t absolute_time_min(absolute_time_t a, absolute_time_t b)
Return the earlier of two timestamps.
Definition: time.h:167
static absolute_time_t make_timeout_time_ms(uint32_t ms)
Convenience method to get the timestamp a number of milliseconds from the current time...
Definition: time.h:141
static bool alarm_pool_add_repeating_timer_ms(alarm_pool_t *pool, int32_t delay_ms, repeating_timer_callback_t callback, void *user_data, repeating_timer_t *out)
Add a repeating timer that is called repeatedly at the specified interval in millisecondsGenerally th...
Definition: time.h:724
static bool is_at_the_end_of_time(absolute_time_t t)
Determine if the given timestamp is "at_the_end_of_time".
Definition: time.h:184
bool alarm_pool_cancel_alarm(alarm_pool_t *pool, alarm_id_t alarm_id)
Cancel an alarm.
Definition: time.c:293
static absolute_time_t delayed_by_us(const absolute_time_t t, uint64_t us)
Return a timestamp value obtained by adding a number of microseconds to another timestamp.
Definition: time.h:94
static void update_us_since_boot(absolute_time_t *t, uint64_t us_since_boot)
update an absolute_time_t value to represent a given number of microseconds since boot ...
Definition: types.h:59
int64_t(* alarm_callback_t)(alarm_id_t id, void *user_data)
User alarm callback.
Definition: time.h:370
static uint32_t to_ms_since_boot(absolute_time_t t)
Convert a timestamp into a number of milliseconds since boot.
Definition: time.h:82
alarm_id_t alarm_pool_add_alarm_at(alarm_pool_t *pool, absolute_time_t time, alarm_callback_t callback, void *user_data, bool fire_if_past)
Add an alarm callback to be called at a specific timeGenerally the callback is called as soon as poss...
Definition: time.c:226
alarm_pool_t * alarm_pool_get_default(void)
The default alarm pool used when alarms are added without specifying an alarm pool, and also used by the SDK to support lower power sleeps and timeouts.
Definition: time.c:93
const absolute_time_t nil_time
The timestamp representing a null timestamp.
static absolute_time_t get_absolute_time(void)
Return a representation of the current time.Returns an opaque high fidelity representation of the cur...
Definition: time.h:61
static alarm_id_t add_alarm_in_us(uint64_t us, alarm_callback_t callback, void *user_data, bool fire_if_past)
Add an alarm callback to be called after a delay specified in microsecondsGenerally the callback is c...
Definition: time.h:611
uint64_t time_us_64(void)
Return the current 64 bit timestamp value in microsecondsReturns the full 64 bits of the hardware tim...
Definition: timer.c:41
uint alarm_pool_hardware_alarm_num(alarm_pool_t *pool)
Return the hardware alarm used by an alarm pool.
Definition: time.c:317
const absolute_time_t at_the_end_of_time
The timestamp representing the end of time; this is actually not the maximum possible timestamp...
static alarm_id_t add_alarm_in_ms(uint32_t ms, alarm_callback_t callback, void *user_data, bool fire_if_past)
Add an alarm callback to be called after a delay specified in millisecondsGenerally the callback is c...
Definition: time.h:637
static alarm_id_t add_alarm_at(absolute_time_t time, alarm_callback_t callback, void *user_data, bool fire_if_past)
Add an alarm callback to be called at a specific timeGenerally the callback is called as soon as poss...
Definition: time.h:585
static uint64_t to_us_since_boot(absolute_time_t t)
convert an absolute_time_t into a number of microseconds since boot.
Definition: types.h:44
alarm_pool_t * alarm_pool_create_with_unused_hardware_alarm(uint max_timers)
Create an alarm pool, claiming an used hardware alarm to back it.
Definition: time.c:190
alarm_id_t alarm_pool_add_alarm_at_force_in_context(alarm_pool_t *pool, absolute_time_t time, alarm_callback_t callback, void *user_data)
Add an alarm callback to be called at or after a specific timeThe callback is called as soon as possi...
Definition: time.c:273
Information about a repeating timer.
Definition: time.h:678
int32_t alarm_id_t
The identifier for an alarm.
Definition: time.h:359
static absolute_time_t delayed_by_ms(const absolute_time_t t, uint32_t ms)
Return a timestamp value obtained by adding a number of milliseconds to another timestamp.
Definition: time.h:113
void alarm_pool_destroy(alarm_pool_t *pool)
Destroy the alarm pool, cancelling all alarms and freeing up the underlying hardware alarm...
Definition: time.c:208
static int64_t absolute_time_diff_us(absolute_time_t from, absolute_time_t to)
Return the difference in microseconds between two timestamps.
Definition: time.h:156
void alarm_pool_init_default(void)
Create the default alarm pool (if not already created or disabled)
Definition: time.c:78
void sleep_us(uint64_t us)
Wait for the given number of microseconds before returning.
Definition: time.c:411
void sleep_ms(uint32_t ms)
Wait for the given number of milliseconds before returning.
Definition: time.c:428
static absolute_time_t make_timeout_time_us(uint64_t us)
Convenience method to get the timestamp a number of microseconds from the current time...
Definition: time.h:131
static bool is_nil_time(absolute_time_t t)
Determine if the given timestamp is nil.
Definition: time.h:199
static alarm_id_t alarm_pool_add_alarm_in_us(alarm_pool_t *pool, uint64_t us, alarm_callback_t callback, void *user_data, bool fire_if_past)
Add an alarm callback to be called after a delay specified in microsecondsGenerally the callback is c...
Definition: time.h:521