2016-07-25 09:04:22 +02:00
|
|
|
#ifndef _INTERNALS_TIMER_H
|
2017-03-01 11:07:28 +01:00
|
|
|
#define _INTERNALS_TIMER_H
|
|
|
|
|
|
|
|
#include <timer.h>
|
|
|
|
#include <stdint.h>
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
/*
|
2017-03-01 11:07:28 +01:00
|
|
|
timer_t
|
|
|
|
A virtual or hardware timer. We need to declare the struct timer_t name
|
|
|
|
so that we can forward-reference it.
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
typedef struct timer_t
|
2016-07-06 11:28:51 +02:00
|
|
|
{
|
2017-03-01 11:07:28 +01:00
|
|
|
// 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.
|
2017-02-25 23:19:35 +01:00
|
|
|
void *callback;
|
2017-03-01 11:07:28 +01:00
|
|
|
void *argument;
|
|
|
|
|
|
|
|
} timer_t;
|
2016-07-06 11:28:51 +02:00
|
|
|
|
2017-03-01 11:07:28 +01:00
|
|
|
// Hardware timers.
|
|
|
|
extern timer_t htimers[3];
|
|
|
|
// Virtual timers.
|
|
|
|
extern timer_t vtimers[TIMER_SLOTS];
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
/*
|
2017-03-01 11:07:28 +01:00
|
|
|
timer_interrupt()
|
|
|
|
Handles the interrupt for the given timer channel.
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
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);
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
/*
|
2017-03-01 11:07:28 +01:00
|
|
|
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.
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2017-03-01 11:07:28 +01:00
|
|
|
void vtimer_updateAll(void);
|
2016-07-06 11:28:51 +02:00
|
|
|
|
2016-07-25 09:04:22 +02:00
|
|
|
#endif // _INTERNALS_TIMER_H
|