/** \addtogroup system * @{ */ /** * \defgroup swtimer Software Timer library * * The swtimer library provides functions for setting, resetting and restarting * software timers, and for checking if a swtimer has expired. * * @{ */ /** * \file * Timer library header file. */ #ifndef __SWTIMER_H__ #define __SWTIMER_H__ #include #define MSG_TIMER 12345 #define SWTIMER_WAKEUP 0 #define SWTIMER_CALLBACK 1 #define SWTIMER_MSG 2 #undef wakeup #if WORDSIZE == 32 typedef uint64_t swtime_t; #else typedef uint32_t swtime_t; #endif /** * A swtimer. * * This structure is used for declaring a swtimer. The swtimer must be set * with swtimer_set() before it can be used. * * \hideinitializer */ typedef struct swtimer_t { swtime_t start; swtime_t interval; struct swtimer_t *next; int action_type; union { struct { int pid; } wakeup; struct { void (*f)(void*); void *ptr; } callback; struct { unsigned int value; int target_pid; } msg; } action; } swtimer_t; swtime_t swtimer_now(); int swtimer_init(); /** * @brief set swtimer interval and activate * @param[in] t pointer to preinitialised swtimer_t * @param[in] interval swtimer interval */ int swtimer_set(swtimer_t *t, swtime_t interval); /** * @brief reset swtimer * @param[in] t pointer to preinitialised swtimer_t */ void swtimer_reset(swtimer_t *t); /** * @brief restart swtimer * @param[in] t pointer to preinitialised swtimer_t */ void swtimer_restart(swtimer_t *t); /** * @brief check if swtimer is expired * @param[in] t pointer to preinitialised swtimer_t * @return */ int swtimer_expired(swtimer_t *t); /** * @brief will cause the calling thread to be suspended from excecution until the number of microseconds has elapsed * @param[in] us number of microseconds * @return 0 on success, < 0 on error */ int swtimer_usleep(swtime_t us); /** * @brief set a swtimer with msg event handler * @param[in] t pointer to preinitialised swtimer_t * @param[in] interval swtimer interval * @param[in] pid process id * @param[in] ptr message value * @return 0 on success, < 0 on error */ int swtimer_set_msg(swtimer_t *t, swtime_t interval, int pid, void *ptr); /** * @brief set a swtimer with wakeup event * @param[in] t pointer to preinitialised swtimer_t * @param[in] pid process id * @return 0 on success, < 0 on error */ int swtimer_set_wakeup(swtimer_t *t, swtime_t interval, int pid); /** * @brief set a swtimer with callback function event handler * @param[in] t pointer to preinitialised swtimer_t * @param[in] interval swtimer interval * @param[in] f_ptr pointer to callback function * @return 0 on success, < 0 on error */ int swtimer_set_cb(swtimer_t *t, swtime_t interval, void (*f_ptr)(void *), void *ptr); /** * @brief remove a swtimer * @param[in] t pointer to preinitialised swtimer_t * @return 0 on success, < 0 on error */ int swtimer_remove(swtimer_t *t); #endif /* __SWTIMER_H__ */ /** @} */ /** @} */