14#ifndef ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_
15#define ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_
47#define COUNTER_CONFIG_INFO_COUNT_UP BIT(0)
63#define COUNTER_TOP_CFG_DONT_RESET BIT(0)
71#define COUNTER_TOP_CFG_RESET_WHEN_LATE BIT(1)
88#define COUNTER_ALARM_CFG_ABSOLUTE BIT(0)
96#define COUNTER_ALARM_CFG_EXPIRE_WHEN_LATE BIT(1)
112#define COUNTER_GUARD_PERIOD_LATE_TO_SET BIT(0)
194#ifdef CONFIG_COUNTER_64BITS_FREQ
202#ifdef CONFIG_COUNTER_64BITS_TICKS
206#ifdef CONFIG_BIG_ENDIAN
338#ifdef CONFIG_COUNTER_64BITS_FREQ
341#ifdef CONFIG_COUNTER_64BITS_TICKS
362static inline bool z_impl_counter_is_counting_up(
const struct device *dev)
378static inline uint8_t z_impl_counter_get_num_of_channels(
const struct device *dev)
382 return config->channels;
387#ifdef CONFIG_COUNTER_64BITS_FREQ
398static inline uint32_t z_impl_counter_get_frequency(
const struct device *dev)
420static inline uint32_t z_impl_counter_get_frequency(
const struct device *dev)
439static inline uint64_t z_impl_counter_get_frequency_64(
const struct device *dev)
441#ifdef CONFIG_COUNTER_64BITS_FREQ
445 if (api->get_freq_64) {
446 return api->get_freq_64(dev);
458#ifdef CONFIG_COUNTER_64BITS_FREQ
459#define z_counter_get_frequency z_impl_counter_get_frequency_64
461#define z_counter_get_frequency z_impl_counter_get_frequency
493 return (us * z_counter_get_frequency(dev)) /
USEC_PER_SEC;
523 return (ticks *
USEC_PER_SEC) / z_counter_get_frequency(dev);
555 return (ns * z_counter_get_frequency(dev)) /
NSEC_PER_SEC;
585 return (ticks *
NSEC_PER_SEC) / z_counter_get_frequency(dev);
601static inline uint32_t z_impl_counter_get_max_top_value(
const struct device *dev)
605 return config->max_top_value;
618static inline int z_impl_counter_start(
const struct device *dev)
622 return api->
start(dev);
636static inline int z_impl_counter_stop(
const struct device *dev)
640 return api->
stop(dev);
653static inline int z_impl_counter_get_value(
const struct device *dev,
uint32_t *ticks)
669static inline int z_impl_counter_reset(
const struct device *dev)
677 return api->
reset(dev);
690static inline int z_impl_counter_set_value(
const struct device *dev,
uint32_t ticks)
724static inline int z_impl_counter_set_channel_alarm(
const struct device *dev,
uint8_t chan_id,
733 return api->
set_alarm(dev, chan_id, alarm_cfg);
750static inline int z_impl_counter_cancel_channel_alarm(
const struct device *dev,
uint8_t chan_id)
791static inline int z_impl_counter_set_top_value(
const struct device *dev,
818static inline int z_impl_counter_get_pending_int(
const struct device *dev)
834static inline uint32_t z_impl_counter_get_top_value(
const struct device *dev)
895static inline int z_impl_counter_set_guard_period(
const struct device *dev,
uint32_t ticks,
936static inline uint64_t z_impl_counter_get_max_top_value_64(
const struct device *dev)
938#ifdef CONFIG_COUNTER_64BITS_TICKS
941 return config->max_top_value_64;
975static inline int z_impl_counter_set_top_value_64(
const struct device *dev,
978#ifdef CONFIG_COUNTER_64BITS_TICKS
985 return api->set_top_value_64(dev, cfg);
1016static inline int z_impl_counter_set_channel_alarm_64(
const struct device *dev,
uint8_t chan_id,
1019#ifdef CONFIG_COUNTER_64BITS_TICKS
1026 return api->set_alarm_64(dev, chan_id, alarm_cfg);
1029 ARG_UNUSED(chan_id);
1030 ARG_UNUSED(alarm_cfg);
1044static inline uint64_t z_impl_counter_get_top_value_64(
const struct device *dev)
1046#ifdef CONFIG_COUNTER_64BITS_TICKS
1049 return api->get_top_value_64(dev);
1110static inline int z_impl_counter_set_guard_period_64(
const struct device *dev,
uint64_t ticks,
1113#ifdef CONFIG_COUNTER_64BITS_TICKS
1116 if (!api->set_guard_period_64) {
1120 return api->set_guard_period_64(dev, ticks,
flags);
1144#ifdef CONFIG_COUNTER_64BITS_TICKS
1147 return (api->get_guard_period_64) ? api->get_guard_period_64(dev,
flags) : 0;
1165static inline int z_impl_counter_get_value_64(
const struct device *dev,
uint64_t *ticks)
1167#ifdef CONFIG_COUNTER_64BITS_TICKS
1170 if (!api->get_value_64) {
1174 return api->get_value_64(dev, ticks);
1192static inline int z_impl_counter_set_value_64(
const struct device *dev,
uint64_t ticks)
1194#ifdef CONFIG_COUNTER_64BITS_TICKS
1197 if (!api->set_value_64) {
1201 return api->set_value_64(dev, ticks);
1217#include <zephyr/syscalls/counter.h>
#define NSEC_PER_SEC
number of nanoseconds per second
Definition clock.h:113
#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:306
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_set_channel_alarm_64(const struct device *dev, uint8_t chan_id, const struct counter_alarm_cfg_64 *alarm_cfg)
Set a single shot alarm on a channel for 64 bits.
int(* counter_api_set_top_value_64)(const struct device *dev, const struct counter_top_cfg_64 *cfg)
Definition counter.h:321
uint64_t(* counter_api_get_top_value_64)(const struct device *dev)
Definition counter.h:320
int(* counter_api_set_value)(const struct device *dev, uint32_t ticks)
Definition counter.h:299
uint64_t counter_ticks_to_us_64(const struct device *dev, uint64_t ticks)
Function to convert ticks with 64 bits to microseconds.
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:296
uint64_t counter_ns_to_ticks_64(const struct device *dev, uint64_t ns)
Function to convert nanoseconds to ticks with 64 bits.
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.
int counter_set_top_value_64(const struct device *dev, const struct counter_top_cfg_64 *cfg)
Set counter top value for 64 bits.
uint64_t counter_us_to_ticks_64(const struct device *dev, uint64_t us)
Function to convert microseconds to ticks with 64 bits.
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:123
int(* counter_api_set_alarm_64)(const struct device *dev, uint8_t chan_id, const struct counter_alarm_cfg_64 *alarm_cfg)
Definition counter.h:315
int counter_get_pending_int(const struct device *dev)
Function to get pending interrupts.
uint64_t counter_get_max_top_value_64(const struct device *dev)
Function to retrieve maximum top value that can be set for 64 bits.
uint64_t counter_get_guard_period_64(const struct device *dev, uint32_t flags)
Return guard period for 64 bits.
uint64_t counter_get_frequency_64(const struct device *dev)
Function to get counter frequency in 64bits.
void(* counter_alarm_callback_64_t)(const struct device *dev, uint8_t chan_id, uint64_t ticks, void *user_data)
Alarm callback.
Definition counter.h:237
uint64_t counter_ticks_to_ns_64(const struct device *dev, uint64_t ticks)
Function to convert ticks with 64 bits to nanoseconds.
int(* counter_api_set_guard_period_64)(const struct device *dev, uint64_t ticks, uint32_t flags)
Definition counter.h:318
uint32_t counter_get_guard_period(const struct device *dev, uint32_t flags)
Return guard period.
int counter_set_value(const struct device *dev, uint32_t ticks)
Set current counter value.
uint64_t(* counter_api_get_guard_period_64)(const struct device *dev, uint32_t flags)
Definition counter.h:317
int(* counter_api_set_guard_period)(const struct device *dev, uint32_t ticks, uint32_t flags)
Definition counter.h:308
uint64_t(* counter_api_get_freq_64)(const struct device *dev)
Definition counter.h:311
uint32_t counter_get_frequency(const struct device *dev)
int(* counter_api_set_value_64)(const struct device *dev, uint64_t ticks)
Definition counter.h:314
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:307
uint32_t(* counter_api_get_pending_int)(const struct device *dev)
Definition counter.h:305
uint32_t(* counter_api_get_freq)(const struct device *dev)
Definition counter.h:310
int counter_set_value_64(const struct device *dev, uint64_t ticks)
Set current counter 64-bit value.
uint64_t counter_get_top_value_64(const struct device *dev)
Function to retrieve current top value for 64 bits.
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:303
int(* counter_api_reset)(const struct device *dev)
Definition counter.h:298
int(* counter_api_start)(const struct device *dev)
Definition counter.h:295
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_set_guard_period_64(const struct device *dev, uint64_t ticks, uint32_t flags)
Set guard period in counter ticks for 64 bits.
int(* counter_api_cancel_alarm)(const struct device *dev, uint8_t chan_id)
Definition counter.h:302
int(* counter_api_get_value_64)(const struct device *dev, uint64_t *ticks)
Definition counter.h:313
int(* counter_api_get_value)(const struct device *dev, uint32_t *ticks)
Definition counter.h:297
uint64_t counter_ticks_to_ns(const struct device *dev, uint32_t ticks)
Function to convert ticks to nanoseconds.
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:300
uint32_t counter_ns_to_ticks(const struct device *dev, uint64_t ns)
Function to convert nanoseconds to ticks.
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:242
void * user_data
User data returned in callback.
Definition counter.h:267
uint32_t flags
Alarm flags (see COUNTER_ALARM_FLAGS).
Definition counter.h:271
counter_alarm_callback_64_t callback
Callback called on alarm (cannot be NULL).
Definition counter.h:263
uint64_t ticks
Number of ticks that triggers the alarm.
Definition counter.h:259
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:190
uint32_t max_top_value
Maximal (default) top value on which counter is reset (cleared or reloaded).
Definition counter.h:216
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:221
uint8_t channels
Number of channels that can be used for setting alarm.
Definition counter.h:227
counter_api_get_top_value get_top_value
Definition counter.h:334
counter_api_set_top_value set_top_value
Definition counter.h:332
counter_api_set_alarm set_alarm
Definition counter.h:330
counter_api_get_value get_value
Definition counter.h:327
counter_api_reset reset
Definition counter.h:328
counter_api_get_pending_int get_pending_int
Definition counter.h:333
counter_api_stop stop
Definition counter.h:326
counter_api_set_guard_period set_guard_period
Definition counter.h:336
counter_api_set_value set_value
Definition counter.h:329
counter_api_start start
Definition counter.h:325
counter_api_get_guard_period get_guard_period
Definition counter.h:335
counter_api_cancel_alarm cancel_alarm
Definition counter.h:331
counter_api_get_freq get_freq
Definition counter.h:337
Top value configuration structure.
Definition counter.h:276
void * user_data
User data passed to callback function (not valid if callback is NULL).
Definition counter.h:288
counter_top_callback_t callback
Callback function (can be NULL).
Definition counter.h:284
uint32_t flags
Flags (see COUNTER_TOP_FLAGS).
Definition counter.h:292
uint64_t ticks
Top value.
Definition counter.h:280
Top value configuration structure.
Definition counter.h:169
uint32_t ticks
Top value.
Definition counter.h:173
uint32_t flags
Flags (see COUNTER_TOP_FLAGS).
Definition counter.h:185
counter_top_callback_t callback
Callback function (can be NULL).
Definition counter.h:177
void * user_data
User data passed to callback function (not valid if callback is NULL).
Definition counter.h:181
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:519
const void * config
Address of device instance config information.
Definition device.h:517