Zephyr Project API  3.3.0
A Scalable Open Source RTOS
regulator.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2019-2020 Peter Bigot Consulting, LLC
3 * Copyright (c) 2021 NXP
4 * Copyright (c) 2022 Nordic Semiconductor ASA
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
8#ifndef ZEPHYR_INCLUDE_DRIVERS_REGULATOR_H_
9#define ZEPHYR_INCLUDE_DRIVERS_REGULATOR_H_
10
18#include <errno.h>
19#include <stdint.h>
20
21#include <zephyr/device.h>
22#include <zephyr/devicetree.h>
23#include <zephyr/kernel.h>
25
26#ifdef __cplusplus
27extern "C" {
28#endif
29
32
35
38
46#define REGULATOR_ERROR_OVER_VOLTAGE BIT(0)
48#define REGULATOR_ERROR_OVER_CURRENT BIT(1)
50#define REGULATOR_ERROR_OVER_TEMP BIT(2)
51
56typedef int (*regulator_dvs_state_set_t)(const struct device *dev,
58
60__subsystem struct regulator_parent_driver_api {
61 regulator_dvs_state_set_t dvs_state_set;
62};
63
64typedef int (*regulator_enable_t)(const struct device *dev);
65typedef int (*regulator_disable_t)(const struct device *dev);
66typedef unsigned int (*regulator_count_voltages_t)(const struct device *dev);
67typedef int (*regulator_list_voltage_t)(const struct device *dev,
68 unsigned int idx, int32_t *volt_uv);
69typedef int (*regulator_set_voltage_t)(const struct device *dev, int32_t min_uv,
70 int32_t max_uv);
71typedef int (*regulator_get_voltage_t)(const struct device *dev,
72 int32_t *volt_uv);
73typedef int (*regulator_set_current_limit_t)(const struct device *dev,
74 int32_t min_ua, int32_t max_ua);
75typedef int (*regulator_get_current_limit_t)(const struct device *dev,
76 int32_t *curr_ua);
77typedef int (*regulator_set_mode_t)(const struct device *dev,
78 regulator_mode_t mode);
79typedef int (*regulator_get_mode_t)(const struct device *dev,
80 regulator_mode_t *mode);
81typedef int (*regulator_get_error_flags_t)(
82 const struct device *dev, regulator_error_flags_t *flags);
83
85__subsystem struct regulator_driver_api {
86 regulator_enable_t enable;
87 regulator_disable_t disable;
88 regulator_count_voltages_t count_voltages;
89 regulator_list_voltage_t list_voltage;
90 regulator_set_voltage_t set_voltage;
91 regulator_get_voltage_t get_voltage;
92 regulator_set_current_limit_t set_current_limit;
93 regulator_get_current_limit_t get_current_limit;
94 regulator_set_mode_t set_mode;
95 regulator_get_mode_t get_mode;
96 regulator_get_error_flags_t get_error_flags;
97};
98
105#define REGULATOR_ALWAYS_ON BIT(0)
107#define REGULATOR_BOOT_ON BIT(1)
109#define REGULATOR_INIT_ENABLED (REGULATOR_ALWAYS_ON | REGULATOR_BOOT_ON)
110
114#define REGULATOR_INITIAL_MODE_UNKNOWN UINT8_MAX
115
121struct regulator_common_config {
123 int32_t min_uv;
125 int32_t max_uv;
127 int32_t min_ua;
129 int32_t max_ua;
131 const regulator_mode_t *allowed_modes;
133 uint8_t allowed_modes_cnt;
135 regulator_mode_t initial_mode;
138};
139
145#define REGULATOR_DT_COMMON_CONFIG_INIT(node_id) \
146 { \
147 .min_uv = DT_PROP_OR(node_id, regulator_min_microvolt, \
148 INT32_MIN), \
149 .max_uv = DT_PROP_OR(node_id, regulator_max_microvolt, \
150 INT32_MAX), \
151 .min_ua = DT_PROP_OR(node_id, regulator_min_microamp, \
152 INT32_MIN), \
153 .max_ua = DT_PROP_OR(node_id, regulator_max_microamp, \
154 INT32_MAX), \
155 .allowed_modes = (const regulator_mode_t []) \
156 DT_PROP_OR(node_id, regulator_allowed_modes, {}), \
157 .allowed_modes_cnt = \
158 DT_PROP_LEN_OR(node_id, regulator_allowed_modes, 0), \
159 .initial_mode = DT_PROP_OR(node_id, regulator_initial_mode, \
160 REGULATOR_INITIAL_MODE_UNKNOWN), \
161 .flags = ((DT_PROP_OR(node_id, regulator_always_on, 0U) * \
162 REGULATOR_ALWAYS_ON) | \
163 (DT_PROP_OR(node_id, regulator_boot_on, 0U) * \
164 REGULATOR_BOOT_ON)), \
165 }
166
172#define REGULATOR_DT_INST_COMMON_CONFIG_INIT(inst) \
173 REGULATOR_DT_COMMON_CONFIG_INIT(DT_DRV_INST(inst))
174
180struct regulator_common_data {
182 struct k_mutex lock;
184 int refcnt;
185};
186
194void regulator_common_data_init(const struct device *dev);
195
217int regulator_common_init(const struct device *dev, bool is_enabled);
218
246static inline int regulator_parent_dvs_state_set(const struct device *dev,
248{
249 const struct regulator_parent_driver_api *api =
250 (const struct regulator_parent_driver_api *)dev->api;
251
252 if (api->dvs_state_set == NULL) {
253 return -ENOSYS;
254 }
255
256 return api->dvs_state_set(dev, state);
257}
258
274int regulator_enable(const struct device *dev);
275
284bool regulator_is_enabled(const struct device *dev);
285
301int regulator_disable(const struct device *dev);
302
314static inline unsigned int regulator_count_voltages(const struct device *dev)
315{
316 const struct regulator_driver_api *api =
317 (const struct regulator_driver_api *)dev->api;
318
319 if (api->count_voltages == NULL) {
320 return 0U;
321 }
322
323 return api->count_voltages(dev);
324}
325
341static inline int regulator_list_voltage(const struct device *dev,
342 unsigned int idx, int32_t *volt_uv)
343{
344 const struct regulator_driver_api *api =
345 (const struct regulator_driver_api *)dev->api;
346
347 if (api->list_voltage == NULL) {
348 return -EINVAL;
349 }
350
351 return api->list_voltage(dev, idx, volt_uv);
352}
353
364bool regulator_is_supported_voltage(const struct device *dev, int32_t min_uv,
365 int32_t max_uv);
366
385int regulator_set_voltage(const struct device *dev, int32_t min_uv,
386 int32_t max_uv);
387
398static inline int regulator_get_voltage(const struct device *dev,
399 int32_t *volt_uv)
400{
401 const struct regulator_driver_api *api =
402 (const struct regulator_driver_api *)dev->api;
403
404 if (api->get_voltage == NULL) {
405 return -ENOSYS;
406 }
407
408 return api->get_voltage(dev, volt_uv);
409}
410
428int regulator_set_current_limit(const struct device *dev, int32_t min_ua,
429 int32_t max_ua);
430
441static inline int regulator_get_current_limit(const struct device *dev,
442 int32_t *curr_ua)
443{
444 const struct regulator_driver_api *api =
445 (const struct regulator_driver_api *)dev->api;
446
447 if (api->get_current_limit == NULL) {
448 return -ENOSYS;
449 }
450
451 return api->get_current_limit(dev, curr_ua);
452}
453
470int regulator_set_mode(const struct device *dev, regulator_mode_t mode);
471
482static inline int regulator_get_mode(const struct device *dev,
483 regulator_mode_t *mode)
484{
485 const struct regulator_driver_api *api =
486 (const struct regulator_driver_api *)dev->api;
487
488 if (api->get_mode == NULL) {
489 return -ENOSYS;
490 }
491
492 return api->get_mode(dev, mode);
493}
494
505static inline int regulator_get_error_flags(const struct device *dev,
507{
508 const struct regulator_driver_api *api =
509 (const struct regulator_driver_api *)dev->api;
510
511 if (api->get_error_flags == NULL) {
512 return -ENOSYS;
513 }
514
515 return api->get_error_flags(dev, flags);
516}
517
518#ifdef __cplusplus
519}
520#endif
521
524#endif /* ZEPHYR_INCLUDE_DRIVERS_REGULATOR_H_ */
Devicetree main header.
System error numbers.
int regulator_enable(const struct device *dev)
Enable a regulator.
int regulator_set_mode(const struct device *dev, regulator_mode_t mode)
Set mode.
uint8_t regulator_mode_t
Definition: regulator.h:34
bool regulator_is_enabled(const struct device *dev)
Check if a regulator is enabled.
int regulator_set_voltage(const struct device *dev, int32_t min_uv, int32_t max_uv)
Set the output voltage.
int regulator_set_current_limit(const struct device *dev, int32_t min_ua, int32_t max_ua)
Set output current limit.
bool regulator_is_supported_voltage(const struct device *dev, int32_t min_uv, int32_t max_uv)
Check if a voltage within a window is supported.
uint8_t regulator_error_flags_t
Definition: regulator.h:37
static int regulator_list_voltage(const struct device *dev, unsigned int idx, int32_t *volt_uv)
Obtain the value of a voltage given an index.
Definition: regulator.h:341
static int regulator_get_current_limit(const struct device *dev, int32_t *curr_ua)
Get output current limit.
Definition: regulator.h:441
static int regulator_get_error_flags(const struct device *dev, regulator_error_flags_t *flags)
Get active error flags.
Definition: regulator.h:505
static unsigned int regulator_count_voltages(const struct device *dev)
Obtain the number of supported voltage levels.
Definition: regulator.h:314
uint8_t regulator_dvs_state_t
Definition: regulator.h:31
static int regulator_get_mode(const struct device *dev, regulator_mode_t *mode)
Get mode.
Definition: regulator.h:482
static int regulator_get_voltage(const struct device *dev, int32_t *volt_uv)
Obtain output voltage.
Definition: regulator.h:398
int regulator_disable(const struct device *dev)
Disable a regulator.
static int regulator_parent_dvs_state_set(const struct device *dev, regulator_dvs_state_t state)
Set a DVS state.
Definition: regulator.h:246
#define EINVAL
Definition: errno.h:61
#define ENOSYS
Definition: errno.h:83
Public kernel APIs.
flags
Definition: parser.h:96
state
Definition: parser_state.h:29
static struct k_spinlock lock
Definition: spinlock_error_case.c:13
__INT32_TYPE__ int32_t
Definition: stdint.h:74
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
Runtime device structure (in ROM) per driver instance.
Definition: device.h:378
const void * api
Definition: device.h:384
Definition: kernel.h:2764
Macro utilities.