Zephyr API Documentation  3.5.0
A Scalable Open Source RTOS
3.5.0
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
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
44#define COUNTER_CONFIG_INFO_COUNT_UP BIT(0)
45
60#define COUNTER_TOP_CFG_DONT_RESET BIT(0)
61
68#define COUNTER_TOP_CFG_RESET_WHEN_LATE BIT(1)
69
85#define COUNTER_ALARM_CFG_ABSOLUTE BIT(0)
86
93#define COUNTER_ALARM_CFG_EXPIRE_WHEN_LATE BIT(1)
94
109#define COUNTER_GUARD_PERIOD_LATE_TO_SET BIT(0)
110
120typedef void (*counter_alarm_callback_t)(const struct device *dev,
121 uint8_t chan_id, uint32_t ticks,
122 void *user_data);
123
156};
157
163typedef void (*counter_top_callback_t)(const struct device *dev,
164 void *user_data);
165
185};
186
208};
209
210typedef int (*counter_api_start)(const struct device *dev);
211typedef int (*counter_api_stop)(const struct device *dev);
212typedef int (*counter_api_get_value)(const struct device *dev,
213 uint32_t *ticks);
214typedef int (*counter_api_get_value_64)(const struct device *dev,
215 uint64_t *ticks);
216typedef int (*counter_api_set_alarm)(const struct device *dev,
217 uint8_t chan_id,
218 const struct counter_alarm_cfg *alarm_cfg);
219typedef int (*counter_api_cancel_alarm)(const struct device *dev,
220 uint8_t chan_id);
221typedef int (*counter_api_set_top_value)(const struct device *dev,
222 const struct counter_top_cfg *cfg);
223typedef uint32_t (*counter_api_get_pending_int)(const struct device *dev);
224typedef uint32_t (*counter_api_get_top_value)(const struct device *dev);
225typedef uint32_t (*counter_api_get_guard_period)(const struct device *dev,
227typedef int (*counter_api_set_guard_period)(const struct device *dev,
228 uint32_t ticks,
230typedef uint32_t (*counter_api_get_freq)(const struct device *dev);
231
232__subsystem struct counter_driver_api {
245};
246
255__syscall bool counter_is_counting_up(const struct device *dev);
256
257static inline bool z_impl_counter_is_counting_up(const struct device *dev)
258{
259 const struct counter_config_info *config =
260 (const struct counter_config_info *)dev->config;
261
262 return config->flags & COUNTER_CONFIG_INFO_COUNT_UP;
263}
264
272__syscall uint8_t counter_get_num_of_channels(const struct device *dev);
273
274static inline uint8_t z_impl_counter_get_num_of_channels(const struct device *dev)
275{
276 const struct counter_config_info *config =
277 (const struct counter_config_info *)dev->config;
278
279 return config->channels;
280}
281
290__syscall uint32_t counter_get_frequency(const struct device *dev);
291
292static inline uint32_t z_impl_counter_get_frequency(const struct device *dev)
293{
294 const struct counter_config_info *config =
295 (const struct counter_config_info *)dev->config;
296 const struct counter_driver_api *api =
297 (struct counter_driver_api *)dev->api;
298
299 return api->get_freq ? api->get_freq(dev) : config->freq;
300}
301
310__syscall uint32_t counter_us_to_ticks(const struct device *dev, uint64_t us);
311
312static inline uint32_t z_impl_counter_us_to_ticks(const struct device *dev,
313 uint64_t us)
314{
315 uint64_t ticks = (us * z_impl_counter_get_frequency(dev)) / USEC_PER_SEC;
316
317 return (ticks > (uint64_t)UINT32_MAX) ? UINT32_MAX : ticks;
318}
319
328__syscall uint64_t counter_ticks_to_us(const struct device *dev, uint32_t ticks);
329
330static inline uint64_t z_impl_counter_ticks_to_us(const struct device *dev,
331 uint32_t ticks)
332{
333 return ((uint64_t)ticks * USEC_PER_SEC) / z_impl_counter_get_frequency(dev);
334}
335
343__syscall uint32_t counter_get_max_top_value(const struct device *dev);
344
345static inline uint32_t z_impl_counter_get_max_top_value(const struct device *dev)
346{
347 const struct counter_config_info *config =
348 (const struct counter_config_info *)dev->config;
349
350 return config->max_top_value;
351}
352
361__syscall int counter_start(const struct device *dev);
362
363static inline int z_impl_counter_start(const struct device *dev)
364{
365 const struct counter_driver_api *api =
366 (struct counter_driver_api *)dev->api;
367
368 return api->start(dev);
369}
370
380__syscall int counter_stop(const struct device *dev);
381
382static inline int z_impl_counter_stop(const struct device *dev)
383{
384 const struct counter_driver_api *api =
385 (struct counter_driver_api *)dev->api;
386
387 return api->stop(dev);
388}
389
398__syscall int counter_get_value(const struct device *dev, uint32_t *ticks);
399
400static inline int z_impl_counter_get_value(const struct device *dev,
401 uint32_t *ticks)
402{
403 const struct counter_driver_api *api =
404 (struct counter_driver_api *)dev->api;
405
406 return api->get_value(dev, ticks);
407}
408
417__syscall int counter_get_value_64(const struct device *dev, uint64_t *ticks);
418
419static inline int z_impl_counter_get_value_64(const struct device *dev,
420 uint64_t *ticks)
421{
422 const struct counter_driver_api *api =
423 (struct counter_driver_api *)dev->api;
424
425 if (!api->get_value_64) {
426 return -ENOTSUP;
427 }
428
429 return api->get_value_64(dev, ticks);
430}
431
452__syscall int counter_set_channel_alarm(const struct device *dev,
453 uint8_t chan_id,
454 const struct counter_alarm_cfg *alarm_cfg);
455
456static inline int z_impl_counter_set_channel_alarm(const struct device *dev,
457 uint8_t chan_id,
458 const struct counter_alarm_cfg *alarm_cfg)
459{
460 const struct counter_driver_api *api =
461 (struct counter_driver_api *)dev->api;
462
463 if (chan_id >= counter_get_num_of_channels(dev)) {
464 return -ENOTSUP;
465 }
466
467 return api->set_alarm(dev, chan_id, alarm_cfg);
468}
469
482__syscall int counter_cancel_channel_alarm(const struct device *dev,
483 uint8_t chan_id);
484
485static inline int z_impl_counter_cancel_channel_alarm(const struct device *dev,
486 uint8_t chan_id)
487{
488 const struct counter_driver_api *api =
489 (struct counter_driver_api *)dev->api;
490
491 if (chan_id >= counter_get_num_of_channels(dev)) {
492 return -ENOTSUP;
493 }
494
495 return api->cancel_alarm(dev, chan_id);
496}
497
522__syscall int counter_set_top_value(const struct device *dev,
523 const struct counter_top_cfg *cfg);
524
525static inline int z_impl_counter_set_top_value(const struct device *dev,
526 const struct counter_top_cfg
527 *cfg)
528{
529 const struct counter_driver_api *api =
530 (struct counter_driver_api *)dev->api;
531
532 if (cfg->ticks > counter_get_max_top_value(dev)) {
533 return -EINVAL;
534 }
535
536 return api->set_top_value(dev, cfg);
537}
538
552__syscall int counter_get_pending_int(const struct device *dev);
553
554static inline int z_impl_counter_get_pending_int(const struct device *dev)
555{
556 const struct counter_driver_api *api =
557 (struct counter_driver_api *)dev->api;
558
559 return api->get_pending_int(dev);
560}
561
569__syscall uint32_t counter_get_top_value(const struct device *dev);
570
571static inline uint32_t z_impl_counter_get_top_value(const struct device *dev)
572{
573 const struct counter_driver_api *api =
574 (struct counter_driver_api *)dev->api;
575
576 return api->get_top_value(dev);
577}
578
631__syscall int counter_set_guard_period(const struct device *dev,
632 uint32_t ticks,
634
635static inline int z_impl_counter_set_guard_period(const struct device *dev,
636 uint32_t ticks, uint32_t flags)
637{
638 const struct counter_driver_api *api =
639 (struct counter_driver_api *)dev->api;
640
641 if (!api->set_guard_period) {
642 return -ENOTSUP;
643 }
644
645 return api->set_guard_period(dev, ticks, flags);
646}
647
659__syscall uint32_t counter_get_guard_period(const struct device *dev,
661
662static inline uint32_t z_impl_counter_get_guard_period(const struct device *dev,
664{
665 const struct counter_driver_api *api =
666 (struct counter_driver_api *)dev->api;
667
668 return (api->get_guard_period) ? api->get_guard_period(dev, flags) : 0;
669}
670
671#ifdef __cplusplus
672}
673#endif
674
679#include <syscalls/counter.h>
680
681#endif /* ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_ */
System error numbers.
#define USEC_PER_SEC
number of microseconds per second
Definition: sys_clock.h:104
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:224
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:211
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:163
void(* counter_alarm_callback_t)(const struct device *dev, uint8_t chan_id, uint32_t ticks, void *user_data)
Alarm callback.
Definition: counter.h:120
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:227
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:44
uint32_t(* counter_api_get_guard_period)(const struct device *dev, uint32_t flags)
Definition: counter.h:225
uint32_t(* counter_api_get_pending_int)(const struct device *dev)
Definition: counter.h:223
uint32_t(* counter_api_get_freq)(const struct device *dev)
Definition: counter.h:230
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:221
int(* counter_api_start)(const struct device *dev)
Definition: counter.h:210
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:219
int(* counter_api_get_value_64)(const struct device *dev, uint64_t *ticks)
Definition: counter.h:214
int(* counter_api_get_value)(const struct device *dev, uint32_t *ticks)
Definition: counter.h:212
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:216
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:61
#define ENOTSUP
Unsupported value.
Definition: errno.h:115
Variables needed for system clock.
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:126
uint32_t ticks
Number of ticks that triggers the alarm.
Definition: counter.h:147
uint32_t flags
Alarm flags (see COUNTER_ALARM_FLAGS).
Definition: counter.h:155
void * user_data
User data returned in callback.
Definition: counter.h:151
counter_alarm_callback_t callback
Callback called on alarm (cannot be NULL).
Definition: counter.h:130
Structure with generic counter features.
Definition: counter.h:189
uint32_t max_top_value
Maximal (default) top value on which counter is reset (cleared or reloaded).
Definition: counter.h:193
uint32_t freq
Frequency of the source clock if synchronous events are counted.
Definition: counter.h:197
uint8_t flags
Flags (see COUNTER_FLAGS).
Definition: counter.h:201
uint8_t channels
Number of channels that can be used for setting alarm.
Definition: counter.h:207
Definition: counter.h:232
counter_api_get_value_64 get_value_64
Definition: counter.h:236
counter_api_get_top_value get_top_value
Definition: counter.h:241
counter_api_set_top_value set_top_value
Definition: counter.h:239
counter_api_set_alarm set_alarm
Definition: counter.h:237
counter_api_get_value get_value
Definition: counter.h:235
counter_api_get_pending_int get_pending_int
Definition: counter.h:240
counter_api_stop stop
Definition: counter.h:234
counter_api_set_guard_period set_guard_period
Definition: counter.h:243
counter_api_start start
Definition: counter.h:233
counter_api_get_guard_period get_guard_period
Definition: counter.h:242
counter_api_cancel_alarm cancel_alarm
Definition: counter.h:238
counter_api_get_freq get_freq
Definition: counter.h:244
Top value configuration structure.
Definition: counter.h:168
uint32_t ticks
Top value.
Definition: counter.h:172
uint32_t flags
Flags (see COUNTER_TOP_FLAGS).
Definition: counter.h:184
counter_top_callback_t callback
Callback function (can be NULL).
Definition: counter.h:176
void * user_data
User data passed to callback function (not valid if callback is NULL).
Definition: counter.h:180
Runtime device structure (in ROM) per driver instance.
Definition: device.h:381
const void * api
Address of the API structure exposed by the device instance.
Definition: device.h:387
const void * config
Address of device instance config information.
Definition: device.h:385