13#ifndef ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_
14#define ZEPHYR_INCLUDE_DRIVERS_COUNTER_H_
46#define COUNTER_CONFIG_INFO_COUNT_UP BIT(0)
62#define COUNTER_TOP_CFG_DONT_RESET BIT(0)
70#define COUNTER_TOP_CFG_RESET_WHEN_LATE BIT(1)
87#define COUNTER_ALARM_CFG_ABSOLUTE BIT(0)
95#define COUNTER_ALARM_CFG_EXPIRE_WHEN_LATE BIT(1)
111#define COUNTER_GUARD_PERIOD_LATE_TO_SET BIT(0)
259static inline bool z_impl_counter_is_counting_up(
const struct device *dev)
276static inline uint8_t z_impl_counter_get_num_of_channels(
const struct device *dev)
294static inline uint32_t z_impl_counter_get_frequency(
const struct device *dev)
301 return api->get_freq ? api->get_freq(dev) : config->
freq;
314static inline uint32_t z_impl_counter_us_to_ticks(
const struct device *dev,
332static inline uint64_t z_impl_counter_ticks_to_us(
const struct device *dev,
347static inline uint32_t z_impl_counter_get_max_top_value(
const struct device *dev)
365static inline int z_impl_counter_start(
const struct device *dev)
370 return api->
start(dev);
384static inline int z_impl_counter_stop(
const struct device *dev)
389 return api->
stop(dev);
402static inline int z_impl_counter_get_value(
const struct device *dev,
421static inline int z_impl_counter_get_value_64(
const struct device *dev,
458static inline int z_impl_counter_set_channel_alarm(
const struct device *dev,
469 return api->
set_alarm(dev, chan_id, alarm_cfg);
487static inline int z_impl_counter_cancel_channel_alarm(
const struct device *dev,
527static inline int z_impl_counter_set_top_value(
const struct device *dev,
556static inline int z_impl_counter_get_pending_int(
const struct device *dev)
573static inline uint32_t z_impl_counter_get_top_value(
const struct device *dev)
637static inline int z_impl_counter_set_guard_period(
const struct device *dev,
664static inline uint32_t z_impl_counter_get_guard_period(
const struct device *dev,
681#include <syscalls/counter.h>
#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:226
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: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:229
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:227
uint32_t(* counter_api_get_pending_int)(const struct device *dev)
Definition: counter.h:225
uint32_t(* counter_api_get_freq)(const struct device *dev)
Definition: counter.h:232
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:223
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:221
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:218
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
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: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:234
counter_api_get_value_64 get_value_64
Definition: counter.h:238
counter_api_get_top_value get_top_value
Definition: counter.h:243
counter_api_set_top_value set_top_value
Definition: counter.h:241
counter_api_set_alarm set_alarm
Definition: counter.h:239
counter_api_get_value get_value
Definition: counter.h:237
counter_api_get_pending_int get_pending_int
Definition: counter.h:242
counter_api_stop stop
Definition: counter.h:236
counter_api_set_guard_period set_guard_period
Definition: counter.h:245
counter_api_start start
Definition: counter.h:235
counter_api_get_guard_period get_guard_period
Definition: counter.h:244
counter_api_cancel_alarm cancel_alarm
Definition: counter.h:240
counter_api_get_freq get_freq
Definition: counter.h:246
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:399
const void * api
Address of the API structure exposed by the device instance.
Definition: device.h:405
const void * config
Address of device instance config information.
Definition: device.h:403
Variables needed for system clock.