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

drivers/timer: added callback argument

This commit is contained in:
Hauke Petersen 2016-02-17 12:18:01 +01:00
parent fde38f0158
commit 2b97513637

View File

@ -55,13 +55,21 @@ extern "C" {
typedef unsigned int tim_t; typedef unsigned int tim_t;
#endif #endif
/**
* @brief Signature of event callback functions triggered from interrupts
*
* @param[in] arg optional context for the callback
* @param[in] channel timer channel that triggered the interrupt
*/
typedef void (*timer_cb_t)(void *arg, int channel);
/** /**
* @brief Default interrupt context entry holding callback and argument * @brief Default interrupt context entry holding callback and argument
* @{ * @{
*/ */
#ifndef HAVE_TIMER_ISR_CTX_T #ifndef HAVE_TIMER_ISR_CTX_T
typedef struct { typedef struct {
void (*cb)(int); /**< callback executed from timer interrupt */ timer_cb_t cb; /**< callback executed from timer interrupt */
void *arg; /**< optional argument given to that callback */ void *arg; /**< optional argument given to that callback */
} timer_isr_ctx_t; } timer_isr_ctx_t;
#endif #endif
@ -82,11 +90,12 @@ typedef struct {
* @param[in] freq requested number of ticks per second * @param[in] freq requested number of ticks per second
* @param[in] callback this callback is called in interrupt context, the * @param[in] callback this callback is called in interrupt context, the
* emitting channel is passed as argument * emitting channel is passed as argument
* @param[in] arg argument to the callback
* *
* @return 0 on success * @return 0 on success
* @return -1 if speed not applicable or unknown device given * @return -1 if speed not applicable or unknown device given
*/ */
int timer_init(tim_t dev, unsigned long freq, void (*callback)(int)); int timer_init(tim_t dev, unsigned long freq, timer_cb_t cb, void *arg);
/** /**
* @brief Set a given timer channel for the given timer device * @brief Set a given timer channel for the given timer device