2020-09-16 08:28:03 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2020 Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
* 2020 Freie Universität Berlin
|
|
|
|
* 2020 Inria
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @ingroup sys_ztimer
|
|
|
|
* @brief Periodic ztimer API
|
|
|
|
*
|
|
|
|
* Once started, the periodic timer will call the configured callback function
|
|
|
|
* once each interval until the timer is either stopped using
|
|
|
|
* ztimer_periodic_stop or the callback function returns a non-zero value.
|
|
|
|
*
|
|
|
|
* Should the timer underflow ((time_at_interrupt + interval) % 2**32 >
|
|
|
|
* interval), the next timer will be scheduled with an offset of zero, thus
|
|
|
|
* fire right away. This leads to a callback for each missed tick, until the
|
|
|
|
* original period can be honoured again.
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
*
|
|
|
|
* ```
|
|
|
|
* #include "ztimer/periodic.h"
|
|
|
|
*
|
2023-09-29 15:38:08 +02:00
|
|
|
* static bool callback(void *arg)
|
2020-09-16 08:28:03 +02:00
|
|
|
* {
|
|
|
|
* puts(arg);
|
2023-09-29 15:38:08 +02:00
|
|
|
*
|
|
|
|
* // keep the timer running
|
|
|
|
* return true;
|
2020-09-16 08:28:03 +02:00
|
|
|
* }
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* int main(void)
|
|
|
|
* {
|
|
|
|
* // allocate timer in .bss with static, so that timer can keep
|
|
|
|
* // running when leaving function scope
|
|
|
|
* static ztimer_periodic_t timer;
|
|
|
|
* // initialize timer
|
|
|
|
* ztimer_periodic_init(ZTIMER_SEC, &timer, callback, "test", 1);
|
|
|
|
*
|
|
|
|
* // start timer
|
|
|
|
* ztimer_periodic_start(&timer);
|
|
|
|
* // timer will tick every 1 second
|
|
|
|
*
|
|
|
|
* // call again to reset timer (will abort current period and trigger next
|
|
|
|
* // after full interval)
|
|
|
|
* ztimer_periodic_start(&timer);
|
|
|
|
*
|
|
|
|
* // stop timer (will not trigger anymore)
|
|
|
|
* ztimer_periodic_stop(&timer);
|
|
|
|
*
|
|
|
|
* // NOTE: if using a stack allocated timer, *it must be stopped before
|
|
|
|
* // going out of scope*!
|
|
|
|
* }
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief ztimer periodic API
|
|
|
|
*
|
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ZTIMER_PERIODIC_H
|
|
|
|
#define ZTIMER_PERIODIC_H
|
|
|
|
|
2021-12-07 17:14:51 +01:00
|
|
|
#include <stdbool.h>
|
2020-09-16 08:28:03 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#include "ztimer.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Periodic timer stop unless it returns this value
|
|
|
|
*/
|
2021-12-07 17:14:51 +01:00
|
|
|
#define ZTIMER_PERIODIC_KEEP_GOING true
|
2020-09-16 08:28:03 +02:00
|
|
|
|
2022-03-07 09:02:20 +01:00
|
|
|
/**
|
|
|
|
* @brief Type of callbacks in @ref ztimer_periodic_t "periodic timers"
|
|
|
|
*/
|
|
|
|
typedef bool (*ztimer_periodic_callback_t)(void *);
|
|
|
|
|
2020-09-16 08:28:03 +02:00
|
|
|
/**
|
|
|
|
* @brief ztimer periodic structure
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2023-03-15 15:13:48 +01:00
|
|
|
ztimer_t timer; /**< timer object used for this timer */
|
|
|
|
ztimer_clock_t *clock; /**< clock for this timer */
|
|
|
|
uint32_t interval; /**< interval of this timer */
|
|
|
|
ztimer_now_t last; /**< last trigger time */
|
|
|
|
ztimer_periodic_callback_t callback; /**< called on each trigger */
|
|
|
|
void *arg; /**< argument for callback */
|
2020-09-16 08:28:03 +02:00
|
|
|
} ztimer_periodic_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize a periodic timer structure
|
|
|
|
*
|
|
|
|
* This sets up the underlying structure of a periodic timer.
|
|
|
|
* After initializing, use @ref ztimer_periodic_start() to start the timer.
|
|
|
|
*
|
|
|
|
* @param[in] clock the clock to configure this timer on
|
|
|
|
* @param[inout] timer periodic timer object to initialize
|
|
|
|
* @param[in] callback function to call on each trigger
|
2021-12-07 17:14:51 +01:00
|
|
|
* returns `true` if the timer should keep going
|
2020-09-16 08:28:03 +02:00
|
|
|
* @param[in] arg argument to pass to callback function
|
|
|
|
* @param[in] interval period length of this timer instance
|
|
|
|
*/
|
|
|
|
void ztimer_periodic_init(ztimer_clock_t *clock, ztimer_periodic_t *timer,
|
2021-12-07 17:14:51 +01:00
|
|
|
bool (*callback)(void *),
|
2020-09-16 08:28:03 +02:00
|
|
|
void *arg, uint32_t interval);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Start or restart a periodic timer
|
|
|
|
*
|
|
|
|
* When called on a newly initialized timer, the timer will start.
|
|
|
|
*
|
|
|
|
* When called on an already running timer, the current interval is reset to its
|
|
|
|
* start (thus the next callback will be called after the configured interval
|
|
|
|
* has passed).
|
|
|
|
*
|
|
|
|
* @param[in] timer periodic timer object to work on
|
|
|
|
*/
|
|
|
|
void ztimer_periodic_start(ztimer_periodic_t *timer);
|
|
|
|
|
2024-10-14 21:15:50 +02:00
|
|
|
/**
|
|
|
|
* @brief Start or restart a periodic timer without initial timer delay
|
|
|
|
*
|
|
|
|
* When called on a newly initialized timer, the timer will start.
|
|
|
|
*
|
|
|
|
* When called on an already running timer, the current interval is reset to its
|
|
|
|
* start (thus the next callback will be called after the configured interval
|
|
|
|
* has passed).
|
|
|
|
*
|
|
|
|
* @param[in] timer periodic timer object to work on
|
|
|
|
*/
|
|
|
|
void ztimer_periodic_start_now(ztimer_periodic_t *timer);
|
|
|
|
|
2020-09-16 08:28:03 +02:00
|
|
|
/**
|
|
|
|
* @brief Stop a periodic timer
|
|
|
|
*
|
|
|
|
* The periodic timer will not trigger anymore.
|
|
|
|
*
|
|
|
|
* @param[in] timer periodic timer object to stop
|
|
|
|
*/
|
|
|
|
void ztimer_periodic_stop(ztimer_periodic_t *timer);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* ZTIMER_PERIODIC_H */
|
|
|
|
/** @} */
|