diff --git a/sys/ztimer/periodic.c b/sys/ztimer/periodic.c index ddd82b8d77..70cba0ece2 100644 --- a/sys/ztimer/periodic.c +++ b/sys/ztimer/periodic.c @@ -54,32 +54,28 @@ static void _ztimer_periodic_callback(void *arg) } void ztimer_periodic_init(ztimer_clock_t *clock, ztimer_periodic_t *timer, - bool (*callback)( - void *), void *arg, uint32_t interval) + bool (*callback)(void *), void *arg, uint32_t interval) { - ztimer_remove(clock, &timer->timer); - *timer = - (ztimer_periodic_t){ .clock = clock, .interval = interval, - .callback = callback, .arg = arg, - .timer = { - .callback = _ztimer_periodic_callback, - .arg = timer - } }; + /* check if this is a reinit, ensure timer is stopped in case */ + if (timer->timer.callback == _ztimer_periodic_callback) { + ztimer_periodic_stop(timer); + } + *timer = (ztimer_periodic_t){ + .clock = clock, .interval = interval, + .callback = callback, .arg = arg, + .timer = { + .callback = _ztimer_periodic_callback, + .arg = timer + } + }; } void ztimer_periodic_start(ztimer_periodic_t *timer) { - ztimer_acquire(timer->clock); - - uint32_t now = ztimer_now(timer->clock); - - timer->last = now; - _ztimer_periodic_reset(timer, now); + timer->last = ztimer_set(timer->clock, &timer->timer, timer->interval) + timer->interval; } void ztimer_periodic_stop(ztimer_periodic_t *timer) { ztimer_remove(timer->clock, &timer->timer); - - ztimer_release(timer->clock); }