Zephyr API Documentation 4.1.99
A Scalable Open Source RTOS
 4.1.99
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
25#include <errno.h>
26
27#include <zephyr/types.h>
28#include <stddef.h>
29#include <zephyr/device.h>
30#include <zephyr/sys_clock.h>
31#include <stdbool.h>
32
33#ifdef __cplusplus
34extern "C" {
35#endif
36
46#define COUNTER_CONFIG_INFO_COUNT_UP BIT(0)
47
62#define COUNTER_TOP_CFG_DONT_RESET BIT(0)
63
70#define COUNTER_TOP_CFG_RESET_WHEN_LATE BIT(1)
71
87#define COUNTER_ALARM_CFG_ABSOLUTE BIT(0)
88
95#define COUNTER_ALARM_CFG_EXPIRE_WHEN_LATE BIT(1)
96
111#define COUNTER_GUARD_PERIOD_LATE_TO_SET BIT(0)
112
122typedef void (*counter_alarm_callback_t)(const struct device *dev,
123 uint8_t chan_id, uint32_t ticks,
124 void *user_data);
125
159
165typedef void (*counter_top_callback_t)(const struct device *dev,
166 void *user_data);
167
188
211
212typedef int (*counter_api_start)(const struct device *dev);
213typedef int (*counter_api_stop)(const struct device *dev);
214typedef int (*counter_api_get_value)(const struct device *dev,
215 uint32_t *ticks);
216typedef int (*counter_api_get_value_64)(const struct device *dev,
217 uint64_t *ticks);
218typedef int (*counter_api_reset)(const struct device *dev);
219typedef int (*counter_api_set_alarm)(const struct device *dev,
220 uint8_t chan_id,
221 const struct counter_alarm_cfg *alarm_cfg);
222typedef int (*counter_api_cancel_alarm)(const struct device *dev,
223 uint8_t chan_id);
224typedef int (*counter_api_set_top_value)(const struct device *dev,
225 const struct counter_top_cfg *cfg);
226typedef uint32_t (*counter_api_get_pending_int)(const struct device *dev);
227typedef uint32_t (*counter_api_get_top_value)(const struct device *dev);
228typedef uint32_t (*counter_api_get_guard_period)(const struct device *dev,
230typedef int (*counter_api_set_guard_period)(const struct device *dev,
231 uint32_t ticks,
233typedef uint32_t (*counter_api_get_freq)(const struct device *dev);
234
250
259__syscall bool counter_is_counting_up(const struct device *dev);
260
261static inline bool z_impl_counter_is_counting_up(const struct device *dev)
262{
263 const struct counter_config_info *config =
264 (const struct counter_config_info *)dev->config;
265
266 return config->flags & COUNTER_CONFIG_INFO_COUNT_UP;
267}
268
276__syscall uint8_t counter_get_num_of_channels(const struct device *dev);
277
278static inline uint8_t z_impl_counter_get_num_of_channels(const struct device *dev)
279{
280 const struct counter_config_info *config =
281 (const struct counter_config_info *)dev->config;
282
283 return config->channels;
284}
285
294__syscall uint32_t counter_get_frequency(const struct device *dev);
295
296static inline uint32_t z_impl_counter_get_frequency(const struct device *dev)
297{
298 const struct counter_config_info *config =
299 (const struct counter_config_info *)dev->config;
300 const struct counter_driver_api *api =
301 (struct counter_driver_api *)dev->api;
302
303 return api->get_freq ? api->get_freq(dev) : config->freq;
304}
305
314__syscall uint32_t counter_us_to_ticks(const struct device *dev, uint64_t us);
315
316static inline uint32_t z_impl_counter_us_to_ticks(const struct device *dev,
317 uint64_t us)
318{
319 uint64_t ticks = (us * z_impl_counter_get_frequency(dev)) / USEC_PER_SEC;
320
321 return (ticks > (uint64_t)UINT32_MAX) ? UINT32_MAX : ticks;
322}
323
332__syscall uint64_t counter_ticks_to_us(const struct device *dev, uint32_t ticks);
333
334static inline uint64_t z_impl_counter_ticks_to_us(const struct device *dev,
335 uint32_t ticks)
336{
337 return ((uint64_t)ticks * USEC_PER_SEC) / z_impl_counter_get_frequency(dev);
338}
339
347__syscall uint32_t counter_get_max_top_value(const struct device *dev);
348
349static inline uint32_t z_impl_counter_get_max_top_value(const struct device *dev)
350{
351 const struct counter_config_info *config =
352 (const struct counter_config_info *)dev->config;
353
354 return config->max_top_value;
355}
356
365__syscall int counter_start(const struct device *dev);
366
367static inline int z_impl_counter_start(const struct device *dev)
368{
369 const struct counter_driver_api *api =
370 (struct counter_driver_api *)dev->api;
371
372 return api->start(dev);
373}
374
384__syscall int counter_stop(const struct device *dev);
385
386static inline int z_impl_counter_stop(const struct device *dev)
387{
388 const struct counter_driver_api *api =
389 (struct counter_driver_api *)dev->api;
390
391 return api->stop(dev);
392}
393
402__syscall int counter_get_value(const struct device *dev, uint32_t *ticks);
403
404static inline int z_impl_counter_get_value(const struct device *dev,
405 uint32_t *ticks)
406{
407 const struct counter_driver_api *api =
408 (struct counter_driver_api *)dev->api;
409
410 return api->get_value(dev, ticks);
411}
412
421__syscall int counter_get_value_64(const struct device *dev, uint64_t *ticks);
422
423static inline int z_impl_counter_get_value_64(const struct device *dev,
424 uint64_t *ticks)
425{
426 const struct counter_driver_api *api =
427 (struct counter_driver_api *)dev->api;
428
429 if (!api->get_value_64) {
430 return -ENOSYS;
431 }
432
433 return api->get_value_64(dev, ticks);
434}
435
443__syscall int counter_reset(const struct device *dev);
444
445static inline int z_impl_counter_reset(const struct device *dev)
446{
447 const struct counter_driver_api *api =
448 (struct counter_driver_api *)dev->api;
449
450 if (!api->reset) {
451 return -ENOSYS;
452 }
453
454 return api->reset(dev);
455}
456
477__syscall int counter_set_channel_alarm(const struct device *dev,
478 uint8_t chan_id,
479 const struct counter_alarm_cfg *alarm_cfg);
480
481static inline int z_impl_counter_set_channel_alarm(const struct device *dev,
482 uint8_t chan_id,
483 const struct counter_alarm_cfg *alarm_cfg)
484{
485 const struct counter_driver_api *api =
486 (struct counter_driver_api *)dev->api;
487
488 if (chan_id >= counter_get_num_of_channels(dev)) {
489 return -ENOTSUP;
490 }
491
492 return api->set_alarm(dev, chan_id, alarm_cfg);
493}
494
507__syscall int counter_cancel_channel_alarm(const struct device *dev,
508 uint8_t chan_id);
509
510static inline int z_impl_counter_cancel_channel_alarm(const struct device *dev,
511 uint8_t chan_id)
512{
513 const struct counter_driver_api *api =
514 (struct counter_driver_api *)dev->api;
515
516 if (chan_id >= counter_get_num_of_channels(dev)) {
517 return -ENOTSUP;
518 }
519
520 return api->cancel_alarm(dev, chan_id);
521}
522
547__syscall int counter_set_top_value(const struct device *dev,
548 const struct counter_top_cfg *cfg);
549
550static inline int z_impl_counter_set_top_value(const struct device *dev,
551 const struct counter_top_cfg
552 *cfg)
553{
554 const struct counter_driver_api *api =
555 (struct counter_driver_api *)dev->api;
556
557 if (cfg->ticks > counter_get_max_top_value(dev)) {
558 return -EINVAL;
559 }
560
561 return api->set_top_value(dev, cfg);
562}
563
577__syscall int counter_get_pending_int(const struct device *dev);
578
579static inline int z_impl_counter_get_pending_int(const struct device *dev)
580{
581 const struct counter_driver_api *api =
582 (struct counter_driver_api *)dev->api;
583
584 return api->get_pending_int(dev);
585}
586
594__syscall uint32_t counter_get_top_value(const struct device *dev);
595
596static inline uint32_t z_impl_counter_get_top_value(const struct device *dev)
597{
598 const struct counter_driver_api *api =
599 (struct counter_driver_api *)dev->api;
600
601 return api->get_top_value(dev);
602}
603
656__syscall int counter_set_guard_period(const struct device *dev,
657 uint32_t ticks,
659
660static inline int z_impl_counter_set_guard_period(const struct device *dev,
661 uint32_t ticks, uint32_t flags)
662{
663 const struct counter_driver_api *api =
664 (struct counter_driver_api *)dev->api;
665
666 if (!api->set_guard_period) {
667 return -ENOSYS;
668 }
669
670 return api->set_guard_period(dev, ticks, flags);
671}
672
684__syscall uint32_t counter_get_guard_period(const struct device *dev,
686
687static inline uint32_t z_impl_counter_get_guard_period(const struct device *dev,
689{
690 const struct counter_driver_api *api =
691 (struct counter_driver_api *)dev->api;
692
693 return (api->get_guard_period) ? api->get_guard_period(dev, flags) : 0;
694}
695
696#ifdef __cplusplus
697}
698#endif
699
704#include <zephyr/syscalls/counter.h>
705
706#endif /* ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_ */
System error numbers.
#define USEC_PER_SEC
number of microseconds per second
Definition sys_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:227
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:213
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:165
void(* counter_alarm_callback_t)(const struct device *dev, uint8_t chan_id, uint32_t ticks, void *user_data)
Alarm callback.
Definition counter.h:122
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:230
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:46
uint32_t(* counter_api_get_guard_period)(const struct device *dev, uint32_t flags)
Definition counter.h:228
uint32_t(* counter_api_get_pending_int)(const struct device *dev)
Definition counter.h:226
uint32_t(* counter_api_get_freq)(const struct device *dev)
Definition counter.h:233
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:224
int(* counter_api_reset)(const struct device *dev)
Definition counter.h:218
int(* counter_api_start)(const struct device *dev)
Definition counter.h:212
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:222
int(* counter_api_get_value_64)(const struct device *dev, uint64_t *ticks)
Definition counter.h:216
int(* counter_api_get_value)(const struct device *dev, uint32_t *ticks)
Definition counter.h:214
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:219
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:128
uint32_t ticks
Number of ticks that triggers the alarm.
Definition counter.h:149
uint32_t flags
Alarm flags (see COUNTER_ALARM_FLAGS).
Definition counter.h:157
void * user_data
User data returned in callback.
Definition counter.h:153
counter_alarm_callback_t callback
Callback called on alarm (cannot be NULL).
Definition counter.h:132
Structure with generic counter features.
Definition counter.h:191
uint32_t max_top_value
Maximal (default) top value on which counter is reset (cleared or reloaded).
Definition counter.h:195
uint32_t freq
Frequency of the source clock if synchronous events are counted.
Definition counter.h:199
uint8_t flags
Flags (see COUNTER_FLAGS).
Definition counter.h:203
uint8_t channels
Number of channels that can be used for setting alarm.
Definition counter.h:209
Definition counter.h:235
counter_api_get_value_64 get_value_64
Definition counter.h:239
counter_api_get_top_value get_top_value
Definition counter.h:245
counter_api_set_top_value set_top_value
Definition counter.h:243
counter_api_set_alarm set_alarm
Definition counter.h:241
counter_api_get_value get_value
Definition counter.h:238
counter_api_reset reset
Definition counter.h:240
counter_api_get_pending_int get_pending_int
Definition counter.h:244
counter_api_stop stop
Definition counter.h:237
counter_api_set_guard_period set_guard_period
Definition counter.h:247
counter_api_start start
Definition counter.h:236
counter_api_get_guard_period get_guard_period
Definition counter.h:246
counter_api_cancel_alarm cancel_alarm
Definition counter.h:242
counter_api_get_freq get_freq
Definition counter.h:248
Top value configuration structure.
Definition counter.h:170
uint32_t ticks
Top value.
Definition counter.h:174
uint32_t flags
Flags (see COUNTER_TOP_FLAGS).
Definition counter.h:186
counter_top_callback_t callback
Callback function (can be NULL).
Definition counter.h:178
void * user_data
User data passed to callback function (not valid if callback is NULL).
Definition counter.h:182
Runtime device structure (in ROM) per driver instance.
Definition device.h:504
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:510
const void * config
Address of device instance config information.
Definition device.h:508
Variables needed for system clock.