Loading...
Searching...
No Matches
timer.h
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2014-2015 Freie Universität Berlin
3 * SPDX-License-Identifier: LGPL-2.1-only
4 */
5
6#pragma once
7
35
36#include <limits.h>
37#include <stdint.h>
38#include <stdbool.h>
39
40#include "architecture.h"
41#include "periph_cpu.h"
42#include "periph_conf.h"
43
44#ifdef __cplusplus
45extern "C" {
46#endif
47
53#ifndef TIMER_DEV
54# define TIMER_DEV(x) (x)
55#endif
56
60#ifndef TIMER_UNDEF
61# define TIMER_UNDEF (UINT_FAST8_MAX)
62#endif
63
70#ifndef HAVE_TIMER_T
71typedef uint_fast8_t tim_t;
72#endif
73
80#ifndef TIM_FLAG_RESET_ON_SET
81# define TIM_FLAG_RESET_ON_SET (0x01)
82#endif
83
91#ifndef TIM_FLAG_RESET_ON_MATCH
92# define TIM_FLAG_RESET_ON_MATCH (0x02)
93#endif
94
101#ifndef TIM_FLAG_SET_STOPPED
102# define TIM_FLAG_SET_STOPPED (0x04)
103#endif
104
111typedef void (*timer_cb_t)(void *arg, int channel);
112
116#ifndef HAVE_TIMER_ISR_CTX_T
117typedef struct {
119 void *arg;
121#endif
122
144int timer_init(tim_t dev, uint32_t freq, timer_cb_t cb, void *arg);
145
160int timer_set(tim_t dev, int channel, unsigned int timeout);
161
176int timer_set_absolute(tim_t dev, int channel, unsigned int value);
177
197int timer_set_periodic(tim_t dev, int channel, unsigned int value, uint8_t flags);
198
208int timer_clear(tim_t dev, int channel);
209
217unsigned int timer_read(tim_t dev);
218
227
239
256__attribute__((pure))
258
273__attribute__((pure))
275
305uint32_t timer_query_freqs(tim_t dev, uword_t index);
306
323uint32_t timer_get_closest_freq(tim_t dev, uint32_t target);
324
325#if defined(DOXYGEN)
344/* As this function is polled, it needs to be inlined, so it is typically
345 * provided through `timer_arch.h`. If a platform ever does not need to go
346 * through static inline here, this declaration's condition can be extended to
347 * be `(defined(MODULE_PERIPH_TIMER_POLL) &&
348 * !defined(PERIPH_TIMER_PROVIDES_INLINE_POLL_CHANNEL) || defined(DOXYGEN)` or
349 * similar. */
350bool timer_poll_channel(tim_t dev, int channel);
351#endif
352
353#if defined(MODULE_PERIPH_TIMER_POLL)
354# include "timer_arch.h" /* IWYU pragma: export */
355#endif
356
357#ifdef __cplusplus
358}
359#endif
360
Platform-independent access to architecture details.
uword_t timer_query_freqs_numof(tim_t dev)
Get the number of different frequencies supported by the given timer.
unsigned int timer_read(tim_t dev)
Read the current value of the given timer device.
bool timer_poll_channel(tim_t dev, int channel)
Check whether a compare channel has matched.
void(* timer_cb_t)(void *arg, int channel)
Signature of event callback functions triggered from interrupts.
Definition timer.h:111
int timer_set_absolute(tim_t dev, int channel, unsigned int value)
Set an absolute timeout value for the given channel of the given timer.
uint32_t timer_get_closest_freq(tim_t dev, uint32_t target)
Search the frequency supported by the timer that is closest to a given target frequency,...
int timer_clear(tim_t dev, int channel)
Clear the given channel of the given timer device.
uint_fast8_t tim_t
Default timer type.
Definition timer.h:71
int timer_init(tim_t dev, uint32_t freq, timer_cb_t cb, void *arg)
Initialize the given timer.
uint32_t timer_query_freqs(tim_t dev, uword_t index)
Iterate over supported frequencies.
int timer_set_periodic(tim_t dev, int channel, unsigned int value, uint8_t flags)
Set an absolute timeout value for the given channel of the given timer.
void timer_stop(tim_t dev)
Stop the given timer.
uword_t timer_query_channel_numof(tim_t dev)
Get the number of timer channels for the given timer.
int timer_set(tim_t dev, int channel, unsigned int timeout)
Set a given timer channel for the given timer device.
void timer_start(tim_t dev)
Start the given timer.
uint< NUM > _t uword_t
Word sized unsigned integer.
Default interrupt context entry holding callback and argument.
Definition timer.h:117
void * arg
optional argument given to that callback
Definition timer.h:119
timer_cb_t cb
callback executed from timer interrupt
Definition timer.h:118