#ifndef _INTERNALS_TIMER_H #define _INTERNALS_TIMER_H #include #include /* timer_t A virtual or hardware timer. We need to declare the struct timer_t name so that we can forward-reference it. */ typedef struct timer_t { // Current delay, how much time elapsed since last interrupt occurred, // and how many repeats are left. int ms_delay; int ms_elapsed; int repeats_left; // Is the virtual slot free? Is the virtual timer active? uint8_t used :1; uint8_t active :1; // Is this a virtual timer? Is this the virtual timer support? uint8_t virtual :1; uint8_t vsupport :1; // How many events do I have received but not executed? uint8_t events :4; // Callback function (NULL for event-firing timers) and its argument. void *callback; void *argument; } timer_t; // Hardware timers. extern timer_t htimers[3]; // Virtual timers. extern timer_t vtimers[TIMER_SLOTS]; /* timer_interrupt() Handles the interrupt for the given timer channel. */ void timer_interrupt(int channel); /* timer_callback_event() Executes the callback of a timer, or pushes a new timer event depending on the timer configuration. Also reduces the amount of repeats left and clears the active flag (or stops the hardware timer) if this number falls from one to zero. */ void timer_callback_event(timer_t *timer); /* vtimer_interrupt() Interrupt handling subsystem for the virtual timers. */ void vtimer_interrupt(void); /* vtimer_updateOne() Update the virtual timer hardware support timer, knowing that a virtual timer with the given delay has been started. */ void vtimer_updateOne(int additional_delay_ms); /* vtimer_updateAll() Updates the virtual timer hardware support after computing the GCD of all virtual timers delays. This is rather long so avoid calling this when possible. */ void vtimer_updateAll(void); #endif // _INTERNALS_TIMER_H