mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-04 04:04:19 +00:00
power: supply: axp288_charger: Fix constant_charge_voltage writes
info->max_cv is in millivolts, divide the microvolt value being written
to constant_charge_voltage by 1000 *before* clamping it to info->max_cv.
Before this fix the code always tried to set constant_charge_voltage
to max_cv / 1000 = 4 millivolt, which ends up in setting it to 4.1V
which is the lowest supported value.
Fixes: 843735b788
("power: axp288_charger: axp288 charger driver")
Cc: stable@vger.kernel.org
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Link: https://lore.kernel.org/r/20240717200333.56669-1-hdegoede@redhat.com
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
This commit is contained in:
parent
d3911f1639
commit
b34ce4a59c
@ -337,8 +337,8 @@ static int axp288_charger_usb_set_property(struct power_supply *psy,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE:
|
case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE:
|
||||||
scaled_val = min(val->intval, info->max_cv);
|
scaled_val = DIV_ROUND_CLOSEST(val->intval, 1000);
|
||||||
scaled_val = DIV_ROUND_CLOSEST(scaled_val, 1000);
|
scaled_val = min(scaled_val, info->max_cv);
|
||||||
ret = axp288_charger_set_cv(info, scaled_val);
|
ret = axp288_charger_set_cv(info, scaled_val);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
dev_warn(&info->pdev->dev, "set charge voltage failed\n");
|
dev_warn(&info->pdev->dev, "set charge voltage failed\n");
|
||||||
|
Loading…
Reference in New Issue
Block a user