Re: [PATCH v3 12/16] power: supply: axp20x_usb_power: Add support for AXP192

From: Andy Shevchenko
Date: Sun Jun 19 2022 - 07:03:36 EST


On Sat, Jun 18, 2022 at 11:40 PM Aidan MacDonald
<aidanmacdonald.0x0@xxxxxxxxx> wrote:
>
> The AXP192 is mostly the same as the AXP202 but has a different
> current limit.

...

> + int ret = regmap_read(power->regmap, AXP20X_VBUS_IPSOUT_MGMT, &v);
> +
> + if (ret)
> + return ret;

Please, split assignment, so it will be like

int ret;

ret = ...
if (ret)

...

> +static int axp192_usb_power_set_current_max(struct axp20x_usb_power *power,
> + int intval)
> +{
> + int val = AXP192_VBUS_CLIMIT_EN;
> + const int mask = AXP192_VBUS_CLIMIT_EN | AXP192_VBUS_CLIMIT_100mA;
> +
> + switch (intval) {
> + case 100000:
> + val |= AXP192_VBUS_CLIMIT_100mA;

> + fallthrough;

It's harder to part and error prone, can't you simply call a
regmap_update_bits with different arguments?

With this suggestion consider the defaults like these:

const int mask = AXP192_VBUS_CLIMIT_EN | AXP192_VBUS_CLIMIT_100mA;
int val = mask;

Then use val & ~AXP192_VBUS_CLIMIT_100mA in the below case.

> + case 500000:
> + return regmap_update_bits(power->regmap,
> + AXP20X_VBUS_IPSOUT_MGMT, mask, val);
> + default:
> + return -EINVAL;
> + }
> +}

--
With Best Regards,
Andy Shevchenko