1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Driver for the TI bq24190 battery charger.
4  *
5  * Author: Mark A. Greer <mgreer@animalcreek.com>
6  */
7 
8 #include <linux/mod_devicetable.h>
9 #include <linux/module.h>
10 #include <linux/interrupt.h>
11 #include <linux/delay.h>
12 #include <linux/pm_runtime.h>
13 #include <linux/power_supply.h>
14 #include <linux/power/bq24190_charger.h>
15 #include <linux/regulator/driver.h>
16 #include <linux/regulator/machine.h>
17 #include <linux/workqueue.h>
18 #include <linux/i2c.h>
19 #include <linux/extcon-provider.h>
20 
21 #define	BQ24190_MANUFACTURER	"Texas Instruments"
22 
23 #define BQ24190_REG_ISC		0x00 /* Input Source Control */
24 #define BQ24190_REG_ISC_EN_HIZ_MASK		BIT(7)
25 #define BQ24190_REG_ISC_EN_HIZ_SHIFT		7
26 #define BQ24190_REG_ISC_VINDPM_MASK		(BIT(6) | BIT(5) | BIT(4) | \
27 						 BIT(3))
28 #define BQ24190_REG_ISC_VINDPM_SHIFT		3
29 #define BQ24190_REG_ISC_IINLIM_MASK		(BIT(2) | BIT(1) | BIT(0))
30 #define BQ24190_REG_ISC_IINLIM_SHIFT		0
31 
32 #define BQ24190_REG_POC		0x01 /* Power-On Configuration */
33 #define BQ24190_REG_POC_RESET_MASK		BIT(7)
34 #define BQ24190_REG_POC_RESET_SHIFT		7
35 #define BQ24190_REG_POC_WDT_RESET_MASK		BIT(6)
36 #define BQ24190_REG_POC_WDT_RESET_SHIFT		6
37 #define BQ24190_REG_POC_CHG_CONFIG_MASK		(BIT(5) | BIT(4))
38 #define BQ24190_REG_POC_CHG_CONFIG_SHIFT	4
39 #define BQ24190_REG_POC_CHG_CONFIG_DISABLE		0x0
40 #define BQ24190_REG_POC_CHG_CONFIG_CHARGE		0x1
41 #define BQ24190_REG_POC_CHG_CONFIG_OTG			0x2
42 #define BQ24190_REG_POC_SYS_MIN_MASK		(BIT(3) | BIT(2) | BIT(1))
43 #define BQ24190_REG_POC_SYS_MIN_SHIFT		1
44 #define BQ24190_REG_POC_SYS_MIN_MIN			3000
45 #define BQ24190_REG_POC_SYS_MIN_MAX			3700
46 #define BQ24190_REG_POC_BOOST_LIM_MASK		BIT(0)
47 #define BQ24190_REG_POC_BOOST_LIM_SHIFT		0
48 
49 #define BQ24190_REG_CCC		0x02 /* Charge Current Control */
50 #define BQ24190_REG_CCC_ICHG_MASK		(BIT(7) | BIT(6) | BIT(5) | \
51 						 BIT(4) | BIT(3) | BIT(2))
52 #define BQ24190_REG_CCC_ICHG_SHIFT		2
53 #define BQ24190_REG_CCC_FORCE_20PCT_MASK	BIT(0)
54 #define BQ24190_REG_CCC_FORCE_20PCT_SHIFT	0
55 
56 #define BQ24190_REG_PCTCC	0x03 /* Pre-charge/Termination Current Cntl */
57 #define BQ24190_REG_PCTCC_IPRECHG_MASK		(BIT(7) | BIT(6) | BIT(5) | \
58 						 BIT(4))
59 #define BQ24190_REG_PCTCC_IPRECHG_SHIFT		4
60 #define BQ24190_REG_PCTCC_IPRECHG_MIN			128
61 #define BQ24190_REG_PCTCC_IPRECHG_MAX			2048
62 #define BQ24190_REG_PCTCC_ITERM_MASK		(BIT(3) | BIT(2) | BIT(1) | \
63 						 BIT(0))
64 #define BQ24190_REG_PCTCC_ITERM_SHIFT		0
65 #define BQ24190_REG_PCTCC_ITERM_MIN			128
66 #define BQ24190_REG_PCTCC_ITERM_MAX			2048
67 
68 #define BQ24190_REG_CVC		0x04 /* Charge Voltage Control */
69 #define BQ24190_REG_CVC_VREG_MASK		(BIT(7) | BIT(6) | BIT(5) | \
70 						 BIT(4) | BIT(3) | BIT(2))
71 #define BQ24190_REG_CVC_VREG_SHIFT		2
72 #define BQ24190_REG_CVC_BATLOWV_MASK		BIT(1)
73 #define BQ24190_REG_CVC_BATLOWV_SHIFT		1
74 #define BQ24190_REG_CVC_VRECHG_MASK		BIT(0)
75 #define BQ24190_REG_CVC_VRECHG_SHIFT		0
76 
77 #define BQ24190_REG_CTTC	0x05 /* Charge Term/Timer Control */
78 #define BQ24190_REG_CTTC_EN_TERM_MASK		BIT(7)
79 #define BQ24190_REG_CTTC_EN_TERM_SHIFT		7
80 #define BQ24190_REG_CTTC_TERM_STAT_MASK		BIT(6)
81 #define BQ24190_REG_CTTC_TERM_STAT_SHIFT	6
82 #define BQ24190_REG_CTTC_WATCHDOG_MASK		(BIT(5) | BIT(4))
83 #define BQ24190_REG_CTTC_WATCHDOG_SHIFT		4
84 #define BQ24190_REG_CTTC_EN_TIMER_MASK		BIT(3)
85 #define BQ24190_REG_CTTC_EN_TIMER_SHIFT		3
86 #define BQ24190_REG_CTTC_CHG_TIMER_MASK		(BIT(2) | BIT(1))
87 #define BQ24190_REG_CTTC_CHG_TIMER_SHIFT	1
88 #define BQ24190_REG_CTTC_JEITA_ISET_MASK	BIT(0)
89 #define BQ24190_REG_CTTC_JEITA_ISET_SHIFT	0
90 
91 #define BQ24190_REG_ICTRC	0x06 /* IR Comp/Thermal Regulation Control */
92 #define BQ24190_REG_ICTRC_BAT_COMP_MASK		(BIT(7) | BIT(6) | BIT(5))
93 #define BQ24190_REG_ICTRC_BAT_COMP_SHIFT	5
94 #define BQ24190_REG_ICTRC_VCLAMP_MASK		(BIT(4) | BIT(3) | BIT(2))
95 #define BQ24190_REG_ICTRC_VCLAMP_SHIFT		2
96 #define BQ24190_REG_ICTRC_TREG_MASK		(BIT(1) | BIT(0))
97 #define BQ24190_REG_ICTRC_TREG_SHIFT		0
98 
99 #define BQ24190_REG_MOC		0x07 /* Misc. Operation Control */
100 #define BQ24190_REG_MOC_DPDM_EN_MASK		BIT(7)
101 #define BQ24190_REG_MOC_DPDM_EN_SHIFT		7
102 #define BQ24190_REG_MOC_TMR2X_EN_MASK		BIT(6)
103 #define BQ24190_REG_MOC_TMR2X_EN_SHIFT		6
104 #define BQ24190_REG_MOC_BATFET_DISABLE_MASK	BIT(5)
105 #define BQ24190_REG_MOC_BATFET_DISABLE_SHIFT	5
106 #define BQ24190_REG_MOC_JEITA_VSET_MASK		BIT(4)
107 #define BQ24190_REG_MOC_JEITA_VSET_SHIFT	4
108 #define BQ24190_REG_MOC_INT_MASK_MASK		(BIT(1) | BIT(0))
109 #define BQ24190_REG_MOC_INT_MASK_SHIFT		0
110 
111 #define BQ24190_REG_SS		0x08 /* System Status */
112 #define BQ24190_REG_SS_VBUS_STAT_MASK		(BIT(7) | BIT(6))
113 #define BQ24190_REG_SS_VBUS_STAT_SHIFT		6
114 #define BQ24190_REG_SS_CHRG_STAT_MASK		(BIT(5) | BIT(4))
115 #define BQ24190_REG_SS_CHRG_STAT_SHIFT		4
116 #define BQ24190_REG_SS_DPM_STAT_MASK		BIT(3)
117 #define BQ24190_REG_SS_DPM_STAT_SHIFT		3
118 #define BQ24190_REG_SS_PG_STAT_MASK		BIT(2)
119 #define BQ24190_REG_SS_PG_STAT_SHIFT		2
120 #define BQ24190_REG_SS_THERM_STAT_MASK		BIT(1)
121 #define BQ24190_REG_SS_THERM_STAT_SHIFT		1
122 #define BQ24190_REG_SS_VSYS_STAT_MASK		BIT(0)
123 #define BQ24190_REG_SS_VSYS_STAT_SHIFT		0
124 
125 #define BQ24190_REG_F		0x09 /* Fault */
126 #define BQ24190_REG_F_WATCHDOG_FAULT_MASK	BIT(7)
127 #define BQ24190_REG_F_WATCHDOG_FAULT_SHIFT	7
128 #define BQ24190_REG_F_BOOST_FAULT_MASK		BIT(6)
129 #define BQ24190_REG_F_BOOST_FAULT_SHIFT		6
130 #define BQ24190_REG_F_CHRG_FAULT_MASK		(BIT(5) | BIT(4))
131 #define BQ24190_REG_F_CHRG_FAULT_SHIFT		4
132 #define BQ24190_REG_F_BAT_FAULT_MASK		BIT(3)
133 #define BQ24190_REG_F_BAT_FAULT_SHIFT		3
134 #define BQ24190_REG_F_NTC_FAULT_MASK		(BIT(2) | BIT(1) | BIT(0))
135 #define BQ24190_REG_F_NTC_FAULT_SHIFT		0
136 
137 #define BQ24190_REG_VPRS	0x0A /* Vendor/Part/Revision Status */
138 #define BQ24190_REG_VPRS_PN_MASK		(BIT(5) | BIT(4) | BIT(3))
139 #define BQ24190_REG_VPRS_PN_SHIFT		3
140 #define BQ24190_REG_VPRS_PN_24190			0x4
141 #define BQ24190_REG_VPRS_PN_24192			0x5 /* Also 24193, 24196 */
142 #define BQ24190_REG_VPRS_PN_24192I			0x3
143 #define BQ24190_REG_VPRS_TS_PROFILE_MASK	BIT(2)
144 #define BQ24190_REG_VPRS_TS_PROFILE_SHIFT	2
145 #define BQ24190_REG_VPRS_DEV_REG_MASK		(BIT(1) | BIT(0))
146 #define BQ24190_REG_VPRS_DEV_REG_SHIFT		0
147 
148 /*
149  * The FAULT register is latched by the bq24190 (except for NTC_FAULT)
150  * so the first read after a fault returns the latched value and subsequent
151  * reads return the current value.  In order to return the fault status
152  * to the user, have the interrupt handler save the reg's value and retrieve
153  * it in the appropriate health/status routine.
154  */
155 struct bq24190_dev_info {
156 	struct i2c_client		*client;
157 	struct device			*dev;
158 	struct extcon_dev		*edev;
159 	struct power_supply		*charger;
160 	struct power_supply		*battery;
161 	struct delayed_work		input_current_limit_work;
162 	char				model_name[I2C_NAME_SIZE];
163 	bool				initialized;
164 	bool				irq_event;
165 	u16				sys_min;
166 	u16				iprechg;
167 	u16				iterm;
168 	struct mutex			f_reg_lock;
169 	u8				f_reg;
170 	u8				ss_reg;
171 	u8				watchdog;
172 };
173 
174 static const unsigned int bq24190_usb_extcon_cable[] = {
175 	EXTCON_USB,
176 	EXTCON_NONE,
177 };
178 
179 /*
180  * The tables below provide a 2-way mapping for the value that goes in
181  * the register field and the real-world value that it represents.
182  * The index of the array is the value that goes in the register; the
183  * number at that index in the array is the real-world value that it
184  * represents.
185  */
186 
187 /* REG00[2:0] (IINLIM) in uAh */
188 static const int bq24190_isc_iinlim_values[] = {
189 	 100000,  150000,  500000,  900000, 1200000, 1500000, 2000000, 3000000
190 };
191 
192 /* REG02[7:2] (ICHG) in uAh */
193 static const int bq24190_ccc_ichg_values[] = {
194 	 512000,  576000,  640000,  704000,  768000,  832000,  896000,  960000,
195 	1024000, 1088000, 1152000, 1216000, 1280000, 1344000, 1408000, 1472000,
196 	1536000, 1600000, 1664000, 1728000, 1792000, 1856000, 1920000, 1984000,
197 	2048000, 2112000, 2176000, 2240000, 2304000, 2368000, 2432000, 2496000,
198 	2560000, 2624000, 2688000, 2752000, 2816000, 2880000, 2944000, 3008000,
199 	3072000, 3136000, 3200000, 3264000, 3328000, 3392000, 3456000, 3520000,
200 	3584000, 3648000, 3712000, 3776000, 3840000, 3904000, 3968000, 4032000,
201 	4096000, 4160000, 4224000, 4288000, 4352000, 4416000, 4480000, 4544000
202 };
203 
204 /* REG04[7:2] (VREG) in uV */
205 static const int bq24190_cvc_vreg_values[] = {
206 	3504000, 3520000, 3536000, 3552000, 3568000, 3584000, 3600000, 3616000,
207 	3632000, 3648000, 3664000, 3680000, 3696000, 3712000, 3728000, 3744000,
208 	3760000, 3776000, 3792000, 3808000, 3824000, 3840000, 3856000, 3872000,
209 	3888000, 3904000, 3920000, 3936000, 3952000, 3968000, 3984000, 4000000,
210 	4016000, 4032000, 4048000, 4064000, 4080000, 4096000, 4112000, 4128000,
211 	4144000, 4160000, 4176000, 4192000, 4208000, 4224000, 4240000, 4256000,
212 	4272000, 4288000, 4304000, 4320000, 4336000, 4352000, 4368000, 4384000,
213 	4400000
214 };
215 
216 /* REG06[1:0] (TREG) in tenths of degrees Celsius */
217 static const int bq24190_ictrc_treg_values[] = {
218 	600, 800, 1000, 1200
219 };
220 
221 /*
222  * Return the index in 'tbl' of greatest value that is less than or equal to
223  * 'val'.  The index range returned is 0 to 'tbl_size' - 1.  Assumes that
224  * the values in 'tbl' are sorted from smallest to largest and 'tbl_size'
225  * is less than 2^8.
226  */
227 static u8 bq24190_find_idx(const int tbl[], int tbl_size, int v)
228 {
229 	int i;
230 
231 	for (i = 1; i < tbl_size; i++)
232 		if (v < tbl[i])
233 			break;
234 
235 	return i - 1;
236 }
237 
238 /* Basic driver I/O routines */
239 
240 static int bq24190_read(struct bq24190_dev_info *bdi, u8 reg, u8 *data)
241 {
242 	int ret;
243 
244 	ret = i2c_smbus_read_byte_data(bdi->client, reg);
245 	if (ret < 0)
246 		return ret;
247 
248 	*data = ret;
249 	return 0;
250 }
251 
252 static int bq24190_write(struct bq24190_dev_info *bdi, u8 reg, u8 data)
253 {
254 	return i2c_smbus_write_byte_data(bdi->client, reg, data);
255 }
256 
257 static int bq24190_read_mask(struct bq24190_dev_info *bdi, u8 reg,
258 		u8 mask, u8 shift, u8 *data)
259 {
260 	u8 v;
261 	int ret;
262 
263 	ret = bq24190_read(bdi, reg, &v);
264 	if (ret < 0)
265 		return ret;
266 
267 	v &= mask;
268 	v >>= shift;
269 	*data = v;
270 
271 	return 0;
272 }
273 
274 static int bq24190_write_mask(struct bq24190_dev_info *bdi, u8 reg,
275 		u8 mask, u8 shift, u8 data)
276 {
277 	u8 v;
278 	int ret;
279 
280 	ret = bq24190_read(bdi, reg, &v);
281 	if (ret < 0)
282 		return ret;
283 
284 	v &= ~mask;
285 	v |= ((data << shift) & mask);
286 
287 	return bq24190_write(bdi, reg, v);
288 }
289 
290 static int bq24190_get_field_val(struct bq24190_dev_info *bdi,
291 		u8 reg, u8 mask, u8 shift,
292 		const int tbl[], int tbl_size,
293 		int *val)
294 {
295 	u8 v;
296 	int ret;
297 
298 	ret = bq24190_read_mask(bdi, reg, mask, shift, &v);
299 	if (ret < 0)
300 		return ret;
301 
302 	v = (v >= tbl_size) ? (tbl_size - 1) : v;
303 	*val = tbl[v];
304 
305 	return 0;
306 }
307 
308 static int bq24190_set_field_val(struct bq24190_dev_info *bdi,
309 		u8 reg, u8 mask, u8 shift,
310 		const int tbl[], int tbl_size,
311 		int val)
312 {
313 	u8 idx;
314 
315 	idx = bq24190_find_idx(tbl, tbl_size, val);
316 
317 	return bq24190_write_mask(bdi, reg, mask, shift, idx);
318 }
319 
320 #ifdef CONFIG_SYSFS
321 /*
322  * There are a numerous options that are configurable on the bq24190
323  * that go well beyond what the power_supply properties provide access to.
324  * Provide sysfs access to them so they can be examined and possibly modified
325  * on the fly.  They will be provided for the charger power_supply object only
326  * and will be prefixed by 'f_' to make them easier to recognize.
327  */
328 
329 #define BQ24190_SYSFS_FIELD(_name, r, f, m, store)			\
330 {									\
331 	.attr	= __ATTR(f_##_name, m, bq24190_sysfs_show, store),	\
332 	.reg	= BQ24190_REG_##r,					\
333 	.mask	= BQ24190_REG_##r##_##f##_MASK,				\
334 	.shift	= BQ24190_REG_##r##_##f##_SHIFT,			\
335 }
336 
337 #define BQ24190_SYSFS_FIELD_RW(_name, r, f)				\
338 		BQ24190_SYSFS_FIELD(_name, r, f, S_IWUSR | S_IRUGO,	\
339 				bq24190_sysfs_store)
340 
341 #define BQ24190_SYSFS_FIELD_RO(_name, r, f)				\
342 		BQ24190_SYSFS_FIELD(_name, r, f, S_IRUGO, NULL)
343 
344 static ssize_t bq24190_sysfs_show(struct device *dev,
345 		struct device_attribute *attr, char *buf);
346 static ssize_t bq24190_sysfs_store(struct device *dev,
347 		struct device_attribute *attr, const char *buf, size_t count);
348 
349 struct bq24190_sysfs_field_info {
350 	struct device_attribute	attr;
351 	u8	reg;
352 	u8	mask;
353 	u8	shift;
354 };
355 
356 /* On i386 ptrace-abi.h defines SS that breaks the macro calls below. */
357 #undef SS
358 
359 static struct bq24190_sysfs_field_info bq24190_sysfs_field_tbl[] = {
360 			/*	sysfs name	reg	field in reg */
361 	BQ24190_SYSFS_FIELD_RW(en_hiz,		ISC,	EN_HIZ),
362 	BQ24190_SYSFS_FIELD_RW(vindpm,		ISC,	VINDPM),
363 	BQ24190_SYSFS_FIELD_RW(iinlim,		ISC,	IINLIM),
364 	BQ24190_SYSFS_FIELD_RW(chg_config,	POC,	CHG_CONFIG),
365 	BQ24190_SYSFS_FIELD_RW(sys_min,		POC,	SYS_MIN),
366 	BQ24190_SYSFS_FIELD_RW(boost_lim,	POC,	BOOST_LIM),
367 	BQ24190_SYSFS_FIELD_RW(ichg,		CCC,	ICHG),
368 	BQ24190_SYSFS_FIELD_RW(force_20_pct,	CCC,	FORCE_20PCT),
369 	BQ24190_SYSFS_FIELD_RW(iprechg,		PCTCC,	IPRECHG),
370 	BQ24190_SYSFS_FIELD_RW(iterm,		PCTCC,	ITERM),
371 	BQ24190_SYSFS_FIELD_RW(vreg,		CVC,	VREG),
372 	BQ24190_SYSFS_FIELD_RW(batlowv,		CVC,	BATLOWV),
373 	BQ24190_SYSFS_FIELD_RW(vrechg,		CVC,	VRECHG),
374 	BQ24190_SYSFS_FIELD_RW(en_term,		CTTC,	EN_TERM),
375 	BQ24190_SYSFS_FIELD_RW(term_stat,	CTTC,	TERM_STAT),
376 	BQ24190_SYSFS_FIELD_RO(watchdog,	CTTC,	WATCHDOG),
377 	BQ24190_SYSFS_FIELD_RW(en_timer,	CTTC,	EN_TIMER),
378 	BQ24190_SYSFS_FIELD_RW(chg_timer,	CTTC,	CHG_TIMER),
379 	BQ24190_SYSFS_FIELD_RW(jeta_iset,	CTTC,	JEITA_ISET),
380 	BQ24190_SYSFS_FIELD_RW(bat_comp,	ICTRC,	BAT_COMP),
381 	BQ24190_SYSFS_FIELD_RW(vclamp,		ICTRC,	VCLAMP),
382 	BQ24190_SYSFS_FIELD_RW(treg,		ICTRC,	TREG),
383 	BQ24190_SYSFS_FIELD_RW(dpdm_en,		MOC,	DPDM_EN),
384 	BQ24190_SYSFS_FIELD_RW(tmr2x_en,	MOC,	TMR2X_EN),
385 	BQ24190_SYSFS_FIELD_RW(batfet_disable,	MOC,	BATFET_DISABLE),
386 	BQ24190_SYSFS_FIELD_RW(jeita_vset,	MOC,	JEITA_VSET),
387 	BQ24190_SYSFS_FIELD_RO(int_mask,	MOC,	INT_MASK),
388 	BQ24190_SYSFS_FIELD_RO(vbus_stat,	SS,	VBUS_STAT),
389 	BQ24190_SYSFS_FIELD_RO(chrg_stat,	SS,	CHRG_STAT),
390 	BQ24190_SYSFS_FIELD_RO(dpm_stat,	SS,	DPM_STAT),
391 	BQ24190_SYSFS_FIELD_RO(pg_stat,		SS,	PG_STAT),
392 	BQ24190_SYSFS_FIELD_RO(therm_stat,	SS,	THERM_STAT),
393 	BQ24190_SYSFS_FIELD_RO(vsys_stat,	SS,	VSYS_STAT),
394 	BQ24190_SYSFS_FIELD_RO(watchdog_fault,	F,	WATCHDOG_FAULT),
395 	BQ24190_SYSFS_FIELD_RO(boost_fault,	F,	BOOST_FAULT),
396 	BQ24190_SYSFS_FIELD_RO(chrg_fault,	F,	CHRG_FAULT),
397 	BQ24190_SYSFS_FIELD_RO(bat_fault,	F,	BAT_FAULT),
398 	BQ24190_SYSFS_FIELD_RO(ntc_fault,	F,	NTC_FAULT),
399 	BQ24190_SYSFS_FIELD_RO(pn,		VPRS,	PN),
400 	BQ24190_SYSFS_FIELD_RO(ts_profile,	VPRS,	TS_PROFILE),
401 	BQ24190_SYSFS_FIELD_RO(dev_reg,		VPRS,	DEV_REG),
402 };
403 
404 static struct attribute *
405 	bq24190_sysfs_attrs[ARRAY_SIZE(bq24190_sysfs_field_tbl) + 1];
406 
407 ATTRIBUTE_GROUPS(bq24190_sysfs);
408 
409 static void bq24190_sysfs_init_attrs(void)
410 {
411 	int i, limit = ARRAY_SIZE(bq24190_sysfs_field_tbl);
412 
413 	for (i = 0; i < limit; i++)
414 		bq24190_sysfs_attrs[i] = &bq24190_sysfs_field_tbl[i].attr.attr;
415 
416 	bq24190_sysfs_attrs[limit] = NULL; /* Has additional entry for this */
417 }
418 
419 static struct bq24190_sysfs_field_info *bq24190_sysfs_field_lookup(
420 		const char *name)
421 {
422 	int i, limit = ARRAY_SIZE(bq24190_sysfs_field_tbl);
423 
424 	for (i = 0; i < limit; i++)
425 		if (!strcmp(name, bq24190_sysfs_field_tbl[i].attr.attr.name))
426 			break;
427 
428 	if (i >= limit)
429 		return NULL;
430 
431 	return &bq24190_sysfs_field_tbl[i];
432 }
433 
434 static ssize_t bq24190_sysfs_show(struct device *dev,
435 		struct device_attribute *attr, char *buf)
436 {
437 	struct power_supply *psy = dev_get_drvdata(dev);
438 	struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy);
439 	struct bq24190_sysfs_field_info *info;
440 	ssize_t count;
441 	int ret;
442 	u8 v;
443 
444 	info = bq24190_sysfs_field_lookup(attr->attr.name);
445 	if (!info)
446 		return -EINVAL;
447 
448 	ret = pm_runtime_get_sync(bdi->dev);
449 	if (ret < 0) {
450 		pm_runtime_put_noidle(bdi->dev);
451 		return ret;
452 	}
453 
454 	ret = bq24190_read_mask(bdi, info->reg, info->mask, info->shift, &v);
455 	if (ret)
456 		count = ret;
457 	else
458 		count = scnprintf(buf, PAGE_SIZE, "%hhx\n", v);
459 
460 	pm_runtime_mark_last_busy(bdi->dev);
461 	pm_runtime_put_autosuspend(bdi->dev);
462 
463 	return count;
464 }
465 
466 static ssize_t bq24190_sysfs_store(struct device *dev,
467 		struct device_attribute *attr, const char *buf, size_t count)
468 {
469 	struct power_supply *psy = dev_get_drvdata(dev);
470 	struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy);
471 	struct bq24190_sysfs_field_info *info;
472 	int ret;
473 	u8 v;
474 
475 	info = bq24190_sysfs_field_lookup(attr->attr.name);
476 	if (!info)
477 		return -EINVAL;
478 
479 	ret = kstrtou8(buf, 0, &v);
480 	if (ret < 0)
481 		return ret;
482 
483 	ret = pm_runtime_get_sync(bdi->dev);
484 	if (ret < 0) {
485 		pm_runtime_put_noidle(bdi->dev);
486 		return ret;
487 	}
488 
489 	ret = bq24190_write_mask(bdi, info->reg, info->mask, info->shift, v);
490 	if (ret)
491 		count = ret;
492 
493 	pm_runtime_mark_last_busy(bdi->dev);
494 	pm_runtime_put_autosuspend(bdi->dev);
495 
496 	return count;
497 }
498 #endif
499 
500 #ifdef CONFIG_REGULATOR
501 static int bq24190_set_charge_mode(struct regulator_dev *dev, u8 val)
502 {
503 	struct bq24190_dev_info *bdi = rdev_get_drvdata(dev);
504 	int ret;
505 
506 	ret = pm_runtime_get_sync(bdi->dev);
507 	if (ret < 0) {
508 		dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", ret);
509 		pm_runtime_put_noidle(bdi->dev);
510 		return ret;
511 	}
512 
513 	ret = bq24190_write_mask(bdi, BQ24190_REG_POC,
514 				 BQ24190_REG_POC_CHG_CONFIG_MASK,
515 				 BQ24190_REG_POC_CHG_CONFIG_SHIFT, val);
516 
517 	pm_runtime_mark_last_busy(bdi->dev);
518 	pm_runtime_put_autosuspend(bdi->dev);
519 
520 	return ret;
521 }
522 
523 static int bq24190_vbus_enable(struct regulator_dev *dev)
524 {
525 	return bq24190_set_charge_mode(dev, BQ24190_REG_POC_CHG_CONFIG_OTG);
526 }
527 
528 static int bq24190_vbus_disable(struct regulator_dev *dev)
529 {
530 	return bq24190_set_charge_mode(dev, BQ24190_REG_POC_CHG_CONFIG_CHARGE);
531 }
532 
533 static int bq24190_vbus_is_enabled(struct regulator_dev *dev)
534 {
535 	struct bq24190_dev_info *bdi = rdev_get_drvdata(dev);
536 	int ret;
537 	u8 val;
538 
539 	ret = pm_runtime_get_sync(bdi->dev);
540 	if (ret < 0) {
541 		dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", ret);
542 		pm_runtime_put_noidle(bdi->dev);
543 		return ret;
544 	}
545 
546 	ret = bq24190_read_mask(bdi, BQ24190_REG_POC,
547 				BQ24190_REG_POC_CHG_CONFIG_MASK,
548 				BQ24190_REG_POC_CHG_CONFIG_SHIFT, &val);
549 
550 	pm_runtime_mark_last_busy(bdi->dev);
551 	pm_runtime_put_autosuspend(bdi->dev);
552 
553 	return ret ? ret : val == BQ24190_REG_POC_CHG_CONFIG_OTG;
554 }
555 
556 static const struct regulator_ops bq24190_vbus_ops = {
557 	.enable = bq24190_vbus_enable,
558 	.disable = bq24190_vbus_disable,
559 	.is_enabled = bq24190_vbus_is_enabled,
560 };
561 
562 static const struct regulator_desc bq24190_vbus_desc = {
563 	.name = "usb_otg_vbus",
564 	.of_match = "usb-otg-vbus",
565 	.type = REGULATOR_VOLTAGE,
566 	.owner = THIS_MODULE,
567 	.ops = &bq24190_vbus_ops,
568 	.fixed_uV = 5000000,
569 	.n_voltages = 1,
570 };
571 
572 static const struct regulator_init_data bq24190_vbus_init_data = {
573 	.constraints = {
574 		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
575 	},
576 };
577 
578 static int bq24190_register_vbus_regulator(struct bq24190_dev_info *bdi)
579 {
580 	struct bq24190_platform_data *pdata = bdi->dev->platform_data;
581 	struct regulator_config cfg = { };
582 	struct regulator_dev *reg;
583 	int ret = 0;
584 
585 	cfg.dev = bdi->dev;
586 	if (pdata && pdata->regulator_init_data)
587 		cfg.init_data = pdata->regulator_init_data;
588 	else
589 		cfg.init_data = &bq24190_vbus_init_data;
590 	cfg.driver_data = bdi;
591 	reg = devm_regulator_register(bdi->dev, &bq24190_vbus_desc, &cfg);
592 	if (IS_ERR(reg)) {
593 		ret = PTR_ERR(reg);
594 		dev_err(bdi->dev, "Can't register regulator: %d\n", ret);
595 	}
596 
597 	return ret;
598 }
599 #else
600 static int bq24190_register_vbus_regulator(struct bq24190_dev_info *bdi)
601 {
602 	return 0;
603 }
604 #endif
605 
606 static int bq24190_set_config(struct bq24190_dev_info *bdi)
607 {
608 	int ret;
609 	u8 v;
610 
611 	ret = bq24190_read(bdi, BQ24190_REG_CTTC, &v);
612 	if (ret < 0)
613 		return ret;
614 
615 	bdi->watchdog = ((v & BQ24190_REG_CTTC_WATCHDOG_MASK) >>
616 					BQ24190_REG_CTTC_WATCHDOG_SHIFT);
617 
618 	/*
619 	 * According to the "Host Mode and default Mode" section of the
620 	 * manual, a write to any register causes the bq24190 to switch
621 	 * from default mode to host mode.  It will switch back to default
622 	 * mode after a WDT timeout unless the WDT is turned off as well.
623 	 * So, by simply turning off the WDT, we accomplish both with the
624 	 * same write.
625 	 */
626 	v &= ~BQ24190_REG_CTTC_WATCHDOG_MASK;
627 
628 	ret = bq24190_write(bdi, BQ24190_REG_CTTC, v);
629 	if (ret < 0)
630 		return ret;
631 
632 	if (bdi->sys_min) {
633 		v = bdi->sys_min / 100 - 30; // manual section 9.5.1.2, table 9
634 		ret = bq24190_write_mask(bdi, BQ24190_REG_POC,
635 					 BQ24190_REG_POC_SYS_MIN_MASK,
636 					 BQ24190_REG_POC_SYS_MIN_SHIFT,
637 					 v);
638 		if (ret < 0)
639 			return ret;
640 	}
641 
642 	if (bdi->iprechg) {
643 		v = bdi->iprechg / 128 - 1; // manual section 9.5.1.4, table 11
644 		ret = bq24190_write_mask(bdi, BQ24190_REG_PCTCC,
645 					 BQ24190_REG_PCTCC_IPRECHG_MASK,
646 					 BQ24190_REG_PCTCC_IPRECHG_SHIFT,
647 					 v);
648 		if (ret < 0)
649 			return ret;
650 	}
651 
652 	if (bdi->iterm) {
653 		v = bdi->iterm / 128 - 1; // manual section 9.5.1.4, table 11
654 		ret = bq24190_write_mask(bdi, BQ24190_REG_PCTCC,
655 					 BQ24190_REG_PCTCC_ITERM_MASK,
656 					 BQ24190_REG_PCTCC_ITERM_SHIFT,
657 					 v);
658 		if (ret < 0)
659 			return ret;
660 	}
661 
662 	return 0;
663 }
664 
665 static int bq24190_register_reset(struct bq24190_dev_info *bdi)
666 {
667 	int ret, limit = 100;
668 	u8 v;
669 
670 	/*
671 	 * This prop. can be passed on device instantiation from platform code:
672 	 * struct property_entry pe[] =
673 	 *   { PROPERTY_ENTRY_BOOL("disable-reset"), ... };
674 	 * struct i2c_board_info bi =
675 	 *   { .type = "bq24190", .addr = 0x6b, .properties = pe, .irq = irq };
676 	 * struct i2c_adapter ad = { ... };
677 	 * i2c_add_adapter(&ad);
678 	 * i2c_new_client_device(&ad, &bi);
679 	 */
680 	if (device_property_read_bool(bdi->dev, "disable-reset"))
681 		return 0;
682 
683 	/* Reset the registers */
684 	ret = bq24190_write_mask(bdi, BQ24190_REG_POC,
685 			BQ24190_REG_POC_RESET_MASK,
686 			BQ24190_REG_POC_RESET_SHIFT,
687 			0x1);
688 	if (ret < 0)
689 		return ret;
690 
691 	/* Reset bit will be cleared by hardware so poll until it is */
692 	do {
693 		ret = bq24190_read_mask(bdi, BQ24190_REG_POC,
694 				BQ24190_REG_POC_RESET_MASK,
695 				BQ24190_REG_POC_RESET_SHIFT,
696 				&v);
697 		if (ret < 0)
698 			return ret;
699 
700 		if (v == 0)
701 			return 0;
702 
703 		usleep_range(100, 200);
704 	} while (--limit);
705 
706 	return -EIO;
707 }
708 
709 /* Charger power supply property routines */
710 
711 static int bq24190_charger_get_charge_type(struct bq24190_dev_info *bdi,
712 		union power_supply_propval *val)
713 {
714 	u8 v;
715 	int type, ret;
716 
717 	ret = bq24190_read_mask(bdi, BQ24190_REG_POC,
718 			BQ24190_REG_POC_CHG_CONFIG_MASK,
719 			BQ24190_REG_POC_CHG_CONFIG_SHIFT,
720 			&v);
721 	if (ret < 0)
722 		return ret;
723 
724 	/* If POC[CHG_CONFIG] (REG01[5:4]) == 0, charge is disabled */
725 	if (!v) {
726 		type = POWER_SUPPLY_CHARGE_TYPE_NONE;
727 	} else {
728 		ret = bq24190_read_mask(bdi, BQ24190_REG_CCC,
729 				BQ24190_REG_CCC_FORCE_20PCT_MASK,
730 				BQ24190_REG_CCC_FORCE_20PCT_SHIFT,
731 				&v);
732 		if (ret < 0)
733 			return ret;
734 
735 		type = (v) ? POWER_SUPPLY_CHARGE_TYPE_TRICKLE :
736 			     POWER_SUPPLY_CHARGE_TYPE_FAST;
737 	}
738 
739 	val->intval = type;
740 
741 	return 0;
742 }
743 
744 static int bq24190_charger_set_charge_type(struct bq24190_dev_info *bdi,
745 		const union power_supply_propval *val)
746 {
747 	u8 chg_config, force_20pct, en_term;
748 	int ret;
749 
750 	/*
751 	 * According to the "Termination when REG02[0] = 1" section of
752 	 * the bq24190 manual, the trickle charge could be less than the
753 	 * termination current so it recommends turning off the termination
754 	 * function.
755 	 *
756 	 * Note: AFAICT from the datasheet, the user will have to manually
757 	 * turn off the charging when in 20% mode.  If its not turned off,
758 	 * there could be battery damage.  So, use this mode at your own risk.
759 	 */
760 	switch (val->intval) {
761 	case POWER_SUPPLY_CHARGE_TYPE_NONE:
762 		chg_config = 0x0;
763 		break;
764 	case POWER_SUPPLY_CHARGE_TYPE_TRICKLE:
765 		chg_config = 0x1;
766 		force_20pct = 0x1;
767 		en_term = 0x0;
768 		break;
769 	case POWER_SUPPLY_CHARGE_TYPE_FAST:
770 		chg_config = 0x1;
771 		force_20pct = 0x0;
772 		en_term = 0x1;
773 		break;
774 	default:
775 		return -EINVAL;
776 	}
777 
778 	if (chg_config) { /* Enabling the charger */
779 		ret = bq24190_write_mask(bdi, BQ24190_REG_CCC,
780 				BQ24190_REG_CCC_FORCE_20PCT_MASK,
781 				BQ24190_REG_CCC_FORCE_20PCT_SHIFT,
782 				force_20pct);
783 		if (ret < 0)
784 			return ret;
785 
786 		ret = bq24190_write_mask(bdi, BQ24190_REG_CTTC,
787 				BQ24190_REG_CTTC_EN_TERM_MASK,
788 				BQ24190_REG_CTTC_EN_TERM_SHIFT,
789 				en_term);
790 		if (ret < 0)
791 			return ret;
792 	}
793 
794 	return bq24190_write_mask(bdi, BQ24190_REG_POC,
795 			BQ24190_REG_POC_CHG_CONFIG_MASK,
796 			BQ24190_REG_POC_CHG_CONFIG_SHIFT, chg_config);
797 }
798 
799 static int bq24190_charger_get_health(struct bq24190_dev_info *bdi,
800 		union power_supply_propval *val)
801 {
802 	u8 v;
803 	int health;
804 
805 	mutex_lock(&bdi->f_reg_lock);
806 	v = bdi->f_reg;
807 	mutex_unlock(&bdi->f_reg_lock);
808 
809 	if (v & BQ24190_REG_F_NTC_FAULT_MASK) {
810 		switch (v >> BQ24190_REG_F_NTC_FAULT_SHIFT & 0x7) {
811 		case 0x1: /* TS1  Cold */
812 		case 0x3: /* TS2  Cold */
813 		case 0x5: /* Both Cold */
814 			health = POWER_SUPPLY_HEALTH_COLD;
815 			break;
816 		case 0x2: /* TS1  Hot */
817 		case 0x4: /* TS2  Hot */
818 		case 0x6: /* Both Hot */
819 			health = POWER_SUPPLY_HEALTH_OVERHEAT;
820 			break;
821 		default:
822 			health = POWER_SUPPLY_HEALTH_UNKNOWN;
823 		}
824 	} else if (v & BQ24190_REG_F_BAT_FAULT_MASK) {
825 		health = POWER_SUPPLY_HEALTH_OVERVOLTAGE;
826 	} else if (v & BQ24190_REG_F_CHRG_FAULT_MASK) {
827 		switch (v >> BQ24190_REG_F_CHRG_FAULT_SHIFT & 0x3) {
828 		case 0x1: /* Input Fault (VBUS OVP or VBAT<VBUS<3.8V) */
829 			/*
830 			 * This could be over-voltage or under-voltage
831 			 * and there's no way to tell which.  Instead
832 			 * of looking foolish and returning 'OVERVOLTAGE'
833 			 * when its really under-voltage, just return
834 			 * 'UNSPEC_FAILURE'.
835 			 */
836 			health = POWER_SUPPLY_HEALTH_UNSPEC_FAILURE;
837 			break;
838 		case 0x2: /* Thermal Shutdown */
839 			health = POWER_SUPPLY_HEALTH_OVERHEAT;
840 			break;
841 		case 0x3: /* Charge Safety Timer Expiration */
842 			health = POWER_SUPPLY_HEALTH_SAFETY_TIMER_EXPIRE;
843 			break;
844 		default:  /* prevent compiler warning */
845 			health = -1;
846 		}
847 	} else if (v & BQ24190_REG_F_BOOST_FAULT_MASK) {
848 		/*
849 		 * This could be over-current or over-voltage but there's
850 		 * no way to tell which.  Return 'OVERVOLTAGE' since there
851 		 * isn't an 'OVERCURRENT' value defined that we can return
852 		 * even if it was over-current.
853 		 */
854 		health = POWER_SUPPLY_HEALTH_OVERVOLTAGE;
855 	} else {
856 		health = POWER_SUPPLY_HEALTH_GOOD;
857 	}
858 
859 	val->intval = health;
860 
861 	return 0;
862 }
863 
864 static int bq24190_charger_get_online(struct bq24190_dev_info *bdi,
865 		union power_supply_propval *val)
866 {
867 	u8 pg_stat, batfet_disable;
868 	int ret;
869 
870 	ret = bq24190_read_mask(bdi, BQ24190_REG_SS,
871 			BQ24190_REG_SS_PG_STAT_MASK,
872 			BQ24190_REG_SS_PG_STAT_SHIFT, &pg_stat);
873 	if (ret < 0)
874 		return ret;
875 
876 	ret = bq24190_read_mask(bdi, BQ24190_REG_MOC,
877 			BQ24190_REG_MOC_BATFET_DISABLE_MASK,
878 			BQ24190_REG_MOC_BATFET_DISABLE_SHIFT, &batfet_disable);
879 	if (ret < 0)
880 		return ret;
881 
882 	val->intval = pg_stat && !batfet_disable;
883 
884 	return 0;
885 }
886 
887 static int bq24190_battery_set_online(struct bq24190_dev_info *bdi,
888 				      const union power_supply_propval *val);
889 static int bq24190_battery_get_status(struct bq24190_dev_info *bdi,
890 				      union power_supply_propval *val);
891 static int bq24190_battery_get_temp_alert_max(struct bq24190_dev_info *bdi,
892 					      union power_supply_propval *val);
893 static int bq24190_battery_set_temp_alert_max(struct bq24190_dev_info *bdi,
894 					      const union power_supply_propval *val);
895 
896 static int bq24190_charger_set_online(struct bq24190_dev_info *bdi,
897 				      const union power_supply_propval *val)
898 {
899 	return bq24190_battery_set_online(bdi, val);
900 }
901 
902 static int bq24190_charger_get_status(struct bq24190_dev_info *bdi,
903 				      union power_supply_propval *val)
904 {
905 	return bq24190_battery_get_status(bdi, val);
906 }
907 
908 static int bq24190_charger_get_temp_alert_max(struct bq24190_dev_info *bdi,
909 					      union power_supply_propval *val)
910 {
911 	return bq24190_battery_get_temp_alert_max(bdi, val);
912 }
913 
914 static int bq24190_charger_set_temp_alert_max(struct bq24190_dev_info *bdi,
915 					      const union power_supply_propval *val)
916 {
917 	return bq24190_battery_set_temp_alert_max(bdi, val);
918 }
919 
920 static int bq24190_charger_get_precharge(struct bq24190_dev_info *bdi,
921 		union power_supply_propval *val)
922 {
923 	u8 v;
924 	int ret;
925 
926 	ret = bq24190_read_mask(bdi, BQ24190_REG_PCTCC,
927 			BQ24190_REG_PCTCC_IPRECHG_MASK,
928 			BQ24190_REG_PCTCC_IPRECHG_SHIFT, &v);
929 	if (ret < 0)
930 		return ret;
931 
932 	val->intval = ++v * 128 * 1000;
933 	return 0;
934 }
935 
936 static int bq24190_charger_get_charge_term(struct bq24190_dev_info *bdi,
937 		union power_supply_propval *val)
938 {
939 	u8 v;
940 	int ret;
941 
942 	ret = bq24190_read_mask(bdi, BQ24190_REG_PCTCC,
943 			BQ24190_REG_PCTCC_ITERM_MASK,
944 			BQ24190_REG_PCTCC_ITERM_SHIFT, &v);
945 	if (ret < 0)
946 		return ret;
947 
948 	val->intval = ++v * 128 * 1000;
949 	return 0;
950 }
951 
952 static int bq24190_charger_get_current(struct bq24190_dev_info *bdi,
953 		union power_supply_propval *val)
954 {
955 	u8 v;
956 	int curr, ret;
957 
958 	ret = bq24190_get_field_val(bdi, BQ24190_REG_CCC,
959 			BQ24190_REG_CCC_ICHG_MASK, BQ24190_REG_CCC_ICHG_SHIFT,
960 			bq24190_ccc_ichg_values,
961 			ARRAY_SIZE(bq24190_ccc_ichg_values), &curr);
962 	if (ret < 0)
963 		return ret;
964 
965 	ret = bq24190_read_mask(bdi, BQ24190_REG_CCC,
966 			BQ24190_REG_CCC_FORCE_20PCT_MASK,
967 			BQ24190_REG_CCC_FORCE_20PCT_SHIFT, &v);
968 	if (ret < 0)
969 		return ret;
970 
971 	/* If FORCE_20PCT is enabled, then current is 20% of ICHG value */
972 	if (v)
973 		curr /= 5;
974 
975 	val->intval = curr;
976 	return 0;
977 }
978 
979 static int bq24190_charger_get_current_max(struct bq24190_dev_info *bdi,
980 		union power_supply_propval *val)
981 {
982 	int idx = ARRAY_SIZE(bq24190_ccc_ichg_values) - 1;
983 
984 	val->intval = bq24190_ccc_ichg_values[idx];
985 	return 0;
986 }
987 
988 static int bq24190_charger_set_current(struct bq24190_dev_info *bdi,
989 		const union power_supply_propval *val)
990 {
991 	u8 v;
992 	int ret, curr = val->intval;
993 
994 	ret = bq24190_read_mask(bdi, BQ24190_REG_CCC,
995 			BQ24190_REG_CCC_FORCE_20PCT_MASK,
996 			BQ24190_REG_CCC_FORCE_20PCT_SHIFT, &v);
997 	if (ret < 0)
998 		return ret;
999 
1000 	/* If FORCE_20PCT is enabled, have to multiply value passed in by 5 */
1001 	if (v)
1002 		curr *= 5;
1003 
1004 	return bq24190_set_field_val(bdi, BQ24190_REG_CCC,
1005 			BQ24190_REG_CCC_ICHG_MASK, BQ24190_REG_CCC_ICHG_SHIFT,
1006 			bq24190_ccc_ichg_values,
1007 			ARRAY_SIZE(bq24190_ccc_ichg_values), curr);
1008 }
1009 
1010 static int bq24190_charger_get_voltage(struct bq24190_dev_info *bdi,
1011 		union power_supply_propval *val)
1012 {
1013 	int voltage, ret;
1014 
1015 	ret = bq24190_get_field_val(bdi, BQ24190_REG_CVC,
1016 			BQ24190_REG_CVC_VREG_MASK, BQ24190_REG_CVC_VREG_SHIFT,
1017 			bq24190_cvc_vreg_values,
1018 			ARRAY_SIZE(bq24190_cvc_vreg_values), &voltage);
1019 	if (ret < 0)
1020 		return ret;
1021 
1022 	val->intval = voltage;
1023 	return 0;
1024 }
1025 
1026 static int bq24190_charger_get_voltage_max(struct bq24190_dev_info *bdi,
1027 		union power_supply_propval *val)
1028 {
1029 	int idx = ARRAY_SIZE(bq24190_cvc_vreg_values) - 1;
1030 
1031 	val->intval = bq24190_cvc_vreg_values[idx];
1032 	return 0;
1033 }
1034 
1035 static int bq24190_charger_set_voltage(struct bq24190_dev_info *bdi,
1036 		const union power_supply_propval *val)
1037 {
1038 	return bq24190_set_field_val(bdi, BQ24190_REG_CVC,
1039 			BQ24190_REG_CVC_VREG_MASK, BQ24190_REG_CVC_VREG_SHIFT,
1040 			bq24190_cvc_vreg_values,
1041 			ARRAY_SIZE(bq24190_cvc_vreg_values), val->intval);
1042 }
1043 
1044 static int bq24190_charger_get_iinlimit(struct bq24190_dev_info *bdi,
1045 		union power_supply_propval *val)
1046 {
1047 	int iinlimit, ret;
1048 
1049 	ret = bq24190_get_field_val(bdi, BQ24190_REG_ISC,
1050 			BQ24190_REG_ISC_IINLIM_MASK,
1051 			BQ24190_REG_ISC_IINLIM_SHIFT,
1052 			bq24190_isc_iinlim_values,
1053 			ARRAY_SIZE(bq24190_isc_iinlim_values), &iinlimit);
1054 	if (ret < 0)
1055 		return ret;
1056 
1057 	val->intval = iinlimit;
1058 	return 0;
1059 }
1060 
1061 static int bq24190_charger_set_iinlimit(struct bq24190_dev_info *bdi,
1062 		const union power_supply_propval *val)
1063 {
1064 	return bq24190_set_field_val(bdi, BQ24190_REG_ISC,
1065 			BQ24190_REG_ISC_IINLIM_MASK,
1066 			BQ24190_REG_ISC_IINLIM_SHIFT,
1067 			bq24190_isc_iinlim_values,
1068 			ARRAY_SIZE(bq24190_isc_iinlim_values), val->intval);
1069 }
1070 
1071 static int bq24190_charger_get_property(struct power_supply *psy,
1072 		enum power_supply_property psp, union power_supply_propval *val)
1073 {
1074 	struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy);
1075 	int ret;
1076 
1077 	dev_dbg(bdi->dev, "prop: %d\n", psp);
1078 
1079 	ret = pm_runtime_get_sync(bdi->dev);
1080 	if (ret < 0) {
1081 		pm_runtime_put_noidle(bdi->dev);
1082 		return ret;
1083 	}
1084 
1085 	switch (psp) {
1086 	case POWER_SUPPLY_PROP_CHARGE_TYPE:
1087 		ret = bq24190_charger_get_charge_type(bdi, val);
1088 		break;
1089 	case POWER_SUPPLY_PROP_HEALTH:
1090 		ret = bq24190_charger_get_health(bdi, val);
1091 		break;
1092 	case POWER_SUPPLY_PROP_ONLINE:
1093 		ret = bq24190_charger_get_online(bdi, val);
1094 		break;
1095 	case POWER_SUPPLY_PROP_STATUS:
1096 		ret = bq24190_charger_get_status(bdi, val);
1097 		break;
1098 	case POWER_SUPPLY_PROP_TEMP_ALERT_MAX:
1099 		ret =  bq24190_charger_get_temp_alert_max(bdi, val);
1100 		break;
1101 	case POWER_SUPPLY_PROP_PRECHARGE_CURRENT:
1102 		ret = bq24190_charger_get_precharge(bdi, val);
1103 		break;
1104 	case POWER_SUPPLY_PROP_CHARGE_TERM_CURRENT:
1105 		ret = bq24190_charger_get_charge_term(bdi, val);
1106 		break;
1107 	case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT:
1108 		ret = bq24190_charger_get_current(bdi, val);
1109 		break;
1110 	case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX:
1111 		ret = bq24190_charger_get_current_max(bdi, val);
1112 		break;
1113 	case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE:
1114 		ret = bq24190_charger_get_voltage(bdi, val);
1115 		break;
1116 	case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX:
1117 		ret = bq24190_charger_get_voltage_max(bdi, val);
1118 		break;
1119 	case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT:
1120 		ret = bq24190_charger_get_iinlimit(bdi, val);
1121 		break;
1122 	case POWER_SUPPLY_PROP_SCOPE:
1123 		val->intval = POWER_SUPPLY_SCOPE_SYSTEM;
1124 		ret = 0;
1125 		break;
1126 	case POWER_SUPPLY_PROP_MODEL_NAME:
1127 		val->strval = bdi->model_name;
1128 		ret = 0;
1129 		break;
1130 	case POWER_SUPPLY_PROP_MANUFACTURER:
1131 		val->strval = BQ24190_MANUFACTURER;
1132 		ret = 0;
1133 		break;
1134 	default:
1135 		ret = -ENODATA;
1136 	}
1137 
1138 	pm_runtime_mark_last_busy(bdi->dev);
1139 	pm_runtime_put_autosuspend(bdi->dev);
1140 
1141 	return ret;
1142 }
1143 
1144 static int bq24190_charger_set_property(struct power_supply *psy,
1145 		enum power_supply_property psp,
1146 		const union power_supply_propval *val)
1147 {
1148 	struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy);
1149 	int ret;
1150 
1151 	dev_dbg(bdi->dev, "prop: %d\n", psp);
1152 
1153 	ret = pm_runtime_get_sync(bdi->dev);
1154 	if (ret < 0) {
1155 		pm_runtime_put_noidle(bdi->dev);
1156 		return ret;
1157 	}
1158 
1159 	switch (psp) {
1160 	case POWER_SUPPLY_PROP_ONLINE:
1161 		ret = bq24190_charger_set_online(bdi, val);
1162 		break;
1163 	case POWER_SUPPLY_PROP_TEMP_ALERT_MAX:
1164 		ret = bq24190_charger_set_temp_alert_max(bdi, val);
1165 		break;
1166 	case POWER_SUPPLY_PROP_CHARGE_TYPE:
1167 		ret = bq24190_charger_set_charge_type(bdi, val);
1168 		break;
1169 	case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT:
1170 		ret = bq24190_charger_set_current(bdi, val);
1171 		break;
1172 	case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE:
1173 		ret = bq24190_charger_set_voltage(bdi, val);
1174 		break;
1175 	case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT:
1176 		ret = bq24190_charger_set_iinlimit(bdi, val);
1177 		break;
1178 	default:
1179 		ret = -EINVAL;
1180 	}
1181 
1182 	pm_runtime_mark_last_busy(bdi->dev);
1183 	pm_runtime_put_autosuspend(bdi->dev);
1184 
1185 	return ret;
1186 }
1187 
1188 static int bq24190_charger_property_is_writeable(struct power_supply *psy,
1189 		enum power_supply_property psp)
1190 {
1191 	switch (psp) {
1192 	case POWER_SUPPLY_PROP_ONLINE:
1193 	case POWER_SUPPLY_PROP_TEMP_ALERT_MAX:
1194 	case POWER_SUPPLY_PROP_CHARGE_TYPE:
1195 	case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT:
1196 	case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE:
1197 	case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT:
1198 		return 1;
1199 	default:
1200 		return 0;
1201 	}
1202 }
1203 
1204 static void bq24190_input_current_limit_work(struct work_struct *work)
1205 {
1206 	struct bq24190_dev_info *bdi =
1207 		container_of(work, struct bq24190_dev_info,
1208 			     input_current_limit_work.work);
1209 
1210 	power_supply_set_input_current_limit_from_supplier(bdi->charger);
1211 }
1212 
1213 /* Sync the input-current-limit with our parent supply (if we have one) */
1214 static void bq24190_charger_external_power_changed(struct power_supply *psy)
1215 {
1216 	struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy);
1217 
1218 	/*
1219 	 * The Power-Good detection may take up to 220ms, sometimes
1220 	 * the external charger detection is quicker, and the bq24190 will
1221 	 * reset to iinlim based on its own charger detection (which is not
1222 	 * hooked up when using external charger detection) resulting in a
1223 	 * too low default 500mA iinlim. Delay setting the input-current-limit
1224 	 * for 300ms to avoid this.
1225 	 */
1226 	queue_delayed_work(system_wq, &bdi->input_current_limit_work,
1227 			   msecs_to_jiffies(300));
1228 }
1229 
1230 static enum power_supply_property bq24190_charger_properties[] = {
1231 	POWER_SUPPLY_PROP_CHARGE_TYPE,
1232 	POWER_SUPPLY_PROP_HEALTH,
1233 	POWER_SUPPLY_PROP_ONLINE,
1234 	POWER_SUPPLY_PROP_STATUS,
1235 	POWER_SUPPLY_PROP_TEMP_ALERT_MAX,
1236 	POWER_SUPPLY_PROP_PRECHARGE_CURRENT,
1237 	POWER_SUPPLY_PROP_CHARGE_TERM_CURRENT,
1238 	POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT,
1239 	POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX,
1240 	POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE,
1241 	POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX,
1242 	POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT,
1243 	POWER_SUPPLY_PROP_SCOPE,
1244 	POWER_SUPPLY_PROP_MODEL_NAME,
1245 	POWER_SUPPLY_PROP_MANUFACTURER,
1246 };
1247 
1248 static char *bq24190_charger_supplied_to[] = {
1249 	"main-battery",
1250 };
1251 
1252 static const struct power_supply_desc bq24190_charger_desc = {
1253 	.name			= "bq24190-charger",
1254 	.type			= POWER_SUPPLY_TYPE_USB,
1255 	.properties		= bq24190_charger_properties,
1256 	.num_properties		= ARRAY_SIZE(bq24190_charger_properties),
1257 	.get_property		= bq24190_charger_get_property,
1258 	.set_property		= bq24190_charger_set_property,
1259 	.property_is_writeable	= bq24190_charger_property_is_writeable,
1260 	.external_power_changed	= bq24190_charger_external_power_changed,
1261 };
1262 
1263 /* Battery power supply property routines */
1264 
1265 static int bq24190_battery_get_status(struct bq24190_dev_info *bdi,
1266 		union power_supply_propval *val)
1267 {
1268 	u8 ss_reg, chrg_fault;
1269 	int status, ret;
1270 
1271 	mutex_lock(&bdi->f_reg_lock);
1272 	chrg_fault = bdi->f_reg;
1273 	mutex_unlock(&bdi->f_reg_lock);
1274 
1275 	chrg_fault &= BQ24190_REG_F_CHRG_FAULT_MASK;
1276 	chrg_fault >>= BQ24190_REG_F_CHRG_FAULT_SHIFT;
1277 
1278 	ret = bq24190_read(bdi, BQ24190_REG_SS, &ss_reg);
1279 	if (ret < 0)
1280 		return ret;
1281 
1282 	/*
1283 	 * The battery must be discharging when any of these are true:
1284 	 * - there is no good power source;
1285 	 * - there is a charge fault.
1286 	 * Could also be discharging when in "supplement mode" but
1287 	 * there is no way to tell when its in that mode.
1288 	 */
1289 	if (!(ss_reg & BQ24190_REG_SS_PG_STAT_MASK) || chrg_fault) {
1290 		status = POWER_SUPPLY_STATUS_DISCHARGING;
1291 	} else {
1292 		ss_reg &= BQ24190_REG_SS_CHRG_STAT_MASK;
1293 		ss_reg >>= BQ24190_REG_SS_CHRG_STAT_SHIFT;
1294 
1295 		switch (ss_reg) {
1296 		case 0x0: /* Not Charging */
1297 			status = POWER_SUPPLY_STATUS_NOT_CHARGING;
1298 			break;
1299 		case 0x1: /* Pre-charge */
1300 		case 0x2: /* Fast Charging */
1301 			status = POWER_SUPPLY_STATUS_CHARGING;
1302 			break;
1303 		case 0x3: /* Charge Termination Done */
1304 			status = POWER_SUPPLY_STATUS_FULL;
1305 			break;
1306 		default:
1307 			ret = -EIO;
1308 		}
1309 	}
1310 
1311 	if (!ret)
1312 		val->intval = status;
1313 
1314 	return ret;
1315 }
1316 
1317 static int bq24190_battery_get_health(struct bq24190_dev_info *bdi,
1318 		union power_supply_propval *val)
1319 {
1320 	u8 v;
1321 	int health;
1322 
1323 	mutex_lock(&bdi->f_reg_lock);
1324 	v = bdi->f_reg;
1325 	mutex_unlock(&bdi->f_reg_lock);
1326 
1327 	if (v & BQ24190_REG_F_BAT_FAULT_MASK) {
1328 		health = POWER_SUPPLY_HEALTH_OVERVOLTAGE;
1329 	} else {
1330 		v &= BQ24190_REG_F_NTC_FAULT_MASK;
1331 		v >>= BQ24190_REG_F_NTC_FAULT_SHIFT;
1332 
1333 		switch (v) {
1334 		case 0x0: /* Normal */
1335 			health = POWER_SUPPLY_HEALTH_GOOD;
1336 			break;
1337 		case 0x1: /* TS1 Cold */
1338 		case 0x3: /* TS2 Cold */
1339 		case 0x5: /* Both Cold */
1340 			health = POWER_SUPPLY_HEALTH_COLD;
1341 			break;
1342 		case 0x2: /* TS1 Hot */
1343 		case 0x4: /* TS2 Hot */
1344 		case 0x6: /* Both Hot */
1345 			health = POWER_SUPPLY_HEALTH_OVERHEAT;
1346 			break;
1347 		default:
1348 			health = POWER_SUPPLY_HEALTH_UNKNOWN;
1349 		}
1350 	}
1351 
1352 	val->intval = health;
1353 	return 0;
1354 }
1355 
1356 static int bq24190_battery_get_online(struct bq24190_dev_info *bdi,
1357 		union power_supply_propval *val)
1358 {
1359 	u8 batfet_disable;
1360 	int ret;
1361 
1362 	ret = bq24190_read_mask(bdi, BQ24190_REG_MOC,
1363 			BQ24190_REG_MOC_BATFET_DISABLE_MASK,
1364 			BQ24190_REG_MOC_BATFET_DISABLE_SHIFT, &batfet_disable);
1365 	if (ret < 0)
1366 		return ret;
1367 
1368 	val->intval = !batfet_disable;
1369 	return 0;
1370 }
1371 
1372 static int bq24190_battery_set_online(struct bq24190_dev_info *bdi,
1373 		const union power_supply_propval *val)
1374 {
1375 	return bq24190_write_mask(bdi, BQ24190_REG_MOC,
1376 			BQ24190_REG_MOC_BATFET_DISABLE_MASK,
1377 			BQ24190_REG_MOC_BATFET_DISABLE_SHIFT, !val->intval);
1378 }
1379 
1380 static int bq24190_battery_get_temp_alert_max(struct bq24190_dev_info *bdi,
1381 		union power_supply_propval *val)
1382 {
1383 	int temp, ret;
1384 
1385 	ret = bq24190_get_field_val(bdi, BQ24190_REG_ICTRC,
1386 			BQ24190_REG_ICTRC_TREG_MASK,
1387 			BQ24190_REG_ICTRC_TREG_SHIFT,
1388 			bq24190_ictrc_treg_values,
1389 			ARRAY_SIZE(bq24190_ictrc_treg_values), &temp);
1390 	if (ret < 0)
1391 		return ret;
1392 
1393 	val->intval = temp;
1394 	return 0;
1395 }
1396 
1397 static int bq24190_battery_set_temp_alert_max(struct bq24190_dev_info *bdi,
1398 		const union power_supply_propval *val)
1399 {
1400 	return bq24190_set_field_val(bdi, BQ24190_REG_ICTRC,
1401 			BQ24190_REG_ICTRC_TREG_MASK,
1402 			BQ24190_REG_ICTRC_TREG_SHIFT,
1403 			bq24190_ictrc_treg_values,
1404 			ARRAY_SIZE(bq24190_ictrc_treg_values), val->intval);
1405 }
1406 
1407 static int bq24190_battery_get_property(struct power_supply *psy,
1408 		enum power_supply_property psp, union power_supply_propval *val)
1409 {
1410 	struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy);
1411 	int ret;
1412 
1413 	dev_warn(bdi->dev, "warning: /sys/class/power_supply/bq24190-battery is deprecated\n");
1414 	dev_dbg(bdi->dev, "prop: %d\n", psp);
1415 
1416 	ret = pm_runtime_get_sync(bdi->dev);
1417 	if (ret < 0) {
1418 		pm_runtime_put_noidle(bdi->dev);
1419 		return ret;
1420 	}
1421 
1422 	switch (psp) {
1423 	case POWER_SUPPLY_PROP_STATUS:
1424 		ret = bq24190_battery_get_status(bdi, val);
1425 		break;
1426 	case POWER_SUPPLY_PROP_HEALTH:
1427 		ret = bq24190_battery_get_health(bdi, val);
1428 		break;
1429 	case POWER_SUPPLY_PROP_ONLINE:
1430 		ret = bq24190_battery_get_online(bdi, val);
1431 		break;
1432 	case POWER_SUPPLY_PROP_TECHNOLOGY:
1433 		/* Could be Li-on or Li-polymer but no way to tell which */
1434 		val->intval = POWER_SUPPLY_TECHNOLOGY_UNKNOWN;
1435 		ret = 0;
1436 		break;
1437 	case POWER_SUPPLY_PROP_TEMP_ALERT_MAX:
1438 		ret = bq24190_battery_get_temp_alert_max(bdi, val);
1439 		break;
1440 	case POWER_SUPPLY_PROP_SCOPE:
1441 		val->intval = POWER_SUPPLY_SCOPE_SYSTEM;
1442 		ret = 0;
1443 		break;
1444 	default:
1445 		ret = -ENODATA;
1446 	}
1447 
1448 	pm_runtime_mark_last_busy(bdi->dev);
1449 	pm_runtime_put_autosuspend(bdi->dev);
1450 
1451 	return ret;
1452 }
1453 
1454 static int bq24190_battery_set_property(struct power_supply *psy,
1455 		enum power_supply_property psp,
1456 		const union power_supply_propval *val)
1457 {
1458 	struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy);
1459 	int ret;
1460 
1461 	dev_warn(bdi->dev, "warning: /sys/class/power_supply/bq24190-battery is deprecated\n");
1462 	dev_dbg(bdi->dev, "prop: %d\n", psp);
1463 
1464 	ret = pm_runtime_get_sync(bdi->dev);
1465 	if (ret < 0) {
1466 		pm_runtime_put_noidle(bdi->dev);
1467 		return ret;
1468 	}
1469 
1470 	switch (psp) {
1471 	case POWER_SUPPLY_PROP_ONLINE:
1472 		ret = bq24190_battery_set_online(bdi, val);
1473 		break;
1474 	case POWER_SUPPLY_PROP_TEMP_ALERT_MAX:
1475 		ret = bq24190_battery_set_temp_alert_max(bdi, val);
1476 		break;
1477 	default:
1478 		ret = -EINVAL;
1479 	}
1480 
1481 	pm_runtime_mark_last_busy(bdi->dev);
1482 	pm_runtime_put_autosuspend(bdi->dev);
1483 
1484 	return ret;
1485 }
1486 
1487 static int bq24190_battery_property_is_writeable(struct power_supply *psy,
1488 		enum power_supply_property psp)
1489 {
1490 	int ret;
1491 
1492 	switch (psp) {
1493 	case POWER_SUPPLY_PROP_ONLINE:
1494 	case POWER_SUPPLY_PROP_TEMP_ALERT_MAX:
1495 		ret = 1;
1496 		break;
1497 	default:
1498 		ret = 0;
1499 	}
1500 
1501 	return ret;
1502 }
1503 
1504 static enum power_supply_property bq24190_battery_properties[] = {
1505 	POWER_SUPPLY_PROP_STATUS,
1506 	POWER_SUPPLY_PROP_HEALTH,
1507 	POWER_SUPPLY_PROP_ONLINE,
1508 	POWER_SUPPLY_PROP_TECHNOLOGY,
1509 	POWER_SUPPLY_PROP_TEMP_ALERT_MAX,
1510 	POWER_SUPPLY_PROP_SCOPE,
1511 };
1512 
1513 static const struct power_supply_desc bq24190_battery_desc = {
1514 	.name			= "bq24190-battery",
1515 	.type			= POWER_SUPPLY_TYPE_BATTERY,
1516 	.properties		= bq24190_battery_properties,
1517 	.num_properties		= ARRAY_SIZE(bq24190_battery_properties),
1518 	.get_property		= bq24190_battery_get_property,
1519 	.set_property		= bq24190_battery_set_property,
1520 	.property_is_writeable	= bq24190_battery_property_is_writeable,
1521 };
1522 
1523 static int bq24190_configure_usb_otg(struct bq24190_dev_info *bdi, u8 ss_reg)
1524 {
1525 	bool otg_enabled;
1526 	int ret;
1527 
1528 	otg_enabled = !!(ss_reg & BQ24190_REG_SS_VBUS_STAT_MASK);
1529 	ret = extcon_set_state_sync(bdi->edev, EXTCON_USB, otg_enabled);
1530 	if (ret < 0)
1531 		dev_err(bdi->dev, "Can't set extcon state to %d: %d\n",
1532 			otg_enabled, ret);
1533 
1534 	return ret;
1535 }
1536 
1537 static void bq24190_check_status(struct bq24190_dev_info *bdi)
1538 {
1539 	const u8 battery_mask_ss = BQ24190_REG_SS_CHRG_STAT_MASK;
1540 	const u8 battery_mask_f = BQ24190_REG_F_BAT_FAULT_MASK
1541 				| BQ24190_REG_F_NTC_FAULT_MASK;
1542 	bool alert_charger = false, alert_battery = false;
1543 	u8 ss_reg = 0, f_reg = 0;
1544 	int i, ret;
1545 
1546 	ret = bq24190_read(bdi, BQ24190_REG_SS, &ss_reg);
1547 	if (ret < 0) {
1548 		dev_err(bdi->dev, "Can't read SS reg: %d\n", ret);
1549 		return;
1550 	}
1551 
1552 	i = 0;
1553 	do {
1554 		ret = bq24190_read(bdi, BQ24190_REG_F, &f_reg);
1555 		if (ret < 0) {
1556 			dev_err(bdi->dev, "Can't read F reg: %d\n", ret);
1557 			return;
1558 		}
1559 	} while (f_reg && ++i < 2);
1560 
1561 	/* ignore over/under voltage fault after disconnect */
1562 	if (f_reg == (1 << BQ24190_REG_F_CHRG_FAULT_SHIFT) &&
1563 	    !(ss_reg & BQ24190_REG_SS_PG_STAT_MASK))
1564 		f_reg = 0;
1565 
1566 	if (f_reg != bdi->f_reg) {
1567 		dev_warn(bdi->dev,
1568 			"Fault: boost %d, charge %d, battery %d, ntc %d\n",
1569 			!!(f_reg & BQ24190_REG_F_BOOST_FAULT_MASK),
1570 			!!(f_reg & BQ24190_REG_F_CHRG_FAULT_MASK),
1571 			!!(f_reg & BQ24190_REG_F_BAT_FAULT_MASK),
1572 			!!(f_reg & BQ24190_REG_F_NTC_FAULT_MASK));
1573 
1574 		mutex_lock(&bdi->f_reg_lock);
1575 		if ((bdi->f_reg & battery_mask_f) != (f_reg & battery_mask_f))
1576 			alert_battery = true;
1577 		if ((bdi->f_reg & ~battery_mask_f) != (f_reg & ~battery_mask_f))
1578 			alert_charger = true;
1579 		bdi->f_reg = f_reg;
1580 		mutex_unlock(&bdi->f_reg_lock);
1581 	}
1582 
1583 	if (ss_reg != bdi->ss_reg) {
1584 		/*
1585 		 * The device is in host mode so when PG_STAT goes from 1->0
1586 		 * (i.e., power removed) HIZ needs to be disabled.
1587 		 */
1588 		if ((bdi->ss_reg & BQ24190_REG_SS_PG_STAT_MASK) &&
1589 				!(ss_reg & BQ24190_REG_SS_PG_STAT_MASK)) {
1590 			ret = bq24190_write_mask(bdi, BQ24190_REG_ISC,
1591 					BQ24190_REG_ISC_EN_HIZ_MASK,
1592 					BQ24190_REG_ISC_EN_HIZ_SHIFT,
1593 					0);
1594 			if (ret < 0)
1595 				dev_err(bdi->dev, "Can't access ISC reg: %d\n",
1596 					ret);
1597 		}
1598 
1599 		if ((bdi->ss_reg & battery_mask_ss) != (ss_reg & battery_mask_ss))
1600 			alert_battery = true;
1601 		if ((bdi->ss_reg & ~battery_mask_ss) != (ss_reg & ~battery_mask_ss))
1602 			alert_charger = true;
1603 		bdi->ss_reg = ss_reg;
1604 	}
1605 
1606 	if (alert_charger || alert_battery) {
1607 		power_supply_changed(bdi->charger);
1608 		bq24190_configure_usb_otg(bdi, ss_reg);
1609 	}
1610 	if (alert_battery && bdi->battery)
1611 		power_supply_changed(bdi->battery);
1612 
1613 	dev_dbg(bdi->dev, "ss_reg: 0x%02x, f_reg: 0x%02x\n", ss_reg, f_reg);
1614 }
1615 
1616 static irqreturn_t bq24190_irq_handler_thread(int irq, void *data)
1617 {
1618 	struct bq24190_dev_info *bdi = data;
1619 	int error;
1620 
1621 	bdi->irq_event = true;
1622 	error = pm_runtime_get_sync(bdi->dev);
1623 	if (error < 0) {
1624 		dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", error);
1625 		pm_runtime_put_noidle(bdi->dev);
1626 		return IRQ_NONE;
1627 	}
1628 	bq24190_check_status(bdi);
1629 	pm_runtime_mark_last_busy(bdi->dev);
1630 	pm_runtime_put_autosuspend(bdi->dev);
1631 	bdi->irq_event = false;
1632 
1633 	return IRQ_HANDLED;
1634 }
1635 
1636 static int bq24190_hw_init(struct bq24190_dev_info *bdi)
1637 {
1638 	u8 v;
1639 	int ret;
1640 
1641 	/* First check that the device really is what its supposed to be */
1642 	ret = bq24190_read_mask(bdi, BQ24190_REG_VPRS,
1643 			BQ24190_REG_VPRS_PN_MASK,
1644 			BQ24190_REG_VPRS_PN_SHIFT,
1645 			&v);
1646 	if (ret < 0)
1647 		return ret;
1648 
1649 	switch (v) {
1650 	case BQ24190_REG_VPRS_PN_24190:
1651 	case BQ24190_REG_VPRS_PN_24192:
1652 	case BQ24190_REG_VPRS_PN_24192I:
1653 		break;
1654 	default:
1655 		dev_err(bdi->dev, "Error unknown model: 0x%02x\n", v);
1656 		return -ENODEV;
1657 	}
1658 
1659 	ret = bq24190_register_reset(bdi);
1660 	if (ret < 0)
1661 		return ret;
1662 
1663 	ret = bq24190_set_config(bdi);
1664 	if (ret < 0)
1665 		return ret;
1666 
1667 	return bq24190_read(bdi, BQ24190_REG_SS, &bdi->ss_reg);
1668 }
1669 
1670 static int bq24190_get_config(struct bq24190_dev_info *bdi)
1671 {
1672 	const char * const s = "ti,system-minimum-microvolt";
1673 	struct power_supply_battery_info *info;
1674 	int v;
1675 
1676 	if (device_property_read_u32(bdi->dev, s, &v) == 0) {
1677 		v /= 1000;
1678 		if (v >= BQ24190_REG_POC_SYS_MIN_MIN
1679 		 && v <= BQ24190_REG_POC_SYS_MIN_MAX)
1680 			bdi->sys_min = v;
1681 		else
1682 			dev_warn(bdi->dev, "invalid value for %s: %u\n", s, v);
1683 	}
1684 
1685 	if (bdi->dev->of_node &&
1686 	    !power_supply_get_battery_info(bdi->charger, &info)) {
1687 		v = info->precharge_current_ua / 1000;
1688 		if (v >= BQ24190_REG_PCTCC_IPRECHG_MIN
1689 		 && v <= BQ24190_REG_PCTCC_IPRECHG_MAX)
1690 			bdi->iprechg = v;
1691 		else
1692 			dev_warn(bdi->dev, "invalid value for battery:precharge-current-microamp: %d\n",
1693 				 v);
1694 
1695 		v = info->charge_term_current_ua / 1000;
1696 		if (v >= BQ24190_REG_PCTCC_ITERM_MIN
1697 		 && v <= BQ24190_REG_PCTCC_ITERM_MAX)
1698 			bdi->iterm = v;
1699 		else
1700 			dev_warn(bdi->dev, "invalid value for battery:charge-term-current-microamp: %d\n",
1701 				 v);
1702 	}
1703 
1704 	return 0;
1705 }
1706 
1707 static int bq24190_probe(struct i2c_client *client,
1708 		const struct i2c_device_id *id)
1709 {
1710 	struct i2c_adapter *adapter = client->adapter;
1711 	struct device *dev = &client->dev;
1712 	struct power_supply_config charger_cfg = {}, battery_cfg = {};
1713 	struct bq24190_dev_info *bdi;
1714 	int ret;
1715 
1716 	if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_BYTE_DATA)) {
1717 		dev_err(dev, "No support for SMBUS_BYTE_DATA\n");
1718 		return -ENODEV;
1719 	}
1720 
1721 	bdi = devm_kzalloc(dev, sizeof(*bdi), GFP_KERNEL);
1722 	if (!bdi) {
1723 		dev_err(dev, "Can't alloc bdi struct\n");
1724 		return -ENOMEM;
1725 	}
1726 
1727 	bdi->client = client;
1728 	bdi->dev = dev;
1729 	strncpy(bdi->model_name, id->name, I2C_NAME_SIZE);
1730 	mutex_init(&bdi->f_reg_lock);
1731 	bdi->f_reg = 0;
1732 	bdi->ss_reg = BQ24190_REG_SS_VBUS_STAT_MASK; /* impossible state */
1733 	INIT_DELAYED_WORK(&bdi->input_current_limit_work,
1734 			  bq24190_input_current_limit_work);
1735 
1736 	i2c_set_clientdata(client, bdi);
1737 
1738 	if (client->irq <= 0) {
1739 		dev_err(dev, "Can't get irq info\n");
1740 		return -EINVAL;
1741 	}
1742 
1743 	bdi->edev = devm_extcon_dev_allocate(dev, bq24190_usb_extcon_cable);
1744 	if (IS_ERR(bdi->edev))
1745 		return PTR_ERR(bdi->edev);
1746 
1747 	ret = devm_extcon_dev_register(dev, bdi->edev);
1748 	if (ret < 0)
1749 		return ret;
1750 
1751 	pm_runtime_enable(dev);
1752 	pm_runtime_use_autosuspend(dev);
1753 	pm_runtime_set_autosuspend_delay(dev, 600);
1754 	ret = pm_runtime_get_sync(dev);
1755 	if (ret < 0) {
1756 		dev_err(dev, "pm_runtime_get failed: %i\n", ret);
1757 		goto out_pmrt;
1758 	}
1759 
1760 #ifdef CONFIG_SYSFS
1761 	bq24190_sysfs_init_attrs();
1762 	charger_cfg.attr_grp = bq24190_sysfs_groups;
1763 #endif
1764 
1765 	charger_cfg.drv_data = bdi;
1766 	charger_cfg.of_node = dev->of_node;
1767 	charger_cfg.supplied_to = bq24190_charger_supplied_to;
1768 	charger_cfg.num_supplicants = ARRAY_SIZE(bq24190_charger_supplied_to);
1769 	bdi->charger = power_supply_register(dev, &bq24190_charger_desc,
1770 						&charger_cfg);
1771 	if (IS_ERR(bdi->charger)) {
1772 		dev_err(dev, "Can't register charger\n");
1773 		ret = PTR_ERR(bdi->charger);
1774 		goto out_pmrt;
1775 	}
1776 
1777 	/* the battery class is deprecated and will be removed. */
1778 	/* in the interim, this property hides it.              */
1779 	if (!device_property_read_bool(dev, "omit-battery-class")) {
1780 		battery_cfg.drv_data = bdi;
1781 		bdi->battery = power_supply_register(dev, &bq24190_battery_desc,
1782 						     &battery_cfg);
1783 		if (IS_ERR(bdi->battery)) {
1784 			dev_err(dev, "Can't register battery\n");
1785 			ret = PTR_ERR(bdi->battery);
1786 			goto out_charger;
1787 		}
1788 	}
1789 
1790 	ret = bq24190_get_config(bdi);
1791 	if (ret < 0) {
1792 		dev_err(dev, "Can't get devicetree config\n");
1793 		goto out_charger;
1794 	}
1795 
1796 	ret = bq24190_hw_init(bdi);
1797 	if (ret < 0) {
1798 		dev_err(dev, "Hardware init failed\n");
1799 		goto out_charger;
1800 	}
1801 
1802 	ret = bq24190_configure_usb_otg(bdi, bdi->ss_reg);
1803 	if (ret < 0)
1804 		goto out_charger;
1805 
1806 	bdi->initialized = true;
1807 
1808 	ret = devm_request_threaded_irq(dev, client->irq, NULL,
1809 			bq24190_irq_handler_thread,
1810 			IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
1811 			"bq24190-charger", bdi);
1812 	if (ret < 0) {
1813 		dev_err(dev, "Can't set up irq handler\n");
1814 		goto out_charger;
1815 	}
1816 
1817 	ret = bq24190_register_vbus_regulator(bdi);
1818 	if (ret < 0)
1819 		goto out_charger;
1820 
1821 	enable_irq_wake(client->irq);
1822 
1823 	pm_runtime_mark_last_busy(dev);
1824 	pm_runtime_put_autosuspend(dev);
1825 
1826 	return 0;
1827 
1828 out_charger:
1829 	if (!IS_ERR_OR_NULL(bdi->battery))
1830 		power_supply_unregister(bdi->battery);
1831 	power_supply_unregister(bdi->charger);
1832 
1833 out_pmrt:
1834 	pm_runtime_put_sync(dev);
1835 	pm_runtime_dont_use_autosuspend(dev);
1836 	pm_runtime_disable(dev);
1837 	return ret;
1838 }
1839 
1840 static int bq24190_remove(struct i2c_client *client)
1841 {
1842 	struct bq24190_dev_info *bdi = i2c_get_clientdata(client);
1843 	int error;
1844 
1845 	error = pm_runtime_get_sync(bdi->dev);
1846 	if (error < 0) {
1847 		dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", error);
1848 		pm_runtime_put_noidle(bdi->dev);
1849 	}
1850 
1851 	bq24190_register_reset(bdi);
1852 	if (bdi->battery)
1853 		power_supply_unregister(bdi->battery);
1854 	power_supply_unregister(bdi->charger);
1855 	if (error >= 0)
1856 		pm_runtime_put_sync(bdi->dev);
1857 	pm_runtime_dont_use_autosuspend(bdi->dev);
1858 	pm_runtime_disable(bdi->dev);
1859 
1860 	return 0;
1861 }
1862 
1863 static __maybe_unused int bq24190_runtime_suspend(struct device *dev)
1864 {
1865 	struct i2c_client *client = to_i2c_client(dev);
1866 	struct bq24190_dev_info *bdi = i2c_get_clientdata(client);
1867 
1868 	if (!bdi->initialized)
1869 		return 0;
1870 
1871 	dev_dbg(bdi->dev, "%s\n", __func__);
1872 
1873 	return 0;
1874 }
1875 
1876 static __maybe_unused int bq24190_runtime_resume(struct device *dev)
1877 {
1878 	struct i2c_client *client = to_i2c_client(dev);
1879 	struct bq24190_dev_info *bdi = i2c_get_clientdata(client);
1880 
1881 	if (!bdi->initialized)
1882 		return 0;
1883 
1884 	if (!bdi->irq_event) {
1885 		dev_dbg(bdi->dev, "checking events on possible wakeirq\n");
1886 		bq24190_check_status(bdi);
1887 	}
1888 
1889 	return 0;
1890 }
1891 
1892 static __maybe_unused int bq24190_pm_suspend(struct device *dev)
1893 {
1894 	struct i2c_client *client = to_i2c_client(dev);
1895 	struct bq24190_dev_info *bdi = i2c_get_clientdata(client);
1896 	int error;
1897 
1898 	error = pm_runtime_get_sync(bdi->dev);
1899 	if (error < 0) {
1900 		dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", error);
1901 		pm_runtime_put_noidle(bdi->dev);
1902 	}
1903 
1904 	bq24190_register_reset(bdi);
1905 
1906 	if (error >= 0) {
1907 		pm_runtime_mark_last_busy(bdi->dev);
1908 		pm_runtime_put_autosuspend(bdi->dev);
1909 	}
1910 
1911 	return 0;
1912 }
1913 
1914 static __maybe_unused int bq24190_pm_resume(struct device *dev)
1915 {
1916 	struct i2c_client *client = to_i2c_client(dev);
1917 	struct bq24190_dev_info *bdi = i2c_get_clientdata(client);
1918 	int error;
1919 
1920 	bdi->f_reg = 0;
1921 	bdi->ss_reg = BQ24190_REG_SS_VBUS_STAT_MASK; /* impossible state */
1922 
1923 	error = pm_runtime_get_sync(bdi->dev);
1924 	if (error < 0) {
1925 		dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", error);
1926 		pm_runtime_put_noidle(bdi->dev);
1927 	}
1928 
1929 	bq24190_register_reset(bdi);
1930 	bq24190_set_config(bdi);
1931 	bq24190_read(bdi, BQ24190_REG_SS, &bdi->ss_reg);
1932 
1933 	if (error >= 0) {
1934 		pm_runtime_mark_last_busy(bdi->dev);
1935 		pm_runtime_put_autosuspend(bdi->dev);
1936 	}
1937 
1938 	/* Things may have changed while suspended so alert upper layer */
1939 	power_supply_changed(bdi->charger);
1940 	if (bdi->battery)
1941 		power_supply_changed(bdi->battery);
1942 
1943 	return 0;
1944 }
1945 
1946 static const struct dev_pm_ops bq24190_pm_ops = {
1947 	SET_RUNTIME_PM_OPS(bq24190_runtime_suspend, bq24190_runtime_resume,
1948 			   NULL)
1949 	SET_SYSTEM_SLEEP_PM_OPS(bq24190_pm_suspend, bq24190_pm_resume)
1950 };
1951 
1952 static const struct i2c_device_id bq24190_i2c_ids[] = {
1953 	{ "bq24190" },
1954 	{ "bq24192" },
1955 	{ "bq24192i" },
1956 	{ "bq24196" },
1957 	{ },
1958 };
1959 MODULE_DEVICE_TABLE(i2c, bq24190_i2c_ids);
1960 
1961 static const struct of_device_id bq24190_of_match[] = {
1962 	{ .compatible = "ti,bq24190", },
1963 	{ .compatible = "ti,bq24192", },
1964 	{ .compatible = "ti,bq24192i", },
1965 	{ .compatible = "ti,bq24196", },
1966 	{ },
1967 };
1968 MODULE_DEVICE_TABLE(of, bq24190_of_match);
1969 
1970 static struct i2c_driver bq24190_driver = {
1971 	.probe		= bq24190_probe,
1972 	.remove		= bq24190_remove,
1973 	.id_table	= bq24190_i2c_ids,
1974 	.driver = {
1975 		.name		= "bq24190-charger",
1976 		.pm		= &bq24190_pm_ops,
1977 		.of_match_table	= bq24190_of_match,
1978 	},
1979 };
1980 module_i2c_driver(bq24190_driver);
1981 
1982 MODULE_LICENSE("GPL");
1983 MODULE_AUTHOR("Mark A. Greer <mgreer@animalcreek.com>");
1984 MODULE_DESCRIPTION("TI BQ24190 Charger Driver");
1985