Re: [RESEND PATCH 3/5] charger: max14577: Configure battery-dependent settings from DTS

From: Krzysztof Kozlowski
Date: Thu Jul 03 2014 - 07:46:06 EST


On czw, 2014-07-03 at 12:36 +0100, Mark Rutland wrote:
> On Tue, Jul 01, 2014 at 08:01:58AM +0100, Krzysztof Kozlowski wrote:
> > Remove hard-coded values for:
> > - Fast Charge current,
> > - End Of Charge current,
> > - Fast Charge timer,
> > - Overvoltage Protection Threshold,
> > - Battery Constant Voltage,
> > and use DTS to configure them. This allows using the max14577 charger
> > driver with different batteries.
> >
> > Now the charger driver requires valid configuration data from DTS. In
> > case of wrong configuration data it fails during probe. Patch adds
> > of_compatible to the charger mfd cell in MFD driver core.
> >
> > Signed-off-by: Krzysztof Kozlowski <k.kozlowski@xxxxxxxxxxx>
> > Cc: Kyungmin Park <kyungmin.park@xxxxxxxxxxx>
> > Cc: Dmitry Eremin-Solenikov <dbaryshkov@xxxxxxxxx>
> > Cc: David Woodhouse <dwmw2@xxxxxxxxxxxxx>
> > Cc: Jenny Tc <jenny.tc@xxxxxxxxx>
> > Acked-by: Lee Jones <lee.jones@xxxxxxxxxx>
> > ---
> > drivers/mfd/max14577.c | 5 +-
> > drivers/power/max14577_charger.c | 232 +++++++++++++++++++++++++++++++----
> > include/linux/mfd/max14577-private.h | 16 +++
> > include/linux/mfd/max14577.h | 8 ++
> > 4 files changed, 233 insertions(+), 28 deletions(-)
>
> [...]
>
> > + pdata = devm_kzalloc(&pdev->dev, sizeof(*pdata), GFP_KERNEL);
> > + if (!pdata) {
> > + dev_err(&pdev->dev, "Memory alloc for charger pdata failed\n");
> > + return ERR_PTR(-ENOMEM);
> > + }
> > +
> > + ret = of_property_read_u32(np, "maxim,fast-charge-timer",
> > + &pdata->fast_charge_timer);
> > + if (ret)
> > + return ERR_PTR(ret);
> > +
> > + ret = of_property_read_u32(np, "maxim,constant-uvolt",
> > + &pdata->constant_uvolt);
> > + if (ret)
> > + return ERR_PTR(ret);
> > +
> > + ret = of_property_read_u32(np, "maxim,fast-charge-uamp",
> > + &pdata->fast_charge_uamp);
> > + if (ret)
> > + return ERR_PTR(ret);
> > +
> > + ret = of_property_read_u32(np, "maxim,eoc-uamp", &pdata->eoc_uamp);
> > + if (ret)
> > + return ERR_PTR(ret);
> > +
> > + ret = of_property_read_u32(np, "maxim,ovp-uvolt", &pdata->ovp_uvolt);
> > + if (ret)
> > + return ERR_PTR(ret);
>
> None of the fields being read into are u32 per the structure definition
> below. Please use a u32 temporary variable or make the fields u32
> values.
>
> It would also be a good idea to print a warning as to _which_ field is
> missing and/or invalid as that really helps someone writing a DTS to
> figure out why the device isn't probing.

Sure, thanks for feedback. I'll fix this and re-spin.

Best regards,
Krzysztof


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/