Rev | Line | |
---|
[9] | 1 | #include "timers.h"
|
---|
| 2 |
|
---|
| 3 | /*===========================================================================*
|
---|
| 4 | * tmrs_settimer *
|
---|
| 5 | *===========================================================================*/
|
---|
| 6 | clock_t tmrs_settimer(tmrs, tp, exp_time, watchdog, new_head)
|
---|
| 7 | timer_t **tmrs; /* pointer to timers queue */
|
---|
| 8 | timer_t *tp; /* the timer to be added */
|
---|
| 9 | clock_t exp_time; /* its expiration time */
|
---|
| 10 | tmr_func_t watchdog; /* watchdog function to be run */
|
---|
| 11 | clock_t *new_head; /* new earliest timer, if non NULL */
|
---|
| 12 | {
|
---|
| 13 | /* Activate a timer to run function 'fp' at time 'exp_time'. If the timer is
|
---|
| 14 | * already in use it is first removed from the timers queue. Then, it is put
|
---|
| 15 | * in the list of active timers with the first to expire in front.
|
---|
| 16 | * The caller responsible for scheduling a new alarm for the timer if needed.
|
---|
| 17 | */
|
---|
| 18 | timer_t **atp;
|
---|
| 19 | clock_t old_head = 0;
|
---|
| 20 |
|
---|
| 21 | if(*tmrs)
|
---|
| 22 | old_head = (*tmrs)->tmr_exp_time;
|
---|
| 23 |
|
---|
| 24 | /* Set the timer's variables. */
|
---|
| 25 | (void) tmrs_clrtimer(tmrs, tp, NULL);
|
---|
| 26 | tp->tmr_exp_time = exp_time;
|
---|
| 27 | tp->tmr_func = watchdog;
|
---|
| 28 |
|
---|
| 29 | /* Add the timer to the active timers. The next timer due is in front. */
|
---|
| 30 | for (atp = tmrs; *atp != NULL; atp = &(*atp)->tmr_next) {
|
---|
| 31 | if (exp_time < (*atp)->tmr_exp_time) break;
|
---|
| 32 | }
|
---|
| 33 | tp->tmr_next = *atp;
|
---|
| 34 | *atp = tp;
|
---|
| 35 | if(new_head)
|
---|
| 36 | (*new_head) = (*tmrs)->tmr_exp_time;
|
---|
| 37 | return old_head;
|
---|
| 38 | }
|
---|
| 39 |
|
---|
Note:
See
TracBrowser
for help on using the repository browser.