Lines Matching +full:pmic +full:- +full:buck +full:- +full:dvs +full:- +full:gpios

1 // SPDX-License-Identifier: GPL-2.0+
3 // max8997.c - Regulator driver for the Maxim 8997/8966
20 #include <linux/mfd/max8997-private.h>
51 int set3 = (max8997->buck125_gpioindex) & 0x1; in max8997_set_gpio()
52 int set2 = ((max8997->buck125_gpioindex) >> 1) & 0x1; in max8997_set_gpio()
53 int set1 = ((max8997->buck125_gpioindex) >> 2) & 0x1; in max8997_set_gpio()
55 gpio_set_value(max8997->buck125_gpios[0], set1); in max8997_set_gpio()
56 gpio_set_value(max8997->buck125_gpios[1], set2); in max8997_set_gpio()
57 gpio_set_value(max8997->buck125_gpios[2], set3); in max8997_set_gpio()
137 return 4000000 + 20000 * (selector - 0x01); in max8997_list_voltage_charger_cv()
141 return -EINVAL; in max8997_list_voltage_charger_cv()
144 return -EINVAL; in max8997_list_voltage_charger_cv()
155 return -EINVAL; in max8997_list_voltage()
159 return -EINVAL; in max8997_list_voltage()
161 val = desc->min + desc->step * selector; in max8997_list_voltage()
162 if (val > desc->max) in max8997_list_voltage()
163 return -EINVAL; in max8997_list_voltage()
175 *reg = MAX8997_REG_LDO1CTRL + (rid - MAX8997_LDO1); in max8997_get_enable_register()
216 *mask = 0x01 << (rid - MAX8997_EN32KHZ_AP); in max8997_get_enable_register()
217 *pattern = 0x01 << (rid - MAX8997_EN32KHZ_AP); in max8997_get_enable_register()
226 *mask = 0x40 << (rid - MAX8997_ESAFEOUT1); in max8997_get_enable_register()
227 *pattern = 0x40 << (rid - MAX8997_ESAFEOUT1); in max8997_get_enable_register()
236 return -EINVAL; in max8997_get_enable_register()
245 struct i2c_client *i2c = max8997->iodev->i2c; in max8997_reg_is_enabled()
263 struct i2c_client *i2c = max8997->iodev->i2c; in max8997_reg_enable()
276 struct i2c_client *i2c = max8997->iodev->i2c; in max8997_reg_disable()
295 reg = MAX8997_REG_LDO1CTRL + (rid - MAX8997_LDO1); in max8997_get_voltage_register()
299 if (max8997->buck1_gpiodvs) in max8997_get_voltage_register()
300 reg += max8997->buck125_gpioindex; in max8997_get_voltage_register()
304 if (max8997->buck2_gpiodvs) in max8997_get_voltage_register()
305 reg += max8997->buck125_gpioindex; in max8997_get_voltage_register()
315 if (max8997->buck5_gpiodvs) in max8997_get_voltage_register()
316 reg += max8997->buck125_gpioindex; in max8997_get_voltage_register()
342 return -EINVAL; in max8997_get_voltage_register()
355 struct i2c_client *i2c = max8997->iodev->i2c; in max8997_get_voltage_sel()
380 return -EINVAL; in max8997_get_voltage_proper_val()
382 if (max_vol < desc->min || min_vol > desc->max) in max8997_get_voltage_proper_val()
383 return -EINVAL; in max8997_get_voltage_proper_val()
385 if (min_vol < desc->min) in max8997_get_voltage_proper_val()
386 min_vol = desc->min; in max8997_get_voltage_proper_val()
388 i = DIV_ROUND_UP(min_vol - desc->min, desc->step); in max8997_get_voltage_proper_val()
390 if (desc->min + desc->step * i > max_vol) in max8997_get_voltage_proper_val()
391 return -EINVAL; in max8997_get_voltage_proper_val()
400 struct i2c_client *i2c = max8997->iodev->i2c; in max8997_set_voltage_charger_cv()
407 return -EINVAL; in max8997_set_voltage_charger_cv()
414 return -EINVAL; in max8997_set_voltage_charger_cv()
421 lb = (min_uV - 4000001) / 20000 + 2; in max8997_set_voltage_charger_cv()
422 ub = (max_uV - 4000000) / 20000 + 1; in max8997_set_voltage_charger_cv()
425 return -EINVAL; in max8997_set_voltage_charger_cv()
433 return -EINVAL; in max8997_set_voltage_charger_cv()
452 struct i2c_client *i2c = max8997->iodev->i2c; in max8997_set_voltage_ldobuck()
463 return -EINVAL; in max8997_set_voltage_ldobuck()
471 return -EINVAL; in max8997_set_voltage_ldobuck()
505 if (max8997->buck1_gpiodvs) in max8997_set_voltage_buck_time_sel()
509 if (max8997->buck2_gpiodvs) in max8997_set_voltage_buck_time_sel()
513 if (max8997->buck5_gpiodvs) in max8997_set_voltage_buck_time_sel()
523 return DIV_ROUND_UP(desc->step * (new_selector - old_selector), in max8997_set_voltage_buck_time_sel()
524 max8997->ramp_delay * 1000); in max8997_set_voltage_buck_time_sel()
533 * When GPIO-DVS mode is used for multiple bucks, changing the voltage value
534 * of one of the bucks may affect that of another buck, which is the side
535 * effect of the change (set_voltage). This function examines the GPIO-DVS
536 * configurations and checks whether such side-effect exists.
549 *best = -1; in max8997_assess_side_effect()
562 return -EINVAL; in max8997_assess_side_effect()
565 buckx_val[0] = max8997->buck1_vol; in max8997_assess_side_effect()
566 buckx_val[1] = max8997->buck2_vol; in max8997_assess_side_effect()
567 buckx_val[2] = max8997->buck5_vol; in max8997_assess_side_effect()
568 buckx_gpiodvs[0] = max8997->buck1_gpiodvs; in max8997_assess_side_effect()
569 buckx_gpiodvs[1] = max8997->buck2_gpiodvs; in max8997_assess_side_effect()
570 buckx_gpiodvs[2] = max8997->buck5_gpiodvs; in max8997_assess_side_effect()
576 side_effect[i] = -1; in max8997_assess_side_effect()
588 diff = (buckx_val[others])[i] - in max8997_assess_side_effect()
589 (buckx_val[others])[max8997->buck125_gpioindex]; in max8997_assess_side_effect()
593 side_effect[i] -= diff; in max8997_assess_side_effect()
605 if (*best == -1) in max8997_assess_side_effect()
606 return -EINVAL; in max8997_assess_side_effect()
612 * For Buck 1 ~ 5 and 7. If it is not controlled by GPIO, this calls
625 return -EINVAL; in max8997_set_voltage_buck()
629 if (max8997->buck1_gpiodvs) in max8997_set_voltage_buck()
633 if (max8997->buck2_gpiodvs) in max8997_set_voltage_buck()
637 if (max8997->buck5_gpiodvs) in max8997_set_voltage_buck()
652 tmp_idx = -1; in max8997_set_voltage_buck()
653 tmp_val = -1; in max8997_set_voltage_buck()
666 } while (desc->min + desc->step * new_val <= desc->max); in max8997_set_voltage_buck()
671 if (max8997->ignore_gpiodvs_side_effect == false) in max8997_set_voltage_buck()
672 return -EINVAL; in max8997_set_voltage_buck()
674 dev_warn(&rdev->dev, in max8997_set_voltage_buck()
675 "MAX8997 GPIO-DVS Side Effect Warning: GPIO SET: %d -> %d\n", in max8997_set_voltage_buck()
676 max8997->buck125_gpioindex, tmp_idx); in max8997_set_voltage_buck()
680 return -EINVAL; in max8997_set_voltage_buck()
682 max8997->buck125_gpioindex = new_idx; in max8997_set_voltage_buck()
694 struct i2c_client *i2c = max8997->iodev->i2c; in max8997_set_voltage_safeout_sel()
699 return -EINVAL; in max8997_set_voltage_safeout_sel()
711 struct i2c_client *i2c = max8997->iodev->i2c; in max8997_reg_disable_suspend()
719 max8997_read_reg(i2c, reg, &max8997->saved_states[rid]); in max8997_reg_disable_suspend()
724 dev_dbg(&rdev->dev, "Conditional Power-Off for %s\n", in max8997_reg_disable_suspend()
725 rdev->desc->name); in max8997_reg_disable_suspend()
729 dev_dbg(&rdev->dev, "Full Power-Off for %s (%xh -> %xh)\n", in max8997_reg_disable_suspend()
730 rdev->desc->name, max8997->saved_states[rid] & mask, in max8997_reg_disable_suspend()
787 return -EINVAL; in max8997_set_current_limit()
798 return -EINVAL; in max8997_get_current_limit()
884 "max8997,pmic-buck125-dvs-gpios", i); in max8997_pmic_dt_parse_dvs_gpio()
886 dev_err(&pdev->dev, "invalid gpio[%d]: %d\n", i, gpio); in max8997_pmic_dt_parse_dvs_gpio()
887 return -EINVAL; in max8997_pmic_dt_parse_dvs_gpio()
889 pdata->buck125_gpios[i] = gpio; in max8997_pmic_dt_parse_dvs_gpio()
897 struct max8997_dev *iodev = dev_get_drvdata(pdev->dev.parent); in max8997_pmic_dt_parse_pdata()
902 pmic_np = iodev->dev->of_node; in max8997_pmic_dt_parse_pdata()
904 dev_err(&pdev->dev, "could not find pmic sub-node\n"); in max8997_pmic_dt_parse_pdata()
905 return -ENODEV; in max8997_pmic_dt_parse_pdata()
910 dev_err(&pdev->dev, "could not find regulators sub-node\n"); in max8997_pmic_dt_parse_pdata()
911 return -EINVAL; in max8997_pmic_dt_parse_pdata()
914 /* count the number of regulators to be supported in pmic */ in max8997_pmic_dt_parse_pdata()
915 pdata->num_regulators = of_get_child_count(regulators_np); in max8997_pmic_dt_parse_pdata()
917 rdata = devm_kcalloc(&pdev->dev, in max8997_pmic_dt_parse_pdata()
918 pdata->num_regulators, sizeof(*rdata), in max8997_pmic_dt_parse_pdata()
922 return -ENOMEM; in max8997_pmic_dt_parse_pdata()
925 pdata->regulators = rdata; in max8997_pmic_dt_parse_pdata()
932 dev_warn(&pdev->dev, "don't know how to configure regulator %pOFn\n", in max8997_pmic_dt_parse_pdata()
937 rdata->id = i; in max8997_pmic_dt_parse_pdata()
938 rdata->initdata = of_get_regulator_init_data(&pdev->dev, in max8997_pmic_dt_parse_pdata()
941 rdata->reg_node = reg_np; in max8997_pmic_dt_parse_pdata()
946 pdata->buck1_gpiodvs = of_property_read_bool(pmic_np, "max8997,pmic-buck1-uses-gpio-dvs"); in max8997_pmic_dt_parse_pdata()
947 pdata->buck2_gpiodvs = of_property_read_bool(pmic_np, "max8997,pmic-buck2-uses-gpio-dvs"); in max8997_pmic_dt_parse_pdata()
948 pdata->buck5_gpiodvs = of_property_read_bool(pmic_np, "max8997,pmic-buck5-uses-gpio-dvs"); in max8997_pmic_dt_parse_pdata()
950 if (pdata->buck1_gpiodvs || pdata->buck2_gpiodvs || in max8997_pmic_dt_parse_pdata()
951 pdata->buck5_gpiodvs) { in max8997_pmic_dt_parse_pdata()
954 return -EINVAL; in max8997_pmic_dt_parse_pdata()
957 "max8997,pmic-buck125-default-dvs-idx", in max8997_pmic_dt_parse_pdata()
958 &pdata->buck125_default_idx)) { in max8997_pmic_dt_parse_pdata()
959 pdata->buck125_default_idx = 0; in max8997_pmic_dt_parse_pdata()
961 if (pdata->buck125_default_idx >= 8) { in max8997_pmic_dt_parse_pdata()
962 pdata->buck125_default_idx = 0; in max8997_pmic_dt_parse_pdata()
963 dev_info(&pdev->dev, "invalid value for default dvs index, using 0 instead\n"); in max8997_pmic_dt_parse_pdata()
968 "max8997,pmic-ignore-gpiodvs-side-effect", NULL)) in max8997_pmic_dt_parse_pdata()
969 pdata->ignore_gpiodvs_side_effect = true; in max8997_pmic_dt_parse_pdata()
975 "max8997,pmic-buck1-dvs-voltage", in max8997_pmic_dt_parse_pdata()
976 pdata->buck1_voltage, dvs_voltage_nr)) { in max8997_pmic_dt_parse_pdata()
977 dev_err(&pdev->dev, "buck1 voltages not specified\n"); in max8997_pmic_dt_parse_pdata()
978 return -EINVAL; in max8997_pmic_dt_parse_pdata()
982 "max8997,pmic-buck2-dvs-voltage", in max8997_pmic_dt_parse_pdata()
983 pdata->buck2_voltage, dvs_voltage_nr)) { in max8997_pmic_dt_parse_pdata()
984 dev_err(&pdev->dev, "buck2 voltages not specified\n"); in max8997_pmic_dt_parse_pdata()
985 return -EINVAL; in max8997_pmic_dt_parse_pdata()
989 "max8997,pmic-buck5-dvs-voltage", in max8997_pmic_dt_parse_pdata()
990 pdata->buck5_voltage, dvs_voltage_nr)) { in max8997_pmic_dt_parse_pdata()
991 dev_err(&pdev->dev, "buck5 voltages not specified\n"); in max8997_pmic_dt_parse_pdata()
992 return -EINVAL; in max8997_pmic_dt_parse_pdata()
1007 struct max8997_dev *iodev = dev_get_drvdata(pdev->dev.parent); in max8997_pmic_probe()
1008 struct max8997_platform_data *pdata = iodev->pdata; in max8997_pmic_probe()
1017 dev_err(&pdev->dev, "No platform init data supplied.\n"); in max8997_pmic_probe()
1018 return -ENODEV; in max8997_pmic_probe()
1021 if (iodev->dev->of_node) { in max8997_pmic_probe()
1027 max8997 = devm_kzalloc(&pdev->dev, sizeof(struct max8997_data), in max8997_pmic_probe()
1030 return -ENOMEM; in max8997_pmic_probe()
1032 max8997->dev = &pdev->dev; in max8997_pmic_probe()
1033 max8997->iodev = iodev; in max8997_pmic_probe()
1034 max8997->num_regulators = pdata->num_regulators; in max8997_pmic_probe()
1036 i2c = max8997->iodev->i2c; in max8997_pmic_probe()
1038 max8997->buck125_gpioindex = pdata->buck125_default_idx; in max8997_pmic_probe()
1039 max8997->buck1_gpiodvs = pdata->buck1_gpiodvs; in max8997_pmic_probe()
1040 max8997->buck2_gpiodvs = pdata->buck2_gpiodvs; in max8997_pmic_probe()
1041 max8997->buck5_gpiodvs = pdata->buck5_gpiodvs; in max8997_pmic_probe()
1042 memcpy(max8997->buck125_gpios, pdata->buck125_gpios, sizeof(int) * 3); in max8997_pmic_probe()
1043 max8997->ignore_gpiodvs_side_effect = pdata->ignore_gpiodvs_side_effect; in max8997_pmic_probe()
1045 nr_dvs = (pdata->buck1_gpiodvs || pdata->buck2_gpiodvs || in max8997_pmic_probe()
1046 pdata->buck5_gpiodvs) ? 8 : 1; in max8997_pmic_probe()
1049 max8997->buck1_vol[i] = ret = in max8997_pmic_probe()
1052 pdata->buck1_voltage[i], in max8997_pmic_probe()
1053 pdata->buck1_voltage[i] + in max8997_pmic_probe()
1058 max8997->buck2_vol[i] = ret = in max8997_pmic_probe()
1061 pdata->buck2_voltage[i], in max8997_pmic_probe()
1062 pdata->buck2_voltage[i] + in max8997_pmic_probe()
1067 max8997->buck5_vol[i] = ret = in max8997_pmic_probe()
1070 pdata->buck5_voltage[i], in max8997_pmic_probe()
1071 pdata->buck5_voltage[i] + in max8997_pmic_probe()
1076 if (max_buck1 < max8997->buck1_vol[i]) in max8997_pmic_probe()
1077 max_buck1 = max8997->buck1_vol[i]; in max8997_pmic_probe()
1078 if (max_buck2 < max8997->buck2_vol[i]) in max8997_pmic_probe()
1079 max_buck2 = max8997->buck2_vol[i]; in max8997_pmic_probe()
1080 if (max_buck5 < max8997->buck5_vol[i]) in max8997_pmic_probe()
1081 max_buck5 = max8997->buck5_vol[i]; in max8997_pmic_probe()
1094 /* Initialize all the DVS related BUCK registers */ in max8997_pmic_probe()
1097 max8997->buck1_vol[i], in max8997_pmic_probe()
1100 max8997->buck2_vol[i], in max8997_pmic_probe()
1103 max8997->buck5_vol[i], in max8997_pmic_probe()
1108 * If buck 1, 2, and 5 do not care DVS GPIO settings, ignore them. in max8997_pmic_probe()
1109 * If at least one of them cares, set gpios. in max8997_pmic_probe()
1111 if (pdata->buck1_gpiodvs || pdata->buck2_gpiodvs || in max8997_pmic_probe()
1112 pdata->buck5_gpiodvs) { in max8997_pmic_probe()
1114 if (!gpio_is_valid(pdata->buck125_gpios[0]) || in max8997_pmic_probe()
1115 !gpio_is_valid(pdata->buck125_gpios[1]) || in max8997_pmic_probe()
1116 !gpio_is_valid(pdata->buck125_gpios[2])) { in max8997_pmic_probe()
1117 dev_err(&pdev->dev, "GPIO NOT VALID\n"); in max8997_pmic_probe()
1118 return -EINVAL; in max8997_pmic_probe()
1121 ret = devm_gpio_request(&pdev->dev, pdata->buck125_gpios[0], in max8997_pmic_probe()
1126 ret = devm_gpio_request(&pdev->dev, pdata->buck125_gpios[1], in max8997_pmic_probe()
1131 ret = devm_gpio_request(&pdev->dev, pdata->buck125_gpios[2], in max8997_pmic_probe()
1136 gpio_direction_output(pdata->buck125_gpios[0], in max8997_pmic_probe()
1137 (max8997->buck125_gpioindex >> 2) in max8997_pmic_probe()
1139 gpio_direction_output(pdata->buck125_gpios[1], in max8997_pmic_probe()
1140 (max8997->buck125_gpioindex >> 1) in max8997_pmic_probe()
1142 gpio_direction_output(pdata->buck125_gpios[2], in max8997_pmic_probe()
1143 (max8997->buck125_gpioindex >> 0) in max8997_pmic_probe()
1147 /* DVS-GPIO disabled */ in max8997_pmic_probe()
1148 max8997_update_reg(i2c, MAX8997_REG_BUCK1CTRL, (pdata->buck1_gpiodvs) ? in max8997_pmic_probe()
1150 max8997_update_reg(i2c, MAX8997_REG_BUCK2CTRL, (pdata->buck2_gpiodvs) ? in max8997_pmic_probe()
1152 max8997_update_reg(i2c, MAX8997_REG_BUCK5CTRL, (pdata->buck5_gpiodvs) ? in max8997_pmic_probe()
1156 max8997->ramp_delay = 10; /* set 10mV/us, which is the default */ in max8997_pmic_probe()
1159 for (i = 0; i < pdata->num_regulators; i++) { in max8997_pmic_probe()
1161 int id = pdata->regulators[i].id; in max8997_pmic_probe()
1166 (desc->max - desc->min) / desc->step + 1; in max8997_pmic_probe()
1174 config.dev = max8997->dev; in max8997_pmic_probe()
1175 config.init_data = pdata->regulators[i].initdata; in max8997_pmic_probe()
1177 config.of_node = pdata->regulators[i].reg_node; in max8997_pmic_probe()
1179 rdev = devm_regulator_register(&pdev->dev, &regulators[id], in max8997_pmic_probe()
1182 dev_err(max8997->dev, "regulator init failed for %d\n", in max8997_pmic_probe()
1192 { "max8997-pmic", 0},
1199 .name = "max8997-pmic",