2016-07-06 11:28:51 +02:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// gint core module: timer
|
|
|
|
//
|
|
|
|
// Basic timer unit manipulation. Starts and stops timers with variable
|
|
|
|
// number of repeats, and allows timer reloads without pause.
|
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
#ifndef _TIMER_H
|
|
|
|
#define _TIMER_H 1
|
|
|
|
|
2016-09-04 11:35:41 +02:00
|
|
|
#include <clock.h>
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
|
|
|
// Constants.
|
|
|
|
//---
|
|
|
|
|
|
|
|
// Timer identifiers.
|
|
|
|
#define TIMER_0 0
|
|
|
|
#define TIMER_TMU0 TIMER_0
|
|
|
|
#define TIMER_1 1
|
|
|
|
#define TIMER_TMU1 TIMER_1
|
|
|
|
#define TIMER_2 2
|
|
|
|
#define TIMER_TMU2 TIMER_2
|
|
|
|
// Timer function identifiers.
|
2016-05-05 18:19:10 +02:00
|
|
|
#define TIMER_KEYBOARD TIMER_TMU0
|
|
|
|
#define TIMER_GRAY TIMER_TMU1
|
|
|
|
#define TIMER_USER TIMER_TMU2
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
// Timer prescalers.
|
|
|
|
#define TIMER_Po_4 0
|
|
|
|
#define TIMER_Po_16 1
|
|
|
|
#define TIMER_Po_64 2
|
|
|
|
#define TIMER_Po_256 3
|
|
|
|
#define TIMER_TCLK 5
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Public API.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
2016-05-05 18:19:10 +02:00
|
|
|
timer_start()
|
2016-07-06 11:28:51 +02:00
|
|
|
Configures and starts a timer. The timer argument expects a timer name.
|
|
|
|
You can use TIMER_USER anytime. You may also use TIMER_GRAY if you're
|
|
|
|
not running the gray engine.
|
2016-12-22 19:47:05 +01:00
|
|
|
Unit names are defined in the clock.h header and must be one of the
|
|
|
|
following:
|
2017-02-25 23:19:35 +01:00
|
|
|
- Clock_us (microseconds)
|
|
|
|
- Clock_ms (milliseconds)
|
|
|
|
- Clock_s (seconds)
|
|
|
|
- Clock_Hz (hertz)
|
|
|
|
- Clock_kHz (kilohertz)
|
|
|
|
- Clock_MHz (megahertz)
|
2016-12-22 19:47:05 +01:00
|
|
|
The number of repeats may to set to 0. In this case, the timer will not
|
|
|
|
stop until timer_stop() is explicitly called.
|
2017-02-25 23:19:35 +01:00
|
|
|
The callback is expected to be a function of the following type:
|
|
|
|
- void callback(void) if data == NULL
|
|
|
|
- void callback(void *data) if data is non-NULL
|
|
|
|
In the latter case, the data pointer will be passed as argument to the
|
|
|
|
callback function.
|
2016-12-22 19:47:05 +01:00
|
|
|
*/
|
|
|
|
void timer_start(int timer, int delay_or_frequency, enum ClockUnit unit,
|
2017-02-25 23:19:35 +01:00
|
|
|
void *callback, void *data, int repeats);
|
2016-12-22 19:47:05 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
timer_start2()
|
|
|
|
Basically the same as timer_start(), but uses a clock-count delay and a
|
|
|
|
prescaler. The possible values for the prescaler are dividers of the
|
|
|
|
peripheral clock frequency Po:
|
2016-07-06 11:28:51 +02:00
|
|
|
- TIMER_Po_4
|
|
|
|
- TIMER_Po_16
|
|
|
|
- TIMER_Po_64
|
|
|
|
- TIMER_Po_256
|
|
|
|
- TIMER_TCLK
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
2017-02-25 23:19:35 +01:00
|
|
|
void timer_start2(int timer, int delay, int prescaler, void *callback,
|
|
|
|
void *data, int repeats);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
timer_stop()
|
|
|
|
Stops the given timer. This function may be called even if the timer is
|
|
|
|
not running.
|
|
|
|
*/
|
|
|
|
void timer_stop(int timer);
|
|
|
|
|
2016-05-20 22:04:15 +02:00
|
|
|
/*
|
|
|
|
timer_reload()
|
2016-12-22 19:47:05 +01:00
|
|
|
Reloads the given timer with the supplied constant. Starts the timer if
|
|
|
|
it was stopped.
|
|
|
|
*/
|
|
|
|
void timer_reload(int timer, int new_delay_or_frequency, enum ClockUnit unit);
|
|
|
|
|
|
|
|
/*
|
|
|
|
timer_reload2()
|
|
|
|
Same as timer_reload(), but again uses the native clock count. The
|
|
|
|
prescaler may not be changed.
|
2016-05-20 22:04:15 +02:00
|
|
|
*/
|
2016-12-22 19:47:05 +01:00
|
|
|
void timer_reload2(int timer, int new_delay);
|
2016-05-20 22:04:15 +02:00
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Internal API.
|
|
|
|
// Referenced for documentation purposes only. Do not call.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
timer_interrupt()
|
|
|
|
Handles the interrupt for the given timer.
|
|
|
|
*/
|
2017-02-25 19:02:07 +01:00
|
|
|
void timer_interrupt(int timer);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
#endif // _TIMER_H
|