14#ifndef ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_H_
15#define ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_H_
37#define CLOCK_CONTROL_SUBSYS_ALL NULL
127 return api->
on(dev, sys);
150 return api->
off(dev, sys);
236 return api->
get_rate(dev, sys, rate);
270 return api->
set_rate(dev, sys, rate);
static int clock_control_get_rate(const struct device *dev, clock_control_subsys_t sys, uint32_t *rate)
Obtain the clock rate of given sub-system.
Definition: clock_control.h:221
static int clock_control_async_on(const struct device *dev, clock_control_subsys_t sys, clock_control_cb_t cb, void *user_data)
Request clock to start with notification when clock has been started.
Definition: clock_control.h:170
void * clock_control_subsys_rate_t
Definition: clock_control.h:63
enum clock_control_status(* clock_control_get_status_fn)(const struct device *dev, clock_control_subsys_t sys)
Definition: clock_control.h:87
int(* clock_control_async_on_fn)(const struct device *dev, clock_control_subsys_t sys, clock_control_cb_t cb, void *user_data)
Definition: clock_control.h:82
void(* clock_control_cb_t)(const struct device *dev, clock_control_subsys_t subsys, void *user_data)
Callback called on clock started.
Definition: clock_control.h:71
static enum clock_control_status clock_control_get_status(const struct device *dev, clock_control_subsys_t sys)
Get clock status.
Definition: clock_control.h:197
static int clock_control_set_rate(const struct device *dev, clock_control_subsys_t sys, clock_control_subsys_rate_t rate)
Set the rate of the clock controlled by the device.
Definition: clock_control.h:255
int(* clock_control_get)(const struct device *dev, clock_control_subsys_t sys, uint32_t *rate)
Definition: clock_control.h:78
int(* clock_control)(const struct device *dev, clock_control_subsys_t sys)
Definition: clock_control.h:75
int(* clock_control_set)(const struct device *dev, clock_control_subsys_t sys, clock_control_subsys_rate_t rate)
Definition: clock_control.h:91
void * clock_control_subsys_t
Definition: clock_control.h:55
clock_control_status
Current clock status.
Definition: clock_control.h:42
static int clock_control_off(const struct device *dev, clock_control_subsys_t sys)
Disable a clock controlled by the device.
Definition: clock_control.h:140
static int clock_control_on(const struct device *dev, clock_control_subsys_t sys)
Enable a clock controlled by the device.
Definition: clock_control.h:117
@ CLOCK_CONTROL_STATUS_ON
Definition: clock_control.h:45
@ CLOCK_CONTROL_STATUS_OFF
Definition: clock_control.h:44
@ CLOCK_CONTROL_STATUS_UNKNOWN
Definition: clock_control.h:47
@ CLOCK_CONTROL_STATUS_UNAVAILABLE
Definition: clock_control.h:46
@ CLOCK_CONTROL_STATUS_STARTING
Definition: clock_control.h:43
bool device_is_ready(const struct device *dev)
Verify that a device is ready for use.
#define ENOSYS
Definition: errno.h:83
#define ENODEV
Definition: errno.h:58
Single-linked list implementation.
__UINT32_TYPE__ uint32_t
Definition: stdint.h:60
Definition: clock_control.h:95
clock_control_set set_rate
Definition: clock_control.h:101
clock_control on
Definition: clock_control.h:96
clock_control_get_status_fn get_status
Definition: clock_control.h:100
clock_control off
Definition: clock_control.h:97
clock_control_async_on_fn async_on
Definition: clock_control.h:98
clock_control_get get_rate
Definition: clock_control.h:99
Runtime device structure (in ROM) per driver instance.
Definition: device.h:450
const void * api
Definition: device.h:456
static const intptr_t user_data[5]
Definition: main.c:590