1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

Merge pull request #17231 from kfessel/p-ztimer-static-head-update

sys/ztimer: make internal head update static
This commit is contained in:
Kaspar Schleiser 2021-11-18 21:36:08 +01:00 committed by GitHub
commit 16c9236a65
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 7 additions and 15 deletions

View File

@ -559,15 +559,6 @@ int ztimer_mutex_lock_timeout(ztimer_clock_t *clock, mutex_t *mutex,
int ztimer_rmutex_lock_timeout(ztimer_clock_t *clock, rmutex_t *rmutex, int ztimer_rmutex_lock_timeout(ztimer_clock_t *clock, rmutex_t *rmutex,
uint32_t timeout); uint32_t timeout);
/**
* @brief Update ztimer clock head list offset
*
* @internal
*
* @param[in] clock ztimer clock to work on
*/
void ztimer_update_head_offset(ztimer_clock_t *clock);
/** /**
* @brief Initialize the board-specific default ztimer configuration * @brief Initialize the board-specific default ztimer configuration
*/ */

View File

@ -40,6 +40,7 @@ static void _add_entry_to_list(ztimer_clock_t *clock, ztimer_base_t *entry);
static void _del_entry_from_list(ztimer_clock_t *clock, ztimer_base_t *entry); static void _del_entry_from_list(ztimer_clock_t *clock, ztimer_base_t *entry);
static void _ztimer_update(ztimer_clock_t *clock); static void _ztimer_update(ztimer_clock_t *clock);
static void _ztimer_print(const ztimer_clock_t *clock); static void _ztimer_print(const ztimer_clock_t *clock);
static void _ztimer_update_head_offset(ztimer_clock_t *clock);
#ifdef MODULE_ZTIMER_EXTEND #ifdef MODULE_ZTIMER_EXTEND
static inline uint32_t _min_u32(uint32_t a, uint32_t b) static inline uint32_t _min_u32(uint32_t a, uint32_t b)
@ -72,7 +73,7 @@ void ztimer_remove(ztimer_clock_t *clock, ztimer_t *timer)
unsigned state = irq_disable(); unsigned state = irq_disable();
if (_is_set(clock, timer)) { if (_is_set(clock, timer)) {
ztimer_update_head_offset(clock); _ztimer_update_head_offset(clock);
_del_entry_from_list(clock, &timer->base); _del_entry_from_list(clock, &timer->base);
_ztimer_update(clock); _ztimer_update(clock);
@ -88,7 +89,7 @@ void ztimer_set(ztimer_clock_t *clock, ztimer_t *timer, uint32_t val)
unsigned state = irq_disable(); unsigned state = irq_disable();
ztimer_update_head_offset(clock); _ztimer_update_head_offset(clock);
if (_is_set(clock, timer)) { if (_is_set(clock, timer)) {
_del_entry_from_list(clock, &timer->base); _del_entry_from_list(clock, &timer->base);
} }
@ -186,7 +187,7 @@ ztimer_now_t _ztimer_now_extend(ztimer_clock_t *clock)
} }
#endif /* MODULE_ZTIMER_EXTEND */ #endif /* MODULE_ZTIMER_EXTEND */
void ztimer_update_head_offset(ztimer_clock_t *clock) static void _ztimer_update_head_offset(ztimer_clock_t *clock)
{ {
uint32_t old_base = clock->list.offset; uint32_t old_base = clock->list.offset;
uint32_t now = ztimer_now(clock); uint32_t now = ztimer_now(clock);
@ -195,7 +196,7 @@ void ztimer_update_head_offset(ztimer_clock_t *clock)
ztimer_base_t *entry = clock->list.next; ztimer_base_t *entry = clock->list.next;
DEBUG( DEBUG(
"clock %p: ztimer_update_head_offset(): diff=%" PRIu32 " old head %p\n", "clock %p: _ztimer_update_head_offset(): diff=%" PRIu32 " old head %p\n",
(void *)clock, diff, (void *)entry); (void *)clock, diff, (void *)entry);
if (entry) { if (entry) {
do { do {
@ -215,7 +216,7 @@ void ztimer_update_head_offset(ztimer_clock_t *clock)
} }
} while (diff && entry); } while (diff && entry);
DEBUG( DEBUG(
"ztimer %p: ztimer_update_head_offset(): now=%" PRIu32 " new head %p", "ztimer %p: _ztimer_update_head_offset(): now=%" PRIu32 " new head %p",
(void *)clock, now, (void *)entry); (void *)clock, now, (void *)entry);
if (entry) { if (entry) {
DEBUG(" offset %" PRIu32 "\n", entry->offset); DEBUG(" offset %" PRIu32 "\n", entry->offset);
@ -374,7 +375,7 @@ void ztimer_handler(ztimer_clock_t *clock)
if (!entry) { if (!entry) {
/* See if any more alarms expired during callback processing */ /* See if any more alarms expired during callback processing */
/* This reduces the number of implicit calls to clock->ops->now() */ /* This reduces the number of implicit calls to clock->ops->now() */
ztimer_update_head_offset(clock); _ztimer_update_head_offset(clock);
entry = _now_next(clock); entry = _now_next(clock);
} }
} }