Zephyr Project API  3.2.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 <zephyr/types.h>
24#include <stddef.h>
25#include <zephyr/device.h>
26#include <stdbool.h>
27
28#ifdef __cplusplus
29extern "C" {
30#endif
31
38#define COUNTER_CONFIG_INFO_COUNT_UP BIT(0)
39
52#define COUNTER_TOP_CFG_DONT_RESET BIT(0)
53
60#define COUNTER_TOP_CFG_RESET_WHEN_LATE BIT(1)
61
75#define COUNTER_ALARM_CFG_ABSOLUTE BIT(0)
76
83#define COUNTER_ALARM_CFG_EXPIRE_WHEN_LATE BIT(1)
84
97#define COUNTER_GUARD_PERIOD_LATE_TO_SET BIT(0)
98
108typedef void (*counter_alarm_callback_t)(const struct device *dev,
109 uint8_t chan_id, uint32_t ticks,
110 void *user_data);
111
131};
132
138typedef void (*counter_top_callback_t)(const struct device *dev,
139 void *user_data);
140
154};
155
171};
172
173typedef int (*counter_api_start)(const struct device *dev);
174typedef int (*counter_api_stop)(const struct device *dev);
175typedef int (*counter_api_get_value)(const struct device *dev,
176 uint32_t *ticks);
177typedef int (*counter_api_get_value_64)(const struct device *dev,
178 uint64_t *ticks);
179typedef int (*counter_api_set_alarm)(const struct device *dev,
180 uint8_t chan_id,
181 const struct counter_alarm_cfg *alarm_cfg);
182typedef int (*counter_api_cancel_alarm)(const struct device *dev,
183 uint8_t chan_id);
184typedef int (*counter_api_set_top_value)(const struct device *dev,
185 const struct counter_top_cfg *cfg);
186typedef uint32_t (*counter_api_get_pending_int)(const struct device *dev);
187typedef uint32_t (*counter_api_get_top_value)(const struct device *dev);
188typedef uint32_t (*counter_api_get_guard_period)(const struct device *dev,
190typedef int (*counter_api_set_guard_period)(const struct device *dev,
191 uint32_t ticks,
193typedef uint32_t (*counter_api_get_freq)(const struct device *dev);
194
195__subsystem struct counter_driver_api {
208};
209
218__syscall bool counter_is_counting_up(const struct device *dev);
219
220static inline bool z_impl_counter_is_counting_up(const struct device *dev)
221{
222 const struct counter_config_info *config =
223 (const struct counter_config_info *)dev->config;
224
225 return config->flags & COUNTER_CONFIG_INFO_COUNT_UP;
226}
227
235__syscall uint8_t counter_get_num_of_channels(const struct device *dev);
236
237static inline uint8_t z_impl_counter_get_num_of_channels(const struct device *dev)
238{
239 const struct counter_config_info *config =
240 (const struct counter_config_info *)dev->config;
241
242 return config->channels;
243}
244
253__syscall uint32_t counter_get_frequency(const struct device *dev);
254
255static inline uint32_t z_impl_counter_get_frequency(const struct device *dev)
256{
257 const struct counter_config_info *config =
258 (const struct counter_config_info *)dev->config;
259 const struct counter_driver_api *api =
260 (struct counter_driver_api *)dev->api;
261
262 return api->get_freq ? api->get_freq(dev) : config->freq;
263}
264
273__syscall uint32_t counter_us_to_ticks(const struct device *dev, uint64_t us);
274
275static inline uint32_t z_impl_counter_us_to_ticks(const struct device *dev,
276 uint64_t us)
277{
278 uint64_t ticks = (us * z_impl_counter_get_frequency(dev)) / USEC_PER_SEC;
279
280 return (ticks > (uint64_t)UINT32_MAX) ? UINT32_MAX : ticks;
281}
282
291__syscall uint64_t counter_ticks_to_us(const struct device *dev, uint32_t ticks);
292
293static inline uint64_t z_impl_counter_ticks_to_us(const struct device *dev,
294 uint32_t ticks)
295{
296 return ((uint64_t)ticks * USEC_PER_SEC) / z_impl_counter_get_frequency(dev);
297}
298
306__syscall uint32_t counter_get_max_top_value(const struct device *dev);
307
308static inline uint32_t z_impl_counter_get_max_top_value(const struct device *dev)
309{
310 const struct counter_config_info *config =
311 (const struct counter_config_info *)dev->config;
312
313 return config->max_top_value;
314}
315
324__syscall int counter_start(const struct device *dev);
325
326static inline int z_impl_counter_start(const struct device *dev)
327{
328 const struct counter_driver_api *api =
329 (struct counter_driver_api *)dev->api;
330
331 return api->start(dev);
332}
333
343__syscall int counter_stop(const struct device *dev);
344
345static inline int z_impl_counter_stop(const struct device *dev)
346{
347 const struct counter_driver_api *api =
348 (struct counter_driver_api *)dev->api;
349
350 return api->stop(dev);
351}
352
361__syscall int counter_get_value(const struct device *dev, uint32_t *ticks);
362
363static inline int z_impl_counter_get_value(const struct device *dev,
364 uint32_t *ticks)
365{
366 const struct counter_driver_api *api =
367 (struct counter_driver_api *)dev->api;
368
369 return api->get_value(dev, ticks);
370}
371
380__syscall int counter_get_value_64(const struct device *dev, uint64_t *ticks);
381
382static inline int z_impl_counter_get_value_64(const struct device *dev,
383 uint64_t *ticks)
384{
385 const struct counter_driver_api *api =
386 (struct counter_driver_api *)dev->api;
387
388 if (!api->get_value_64) {
389 return -ENOTSUP;
390 }
391
392 return api->get_value_64(dev, ticks);
393}
394
415__syscall int counter_set_channel_alarm(const struct device *dev,
416 uint8_t chan_id,
417 const struct counter_alarm_cfg *alarm_cfg);
418
419static inline int z_impl_counter_set_channel_alarm(const struct device *dev,
420 uint8_t chan_id,
421 const struct counter_alarm_cfg *alarm_cfg)
422{
423 const struct counter_driver_api *api =
424 (struct counter_driver_api *)dev->api;
425
426 if (chan_id >= counter_get_num_of_channels(dev)) {
427 return -ENOTSUP;
428 }
429
430 return api->set_alarm(dev, chan_id, alarm_cfg);
431}
432
445__syscall int counter_cancel_channel_alarm(const struct device *dev,
446 uint8_t chan_id);
447
448static inline int z_impl_counter_cancel_channel_alarm(const struct device *dev,
449 uint8_t chan_id)
450{
451 const struct counter_driver_api *api =
452 (struct counter_driver_api *)dev->api;
453
454 if (chan_id >= counter_get_num_of_channels(dev)) {
455 return -ENOTSUP;
456 }
457
458 return api->cancel_alarm(dev, chan_id);
459}
460
485__syscall int counter_set_top_value(const struct device *dev,
486 const struct counter_top_cfg *cfg);
487
488static inline int z_impl_counter_set_top_value(const struct device *dev,
489 const struct counter_top_cfg
490 *cfg)
491{
492 const struct counter_driver_api *api =
493 (struct counter_driver_api *)dev->api;
494
495 if (cfg->ticks > counter_get_max_top_value(dev)) {
496 return -EINVAL;
497 }
498
499 return api->set_top_value(dev, cfg);
500}
501
515__syscall int counter_get_pending_int(const struct device *dev);
516
517static inline int z_impl_counter_get_pending_int(const struct device *dev)
518{
519 const struct counter_driver_api *api =
520 (struct counter_driver_api *)dev->api;
521
522 return api->get_pending_int(dev);
523}
524
532__syscall uint32_t counter_get_top_value(const struct device *dev);
533
534static inline uint32_t z_impl_counter_get_top_value(const struct device *dev)
535{
536 const struct counter_driver_api *api =
537 (struct counter_driver_api *)dev->api;
538
539 return api->get_top_value(dev);
540}
541
570__syscall int counter_set_guard_period(const struct device *dev,
571 uint32_t ticks,
573
574static inline int z_impl_counter_set_guard_period(const struct device *dev,
575 uint32_t ticks, uint32_t flags)
576{
577 const struct counter_driver_api *api =
578 (struct counter_driver_api *)dev->api;
579
580 if (!api->set_guard_period) {
581 return -ENOTSUP;
582 }
583
584 return api->set_guard_period(dev, ticks, flags);
585}
586
598__syscall uint32_t counter_get_guard_period(const struct device *dev,
600
601static inline uint32_t z_impl_counter_get_guard_period(const struct device *dev,
603{
604 const struct counter_driver_api *api =
605 (struct counter_driver_api *)dev->api;
606
607 return (api->get_guard_period) ? api->get_guard_period(dev, flags) : 0;
608}
609
610#ifdef __cplusplus
611}
612#endif
613
618#include <syscalls/counter.h>
619
620#endif /* ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_ */
#define COUNTER_CONFIG_INFO_COUNT_UP
Counter count up flag.
Definition: counter.h:38
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:187
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:174
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:138
void(* counter_alarm_callback_t)(const struct device *dev, uint8_t chan_id, uint32_t ticks, void *user_data)
Alarm callback.
Definition: counter.h:108
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:190
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:188
uint32_t(* counter_api_get_pending_int)(const struct device *dev)
Definition: counter.h:186
uint32_t(* counter_api_get_freq)(const struct device *dev)
Definition: counter.h:193
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:184
int(* counter_api_start)(const struct device *dev)
Definition: counter.h:173
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:182
int(* counter_api_get_value_64)(const struct device *dev, uint64_t *ticks)
Definition: counter.h:177
int(* counter_api_get_value)(const struct device *dev, uint32_t *ticks)
Definition: counter.h:175
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:179
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
flags
Definition: http_parser.h:131
#define USEC_PER_SEC
Definition: sys_clock.h:136
__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
Definition: counter.h:128
uint32_t flags
Definition: counter.h:130
void * user_data
Definition: counter.h:129
counter_alarm_callback_t callback
Definition: counter.h:127
Structure with generic counter features.
Definition: counter.h:166
uint32_t max_top_value
Definition: counter.h:167
uint32_t freq
Definition: counter.h:168
uint8_t flags
Definition: counter.h:169
uint8_t channels
Definition: counter.h:170
Definition: counter.h:195
counter_api_get_value_64 get_value_64
Definition: counter.h:199
counter_api_get_top_value get_top_value
Definition: counter.h:204
counter_api_set_top_value set_top_value
Definition: counter.h:202
counter_api_set_alarm set_alarm
Definition: counter.h:200
counter_api_get_value get_value
Definition: counter.h:198
counter_api_get_pending_int get_pending_int
Definition: counter.h:203
counter_api_stop stop
Definition: counter.h:197
counter_api_set_guard_period set_guard_period
Definition: counter.h:206
counter_api_start start
Definition: counter.h:196
counter_api_get_guard_period get_guard_period
Definition: counter.h:205
counter_api_cancel_alarm cancel_alarm
Definition: counter.h:201
counter_api_get_freq get_freq
Definition: counter.h:207
Top value configuration structure.
Definition: counter.h:149
uint32_t ticks
Definition: counter.h:150
uint32_t flags
Definition: counter.h:153
counter_top_callback_t callback
Definition: counter.h:151
void * user_data
Definition: counter.h:152
Runtime device structure (in ROM) per driver instance.
Definition: device.h:435
const void * api
Definition: device.h:441
const void * config
Definition: device.h:439
static const intptr_t user_data[5]
Definition: main.c:588