Zephyr Project API 4.2.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
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
14#ifndef ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_
15#define ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_
16
26#include <errno.h>
27
28#include <zephyr/types.h>
29#include <stddef.h>
30#include <zephyr/device.h>
31#include <zephyr/sys_clock.h>
32#include <stdbool.h>
33
34#ifdef __cplusplus
35extern "C" {
36#endif
37
47#define COUNTER_CONFIG_INFO_COUNT_UP BIT(0)
48
63#define COUNTER_TOP_CFG_DONT_RESET BIT(0)
64
71#define COUNTER_TOP_CFG_RESET_WHEN_LATE BIT(1)
72
88#define COUNTER_ALARM_CFG_ABSOLUTE BIT(0)
89
96#define COUNTER_ALARM_CFG_EXPIRE_WHEN_LATE BIT(1)
97
112#define COUNTER_GUARD_PERIOD_LATE_TO_SET BIT(0)
113
123typedef void (*counter_alarm_callback_t)(const struct device *dev,
124 uint8_t chan_id, uint32_t ticks,
125 void *user_data);
126
160
166typedef void (*counter_top_callback_t)(const struct device *dev,
167 void *user_data);
168
189
212
213typedef int (*counter_api_start)(const struct device *dev);
214typedef int (*counter_api_stop)(const struct device *dev);
215typedef int (*counter_api_get_value)(const struct device *dev,
216 uint32_t *ticks);
217typedef int (*counter_api_get_value_64)(const struct device *dev,
218 uint64_t *ticks);
219typedef int (*counter_api_reset)(const struct device *dev);
220typedef int (*counter_api_set_alarm)(const struct device *dev,
221 uint8_t chan_id,
222 const struct counter_alarm_cfg *alarm_cfg);
223typedef int (*counter_api_cancel_alarm)(const struct device *dev,
224 uint8_t chan_id);
225typedef int (*counter_api_set_top_value)(const struct device *dev,
226 const struct counter_top_cfg *cfg);
227typedef uint32_t (*counter_api_get_pending_int)(const struct device *dev);
228typedef uint32_t (*counter_api_get_top_value)(const struct device *dev);
229typedef uint32_t (*counter_api_get_guard_period)(const struct device *dev,
231typedef int (*counter_api_set_guard_period)(const struct device *dev,
232 uint32_t ticks,
234typedef uint32_t (*counter_api_get_freq)(const struct device *dev);
235
251
260__syscall bool counter_is_counting_up(const struct device *dev);
261
262static inline bool z_impl_counter_is_counting_up(const struct device *dev)
263{
264 const struct counter_config_info *config =
265 (const struct counter_config_info *)dev->config;
266
267 return config->flags & COUNTER_CONFIG_INFO_COUNT_UP;
268}
269
277__syscall uint8_t counter_get_num_of_channels(const struct device *dev);
278
279static inline uint8_t z_impl_counter_get_num_of_channels(const struct device *dev)
280{
281 const struct counter_config_info *config =
282 (const struct counter_config_info *)dev->config;
283
284 return config->channels;
285}
286
295__syscall uint32_t counter_get_frequency(const struct device *dev);
296
297static inline uint32_t z_impl_counter_get_frequency(const struct device *dev)
298{
299 const struct counter_config_info *config =
300 (const struct counter_config_info *)dev->config;
301 const struct counter_driver_api *api =
302 (struct counter_driver_api *)dev->api;
303
304 return api->get_freq ? api->get_freq(dev) : config->freq;
305}
306
315__syscall uint32_t counter_us_to_ticks(const struct device *dev, uint64_t us);
316
317static inline uint32_t z_impl_counter_us_to_ticks(const struct device *dev,
318 uint64_t us)
319{
320 uint64_t ticks = (us * z_impl_counter_get_frequency(dev)) / USEC_PER_SEC;
321
322 return (ticks > (uint64_t)UINT32_MAX) ? UINT32_MAX : ticks;
323}
324
333__syscall uint64_t counter_ticks_to_us(const struct device *dev, uint32_t ticks);
334
335static inline uint64_t z_impl_counter_ticks_to_us(const struct device *dev,
336 uint32_t ticks)
337{
338 return ((uint64_t)ticks * USEC_PER_SEC) / z_impl_counter_get_frequency(dev);
339}
340
348__syscall uint32_t counter_get_max_top_value(const struct device *dev);
349
350static inline uint32_t z_impl_counter_get_max_top_value(const struct device *dev)
351{
352 const struct counter_config_info *config =
353 (const struct counter_config_info *)dev->config;
354
355 return config->max_top_value;
356}
357
366__syscall int counter_start(const struct device *dev);
367
368static inline int z_impl_counter_start(const struct device *dev)
369{
370 const struct counter_driver_api *api =
371 (struct counter_driver_api *)dev->api;
372
373 return api->start(dev);
374}
375
385__syscall int counter_stop(const struct device *dev);
386
387static inline int z_impl_counter_stop(const struct device *dev)
388{
389 const struct counter_driver_api *api =
390 (struct counter_driver_api *)dev->api;
391
392 return api->stop(dev);
393}
394
403__syscall int counter_get_value(const struct device *dev, uint32_t *ticks);
404
405static inline int z_impl_counter_get_value(const struct device *dev,
406 uint32_t *ticks)
407{
408 const struct counter_driver_api *api =
409 (struct counter_driver_api *)dev->api;
410
411 return api->get_value(dev, ticks);
412}
413
422__syscall int counter_get_value_64(const struct device *dev, uint64_t *ticks);
423
424static inline int z_impl_counter_get_value_64(const struct device *dev,
425 uint64_t *ticks)
426{
427 const struct counter_driver_api *api =
428 (struct counter_driver_api *)dev->api;
429
430 if (!api->get_value_64) {
431 return -ENOSYS;
432 }
433
434 return api->get_value_64(dev, ticks);
435}
436
444__syscall int counter_reset(const struct device *dev);
445
446static inline int z_impl_counter_reset(const struct device *dev)
447{
448 const struct counter_driver_api *api =
449 (struct counter_driver_api *)dev->api;
450
451 if (!api->reset) {
452 return -ENOSYS;
453 }
454
455 return api->reset(dev);
456}
457
478__syscall int counter_set_channel_alarm(const struct device *dev,
479 uint8_t chan_id,
480 const struct counter_alarm_cfg *alarm_cfg);
481
482static inline int z_impl_counter_set_channel_alarm(const struct device *dev,
483 uint8_t chan_id,
484 const struct counter_alarm_cfg *alarm_cfg)
485{
486 const struct counter_driver_api *api =
487 (struct counter_driver_api *)dev->api;
488
489 if (chan_id >= counter_get_num_of_channels(dev)) {
490 return -ENOTSUP;
491 }
492
493 return api->set_alarm(dev, chan_id, alarm_cfg);
494}
495
508__syscall int counter_cancel_channel_alarm(const struct device *dev,
509 uint8_t chan_id);
510
511static inline int z_impl_counter_cancel_channel_alarm(const struct device *dev,
512 uint8_t chan_id)
513{
514 const struct counter_driver_api *api =
515 (struct counter_driver_api *)dev->api;
516
517 if (chan_id >= counter_get_num_of_channels(dev)) {
518 return -ENOTSUP;
519 }
520
521 return api->cancel_alarm(dev, chan_id);
522}
523
548__syscall int counter_set_top_value(const struct device *dev,
549 const struct counter_top_cfg *cfg);
550
551static inline int z_impl_counter_set_top_value(const struct device *dev,
552 const struct counter_top_cfg
553 *cfg)
554{
555 const struct counter_driver_api *api =
556 (struct counter_driver_api *)dev->api;
557
558 if (cfg->ticks > counter_get_max_top_value(dev)) {
559 return -EINVAL;
560 }
561
562 return api->set_top_value(dev, cfg);
563}
564
578__syscall int counter_get_pending_int(const struct device *dev);
579
580static inline int z_impl_counter_get_pending_int(const struct device *dev)
581{
582 const struct counter_driver_api *api =
583 (struct counter_driver_api *)dev->api;
584
585 return api->get_pending_int(dev);
586}
587
595__syscall uint32_t counter_get_top_value(const struct device *dev);
596
597static inline uint32_t z_impl_counter_get_top_value(const struct device *dev)
598{
599 const struct counter_driver_api *api =
600 (struct counter_driver_api *)dev->api;
601
602 return api->get_top_value(dev);
603}
604
657__syscall int counter_set_guard_period(const struct device *dev,
658 uint32_t ticks,
660
661static inline int z_impl_counter_set_guard_period(const struct device *dev,
662 uint32_t ticks, uint32_t flags)
663{
664 const struct counter_driver_api *api =
665 (struct counter_driver_api *)dev->api;
666
667 if (!api->set_guard_period) {
668 return -ENOSYS;
669 }
670
671 return api->set_guard_period(dev, ticks, flags);
672}
673
685__syscall uint32_t counter_get_guard_period(const struct device *dev,
687
688static inline uint32_t z_impl_counter_get_guard_period(const struct device *dev,
690{
691 const struct counter_driver_api *api =
692 (struct counter_driver_api *)dev->api;
693
694 return (api->get_guard_period) ? api->get_guard_period(dev, flags) : 0;
695}
696
697#ifdef __cplusplus
698}
699#endif
700
705#include <zephyr/syscalls/counter.h>
706
707#endif /* ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_ */
System error numbers.
#define USEC_PER_SEC
number of microseconds per second
Definition clock.h:110
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:228
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_reset(const struct device *dev)
Reset the counter to the initial value.
int(* counter_api_stop)(const struct device *dev)
Definition counter.h:214
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:166
void(* counter_alarm_callback_t)(const struct device *dev, uint8_t chan_id, uint32_t ticks, void *user_data)
Alarm callback.
Definition counter.h:123
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:231
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.
#define COUNTER_CONFIG_INFO_COUNT_UP
Counter count up flag.
Definition counter.h:47
uint32_t(* counter_api_get_guard_period)(const struct device *dev, uint32_t flags)
Definition counter.h:229
uint32_t(* counter_api_get_pending_int)(const struct device *dev)
Definition counter.h:227
uint32_t(* counter_api_get_freq)(const struct device *dev)
Definition counter.h:234
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:225
int(* counter_api_reset)(const struct device *dev)
Definition counter.h:219
int(* counter_api_start)(const struct device *dev)
Definition counter.h:213
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:223
int(* counter_api_get_value_64)(const struct device *dev, uint64_t *ticks)
Definition counter.h:217
int(* counter_api_get_value)(const struct device *dev, uint32_t *ticks)
Definition counter.h:215
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:220
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
Invalid argument.
Definition errno.h:60
#define ENOSYS
Function not implemented.
Definition errno.h:82
#define ENOTSUP
Unsupported value.
Definition errno.h:114
flags
Definition parser.h:97
__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
Number of ticks that triggers the alarm.
Definition counter.h:150
uint32_t flags
Alarm flags (see COUNTER_ALARM_FLAGS).
Definition counter.h:158
void * user_data
User data returned in callback.
Definition counter.h:154
counter_alarm_callback_t callback
Callback called on alarm (cannot be NULL).
Definition counter.h:133
Structure with generic counter features.
Definition counter.h:192
uint32_t max_top_value
Maximal (default) top value on which counter is reset (cleared or reloaded).
Definition counter.h:196
uint32_t freq
Frequency of the source clock if synchronous events are counted.
Definition counter.h:200
uint8_t flags
Flags (see COUNTER_FLAGS).
Definition counter.h:204
uint8_t channels
Number of channels that can be used for setting alarm.
Definition counter.h:210
Definition counter.h:236
counter_api_get_value_64 get_value_64
Definition counter.h:240
counter_api_get_top_value get_top_value
Definition counter.h:246
counter_api_set_top_value set_top_value
Definition counter.h:244
counter_api_set_alarm set_alarm
Definition counter.h:242
counter_api_get_value get_value
Definition counter.h:239
counter_api_reset reset
Definition counter.h:241
counter_api_get_pending_int get_pending_int
Definition counter.h:245
counter_api_stop stop
Definition counter.h:238
counter_api_set_guard_period set_guard_period
Definition counter.h:248
counter_api_start start
Definition counter.h:237
counter_api_get_guard_period get_guard_period
Definition counter.h:247
counter_api_cancel_alarm cancel_alarm
Definition counter.h:243
counter_api_get_freq get_freq
Definition counter.h:249
Top value configuration structure.
Definition counter.h:171
uint32_t ticks
Top value.
Definition counter.h:175
uint32_t flags
Flags (see COUNTER_TOP_FLAGS).
Definition counter.h:187
counter_top_callback_t callback
Callback function (can be NULL).
Definition counter.h:179
void * user_data
User data passed to callback function (not valid if callback is NULL).
Definition counter.h:183
Runtime device structure (in ROM) per driver instance.
Definition device.h:510
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:516
const void * config
Address of device instance config information.
Definition device.h:514