Zephyr Project API  3.3.0
A Scalable Open Source RTOS
counter.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018 Nordic Semiconductor ASA
3 * Copyright (c) 2016 Intel Corporation
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
13#ifndef ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_
14#define ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_
15
23#include <errno.h>
24
25#include <zephyr/types.h>
26#include <stddef.h>
27#include <zephyr/device.h>
28#include <zephyr/sys_clock.h>
29#include <stdbool.h>
30
31#ifdef __cplusplus
32extern "C" {
33#endif
34
41#define COUNTER_CONFIG_INFO_COUNT_UP BIT(0)
42
55#define COUNTER_TOP_CFG_DONT_RESET BIT(0)
56
63#define COUNTER_TOP_CFG_RESET_WHEN_LATE BIT(1)
64
78#define COUNTER_ALARM_CFG_ABSOLUTE BIT(0)
79
86#define COUNTER_ALARM_CFG_EXPIRE_WHEN_LATE BIT(1)
87
100#define COUNTER_GUARD_PERIOD_LATE_TO_SET BIT(0)
101
111typedef void (*counter_alarm_callback_t)(const struct device *dev,
112 uint8_t chan_id, uint32_t ticks,
113 void *user_data);
114
134};
135
141typedef void (*counter_top_callback_t)(const struct device *dev,
142 void *user_data);
143
157};
158
174};
175
176typedef int (*counter_api_start)(const struct device *dev);
177typedef int (*counter_api_stop)(const struct device *dev);
178typedef int (*counter_api_get_value)(const struct device *dev,
179 uint32_t *ticks);
180typedef int (*counter_api_get_value_64)(const struct device *dev,
181 uint64_t *ticks);
182typedef int (*counter_api_set_alarm)(const struct device *dev,
183 uint8_t chan_id,
184 const struct counter_alarm_cfg *alarm_cfg);
185typedef int (*counter_api_cancel_alarm)(const struct device *dev,
186 uint8_t chan_id);
187typedef int (*counter_api_set_top_value)(const struct device *dev,
188 const struct counter_top_cfg *cfg);
189typedef uint32_t (*counter_api_get_pending_int)(const struct device *dev);
190typedef uint32_t (*counter_api_get_top_value)(const struct device *dev);
191typedef uint32_t (*counter_api_get_guard_period)(const struct device *dev,
193typedef int (*counter_api_set_guard_period)(const struct device *dev,
194 uint32_t ticks,
196typedef uint32_t (*counter_api_get_freq)(const struct device *dev);
197
198__subsystem struct counter_driver_api {
211};
212
221__syscall bool counter_is_counting_up(const struct device *dev);
222
223static inline bool z_impl_counter_is_counting_up(const struct device *dev)
224{
225 const struct counter_config_info *config =
226 (const struct counter_config_info *)dev->config;
227
228 return config->flags & COUNTER_CONFIG_INFO_COUNT_UP;
229}
230
238__syscall uint8_t counter_get_num_of_channels(const struct device *dev);
239
240static inline uint8_t z_impl_counter_get_num_of_channels(const struct device *dev)
241{
242 const struct counter_config_info *config =
243 (const struct counter_config_info *)dev->config;
244
245 return config->channels;
246}
247
256__syscall uint32_t counter_get_frequency(const struct device *dev);
257
258static inline uint32_t z_impl_counter_get_frequency(const struct device *dev)
259{
260 const struct counter_config_info *config =
261 (const struct counter_config_info *)dev->config;
262 const struct counter_driver_api *api =
263 (struct counter_driver_api *)dev->api;
264
265 return api->get_freq ? api->get_freq(dev) : config->freq;
266}
267
276__syscall uint32_t counter_us_to_ticks(const struct device *dev, uint64_t us);
277
278static inline uint32_t z_impl_counter_us_to_ticks(const struct device *dev,
279 uint64_t us)
280{
281 uint64_t ticks = (us * z_impl_counter_get_frequency(dev)) / USEC_PER_SEC;
282
283 return (ticks > (uint64_t)UINT32_MAX) ? UINT32_MAX : ticks;
284}
285
294__syscall uint64_t counter_ticks_to_us(const struct device *dev, uint32_t ticks);
295
296static inline uint64_t z_impl_counter_ticks_to_us(const struct device *dev,
297 uint32_t ticks)
298{
299 return ((uint64_t)ticks * USEC_PER_SEC) / z_impl_counter_get_frequency(dev);
300}
301
309__syscall uint32_t counter_get_max_top_value(const struct device *dev);
310
311static inline uint32_t z_impl_counter_get_max_top_value(const struct device *dev)
312{
313 const struct counter_config_info *config =
314 (const struct counter_config_info *)dev->config;
315
316 return config->max_top_value;
317}
318
327__syscall int counter_start(const struct device *dev);
328
329static inline int z_impl_counter_start(const struct device *dev)
330{
331 const struct counter_driver_api *api =
332 (struct counter_driver_api *)dev->api;
333
334 return api->start(dev);
335}
336
346__syscall int counter_stop(const struct device *dev);
347
348static inline int z_impl_counter_stop(const struct device *dev)
349{
350 const struct counter_driver_api *api =
351 (struct counter_driver_api *)dev->api;
352
353 return api->stop(dev);
354}
355
364__syscall int counter_get_value(const struct device *dev, uint32_t *ticks);
365
366static inline int z_impl_counter_get_value(const struct device *dev,
367 uint32_t *ticks)
368{
369 const struct counter_driver_api *api =
370 (struct counter_driver_api *)dev->api;
371
372 return api->get_value(dev, ticks);
373}
374
383__syscall int counter_get_value_64(const struct device *dev, uint64_t *ticks);
384
385static inline int z_impl_counter_get_value_64(const struct device *dev,
386 uint64_t *ticks)
387{
388 const struct counter_driver_api *api =
389 (struct counter_driver_api *)dev->api;
390
391 if (!api->get_value_64) {
392 return -ENOTSUP;
393 }
394
395 return api->get_value_64(dev, ticks);
396}
397
418__syscall int counter_set_channel_alarm(const struct device *dev,
419 uint8_t chan_id,
420 const struct counter_alarm_cfg *alarm_cfg);
421
422static inline int z_impl_counter_set_channel_alarm(const struct device *dev,
423 uint8_t chan_id,
424 const struct counter_alarm_cfg *alarm_cfg)
425{
426 const struct counter_driver_api *api =
427 (struct counter_driver_api *)dev->api;
428
429 if (chan_id >= counter_get_num_of_channels(dev)) {
430 return -ENOTSUP;
431 }
432
433 return api->set_alarm(dev, chan_id, alarm_cfg);
434}
435
448__syscall int counter_cancel_channel_alarm(const struct device *dev,
449 uint8_t chan_id);
450
451static inline int z_impl_counter_cancel_channel_alarm(const struct device *dev,
452 uint8_t chan_id)
453{
454 const struct counter_driver_api *api =
455 (struct counter_driver_api *)dev->api;
456
457 if (chan_id >= counter_get_num_of_channels(dev)) {
458 return -ENOTSUP;
459 }
460
461 return api->cancel_alarm(dev, chan_id);
462}
463
488__syscall int counter_set_top_value(const struct device *dev,
489 const struct counter_top_cfg *cfg);
490
491static inline int z_impl_counter_set_top_value(const struct device *dev,
492 const struct counter_top_cfg
493 *cfg)
494{
495 const struct counter_driver_api *api =
496 (struct counter_driver_api *)dev->api;
497
498 if (cfg->ticks > counter_get_max_top_value(dev)) {
499 return -EINVAL;
500 }
501
502 return api->set_top_value(dev, cfg);
503}
504
518__syscall int counter_get_pending_int(const struct device *dev);
519
520static inline int z_impl_counter_get_pending_int(const struct device *dev)
521{
522 const struct counter_driver_api *api =
523 (struct counter_driver_api *)dev->api;
524
525 return api->get_pending_int(dev);
526}
527
535__syscall uint32_t counter_get_top_value(const struct device *dev);
536
537static inline uint32_t z_impl_counter_get_top_value(const struct device *dev)
538{
539 const struct counter_driver_api *api =
540 (struct counter_driver_api *)dev->api;
541
542 return api->get_top_value(dev);
543}
544
573__syscall int counter_set_guard_period(const struct device *dev,
574 uint32_t ticks,
576
577static inline int z_impl_counter_set_guard_period(const struct device *dev,
578 uint32_t ticks, uint32_t flags)
579{
580 const struct counter_driver_api *api =
581 (struct counter_driver_api *)dev->api;
582
583 if (!api->set_guard_period) {
584 return -ENOTSUP;
585 }
586
587 return api->set_guard_period(dev, ticks, flags);
588}
589
601__syscall uint32_t counter_get_guard_period(const struct device *dev,
603
604static inline uint32_t z_impl_counter_get_guard_period(const struct device *dev,
606{
607 const struct counter_driver_api *api =
608 (struct counter_driver_api *)dev->api;
609
610 return (api->get_guard_period) ? api->get_guard_period(dev, flags) : 0;
611}
612
613#ifdef __cplusplus
614}
615#endif
616
621#include <syscalls/counter.h>
622
623#endif /* ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_ */
System error numbers.
#define COUNTER_CONFIG_INFO_COUNT_UP
Counter count up flag.
Definition: counter.h:41
int counter_set_channel_alarm(const struct device *dev, uint8_t chan_id, const struct counter_alarm_cfg *alarm_cfg)
Set a single shot alarm on a channel.
uint32_t(* counter_api_get_top_value)(const struct device *dev)
Definition: counter.h:190
uint8_t counter_get_num_of_channels(const struct device *dev)
Function to get number of alarm channels.
int counter_start(const struct device *dev)
Start counter device in free running mode.
uint32_t counter_get_top_value(const struct device *dev)
Function to retrieve current top value.
int(* counter_api_stop)(const struct device *dev)
Definition: counter.h:177
int counter_set_top_value(const struct device *dev, const struct counter_top_cfg *cfg)
Set counter top value.
int counter_get_value_64(const struct device *dev, uint64_t *ticks)
Get current counter 64-bit value.
void(* counter_top_callback_t)(const struct device *dev, void *user_data)
Callback called when counter turns around.
Definition: counter.h:141
void(* counter_alarm_callback_t)(const struct device *dev, uint8_t chan_id, uint32_t ticks, void *user_data)
Alarm callback.
Definition: counter.h:111
int counter_get_pending_int(const struct device *dev)
Function to get pending interrupts.
uint32_t counter_get_guard_period(const struct device *dev, uint32_t flags)
Return guard period.
int(* counter_api_set_guard_period)(const struct device *dev, uint32_t ticks, uint32_t flags)
Definition: counter.h:193
uint32_t counter_get_frequency(const struct device *dev)
Function to get counter frequency.
int counter_get_value(const struct device *dev, uint32_t *ticks)
Get current counter value.
uint32_t(* counter_api_get_guard_period)(const struct device *dev, uint32_t flags)
Definition: counter.h:191
uint32_t(* counter_api_get_pending_int)(const struct device *dev)
Definition: counter.h:189
uint32_t(* counter_api_get_freq)(const struct device *dev)
Definition: counter.h:196
uint64_t counter_ticks_to_us(const struct device *dev, uint32_t ticks)
Function to convert ticks to microseconds.
int(* counter_api_set_top_value)(const struct device *dev, const struct counter_top_cfg *cfg)
Definition: counter.h:187
int(* counter_api_start)(const struct device *dev)
Definition: counter.h:176
int counter_set_guard_period(const struct device *dev, uint32_t ticks, uint32_t flags)
Set guard period in counter ticks.
uint32_t counter_us_to_ticks(const struct device *dev, uint64_t us)
Function to convert microseconds to ticks.
bool counter_is_counting_up(const struct device *dev)
Function to check if counter is counting up.
int(* counter_api_cancel_alarm)(const struct device *dev, uint8_t chan_id)
Definition: counter.h:185
int(* counter_api_get_value_64)(const struct device *dev, uint64_t *ticks)
Definition: counter.h:180
int(* counter_api_get_value)(const struct device *dev, uint32_t *ticks)
Definition: counter.h:178
int counter_cancel_channel_alarm(const struct device *dev, uint8_t chan_id)
Cancel an alarm on a channel.
int(* counter_api_set_alarm)(const struct device *dev, uint8_t chan_id, const struct counter_alarm_cfg *alarm_cfg)
Definition: counter.h:182
int counter_stop(const struct device *dev)
Stop counter device.
uint32_t counter_get_max_top_value(const struct device *dev)
Function to retrieve maximum top value that can be set.
#define EINVAL
Definition: errno.h:61
#define ENOTSUP
Definition: errno.h:115
Variables needed for system clock.
#define USEC_PER_SEC
Definition: sys_clock.h:136
flags
Definition: parser.h:96
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT64_TYPE__ uint64_t
Definition: stdint.h:91
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
#define UINT32_MAX
Definition: stdint.h:29
Alarm callback structure.
Definition: counter.h:129
uint32_t ticks
Definition: counter.h:131
uint32_t flags
Definition: counter.h:133
void * user_data
Definition: counter.h:132
counter_alarm_callback_t callback
Definition: counter.h:130
Structure with generic counter features.
Definition: counter.h:169
uint32_t max_top_value
Definition: counter.h:170
uint32_t freq
Definition: counter.h:171
uint8_t flags
Definition: counter.h:172
uint8_t channels
Definition: counter.h:173
Definition: counter.h:198
counter_api_get_value_64 get_value_64
Definition: counter.h:202
counter_api_get_top_value get_top_value
Definition: counter.h:207
counter_api_set_top_value set_top_value
Definition: counter.h:205
counter_api_set_alarm set_alarm
Definition: counter.h:203
counter_api_get_value get_value
Definition: counter.h:201
counter_api_get_pending_int get_pending_int
Definition: counter.h:206
counter_api_stop stop
Definition: counter.h:200
counter_api_set_guard_period set_guard_period
Definition: counter.h:209
counter_api_start start
Definition: counter.h:199
counter_api_get_guard_period get_guard_period
Definition: counter.h:208
counter_api_cancel_alarm cancel_alarm
Definition: counter.h:204
counter_api_get_freq get_freq
Definition: counter.h:210
Top value configuration structure.
Definition: counter.h:152
uint32_t ticks
Definition: counter.h:153
uint32_t flags
Definition: counter.h:156
counter_top_callback_t callback
Definition: counter.h:154
void * user_data
Definition: counter.h:155
Runtime device structure (in ROM) per driver instance.
Definition: device.h:378
const void * api
Definition: device.h:384
const void * config
Definition: device.h:382
static const intptr_t user_data[5]
Definition: main.c:588