[Gta04-owner] [PATCH 13/15] twl4030_charger: add ac/mode to match usb/mode
NeilBrown
neilb at suse.de
Mon Mar 23 00:13:19 CET 2015
On Fri, 6 Mar 2015 23:59:04 +0200 Grazvydas Ignotas <notasas at gmail.com> wrote:
> On Tue, Feb 24, 2015 at 6:33 AM, NeilBrown <neilb at suse.de> wrote:
> > This allows AC charging to be turned off, much like usb charging.
> >
> > "continuous" (aka "linear") mode maps to the CVENAC (constant voltage)
> > feature of the twl4030.
>
> Are you sure? Before your patches CVENAC was set at all times and and
> charger still worked in automatic mode.
>
> >
> > Signed-off-by: NeilBrown <neilb at suse.de>
> > ---
> > drivers/power/twl4030_charger.c | 40 +++++++++++++++++++++++++++++----------
> > 1 file changed, 30 insertions(+), 10 deletions(-)
> >
> > diff --git a/drivers/power/twl4030_charger.c b/drivers/power/twl4030_charger.c
> > index 6c53f0b601a4..e5a0225ea87e 100644
> > --- a/drivers/power/twl4030_charger.c
> > +++ b/drivers/power/twl4030_charger.c
> > @@ -112,7 +112,7 @@ struct twl4030_bci {
> > int ichg_eoc, ichg_lo, ichg_hi;
> > int usb_cur, ac_cur;
> > bool ac_is_active;
> > - int usb_mode; /* charging mode requested */
> > + int usb_mode, ac_mode; /* charging mode requested */
> > #define CHARGE_OFF 0
> > #define CHARGE_AUTO 1
> > #define CHARGE_LINEAR 2
> > @@ -449,12 +449,18 @@ static int twl4030_charger_enable_usb(struct twl4030_bci *bci, bool enable)
> > /*
> > * Enable/Disable AC Charge funtionality.
> > */
> > -static int twl4030_charger_enable_ac(bool enable)
> > +static int twl4030_charger_enable_ac(struct twl4030_bci *bci, bool enable)
> > {
> > int ret;
> >
> > - if (enable)
> > - ret = twl4030_clear_set_boot_bci(0, TWL4030_BCIAUTOAC);
> > + if (bci->ac_mode == CHARGE_OFF)
> > + enable = false;
> > +
> > + if (enable && bci->ac_mode == CHARGE_LINEAR)
> > + ret = twl4030_clear_set_boot_bci(0, (TWL4030_CVENAC |
> > + TWL4030_BCIAUTOAC));
> > + else if (enable)
> > + ret = twl4030_clear_set_boot_bci(TWL4030_CVENAC, TWL4030_BCIAUTOAC);
> > else
> > ret = twl4030_clear_set_boot_bci(TWL4030_BCIAUTOAC, 0);
>
> CVENAC is required to be set for operation on AC without battery
> (which works fine on most pandora boards). After this patch, when
> booted without battery, the board will reset before there is a chance
> to set the linear mode by userspace, because this is called on
> probe...
>
Yes, it looks like I misunderstood CVENAC a bit - thanks.
I've removed 'continuous' mode for AC and no longer clear or set that bit.
Thanks,
NeilBrown
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 811 bytes
Desc: OpenPGP digital signature
URL: <http://lists.goldelico.com/pipermail/gta04-owner/attachments/20150323/72d656cc/attachment-0001.asc>
More information about the Gta04-owner
mailing list