aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew Chew <achew@nvidia.com>2013-06-06 17:12:43 -0400
committerAnton Vorontsov <anton@enomsg.org>2013-06-09 13:07:34 -0400
commite24142178fc2f60824af4312d326edacdcd667a3 (patch)
tree9cfdfac74ecff5b45b94baba14fa3527a74789c0
parent9d5e2a023eee96b2326f9b0830a753b400917280 (diff)
tps65090-charger: Fix AC detect
The VACG interrupt was not being enabled. Thus, interrupts were never generated when AC status changes. In addition, interrupts were never cleared after taking and processing the interrupt. Added the register offset for the INTR_MASK register, since this is needed to unmask the VACG interrupt. Enabled the VACG interrupt in tps65090_config_charger(). Cleared interrupts after processing, in tps65090_charger_isr(). Also removed unused variable "enable" in tps65090_enable_charging(), and fixed a typo in one of the dev_err() prints. Signed-off-by: Andrew Chew <achew@nvidia.com> Tested-by: Rhyland Klein <rklein@nvidia.com> Acked-by: Rhyland Klein <rklein@nvidia.com> Signed-off-by: Anton Vorontsov <anton@enomsg.org>
-rw-r--r--drivers/power/tps65090-charger.c35
1 files changed, 30 insertions, 5 deletions
diff --git a/drivers/power/tps65090-charger.c b/drivers/power/tps65090-charger.c
index 77ab8561fa34..e628f9813e08 100644
--- a/drivers/power/tps65090-charger.c
+++ b/drivers/power/tps65090-charger.c
@@ -27,6 +27,7 @@
27#include <linux/mfd/tps65090.h> 27#include <linux/mfd/tps65090.h>
28 28
29#define TPS65090_REG_INTR_STS 0x00 29#define TPS65090_REG_INTR_STS 0x00
30#define TPS65090_REG_INTR_MASK 0x02
30#define TPS65090_REG_CG_CTRL0 0x04 31#define TPS65090_REG_CG_CTRL0 0x04
31#define TPS65090_REG_CG_CTRL1 0x05 32#define TPS65090_REG_CG_CTRL1 0x05
32#define TPS65090_REG_CG_CTRL2 0x06 33#define TPS65090_REG_CG_CTRL2 0x06
@@ -67,8 +68,7 @@ static int tps65090_low_chrg_current(struct tps65090_charger *charger)
67 return 0; 68 return 0;
68} 69}
69 70
70static int tps65090_enable_charging(struct tps65090_charger *charger, 71static int tps65090_enable_charging(struct tps65090_charger *charger)
71 uint8_t enable)
72{ 72{
73 int ret; 73 int ret;
74 uint8_t ctrl0 = 0; 74 uint8_t ctrl0 = 0;
@@ -84,7 +84,7 @@ static int tps65090_enable_charging(struct tps65090_charger *charger,
84 ret = tps65090_write(charger->dev->parent, TPS65090_REG_CG_CTRL0, 84 ret = tps65090_write(charger->dev->parent, TPS65090_REG_CG_CTRL0,
85 (ctrl0 | TPS65090_CHARGER_ENABLE)); 85 (ctrl0 | TPS65090_CHARGER_ENABLE));
86 if (ret < 0) { 86 if (ret < 0) {
87 dev_err(charger->dev, "%s(): error reading in register 0x%x\n", 87 dev_err(charger->dev, "%s(): error writing in register 0x%x\n",
88 __func__, TPS65090_REG_CG_CTRL0); 88 __func__, TPS65090_REG_CG_CTRL0);
89 return ret; 89 return ret;
90 } 90 }
@@ -93,6 +93,7 @@ static int tps65090_enable_charging(struct tps65090_charger *charger,
93 93
94static int tps65090_config_charger(struct tps65090_charger *charger) 94static int tps65090_config_charger(struct tps65090_charger *charger)
95{ 95{
96 uint8_t intrmask = 0;
96 int ret; 97 int ret;
97 98
98 if (charger->pdata->enable_low_current_chrg) { 99 if (charger->pdata->enable_low_current_chrg) {
@@ -104,6 +105,23 @@ static int tps65090_config_charger(struct tps65090_charger *charger)
104 } 105 }
105 } 106 }
106 107
108 /* Enable the VACG interrupt for AC power detect */
109 ret = tps65090_read(charger->dev->parent, TPS65090_REG_INTR_MASK,
110 &intrmask);
111 if (ret < 0) {
112 dev_err(charger->dev, "%s(): error reading in register 0x%x\n",
113 __func__, TPS65090_REG_INTR_MASK);
114 return ret;
115 }
116
117 ret = tps65090_write(charger->dev->parent, TPS65090_REG_INTR_MASK,
118 (intrmask | TPS65090_VACG));
119 if (ret < 0) {
120 dev_err(charger->dev, "%s(): error writing in register 0x%x\n",
121 __func__, TPS65090_REG_CG_CTRL0);
122 return ret;
123 }
124
107 return 0; 125 return 0;
108} 126}
109 127
@@ -146,7 +164,7 @@ static irqreturn_t tps65090_charger_isr(int irq, void *dev_id)
146 } 164 }
147 165
148 if (intrsts & TPS65090_VACG) { 166 if (intrsts & TPS65090_VACG) {
149 ret = tps65090_enable_charging(charger, 1); 167 ret = tps65090_enable_charging(charger);
150 if (ret < 0) 168 if (ret < 0)
151 return IRQ_HANDLED; 169 return IRQ_HANDLED;
152 charger->ac_online = 1; 170 charger->ac_online = 1;
@@ -154,6 +172,13 @@ static irqreturn_t tps65090_charger_isr(int irq, void *dev_id)
154 charger->ac_online = 0; 172 charger->ac_online = 0;
155 } 173 }
156 174
175 /* Clear interrupts. */
176 ret = tps65090_write(charger->dev->parent, TPS65090_REG_INTR_STS, 0x00);
177 if (ret < 0) {
178 dev_err(charger->dev, "%s(): Error in writing reg 0x%x\n",
179 __func__, TPS65090_REG_INTR_STS);
180 }
181
157 if (charger->prev_ac_online != charger->ac_online) 182 if (charger->prev_ac_online != charger->ac_online)
158 power_supply_changed(&charger->ac); 183 power_supply_changed(&charger->ac);
159 184
@@ -270,7 +295,7 @@ static int tps65090_charger_probe(struct platform_device *pdev)
270 } 295 }
271 296
272 if (status1 != 0) { 297 if (status1 != 0) {
273 ret = tps65090_enable_charging(cdata, 1); 298 ret = tps65090_enable_charging(cdata);
274 if (ret < 0) { 299 if (ret < 0) {
275 dev_err(cdata->dev, "error enabling charger\n"); 300 dev_err(cdata->dev, "error enabling charger\n");
276 goto fail_free_irq; 301 goto fail_free_irq;