Re: [PATCH 08/15] twl4030_charger: distinguish between USB current and 'AC' current

2015-03-03 Thread NeilBrown
On Mon, 2 Mar 2015 22:05:10 +0100 Pavel Machek  wrote:

> Hi!
> 
> > The twl4030 charger has two current sources, 'USB' and 'AC' (which is
> > really DC of course...).
> > 
> > If 'AC' is providing current, we should set the current limit
> > differently to when it isn't (and so USB is used).
> > So split 'cur' into 'usb_cur' and 'ac_cur' and use accordingly.
> > 
> > Now we must review the current setting on any interrupt or USB
> > event which might indicate that the charger-source has changed.
> > 
> > Signed-off-by: NeilBrown 
> 
> > @@ -103,7 +104,9 @@ struct twl4030_bci {
> > /* ichg values in uA. If any are 'large', we set CGAIN to
> 
> ichg/_cur values
> 
> >  * '1' which doubles the range for half the precision.
> >  */
> > -   int ichg_eoc, ichg_lo, ichg_hi, cur;
> > +   int ichg_eoc, ichg_lo, ichg_hi;
> > +   int usb_cur, ac_cur;
> 
> > +   /* If VAC exceeds 4.5V (MADC 11) and ac is enabled, set current
> > +* for 'ac'
> 
>   /*
>* If AC voltage exceeds 4.5V (MADC 11) and AC is enabled, set current
>* for 'ac'.
> 
> 
> Acked-by: Pavel Machek 
> 

Thanks - I made those changes, or something much like them.

NeilBrown


pgpIpeDsG7pEg.pgp
Description: OpenPGP digital signature


Re: [PATCH 08/15] twl4030_charger: distinguish between USB current and 'AC' current

2015-03-02 Thread Pavel Machek
Hi!

> The twl4030 charger has two current sources, 'USB' and 'AC' (which is
> really DC of course...).
> 
> If 'AC' is providing current, we should set the current limit
> differently to when it isn't (and so USB is used).
> So split 'cur' into 'usb_cur' and 'ac_cur' and use accordingly.
> 
> Now we must review the current setting on any interrupt or USB
> event which might indicate that the charger-source has changed.
> 
> Signed-off-by: NeilBrown 

> @@ -103,7 +104,9 @@ struct twl4030_bci {
>   /* ichg values in uA. If any are 'large', we set CGAIN to

ichg/_cur values

>* '1' which doubles the range for half the precision.
>*/
> - int ichg_eoc, ichg_lo, ichg_hi, cur;
> + int ichg_eoc, ichg_lo, ichg_hi;
> + int usb_cur, ac_cur;

> + /* If VAC exceeds 4.5V (MADC 11) and ac is enabled, set current
> +  * for 'ac'

/*
 * If AC voltage exceeds 4.5V (MADC 11) and AC is enabled, set current
 * for 'ac'.


Acked-by: Pavel Machek 

-- 
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) 
http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[PATCH 08/15] twl4030_charger: distinguish between USB current and 'AC' current

2015-02-23 Thread NeilBrown
The twl4030 charger has two current sources, 'USB' and 'AC' (which is
really DC of course...).

If 'AC' is providing current, we should set the current limit
differently to when it isn't (and so USB is used).
So split 'cur' into 'usb_cur' and 'ac_cur' and use accordingly.

Now we must review the current setting on any interrupt or USB
event which might indicate that the charger-source has changed.

Signed-off-by: NeilBrown 
---
 drivers/power/twl4030_charger.c |   30 +-
 1 file changed, 25 insertions(+), 5 deletions(-)

diff --git a/drivers/power/twl4030_charger.c b/drivers/power/twl4030_charger.c
index 7c35cd9ba171..bfc9b808301e 100644
--- a/drivers/power/twl4030_charger.c
+++ b/drivers/power/twl4030_charger.c
@@ -22,6 +22,7 @@
 #include 
 #include 
 #include 
+#include 
 
 #define TWL4030_BCIMSTATEC 0x02
 #define TWL4030_BCIICHG0x08
@@ -103,7 +104,9 @@ struct twl4030_bci {
/* ichg values in uA. If any are 'large', we set CGAIN to
 * '1' which doubles the range for half the precision.
 */
-   int ichg_eoc, ichg_lo, ichg_hi, cur;
+   int ichg_eoc, ichg_lo, ichg_hi;
+   int usb_cur, ac_cur;
+   boolac_is_active;
 
unsigned long   event;
 };
@@ -224,11 +227,23 @@ static int ua2regval(int ua, bool cgain)
 static int twl4030_charger_update_current(struct twl4030_bci *bci)
 {
int status;
+   int cur;
unsigned reg, cur_reg;
u8 bcictl1, oldreg, fullreg;
int cgain = 0;
u8 boot_bci;
 
+   /* If VAC exceeds 4.5V (MADC 11) and ac is enabled, set current
+* for 'ac'
+*/
+   if (twl4030_get_madc_conversion(11) > 4500) {
+   cur = bci->ac_cur;
+   bci->ac_is_active = 1;
+   } else {
+   cur = bci->usb_cur;
+   bci->ac_is_active = 0;
+   }
+
/* First, check thresholds and see if cgain is needed */
if (bci->ichg_eoc >= 20)
cgain = 1;
@@ -236,7 +251,7 @@ static int twl4030_charger_update_current(struct 
twl4030_bci *bci)
cgain = 1;
if (bci->ichg_hi >= 82)
cgain = 1;
-   if (bci->cur > 852000)
+   if (cur > 852000)
cgain = 1;
 
status = twl4030_bci_read(TWL4030_BCICTL1, &bcictl1);
@@ -311,7 +326,7 @@ static int twl4030_charger_update_current(struct 
twl4030_bci *bci)
 
/* And finally, set the current.  This is stored in
 * two registers. */
-   reg = ua2regval(bci->cur, cgain);
+   reg = ua2regval(cur, cgain);
/* we have only 10 bit */
if (reg > 0x3ff)
reg = 0x3ff;
@@ -364,6 +379,8 @@ static int twl4030_charger_enable_usb(struct twl4030_bci 
*bci, bool enable)
 
if (enable && !IS_ERR_OR_NULL(bci->transceiver)) {
 
+   twl4030_charger_update_current(bci);
+
/* Need to keep phy powered */
if (!bci->usb_enabled) {
pm_runtime_get_sync(bci->transceiver->dev);
@@ -456,6 +473,7 @@ static irqreturn_t twl4030_charger_interrupt(int irq, void 
*arg)
struct twl4030_bci *bci = arg;
 
dev_dbg(bci->dev, "CHG_PRES irq\n");
+   twl4030_charger_update_current(bci);
power_supply_changed(&bci->ac);
power_supply_changed(&bci->usb);
 
@@ -488,6 +506,7 @@ static irqreturn_t twl4030_bci_interrupt(int irq, void *arg)
power_supply_changed(&bci->ac);
power_supply_changed(&bci->usb);
}
+   twl4030_charger_update_current(bci);
 
/* various monitoring events, for now we just log them here */
if (irqs1 & (TWL4030_TBATOR2 | TWL4030_TBATOR1))
@@ -701,10 +720,11 @@ static int __init twl4030_bci_probe(struct 
platform_device *pdev)
bci->ichg_eoc = 80100; /* Stop charging when current drops to here */
bci->ichg_lo = 241000; /* low threshold */
bci->ichg_hi = 50; /* High threshold */
+   bci->ac_cur = 50; /* 500mA */
if (allow_usb)
-   bci->cur = 50;  /* 500mA */
+   bci->usb_cur = 50;  /* 500mA */
else
-   bci->cur = 10;  /* 100mA */
+   bci->usb_cur = 10;  /* 100mA */
 
bci->dev = &pdev->dev;
bci->irq_chg = platform_get_irq(pdev, 0);


--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html