Lines Matching +full:pmic +full:- +full:buck4 +full:- +full:uses +full:- +full:gpio +full:- +full:dvs
1 // SPDX-License-Identifier: GPL-2.0+
8 #include <linux/gpio/consumer.h>
170 *reg = S5M8767_REG_LDO1CTRL + (reg_id - S5M8767_LDO1); in s5m8767_get_register()
173 *reg = S5M8767_REG_LDO3CTRL + (reg_id - S5M8767_LDO3); in s5m8767_get_register()
179 *reg = S5M8767_REG_BUCK2CTRL + (reg_id - S5M8767_BUCK2) * 9; in s5m8767_get_register()
185 *reg = S5M8767_REG_BUCK6CTRL1 + (reg_id - S5M8767_BUCK6) * 2; in s5m8767_get_register()
188 return -EINVAL; in s5m8767_get_register()
191 for (i = 0; i < s5m8767->num_regulators; i++) { in s5m8767_get_register()
192 if (s5m8767->opmode[i].id == reg_id) { in s5m8767_get_register()
193 mode = s5m8767->opmode[i].mode; in s5m8767_get_register()
198 if (i >= s5m8767->num_regulators) in s5m8767_get_register()
199 return -EINVAL; in s5m8767_get_register()
212 reg = S5M8767_REG_LDO1CTRL + (reg_id - S5M8767_LDO1); in s5m8767_get_vsel_reg()
215 reg = S5M8767_REG_LDO3CTRL + (reg_id - S5M8767_LDO3); in s5m8767_get_vsel_reg()
222 if (s5m8767->buck2_gpiodvs) in s5m8767_get_vsel_reg()
223 reg += s5m8767->buck_gpioindex; in s5m8767_get_vsel_reg()
227 if (s5m8767->buck3_gpiodvs) in s5m8767_get_vsel_reg()
228 reg += s5m8767->buck_gpioindex; in s5m8767_get_vsel_reg()
232 if (s5m8767->buck4_gpiodvs) in s5m8767_get_vsel_reg()
233 reg += s5m8767->buck_gpioindex; in s5m8767_get_vsel_reg()
239 reg = S5M8767_REG_BUCK6CTRL2 + (reg_id - S5M8767_BUCK6) * 2; in s5m8767_get_vsel_reg()
242 return -EINVAL; in s5m8767_get_vsel_reg()
254 return -EINVAL; in s5m8767_convert_voltage_to_sel()
256 if (min_vol > desc->max) in s5m8767_convert_voltage_to_sel()
257 return -EINVAL; in s5m8767_convert_voltage_to_sel()
259 if (min_vol < desc->min) in s5m8767_convert_voltage_to_sel()
260 min_vol = desc->min; in s5m8767_convert_voltage_to_sel()
262 selector = DIV_ROUND_UP(min_vol - desc->min, desc->step); in s5m8767_convert_voltage_to_sel()
264 if (desc->min + desc->step * selector > desc->max) in s5m8767_convert_voltage_to_sel()
265 return -EINVAL; in s5m8767_convert_voltage_to_sel()
272 int temp_index = s5m8767->buck_gpioindex; in s5m8767_set_high()
274 gpio_set_value(s5m8767->buck_gpios[0], (temp_index >> 2) & 0x1); in s5m8767_set_high()
275 gpio_set_value(s5m8767->buck_gpios[1], (temp_index >> 1) & 0x1); in s5m8767_set_high()
276 gpio_set_value(s5m8767->buck_gpios[2], temp_index & 0x1); in s5m8767_set_high()
283 int temp_index = s5m8767->buck_gpioindex; in s5m8767_set_low()
285 gpio_set_value(s5m8767->buck_gpios[2], temp_index & 0x1); in s5m8767_set_low()
286 gpio_set_value(s5m8767->buck_gpios[1], (temp_index >> 1) & 0x1); in s5m8767_set_low()
287 gpio_set_value(s5m8767->buck_gpios[0], (temp_index >> 2) & 0x1); in s5m8767_set_low()
304 if (reg_id == S5M8767_BUCK2 && s5m8767->buck2_gpiodvs) in s5m8767_set_voltage_sel()
305 buck234_vol = &s5m8767->buck2_vol[0]; in s5m8767_set_voltage_sel()
306 else if (reg_id == S5M8767_BUCK3 && s5m8767->buck3_gpiodvs) in s5m8767_set_voltage_sel()
307 buck234_vol = &s5m8767->buck3_vol[0]; in s5m8767_set_voltage_sel()
308 else if (reg_id == S5M8767_BUCK4 && s5m8767->buck4_gpiodvs) in s5m8767_set_voltage_sel()
309 buck234_vol = &s5m8767->buck4_vol[0]; in s5m8767_set_voltage_sel()
312 return -EINVAL; in s5m8767_set_voltage_sel()
316 return -EINVAL; in s5m8767_set_voltage_sel()
319 /* buck234_vol != NULL means to control buck234 voltage via DVS GPIO */ in s5m8767_set_voltage_sel()
325 old_index = s5m8767->buck_gpioindex; in s5m8767_set_voltage_sel()
326 s5m8767->buck_gpioindex = index; in s5m8767_set_voltage_sel()
343 if ((old_sel < new_sel) && s5m8767->ramp_delay) in s5m8767_set_voltage_time_sel()
344 return DIV_ROUND_UP(rdev->desc->uV_step * (new_sel - old_sel), in s5m8767_set_voltage_time_sel()
345 s5m8767->ramp_delay * 1000); in s5m8767_set_voltage_time_sel()
416 s5m8767_regulator_desc(BUCK4),
425 * Enable GPIO control over BUCK9 in regulator_config for that regulator.
433 if (rdata->id != S5M8767_BUCK9) in s5m8767_regulator_config_ext_control()
437 for (i = 0; i < s5m8767->num_regulators; i++) { in s5m8767_regulator_config_ext_control()
438 const struct sec_opmode_data *opmode = &s5m8767->opmode[i]; in s5m8767_regulator_config_ext_control()
439 if (opmode->id == rdata->id) { in s5m8767_regulator_config_ext_control()
440 mode = s5m8767_opmode_reg[rdata->id][opmode->mode]; in s5m8767_regulator_config_ext_control()
445 dev_warn(s5m8767->dev, in s5m8767_regulator_config_ext_control()
446 "ext-control for %pOFn: mismatched op_mode (%x), ignoring\n", in s5m8767_regulator_config_ext_control()
447 rdata->reg_node, mode); in s5m8767_regulator_config_ext_control()
451 if (!rdata->ext_control_gpiod) { in s5m8767_regulator_config_ext_control()
452 dev_warn(s5m8767->dev, in s5m8767_regulator_config_ext_control()
453 "ext-control for %pOFn: GPIO not valid, ignoring\n", in s5m8767_regulator_config_ext_control()
454 rdata->reg_node); in s5m8767_regulator_config_ext_control()
458 config->ena_gpiod = rdata->ext_control_gpiod; in s5m8767_regulator_config_ext_control()
462 * Turn on GPIO control over BUCK9.
471 return -EINVAL; in s5m8767_enable_ext_control()
477 return regmap_update_bits(s5m8767->iodev->regmap_pmic, in s5m8767_enable_ext_control()
488 int i, gpio; in s5m8767_pmic_dt_parse_dvs_gpio() local
491 gpio = of_get_named_gpio(pmic_np, in s5m8767_pmic_dt_parse_dvs_gpio()
492 "s5m8767,pmic-buck-dvs-gpios", i); in s5m8767_pmic_dt_parse_dvs_gpio()
493 if (!gpio_is_valid(gpio)) { in s5m8767_pmic_dt_parse_dvs_gpio()
494 dev_err(iodev->dev, "invalid gpio[%d]: %d\n", i, gpio); in s5m8767_pmic_dt_parse_dvs_gpio()
495 return -EINVAL; in s5m8767_pmic_dt_parse_dvs_gpio()
497 pdata->buck_gpios[i] = gpio; in s5m8767_pmic_dt_parse_dvs_gpio()
506 int i, gpio; in s5m8767_pmic_dt_parse_ds_gpio() local
509 gpio = of_get_named_gpio(pmic_np, in s5m8767_pmic_dt_parse_ds_gpio()
510 "s5m8767,pmic-buck-ds-gpios", i); in s5m8767_pmic_dt_parse_ds_gpio()
511 if (!gpio_is_valid(gpio)) { in s5m8767_pmic_dt_parse_ds_gpio()
512 dev_err(iodev->dev, "invalid gpio[%d]: %d\n", i, gpio); in s5m8767_pmic_dt_parse_ds_gpio()
513 return -EINVAL; in s5m8767_pmic_dt_parse_ds_gpio()
515 pdata->buck_ds[i] = gpio; in s5m8767_pmic_dt_parse_ds_gpio()
523 struct sec_pmic_dev *iodev = dev_get_drvdata(pdev->dev.parent); in s5m8767_pmic_dt_parse_pdata()
529 pmic_np = iodev->dev->of_node; in s5m8767_pmic_dt_parse_pdata()
531 dev_err(iodev->dev, "could not find pmic sub-node\n"); in s5m8767_pmic_dt_parse_pdata()
532 return -ENODEV; in s5m8767_pmic_dt_parse_pdata()
537 dev_err(iodev->dev, "could not find regulators sub-node\n"); in s5m8767_pmic_dt_parse_pdata()
538 return -EINVAL; in s5m8767_pmic_dt_parse_pdata()
541 /* count the number of regulators to be supported in pmic */ in s5m8767_pmic_dt_parse_pdata()
542 pdata->num_regulators = of_get_child_count(regulators_np); in s5m8767_pmic_dt_parse_pdata()
544 rdata = devm_kcalloc(&pdev->dev, in s5m8767_pmic_dt_parse_pdata()
545 pdata->num_regulators, sizeof(*rdata), in s5m8767_pmic_dt_parse_pdata()
549 return -ENOMEM; in s5m8767_pmic_dt_parse_pdata()
552 rmode = devm_kcalloc(&pdev->dev, in s5m8767_pmic_dt_parse_pdata()
553 pdata->num_regulators, sizeof(*rmode), in s5m8767_pmic_dt_parse_pdata()
557 return -ENOMEM; in s5m8767_pmic_dt_parse_pdata()
560 pdata->regulators = rdata; in s5m8767_pmic_dt_parse_pdata()
561 pdata->opmode = rmode; in s5m8767_pmic_dt_parse_pdata()
568 dev_warn(iodev->dev, in s5m8767_pmic_dt_parse_pdata()
574 rdata->ext_control_gpiod = devm_fwnode_gpiod_get( in s5m8767_pmic_dt_parse_pdata()
575 &pdev->dev, in s5m8767_pmic_dt_parse_pdata()
577 "s5m8767,pmic-ext-control", in s5m8767_pmic_dt_parse_pdata()
580 if (PTR_ERR(rdata->ext_control_gpiod) == -ENOENT) { in s5m8767_pmic_dt_parse_pdata()
581 rdata->ext_control_gpiod = NULL; in s5m8767_pmic_dt_parse_pdata()
582 } else if (IS_ERR(rdata->ext_control_gpiod)) { in s5m8767_pmic_dt_parse_pdata()
585 return PTR_ERR(rdata->ext_control_gpiod); in s5m8767_pmic_dt_parse_pdata()
588 rdata->id = i; in s5m8767_pmic_dt_parse_pdata()
589 rdata->initdata = of_get_regulator_init_data( in s5m8767_pmic_dt_parse_pdata()
590 &pdev->dev, reg_np, in s5m8767_pmic_dt_parse_pdata()
592 rdata->reg_node = reg_np; in s5m8767_pmic_dt_parse_pdata()
594 rmode->id = i; in s5m8767_pmic_dt_parse_pdata()
596 &rmode->mode)) { in s5m8767_pmic_dt_parse_pdata()
597 dev_warn(iodev->dev, in s5m8767_pmic_dt_parse_pdata()
601 rmode->mode = S5M8767_OPMODE_NORMAL_MODE; in s5m8767_pmic_dt_parse_pdata()
608 if (of_get_property(pmic_np, "s5m8767,pmic-buck2-uses-gpio-dvs", NULL)) { in s5m8767_pmic_dt_parse_pdata()
609 pdata->buck2_gpiodvs = true; in s5m8767_pmic_dt_parse_pdata()
612 "s5m8767,pmic-buck2-dvs-voltage", in s5m8767_pmic_dt_parse_pdata()
613 pdata->buck2_voltage, dvs_voltage_nr)) { in s5m8767_pmic_dt_parse_pdata()
614 dev_err(iodev->dev, "buck2 voltages not specified\n"); in s5m8767_pmic_dt_parse_pdata()
615 return -EINVAL; in s5m8767_pmic_dt_parse_pdata()
619 if (of_get_property(pmic_np, "s5m8767,pmic-buck3-uses-gpio-dvs", NULL)) { in s5m8767_pmic_dt_parse_pdata()
620 pdata->buck3_gpiodvs = true; in s5m8767_pmic_dt_parse_pdata()
623 "s5m8767,pmic-buck3-dvs-voltage", in s5m8767_pmic_dt_parse_pdata()
624 pdata->buck3_voltage, dvs_voltage_nr)) { in s5m8767_pmic_dt_parse_pdata()
625 dev_err(iodev->dev, "buck3 voltages not specified\n"); in s5m8767_pmic_dt_parse_pdata()
626 return -EINVAL; in s5m8767_pmic_dt_parse_pdata()
630 if (of_get_property(pmic_np, "s5m8767,pmic-buck4-uses-gpio-dvs", NULL)) { in s5m8767_pmic_dt_parse_pdata()
631 pdata->buck4_gpiodvs = true; in s5m8767_pmic_dt_parse_pdata()
634 "s5m8767,pmic-buck4-dvs-voltage", in s5m8767_pmic_dt_parse_pdata()
635 pdata->buck4_voltage, dvs_voltage_nr)) { in s5m8767_pmic_dt_parse_pdata()
636 dev_err(iodev->dev, "buck4 voltages not specified\n"); in s5m8767_pmic_dt_parse_pdata()
637 return -EINVAL; in s5m8767_pmic_dt_parse_pdata()
641 if (pdata->buck2_gpiodvs || pdata->buck3_gpiodvs || in s5m8767_pmic_dt_parse_pdata()
642 pdata->buck4_gpiodvs) { in s5m8767_pmic_dt_parse_pdata()
645 return -EINVAL; in s5m8767_pmic_dt_parse_pdata()
648 "s5m8767,pmic-buck-default-dvs-idx", in s5m8767_pmic_dt_parse_pdata()
649 &pdata->buck_default_idx)) { in s5m8767_pmic_dt_parse_pdata()
650 pdata->buck_default_idx = 0; in s5m8767_pmic_dt_parse_pdata()
652 if (pdata->buck_default_idx >= 8) { in s5m8767_pmic_dt_parse_pdata()
653 pdata->buck_default_idx = 0; in s5m8767_pmic_dt_parse_pdata()
654 dev_info(iodev->dev, in s5m8767_pmic_dt_parse_pdata()
655 "invalid value for default dvs index, use 0\n"); in s5m8767_pmic_dt_parse_pdata()
662 return -EINVAL; in s5m8767_pmic_dt_parse_pdata()
664 if (of_get_property(pmic_np, "s5m8767,pmic-buck2-ramp-enable", NULL)) in s5m8767_pmic_dt_parse_pdata()
665 pdata->buck2_ramp_enable = true; in s5m8767_pmic_dt_parse_pdata()
667 if (of_get_property(pmic_np, "s5m8767,pmic-buck3-ramp-enable", NULL)) in s5m8767_pmic_dt_parse_pdata()
668 pdata->buck3_ramp_enable = true; in s5m8767_pmic_dt_parse_pdata()
670 if (of_get_property(pmic_np, "s5m8767,pmic-buck4-ramp-enable", NULL)) in s5m8767_pmic_dt_parse_pdata()
671 pdata->buck4_ramp_enable = true; in s5m8767_pmic_dt_parse_pdata()
673 if (pdata->buck2_ramp_enable || pdata->buck3_ramp_enable in s5m8767_pmic_dt_parse_pdata()
674 || pdata->buck4_ramp_enable) { in s5m8767_pmic_dt_parse_pdata()
675 if (of_property_read_u32(pmic_np, "s5m8767,pmic-buck-ramp-delay", in s5m8767_pmic_dt_parse_pdata()
676 &pdata->buck_ramp_delay)) in s5m8767_pmic_dt_parse_pdata()
677 pdata->buck_ramp_delay = 0; in s5m8767_pmic_dt_parse_pdata()
692 struct sec_pmic_dev *iodev = dev_get_drvdata(pdev->dev.parent); in s5m8767_pmic_probe()
693 struct sec_platform_data *pdata = iodev->pdata; in s5m8767_pmic_probe()
699 dev_err(pdev->dev.parent, "Platform data not supplied\n"); in s5m8767_pmic_probe()
700 return -ENODEV; in s5m8767_pmic_probe()
703 if (iodev->dev->of_node) { in s5m8767_pmic_probe()
709 if (pdata->buck2_gpiodvs) { in s5m8767_pmic_probe()
710 if (pdata->buck3_gpiodvs || pdata->buck4_gpiodvs) { in s5m8767_pmic_probe()
711 dev_err(&pdev->dev, "S5M8767 GPIO DVS NOT VALID\n"); in s5m8767_pmic_probe()
712 return -EINVAL; in s5m8767_pmic_probe()
716 if (pdata->buck3_gpiodvs) { in s5m8767_pmic_probe()
717 if (pdata->buck2_gpiodvs || pdata->buck4_gpiodvs) { in s5m8767_pmic_probe()
718 dev_err(&pdev->dev, "S5M8767 GPIO DVS NOT VALID\n"); in s5m8767_pmic_probe()
719 return -EINVAL; in s5m8767_pmic_probe()
723 if (pdata->buck4_gpiodvs) { in s5m8767_pmic_probe()
724 if (pdata->buck2_gpiodvs || pdata->buck3_gpiodvs) { in s5m8767_pmic_probe()
725 dev_err(&pdev->dev, "S5M8767 GPIO DVS NOT VALID\n"); in s5m8767_pmic_probe()
726 return -EINVAL; in s5m8767_pmic_probe()
730 s5m8767 = devm_kzalloc(&pdev->dev, sizeof(struct s5m8767_info), in s5m8767_pmic_probe()
733 return -ENOMEM; in s5m8767_pmic_probe()
735 s5m8767->dev = &pdev->dev; in s5m8767_pmic_probe()
736 s5m8767->iodev = iodev; in s5m8767_pmic_probe()
737 s5m8767->num_regulators = pdata->num_regulators; in s5m8767_pmic_probe()
740 s5m8767->buck_gpioindex = pdata->buck_default_idx; in s5m8767_pmic_probe()
741 s5m8767->buck2_gpiodvs = pdata->buck2_gpiodvs; in s5m8767_pmic_probe()
742 s5m8767->buck3_gpiodvs = pdata->buck3_gpiodvs; in s5m8767_pmic_probe()
743 s5m8767->buck4_gpiodvs = pdata->buck4_gpiodvs; in s5m8767_pmic_probe()
744 s5m8767->buck_gpios[0] = pdata->buck_gpios[0]; in s5m8767_pmic_probe()
745 s5m8767->buck_gpios[1] = pdata->buck_gpios[1]; in s5m8767_pmic_probe()
746 s5m8767->buck_gpios[2] = pdata->buck_gpios[2]; in s5m8767_pmic_probe()
747 s5m8767->buck_ds[0] = pdata->buck_ds[0]; in s5m8767_pmic_probe()
748 s5m8767->buck_ds[1] = pdata->buck_ds[1]; in s5m8767_pmic_probe()
749 s5m8767->buck_ds[2] = pdata->buck_ds[2]; in s5m8767_pmic_probe()
751 s5m8767->ramp_delay = pdata->buck_ramp_delay; in s5m8767_pmic_probe()
752 s5m8767->buck2_ramp = pdata->buck2_ramp_enable; in s5m8767_pmic_probe()
753 s5m8767->buck3_ramp = pdata->buck3_ramp_enable; in s5m8767_pmic_probe()
754 s5m8767->buck4_ramp = pdata->buck4_ramp_enable; in s5m8767_pmic_probe()
755 s5m8767->opmode = pdata->opmode; in s5m8767_pmic_probe()
758 pdata->buck2_init); in s5m8767_pmic_probe()
760 regmap_write(s5m8767->iodev->regmap_pmic, S5M8767_REG_BUCK2DVS2, in s5m8767_pmic_probe()
764 pdata->buck3_init); in s5m8767_pmic_probe()
766 regmap_write(s5m8767->iodev->regmap_pmic, S5M8767_REG_BUCK3DVS2, in s5m8767_pmic_probe()
770 pdata->buck4_init); in s5m8767_pmic_probe()
772 regmap_write(s5m8767->iodev->regmap_pmic, S5M8767_REG_BUCK4DVS2, in s5m8767_pmic_probe()
776 if (s5m8767->buck2_gpiodvs) { in s5m8767_pmic_probe()
777 s5m8767->buck2_vol[i] = in s5m8767_pmic_probe()
780 pdata->buck2_voltage[i]); in s5m8767_pmic_probe()
783 if (s5m8767->buck3_gpiodvs) { in s5m8767_pmic_probe()
784 s5m8767->buck3_vol[i] = in s5m8767_pmic_probe()
787 pdata->buck3_voltage[i]); in s5m8767_pmic_probe()
790 if (s5m8767->buck4_gpiodvs) { in s5m8767_pmic_probe()
791 s5m8767->buck4_vol[i] = in s5m8767_pmic_probe()
794 pdata->buck4_voltage[i]); in s5m8767_pmic_probe()
798 if (pdata->buck2_gpiodvs || pdata->buck3_gpiodvs || in s5m8767_pmic_probe()
799 pdata->buck4_gpiodvs) { in s5m8767_pmic_probe()
801 if (!gpio_is_valid(pdata->buck_gpios[0]) || in s5m8767_pmic_probe()
802 !gpio_is_valid(pdata->buck_gpios[1]) || in s5m8767_pmic_probe()
803 !gpio_is_valid(pdata->buck_gpios[2])) { in s5m8767_pmic_probe()
804 dev_err(&pdev->dev, "GPIO NOT VALID\n"); in s5m8767_pmic_probe()
805 return -EINVAL; in s5m8767_pmic_probe()
808 ret = devm_gpio_request(&pdev->dev, pdata->buck_gpios[0], in s5m8767_pmic_probe()
813 ret = devm_gpio_request(&pdev->dev, pdata->buck_gpios[1], in s5m8767_pmic_probe()
818 ret = devm_gpio_request(&pdev->dev, pdata->buck_gpios[2], in s5m8767_pmic_probe()
823 /* SET1 GPIO */ in s5m8767_pmic_probe()
824 gpio_direction_output(pdata->buck_gpios[0], in s5m8767_pmic_probe()
825 (s5m8767->buck_gpioindex >> 2) & 0x1); in s5m8767_pmic_probe()
826 /* SET2 GPIO */ in s5m8767_pmic_probe()
827 gpio_direction_output(pdata->buck_gpios[1], in s5m8767_pmic_probe()
828 (s5m8767->buck_gpioindex >> 1) & 0x1); in s5m8767_pmic_probe()
829 /* SET3 GPIO */ in s5m8767_pmic_probe()
830 gpio_direction_output(pdata->buck_gpios[2], in s5m8767_pmic_probe()
831 (s5m8767->buck_gpioindex >> 0) & 0x1); in s5m8767_pmic_probe()
834 ret = devm_gpio_request(&pdev->dev, pdata->buck_ds[0], "S5M8767 DS2"); in s5m8767_pmic_probe()
838 ret = devm_gpio_request(&pdev->dev, pdata->buck_ds[1], "S5M8767 DS3"); in s5m8767_pmic_probe()
842 ret = devm_gpio_request(&pdev->dev, pdata->buck_ds[2], "S5M8767 DS4"); in s5m8767_pmic_probe()
846 /* DS2 GPIO */ in s5m8767_pmic_probe()
847 gpio_direction_output(pdata->buck_ds[0], 0x0); in s5m8767_pmic_probe()
848 /* DS3 GPIO */ in s5m8767_pmic_probe()
849 gpio_direction_output(pdata->buck_ds[1], 0x0); in s5m8767_pmic_probe()
850 /* DS4 GPIO */ in s5m8767_pmic_probe()
851 gpio_direction_output(pdata->buck_ds[2], 0x0); in s5m8767_pmic_probe()
853 regmap_update_bits(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
855 (pdata->buck2_gpiodvs) ? (1 << 1) : (0 << 1)); in s5m8767_pmic_probe()
856 regmap_update_bits(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
858 (pdata->buck3_gpiodvs) ? (1 << 1) : (0 << 1)); in s5m8767_pmic_probe()
859 regmap_update_bits(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
861 (pdata->buck4_gpiodvs) ? (1 << 1) : (0 << 1)); in s5m8767_pmic_probe()
863 /* Initialize GPIO DVS registers */ in s5m8767_pmic_probe()
865 if (s5m8767->buck2_gpiodvs) { in s5m8767_pmic_probe()
866 regmap_write(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
868 s5m8767->buck2_vol[i]); in s5m8767_pmic_probe()
871 if (s5m8767->buck3_gpiodvs) { in s5m8767_pmic_probe()
872 regmap_write(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
874 s5m8767->buck3_vol[i]); in s5m8767_pmic_probe()
877 if (s5m8767->buck4_gpiodvs) { in s5m8767_pmic_probe()
878 regmap_write(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
880 s5m8767->buck4_vol[i]); in s5m8767_pmic_probe()
884 if (s5m8767->buck2_ramp) in s5m8767_pmic_probe()
885 regmap_update_bits(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
888 if (s5m8767->buck3_ramp) in s5m8767_pmic_probe()
889 regmap_update_bits(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
892 if (s5m8767->buck4_ramp) in s5m8767_pmic_probe()
893 regmap_update_bits(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
896 if (s5m8767->buck2_ramp || s5m8767->buck3_ramp in s5m8767_pmic_probe()
897 || s5m8767->buck4_ramp) { in s5m8767_pmic_probe()
899 switch (s5m8767->ramp_delay) { in s5m8767_pmic_probe()
918 regmap_update_bits(s5m8767->iodev->regmap_pmic, in s5m8767_pmic_probe()
924 for (i = 0; i < pdata->num_regulators; i++) { in s5m8767_pmic_probe()
926 int id = pdata->regulators[i].id; in s5m8767_pmic_probe()
933 (desc->max - desc->min) / desc->step + 1; in s5m8767_pmic_probe()
934 regulators[id].min_uV = desc->min; in s5m8767_pmic_probe()
935 regulators[id].uV_step = desc->step; in s5m8767_pmic_probe()
946 dev_err(s5m8767->dev, "error reading registers\n"); in s5m8767_pmic_probe()
954 config.dev = s5m8767->dev; in s5m8767_pmic_probe()
955 config.init_data = pdata->regulators[i].initdata; in s5m8767_pmic_probe()
957 config.regmap = iodev->regmap_pmic; in s5m8767_pmic_probe()
958 config.of_node = pdata->regulators[i].reg_node; in s5m8767_pmic_probe()
960 if (pdata->regulators[i].ext_control_gpiod) { in s5m8767_pmic_probe()
963 &pdata->regulators[i], &config); in s5m8767_pmic_probe()
966 * Hand the GPIO descriptor management over to the in s5m8767_pmic_probe()
969 devm_gpiod_unhinge(s5m8767->dev, config.ena_gpiod); in s5m8767_pmic_probe()
971 rdev = devm_regulator_register(&pdev->dev, ®ulators[id], in s5m8767_pmic_probe()
975 dev_err(s5m8767->dev, "regulator init failed for %d\n", in s5m8767_pmic_probe()
980 if (pdata->regulators[i].ext_control_gpiod) { in s5m8767_pmic_probe()
983 dev_err(s5m8767->dev, in s5m8767_pmic_probe()
984 "failed to enable gpio control over %s: %d\n", in s5m8767_pmic_probe()
985 rdev->desc->name, ret); in s5m8767_pmic_probe()
995 { "s5m8767-pmic", 0},
1002 .name = "s5m8767-pmic",