1 /*
2 * Copyright (c) 2023 Nordic Semiconductor ASA
3 * SPDX-License-Identifier: Apache-2.0
4 */
5
6 #define DT_DRV_COMPAT nordic_npm1300_regulator
7
8 #include <errno.h>
9 #include <string.h>
10
11 #include <zephyr/drivers/gpio.h>
12 #include <zephyr/drivers/regulator.h>
13 #include <zephyr/drivers/mfd/npm1300.h>
14 #include <zephyr/dt-bindings/regulator/npm1300.h>
15 #include <zephyr/sys/linear_range.h>
16 #include <zephyr/sys/util.h>
17
18 /* nPM1300 voltage sources */
19 enum npm1300_sources {
20 NPM1300_SOURCE_BUCK1,
21 NPM1300_SOURCE_BUCK2,
22 NPM1300_SOURCE_LDO1,
23 NPM1300_SOURCE_LDO2,
24 };
25
26 /* nPM1300 gpio control channels */
27 enum npm1300_gpio_type {
28 NPM1300_GPIO_TYPE_ENABLE,
29 NPM1300_GPIO_TYPE_RETENTION,
30 NPM1300_GPIO_TYPE_PWM
31 };
32
33 /* nPM1300 regulator base addresses */
34 #define BUCK_BASE 0x04U
35 #define LDSW_BASE 0x08U
36 #define SHIP_BASE 0x0BU
37
38 /* nPM1300 regulator register offsets */
39 #define BUCK_OFFSET_EN_SET 0x00U
40 #define BUCK_OFFSET_EN_CLR 0x01U
41 #define BUCK_OFFSET_PWM_SET 0x04U
42 #define BUCK_OFFSET_PWM_CLR 0x05U
43 #define BUCK_OFFSET_VOUT_NORM 0x08U
44 #define BUCK_OFFSET_VOUT_RET 0x09U
45 #define BUCK_OFFSET_EN_CTRL 0x0CU
46 #define BUCK_OFFSET_VRET_CTRL 0x0DU
47 #define BUCK_OFFSET_PWM_CTRL 0x0EU
48 #define BUCK_OFFSET_SW_CTRL 0x0FU
49 #define BUCK_OFFSET_VOUT_STAT 0x10U
50 #define BUCK_OFFSET_CTRL0 0x15U
51 #define BUCK_OFFSET_STATUS 0x34U
52
53 /* nPM1300 ldsw register offsets */
54 #define LDSW_OFFSET_EN_SET 0x00U
55 #define LDSW_OFFSET_EN_CLR 0x01U
56 #define LDSW_OFFSET_STATUS 0x04U
57 #define LDSW_OFFSET_GPISEL 0x05U
58 #define LDSW_OFFSET_CONFIG 0x07U
59 #define LDSW_OFFSET_LDOSEL 0x08U
60 #define LDSW_OFFSET_VOUTSEL 0x0CU
61
62 /* nPM1300 ship register offsets */
63 #define SHIP_OFFSET_SHIP 0x02U
64
65 #define BUCK1_ON_MASK 0x04U
66 #define BUCK2_ON_MASK 0x40U
67
68 #define LDSW1_ON_MASK 0x03U
69 #define LDSW2_ON_MASK 0x0CU
70
71 #define LDSW1_SOFTSTART_MASK 0x0CU
72 #define LDSW1_SOFTSTART_SHIFT 2U
73 #define LDSW2_SOFTSTART_MASK 0x30U
74 #define LDSW2_SOFTSTART_SHIFT 4U
75
76 struct regulator_npm1300_pconfig {
77 const struct device *mfd;
78 struct gpio_dt_spec dvs_state_pins[5];
79 };
80
81 struct regulator_npm1300_config {
82 struct regulator_common_config common;
83 const struct device *mfd;
84 uint8_t source;
85 int32_t retention_uv;
86 struct gpio_dt_spec enable_gpios;
87 struct gpio_dt_spec retention_gpios;
88 struct gpio_dt_spec pwm_gpios;
89 uint8_t soft_start;
90 };
91
92 struct regulator_npm1300_data {
93 struct regulator_common_data data;
94 };
95
96 /* Linear range for output voltage, common for all bucks and LDOs on this device */
97 static const struct linear_range buckldo_range = LINEAR_RANGE_INIT(1000000, 100000, 0U, 23U);
98
regulator_npm1300_count_voltages(const struct device * dev)99 unsigned int regulator_npm1300_count_voltages(const struct device *dev)
100 {
101 const struct regulator_npm1300_config *config = dev->config;
102
103 switch (config->source) {
104 case NPM1300_SOURCE_BUCK1:
105 case NPM1300_SOURCE_BUCK2:
106 case NPM1300_SOURCE_LDO1:
107 case NPM1300_SOURCE_LDO2:
108 return linear_range_values_count(&buckldo_range);
109 default:
110 return 0;
111 }
112 }
113
regulator_npm1300_list_voltage(const struct device * dev,unsigned int idx,int32_t * volt_uv)114 int regulator_npm1300_list_voltage(const struct device *dev, unsigned int idx, int32_t *volt_uv)
115 {
116 const struct regulator_npm1300_config *config = dev->config;
117
118 switch (config->source) {
119 case NPM1300_SOURCE_BUCK1:
120 case NPM1300_SOURCE_BUCK2:
121 case NPM1300_SOURCE_LDO1:
122 case NPM1300_SOURCE_LDO2:
123 return linear_range_get_value(&buckldo_range, idx, volt_uv);
124 default:
125 return -EINVAL;
126 }
127 }
128
retention_set_voltage(const struct device * dev,int32_t retention_uv)129 static int retention_set_voltage(const struct device *dev, int32_t retention_uv)
130 {
131 const struct regulator_npm1300_config *config = dev->config;
132 uint16_t idx;
133 uint8_t chan;
134 int ret;
135
136 switch (config->source) {
137 case NPM1300_SOURCE_BUCK1:
138 chan = 0U;
139 break;
140 case NPM1300_SOURCE_BUCK2:
141 chan = 1U;
142 break;
143 default:
144 return -ENOTSUP;
145 }
146
147 ret = linear_range_get_win_index(&buckldo_range, retention_uv, retention_uv, &idx);
148
149 if (ret == -EINVAL) {
150 return ret;
151 }
152
153 return mfd_npm1300_reg_write(config->mfd, BUCK_BASE, BUCK_OFFSET_VOUT_RET + (chan * 2U),
154 idx);
155 }
156
buck_get_voltage_index(const struct device * dev,uint8_t chan,uint8_t * idx)157 static int buck_get_voltage_index(const struct device *dev, uint8_t chan, uint8_t *idx)
158 {
159 const struct regulator_npm1300_config *config = dev->config;
160 uint8_t sel;
161 int ret;
162
163 ret = mfd_npm1300_reg_read(config->mfd, BUCK_BASE, BUCK_OFFSET_SW_CTRL, &sel);
164
165 if (ret < 0) {
166 return ret;
167 }
168
169 if ((sel >> chan) & 1U) {
170 /* SW control */
171 return mfd_npm1300_reg_read(config->mfd, BUCK_BASE,
172 BUCK_OFFSET_VOUT_NORM + (chan * 2U), idx);
173 }
174
175 /* VSET pin control */
176 return mfd_npm1300_reg_read(config->mfd, BUCK_BASE, BUCK_OFFSET_VOUT_STAT + chan, idx);
177 }
178
buck_set_voltage(const struct device * dev,uint8_t chan,int32_t min_uv,int32_t max_uv)179 static int buck_set_voltage(const struct device *dev, uint8_t chan, int32_t min_uv, int32_t max_uv)
180 {
181 const struct regulator_npm1300_config *config = dev->config;
182 uint8_t mask;
183 uint8_t curr_idx;
184 uint16_t idx;
185 int ret;
186
187 ret = linear_range_get_win_index(&buckldo_range, min_uv, max_uv, &idx);
188
189 if (ret == -EINVAL) {
190 return ret;
191 }
192
193 /* Get current setting, and return if current and new index match */
194 ret = buck_get_voltage_index(dev, chan, &curr_idx);
195
196 if ((ret < 0) || (idx == curr_idx)) {
197 return ret;
198 }
199
200 ret = mfd_npm1300_reg_write(config->mfd, BUCK_BASE, BUCK_OFFSET_VOUT_NORM + (chan * 2U),
201 idx);
202
203 if (ret < 0) {
204 return ret;
205 }
206
207 /* Enable SW control of buck output */
208 mask = BIT(chan);
209 return mfd_npm1300_reg_update(config->mfd, BUCK_BASE, BUCK_OFFSET_SW_CTRL, mask, mask);
210 }
211
ldo_set_voltage(const struct device * dev,uint8_t chan,int32_t min_uv,int32_t max_uv)212 static int ldo_set_voltage(const struct device *dev, uint8_t chan, int32_t min_uv, int32_t max_uv)
213 {
214 const struct regulator_npm1300_config *config = dev->config;
215 uint16_t idx;
216 int ret;
217
218 ret = linear_range_get_win_index(&buckldo_range, min_uv, max_uv, &idx);
219
220 if (ret == -EINVAL) {
221 return ret;
222 }
223
224 return mfd_npm1300_reg_write(config->mfd, LDSW_BASE, LDSW_OFFSET_VOUTSEL + chan, idx);
225 }
226
regulator_npm1300_set_voltage(const struct device * dev,int32_t min_uv,int32_t max_uv)227 int regulator_npm1300_set_voltage(const struct device *dev, int32_t min_uv, int32_t max_uv)
228 {
229 const struct regulator_npm1300_config *config = dev->config;
230
231 switch (config->source) {
232 case NPM1300_SOURCE_BUCK1:
233 return buck_set_voltage(dev, 0, min_uv, max_uv);
234 case NPM1300_SOURCE_BUCK2:
235 return buck_set_voltage(dev, 1, min_uv, max_uv);
236 case NPM1300_SOURCE_LDO1:
237 return ldo_set_voltage(dev, 0, min_uv, max_uv);
238 case NPM1300_SOURCE_LDO2:
239 return ldo_set_voltage(dev, 1, min_uv, max_uv);
240 default:
241 return -ENODEV;
242 }
243 }
244
buck_get_voltage(const struct device * dev,uint8_t chan,int32_t * volt_uv)245 static int buck_get_voltage(const struct device *dev, uint8_t chan, int32_t *volt_uv)
246 {
247 uint8_t idx;
248 int ret;
249
250 ret = buck_get_voltage_index(dev, chan, &idx);
251
252 if (ret < 0) {
253 return ret;
254 }
255
256 return linear_range_get_value(&buckldo_range, idx, volt_uv);
257 }
258
ldo_get_voltage(const struct device * dev,uint8_t chan,int32_t * volt_uv)259 static int ldo_get_voltage(const struct device *dev, uint8_t chan, int32_t *volt_uv)
260 {
261 const struct regulator_npm1300_config *config = dev->config;
262 uint8_t idx;
263 int ret;
264
265 ret = mfd_npm1300_reg_read(config->mfd, LDSW_BASE, LDSW_OFFSET_VOUTSEL + chan, &idx);
266
267 if (ret < 0) {
268 return ret;
269 }
270
271 return linear_range_get_value(&buckldo_range, idx, volt_uv);
272 }
273
regulator_npm1300_get_voltage(const struct device * dev,int32_t * volt_uv)274 int regulator_npm1300_get_voltage(const struct device *dev, int32_t *volt_uv)
275 {
276 const struct regulator_npm1300_config *config = dev->config;
277
278 switch (config->source) {
279 case NPM1300_SOURCE_BUCK1:
280 return buck_get_voltage(dev, 0, volt_uv);
281 case NPM1300_SOURCE_BUCK2:
282 return buck_get_voltage(dev, 1, volt_uv);
283 case NPM1300_SOURCE_LDO1:
284 return ldo_get_voltage(dev, 0, volt_uv);
285 case NPM1300_SOURCE_LDO2:
286 return ldo_get_voltage(dev, 1, volt_uv);
287 default:
288 return -ENODEV;
289 }
290 }
291
set_buck_mode(const struct device * dev,uint8_t chan,regulator_mode_t mode)292 static int set_buck_mode(const struct device *dev, uint8_t chan, regulator_mode_t mode)
293 {
294 const struct regulator_npm1300_config *config = dev->config;
295 uint8_t pfm_mask = BIT(chan);
296 uint8_t pfm_data;
297 uint8_t pwm_reg;
298 int ret;
299
300 switch (mode) {
301 case NPM1300_BUCK_MODE_PWM:
302 pfm_data = 0U;
303 pwm_reg = BUCK_OFFSET_PWM_SET;
304 break;
305 case NPM1300_BUCK_MODE_AUTO:
306 pfm_data = 0U;
307 pwm_reg = BUCK_OFFSET_PWM_CLR;
308 break;
309 case NPM1300_BUCK_MODE_PFM:
310 pfm_data = pfm_mask;
311 pwm_reg = BUCK_OFFSET_PWM_CLR;
312 break;
313 default:
314 return -ENOTSUP;
315 }
316
317 ret = mfd_npm1300_reg_update(config->mfd, BUCK_BASE, BUCK_OFFSET_CTRL0, pfm_data, pfm_mask);
318 if (ret < 0) {
319 return ret;
320 }
321
322 return mfd_npm1300_reg_write(config->mfd, BUCK_BASE, pwm_reg + (chan * 2U), 1U);
323 }
324
set_ldsw_mode(const struct device * dev,uint8_t chan,regulator_mode_t mode)325 static int set_ldsw_mode(const struct device *dev, uint8_t chan, regulator_mode_t mode)
326 {
327 const struct regulator_npm1300_config *config = dev->config;
328
329 switch (mode) {
330 case NPM1300_LDSW_MODE_LDO:
331 return mfd_npm1300_reg_write(config->mfd, LDSW_BASE, LDSW_OFFSET_LDOSEL + chan, 1U);
332 case NPM1300_LDSW_MODE_LDSW:
333 return mfd_npm1300_reg_write(config->mfd, LDSW_BASE, LDSW_OFFSET_LDOSEL + chan, 0U);
334 default:
335 return -ENOTSUP;
336 }
337 }
338
regulator_npm1300_set_mode(const struct device * dev,regulator_mode_t mode)339 int regulator_npm1300_set_mode(const struct device *dev, regulator_mode_t mode)
340 {
341 const struct regulator_npm1300_config *config = dev->config;
342
343 switch (config->source) {
344 case NPM1300_SOURCE_BUCK1:
345 return set_buck_mode(dev, 0, mode);
346 case NPM1300_SOURCE_BUCK2:
347 return set_buck_mode(dev, 1, mode);
348 case NPM1300_SOURCE_LDO1:
349 return set_ldsw_mode(dev, 0, mode);
350 case NPM1300_SOURCE_LDO2:
351 return set_ldsw_mode(dev, 1, mode);
352 default:
353 return -ENOTSUP;
354 }
355 }
356
regulator_npm1300_enable(const struct device * dev)357 int regulator_npm1300_enable(const struct device *dev)
358 {
359 const struct regulator_npm1300_config *config = dev->config;
360
361 switch (config->source) {
362 case NPM1300_SOURCE_BUCK1:
363 return mfd_npm1300_reg_write(config->mfd, BUCK_BASE, BUCK_OFFSET_EN_SET, 1U);
364 case NPM1300_SOURCE_BUCK2:
365 return mfd_npm1300_reg_write(config->mfd, BUCK_BASE, BUCK_OFFSET_EN_SET + 2U, 1U);
366 case NPM1300_SOURCE_LDO1:
367 return mfd_npm1300_reg_write(config->mfd, LDSW_BASE, LDSW_OFFSET_EN_SET, 1U);
368 case NPM1300_SOURCE_LDO2:
369 return mfd_npm1300_reg_write(config->mfd, LDSW_BASE, LDSW_OFFSET_EN_SET + 2U, 1U);
370 default:
371 return 0;
372 }
373 }
374
regulator_npm1300_disable(const struct device * dev)375 int regulator_npm1300_disable(const struct device *dev)
376 {
377 const struct regulator_npm1300_config *config = dev->config;
378
379 switch (config->source) {
380 case NPM1300_SOURCE_BUCK1:
381 return mfd_npm1300_reg_write(config->mfd, BUCK_BASE, BUCK_OFFSET_EN_CLR, 1U);
382 case NPM1300_SOURCE_BUCK2:
383 return mfd_npm1300_reg_write(config->mfd, BUCK_BASE, BUCK_OFFSET_EN_CLR + 2U, 1U);
384 case NPM1300_SOURCE_LDO1:
385 return mfd_npm1300_reg_write(config->mfd, LDSW_BASE, LDSW_OFFSET_EN_CLR, 1U);
386 case NPM1300_SOURCE_LDO2:
387 return mfd_npm1300_reg_write(config->mfd, LDSW_BASE, LDSW_OFFSET_EN_CLR + 2U, 1U);
388 default:
389 return 0;
390 }
391 }
392
regulator_npm1300_set_buck_pin_ctrl(const struct device * dev,uint8_t chan,uint8_t pin,uint8_t inv,enum npm1300_gpio_type type)393 static int regulator_npm1300_set_buck_pin_ctrl(const struct device *dev, uint8_t chan, uint8_t pin,
394 uint8_t inv, enum npm1300_gpio_type type)
395 {
396 const struct regulator_npm1300_config *config = dev->config;
397 uint8_t ctrl;
398 uint8_t mask;
399
400 switch (chan) {
401 case 0:
402 /* Invert control in bit 6, pin control in bits 2-0 */
403 ctrl = (inv << 6U) | (pin + 1U);
404 mask = BIT(6U) | BIT_MASK(3U);
405 break;
406 case 1:
407 /* Invert control in bit 7, pin control in bits 5-3 */
408 ctrl = (inv << 7U) | ((pin + 1U) << 3U);
409 mask = BIT(7U) | (BIT_MASK(3U) << 3U);
410 break;
411 default:
412 return -EINVAL;
413 }
414
415 switch (type) {
416 case NPM1300_GPIO_TYPE_ENABLE:
417 return mfd_npm1300_reg_update(config->mfd, BUCK_BASE, BUCK_OFFSET_EN_CTRL, ctrl,
418 mask);
419 case NPM1300_GPIO_TYPE_PWM:
420 return mfd_npm1300_reg_update(config->mfd, BUCK_BASE, BUCK_OFFSET_PWM_CTRL, ctrl,
421 mask);
422 case NPM1300_GPIO_TYPE_RETENTION:
423 return mfd_npm1300_reg_update(config->mfd, BUCK_BASE, BUCK_OFFSET_VRET_CTRL, ctrl,
424 mask);
425 default:
426 return -ENOTSUP;
427 }
428 }
429
regulator_npm1300_set_ldsw_pin_ctrl(const struct device * dev,uint8_t chan,uint8_t pin,uint8_t inv,enum npm1300_gpio_type type)430 static int regulator_npm1300_set_ldsw_pin_ctrl(const struct device *dev, uint8_t chan, uint8_t pin,
431 uint8_t inv, enum npm1300_gpio_type type)
432 {
433 const struct regulator_npm1300_config *config = dev->config;
434 uint8_t ctrl;
435
436 if (type != NPM1300_GPIO_TYPE_ENABLE) {
437 return -ENOTSUP;
438 }
439
440 ctrl = (pin + 1U) | (inv << 3U);
441
442 return mfd_npm1300_reg_write(config->mfd, LDSW_BASE, LDSW_OFFSET_GPISEL + chan, ctrl);
443 }
444
regulator_npm1300_set_pin_ctrl(const struct device * dev,const struct gpio_dt_spec * spec,enum npm1300_gpio_type type)445 int regulator_npm1300_set_pin_ctrl(const struct device *dev, const struct gpio_dt_spec *spec,
446 enum npm1300_gpio_type type)
447 {
448 const struct regulator_npm1300_config *config = dev->config;
449 uint8_t inv;
450
451 if (spec->port == NULL) {
452 return 0;
453 }
454
455 inv = (spec->dt_flags & GPIO_ACTIVE_LOW) != 0U;
456
457 switch (config->source) {
458 case NPM1300_SOURCE_BUCK1:
459 return regulator_npm1300_set_buck_pin_ctrl(dev, 0, spec->pin, inv, type);
460 case NPM1300_SOURCE_BUCK2:
461 return regulator_npm1300_set_buck_pin_ctrl(dev, 1, spec->pin, inv, type);
462 case NPM1300_SOURCE_LDO1:
463 return regulator_npm1300_set_ldsw_pin_ctrl(dev, 0, spec->pin, inv, type);
464 case NPM1300_SOURCE_LDO2:
465 return regulator_npm1300_set_ldsw_pin_ctrl(dev, 1, spec->pin, inv, type);
466 default:
467 return -ENODEV;
468 }
469 }
470
regulator_npm1300_dvs_state_set(const struct device * dev,regulator_dvs_state_t state)471 int regulator_npm1300_dvs_state_set(const struct device *dev, regulator_dvs_state_t state)
472 {
473 const struct regulator_npm1300_pconfig *pconfig = dev->config;
474 const struct gpio_dt_spec *spec;
475 int ret;
476
477 for (size_t idx = 0U; idx < 5U; idx++) {
478 spec = &pconfig->dvs_state_pins[idx];
479
480 if (spec->port != NULL) {
481 ret = gpio_pin_set_dt(spec, ((state >> idx) & 1U) != 0U);
482
483 if (ret != 0) {
484 return ret;
485 }
486 }
487 }
488
489 return 0;
490 }
491
regulator_npm1300_ship_mode(const struct device * dev)492 int regulator_npm1300_ship_mode(const struct device *dev)
493 {
494 const struct regulator_npm1300_pconfig *pconfig = dev->config;
495
496 return mfd_npm1300_reg_write(pconfig->mfd, SHIP_BASE, SHIP_OFFSET_SHIP, 1U);
497 }
498
499 static DEVICE_API(regulator_parent, parent_api) = {
500 .dvs_state_set = regulator_npm1300_dvs_state_set,
501 .ship_mode = regulator_npm1300_ship_mode,
502 };
503
regulator_npm1300_common_init(const struct device * dev)504 int regulator_npm1300_common_init(const struct device *dev)
505 {
506 const struct regulator_npm1300_pconfig *pconfig = dev->config;
507 const struct gpio_dt_spec *spec;
508 int ret;
509
510 for (size_t idx = 0U; idx < 5U; idx++) {
511 spec = &pconfig->dvs_state_pins[idx];
512
513 if (spec->port != NULL) {
514 if (!gpio_is_ready_dt(spec)) {
515 return -ENODEV;
516 }
517
518 ret = gpio_pin_configure_dt(spec, GPIO_OUTPUT);
519 if (ret != 0) {
520 return ret;
521 }
522 }
523 }
524
525 return 0;
526 }
527
get_enabled_reg(const struct device * dev,uint8_t base,uint8_t offset,uint8_t mask,bool * enabled)528 static int get_enabled_reg(const struct device *dev, uint8_t base, uint8_t offset, uint8_t mask,
529 bool *enabled)
530 {
531 const struct regulator_npm1300_config *config = dev->config;
532 uint8_t data;
533
534 int ret = mfd_npm1300_reg_read(config->mfd, base, offset, &data);
535
536 if (ret < 0) {
537 return ret;
538 }
539
540 *enabled = (data & mask) != 0U;
541
542 return 0;
543 }
544
get_enabled(const struct device * dev,bool * enabled)545 static int get_enabled(const struct device *dev, bool *enabled)
546 {
547 const struct regulator_npm1300_config *config = dev->config;
548
549 switch (config->source) {
550 case NPM1300_SOURCE_BUCK1:
551 return get_enabled_reg(dev, BUCK_BASE, BUCK_OFFSET_STATUS, BUCK1_ON_MASK, enabled);
552 case NPM1300_SOURCE_BUCK2:
553 return get_enabled_reg(dev, BUCK_BASE, BUCK_OFFSET_STATUS, BUCK2_ON_MASK, enabled);
554 case NPM1300_SOURCE_LDO1:
555 return get_enabled_reg(dev, LDSW_BASE, LDSW_OFFSET_STATUS, LDSW1_ON_MASK, enabled);
556 case NPM1300_SOURCE_LDO2:
557 return get_enabled_reg(dev, LDSW_BASE, LDSW_OFFSET_STATUS, LDSW2_ON_MASK, enabled);
558 default:
559 return -ENODEV;
560 }
561 }
562
soft_start_set(const struct device * dev,uint8_t soft_start)563 static int soft_start_set(const struct device *dev, uint8_t soft_start)
564 {
565 const struct regulator_npm1300_config *config = dev->config;
566
567 switch (config->source) {
568 case NPM1300_SOURCE_LDO1:
569 return mfd_npm1300_reg_update(config->mfd, LDSW_BASE, LDSW_OFFSET_CONFIG,
570 soft_start << LDSW1_SOFTSTART_SHIFT,
571 LDSW1_SOFTSTART_MASK);
572 case NPM1300_SOURCE_LDO2:
573 return mfd_npm1300_reg_update(config->mfd, LDSW_BASE, LDSW_OFFSET_CONFIG,
574 soft_start << LDSW2_SOFTSTART_SHIFT,
575 LDSW2_SOFTSTART_MASK);
576 default:
577 return -ENOTSUP;
578 }
579 }
580
regulator_npm1300_init(const struct device * dev)581 int regulator_npm1300_init(const struct device *dev)
582 {
583 const struct regulator_npm1300_config *config = dev->config;
584 bool enabled;
585 int ret = 0;
586
587 if (!device_is_ready(config->mfd)) {
588 return -ENODEV;
589 }
590
591 ret = get_enabled(dev, &enabled);
592 if (ret < 0) {
593 return ret;
594 }
595
596 ret = regulator_common_init(dev, enabled);
597 if (ret < 0) {
598 return ret;
599 }
600
601 /* Configure retention voltage */
602 if (config->retention_uv != 0) {
603 ret = retention_set_voltage(dev, config->retention_uv);
604 if (ret != 0) {
605 return ret;
606 }
607 }
608
609 /* Configure soft start */
610 if (config->soft_start != UINT8_MAX) {
611 ret = soft_start_set(dev, config->soft_start);
612 if (ret != 0) {
613 return ret;
614 }
615 }
616
617 /* Configure GPIO pin control */
618 ret = regulator_npm1300_set_pin_ctrl(dev, &config->enable_gpios, NPM1300_GPIO_TYPE_ENABLE);
619 if (ret != 0) {
620 return ret;
621 }
622
623 ret = regulator_npm1300_set_pin_ctrl(dev, &config->retention_gpios,
624 NPM1300_GPIO_TYPE_RETENTION);
625 if (ret != 0) {
626 return ret;
627 }
628
629 ret = regulator_npm1300_set_pin_ctrl(dev, &config->pwm_gpios, NPM1300_GPIO_TYPE_PWM);
630 if (ret != 0) {
631 return ret;
632 }
633
634 return ret;
635 }
636
637 static DEVICE_API(regulator, api) = {
638 .enable = regulator_npm1300_enable,
639 .disable = regulator_npm1300_disable,
640 .count_voltages = regulator_npm1300_count_voltages,
641 .list_voltage = regulator_npm1300_list_voltage,
642 .set_voltage = regulator_npm1300_set_voltage,
643 .get_voltage = regulator_npm1300_get_voltage,
644 .set_mode = regulator_npm1300_set_mode,
645 };
646
647 #define REGULATOR_NPM1300_DEFINE(node_id, id, _source) \
648 static struct regulator_npm1300_data data_##id; \
649 \
650 static const struct regulator_npm1300_config config_##id = { \
651 .common = REGULATOR_DT_COMMON_CONFIG_INIT(node_id), \
652 .mfd = DEVICE_DT_GET(DT_GPARENT(node_id)), \
653 .source = _source, \
654 .retention_uv = DT_PROP_OR(node_id, retention_microvolt, 0), \
655 .soft_start = DT_ENUM_IDX_OR(node_id, soft_start_microamp, UINT8_MAX), \
656 .enable_gpios = GPIO_DT_SPEC_GET_OR(node_id, enable_gpios, {0}), \
657 .retention_gpios = GPIO_DT_SPEC_GET_OR(node_id, retention_gpios, {0}), \
658 .pwm_gpios = GPIO_DT_SPEC_GET_OR(node_id, pwm_gpios, {0})}; \
659 \
660 DEVICE_DT_DEFINE(node_id, regulator_npm1300_init, NULL, &data_##id, &config_##id, \
661 POST_KERNEL, CONFIG_REGULATOR_NPM1300_INIT_PRIORITY, &api);
662
663 #define REGULATOR_NPM1300_DEFINE_COND(inst, child, source) \
664 COND_CODE_1(DT_NODE_EXISTS(DT_INST_CHILD(inst, child)), \
665 (REGULATOR_NPM1300_DEFINE(DT_INST_CHILD(inst, child), child##inst, source)), \
666 ())
667
668 #define REGULATOR_NPM1300_DEFINE_ALL(inst) \
669 static const struct regulator_npm1300_pconfig config_##inst = { \
670 .mfd = DEVICE_DT_GET(DT_INST_PARENT(inst)), \
671 .dvs_state_pins = {GPIO_DT_SPEC_INST_GET_BY_IDX_OR(inst, dvs_gpios, 0, {0}), \
672 GPIO_DT_SPEC_INST_GET_BY_IDX_OR(inst, dvs_gpios, 1, {0}), \
673 GPIO_DT_SPEC_INST_GET_BY_IDX_OR(inst, dvs_gpios, 2, {0}), \
674 GPIO_DT_SPEC_INST_GET_BY_IDX_OR(inst, dvs_gpios, 3, {0}), \
675 GPIO_DT_SPEC_INST_GET_BY_IDX_OR(inst, dvs_gpios, 4, {0})}}; \
676 \
677 DEVICE_DT_INST_DEFINE(inst, regulator_npm1300_common_init, NULL, NULL, &config_##inst, \
678 POST_KERNEL, CONFIG_REGULATOR_NPM1300_COMMON_INIT_PRIORITY, \
679 &parent_api); \
680 \
681 REGULATOR_NPM1300_DEFINE_COND(inst, buck1, NPM1300_SOURCE_BUCK1) \
682 REGULATOR_NPM1300_DEFINE_COND(inst, buck2, NPM1300_SOURCE_BUCK2) \
683 REGULATOR_NPM1300_DEFINE_COND(inst, ldo1, NPM1300_SOURCE_LDO1) \
684 REGULATOR_NPM1300_DEFINE_COND(inst, ldo2, NPM1300_SOURCE_LDO2)
685
686 DT_INST_FOREACH_STATUS_OKAY(REGULATOR_NPM1300_DEFINE_ALL)
687