diff options
author | Lee Jones <lee.jones@linaro.org> | 2013-01-23 09:33:47 -0500 |
---|---|---|
committer | Lee Jones <lee.jones@linaro.org> | 2013-01-23 09:39:13 -0500 |
commit | 2fa5b0f4a5fff1fe77665ac380ca4322df42fe8d (patch) | |
tree | 5628fa696f4b3f3d518fc3c2e161779bbb8722ea /drivers | |
parent | d80108fc69484c20c3b85d7cdc948e191e843fa4 (diff) |
pm2301: Move all configuration and emum structs out to a header file
Also shift the file description to a more suitable location.
Signed-off-by: Lee Jones <lee.jones@linaro.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/power/pm2301_charger.c | 478 | ||||
-rw-r--r-- | drivers/power/pm2301_charger.h | 486 |
2 files changed, 489 insertions, 475 deletions
diff --git a/drivers/power/pm2301_charger.c b/drivers/power/pm2301_charger.c index 60a30323151e..e7a360a0426f 100644 --- a/drivers/power/pm2301_charger.c +++ b/drivers/power/pm2301_charger.c | |||
@@ -1,8 +1,8 @@ | |||
1 | /* | 1 | /* |
2 | * Power supply driver for ST Ericsson pm2xxx_charger charger | ||
3 | * | ||
4 | * Copyright 2012 ST Ericsson. | 2 | * Copyright 2012 ST Ericsson. |
5 | * | 3 | * |
4 | * Power supply driver for ST Ericsson pm2xxx_charger charger | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | 6 | * This program is free software; you can redistribute it and/or modify |
7 | * it under the terms of the GNU General Public License version 2 as | 7 | * it under the terms of the GNU General Public License version 2 as |
8 | * published by the Free Software Foundation. | 8 | * published by the Free Software Foundation. |
@@ -29,285 +29,7 @@ | |||
29 | #include <linux/mfd/abx500/ux500_chargalg.h> | 29 | #include <linux/mfd/abx500/ux500_chargalg.h> |
30 | #include <linux/pm2301_charger.h> | 30 | #include <linux/pm2301_charger.h> |
31 | 31 | ||
32 | #define MAIN_WDOG_ENA 0x01 | 32 | #include "pm2301_charger.h" |
33 | #define MAIN_WDOG_KICK 0x02 | ||
34 | #define MAIN_WDOG_DIS 0x00 | ||
35 | #define CHARG_WD_KICK 0x01 | ||
36 | #define MAIN_CH_ENA 0x01 | ||
37 | #define MAIN_CH_NO_OVERSHOOT_ENA_N 0x02 | ||
38 | #define MAIN_CH_DET 0x01 | ||
39 | #define MAIN_CH_CV_ON 0x04 | ||
40 | #define OTP_ENABLE_WD 0x01 | ||
41 | |||
42 | #define MAIN_CH_INPUT_CURR_SHIFT 4 | ||
43 | |||
44 | #define LED_INDICATOR_PWM_ENA 0x01 | ||
45 | #define LED_INDICATOR_PWM_DIS 0x00 | ||
46 | #define LED_IND_CUR_5MA 0x04 | ||
47 | #define LED_INDICATOR_PWM_DUTY_252_256 0xBF | ||
48 | |||
49 | /* HW failure constants */ | ||
50 | #define MAIN_CH_TH_PROT 0x02 | ||
51 | #define MAIN_CH_NOK 0x01 | ||
52 | |||
53 | /* Watchdog timeout constant */ | ||
54 | #define WD_TIMER 0x30 /* 4min */ | ||
55 | #define WD_KICK_INTERVAL (60 * HZ) | ||
56 | |||
57 | /* Constant voltage/current */ | ||
58 | #define PM2XXX_CONST_CURR 0x0 | ||
59 | #define PM2XXX_CONST_VOLT 0x1 | ||
60 | |||
61 | /* Lowest charger voltage is 3.39V -> 0x4E */ | ||
62 | #define LOW_VOLT_REG 0x4E | ||
63 | |||
64 | #define PM2XXX_BATT_CTRL_REG1 0x00 | ||
65 | #define PM2XXX_BATT_CTRL_REG2 0x01 | ||
66 | #define PM2XXX_BATT_CTRL_REG3 0x02 | ||
67 | #define PM2XXX_BATT_CTRL_REG4 0x03 | ||
68 | #define PM2XXX_BATT_CTRL_REG5 0x04 | ||
69 | #define PM2XXX_BATT_CTRL_REG6 0x05 | ||
70 | #define PM2XXX_BATT_CTRL_REG7 0x06 | ||
71 | #define PM2XXX_BATT_CTRL_REG8 0x07 | ||
72 | #define PM2XXX_NTC_CTRL_REG1 0x08 | ||
73 | #define PM2XXX_NTC_CTRL_REG2 0x09 | ||
74 | #define PM2XXX_BATT_CTRL_REG9 0x0A | ||
75 | #define PM2XXX_BATT_STAT_REG1 0x0B | ||
76 | #define PM2XXX_INP_VOLT_VPWR2 0x11 | ||
77 | #define PM2XXX_INP_DROP_VPWR2 0x13 | ||
78 | #define PM2XXX_INP_VOLT_VPWR1 0x15 | ||
79 | #define PM2XXX_INP_DROP_VPWR1 0x17 | ||
80 | #define PM2XXX_INP_MODE_VPWR 0x18 | ||
81 | #define PM2XXX_BATT_WD_KICK 0x70 | ||
82 | #define PM2XXX_DEV_VER_STAT 0x0C | ||
83 | #define PM2XXX_THERM_WARN_CTRL_REG 0x20 | ||
84 | #define PM2XXX_BATT_DISC_REG 0x21 | ||
85 | #define PM2XXX_BATT_LOW_LEV_COMP_REG 0x22 | ||
86 | #define PM2XXX_BATT_LOW_LEV_VAL_REG 0x23 | ||
87 | #define PM2XXX_I2C_PAD_CTRL_REG 0x24 | ||
88 | #define PM2XXX_SW_CTRL_REG 0x26 | ||
89 | #define PM2XXX_LED_CTRL_REG 0x28 | ||
90 | |||
91 | #define PM2XXX_REG_INT1 0x40 | ||
92 | #define PM2XXX_MASK_REG_INT1 0x50 | ||
93 | #define PM2XXX_SRCE_REG_INT1 0x60 | ||
94 | #define PM2XXX_REG_INT2 0x41 | ||
95 | #define PM2XXX_MASK_REG_INT2 0x51 | ||
96 | #define PM2XXX_SRCE_REG_INT2 0x61 | ||
97 | #define PM2XXX_REG_INT3 0x42 | ||
98 | #define PM2XXX_MASK_REG_INT3 0x52 | ||
99 | #define PM2XXX_SRCE_REG_INT3 0x62 | ||
100 | #define PM2XXX_REG_INT4 0x43 | ||
101 | #define PM2XXX_MASK_REG_INT4 0x53 | ||
102 | #define PM2XXX_SRCE_REG_INT4 0x63 | ||
103 | #define PM2XXX_REG_INT5 0x44 | ||
104 | #define PM2XXX_MASK_REG_INT5 0x54 | ||
105 | #define PM2XXX_SRCE_REG_INT5 0x64 | ||
106 | #define PM2XXX_REG_INT6 0x45 | ||
107 | #define PM2XXX_MASK_REG_INT6 0x55 | ||
108 | #define PM2XXX_SRCE_REG_INT6 0x65 | ||
109 | |||
110 | #define VPWR_OVV 0x0 | ||
111 | #define VSYSTEM_OVV 0x1 | ||
112 | |||
113 | /* control Reg 1 */ | ||
114 | #define PM2XXX_CH_RESUME_EN 0x1 | ||
115 | #define PM2XXX_CH_RESUME_DIS 0x0 | ||
116 | |||
117 | /* control Reg 2 */ | ||
118 | #define PM2XXX_CH_AUTO_RESUME_EN 0X2 | ||
119 | #define PM2XXX_CH_AUTO_RESUME_DIS 0X0 | ||
120 | #define PM2XXX_CHARGER_ENA 0x4 | ||
121 | #define PM2XXX_CHARGER_DIS 0x0 | ||
122 | |||
123 | /* control Reg 3 */ | ||
124 | #define PM2XXX_CH_WD_CC_PHASE_OFF 0x0 | ||
125 | #define PM2XXX_CH_WD_CC_PHASE_5MIN 0x1 | ||
126 | #define PM2XXX_CH_WD_CC_PHASE_10MIN 0x2 | ||
127 | #define PM2XXX_CH_WD_CC_PHASE_30MIN 0x3 | ||
128 | #define PM2XXX_CH_WD_CC_PHASE_60MIN 0x4 | ||
129 | #define PM2XXX_CH_WD_CC_PHASE_120MIN 0x5 | ||
130 | #define PM2XXX_CH_WD_CC_PHASE_240MIN 0x6 | ||
131 | #define PM2XXX_CH_WD_CC_PHASE_360MIN 0x7 | ||
132 | |||
133 | #define PM2XXX_CH_WD_CV_PHASE_OFF (0x0<<3) | ||
134 | #define PM2XXX_CH_WD_CV_PHASE_5MIN (0x1<<3) | ||
135 | #define PM2XXX_CH_WD_CV_PHASE_10MIN (0x2<<3) | ||
136 | #define PM2XXX_CH_WD_CV_PHASE_30MIN (0x3<<3) | ||
137 | #define PM2XXX_CH_WD_CV_PHASE_60MIN (0x4<<3) | ||
138 | #define PM2XXX_CH_WD_CV_PHASE_120MIN (0x5<<3) | ||
139 | #define PM2XXX_CH_WD_CV_PHASE_240MIN (0x6<<3) | ||
140 | #define PM2XXX_CH_WD_CV_PHASE_360MIN (0x7<<3) | ||
141 | |||
142 | /* control Reg 4 */ | ||
143 | #define PM2XXX_CH_WD_PRECH_PHASE_OFF 0x0 | ||
144 | #define PM2XXX_CH_WD_PRECH_PHASE_1MIN 0x1 | ||
145 | #define PM2XXX_CH_WD_PRECH_PHASE_5MIN 0x2 | ||
146 | #define PM2XXX_CH_WD_PRECH_PHASE_10MIN 0x3 | ||
147 | #define PM2XXX_CH_WD_PRECH_PHASE_30MIN 0x4 | ||
148 | #define PM2XXX_CH_WD_PRECH_PHASE_60MIN 0x5 | ||
149 | #define PM2XXX_CH_WD_PRECH_PHASE_120MIN 0x6 | ||
150 | #define PM2XXX_CH_WD_PRECH_PHASE_240MIN 0x7 | ||
151 | |||
152 | /* control Reg 5 */ | ||
153 | #define PM2XXX_CH_WD_AUTO_TIMEOUT_NONE 0x0 | ||
154 | #define PM2XXX_CH_WD_AUTO_TIMEOUT_20MIN 0x1 | ||
155 | |||
156 | /* control Reg 6 */ | ||
157 | #define PM2XXX_DIR_CH_CC_CURRENT_MASK 0x0F | ||
158 | #define PM2XXX_DIR_CH_CC_CURRENT_200MA 0x0 | ||
159 | #define PM2XXX_DIR_CH_CC_CURRENT_400MA 0x2 | ||
160 | #define PM2XXX_DIR_CH_CC_CURRENT_600MA 0x3 | ||
161 | #define PM2XXX_DIR_CH_CC_CURRENT_800MA 0x4 | ||
162 | #define PM2XXX_DIR_CH_CC_CURRENT_1000MA 0x5 | ||
163 | #define PM2XXX_DIR_CH_CC_CURRENT_1200MA 0x6 | ||
164 | #define PM2XXX_DIR_CH_CC_CURRENT_1400MA 0x7 | ||
165 | #define PM2XXX_DIR_CH_CC_CURRENT_1600MA 0x8 | ||
166 | #define PM2XXX_DIR_CH_CC_CURRENT_1800MA 0x9 | ||
167 | #define PM2XXX_DIR_CH_CC_CURRENT_2000MA 0xA | ||
168 | #define PM2XXX_DIR_CH_CC_CURRENT_2200MA 0xB | ||
169 | #define PM2XXX_DIR_CH_CC_CURRENT_2400MA 0xC | ||
170 | #define PM2XXX_DIR_CH_CC_CURRENT_2600MA 0xD | ||
171 | #define PM2XXX_DIR_CH_CC_CURRENT_2800MA 0xE | ||
172 | #define PM2XXX_DIR_CH_CC_CURRENT_3000MA 0xF | ||
173 | |||
174 | #define PM2XXX_CH_PRECH_CURRENT_MASK 0x30 | ||
175 | #define PM2XXX_CH_PRECH_CURRENT_25MA (0x0<<4) | ||
176 | #define PM2XXX_CH_PRECH_CURRENT_50MA (0x1<<4) | ||
177 | #define PM2XXX_CH_PRECH_CURRENT_75MA (0x2<<4) | ||
178 | #define PM2XXX_CH_PRECH_CURRENT_100MA (0x3<<4) | ||
179 | |||
180 | #define PM2XXX_CH_EOC_CURRENT_MASK 0xC0 | ||
181 | #define PM2XXX_CH_EOC_CURRENT_100MA (0x0<<6) | ||
182 | #define PM2XXX_CH_EOC_CURRENT_150MA (0x1<<6) | ||
183 | #define PM2XXX_CH_EOC_CURRENT_300MA (0x2<<6) | ||
184 | #define PM2XXX_CH_EOC_CURRENT_400MA (0x3<<6) | ||
185 | |||
186 | /* control Reg 7 */ | ||
187 | #define PM2XXX_CH_PRECH_VOL_2_5 0x0 | ||
188 | #define PM2XXX_CH_PRECH_VOL_2_7 0x1 | ||
189 | #define PM2XXX_CH_PRECH_VOL_2_9 0x2 | ||
190 | #define PM2XXX_CH_PRECH_VOL_3_1 0x3 | ||
191 | |||
192 | #define PM2XXX_CH_VRESUME_VOL_3_2 (0x0<<2) | ||
193 | #define PM2XXX_CH_VRESUME_VOL_3_4 (0x1<<2) | ||
194 | #define PM2XXX_CH_VRESUME_VOL_3_6 (0x2<<2) | ||
195 | #define PM2XXX_CH_VRESUME_VOL_3_8 (0x3<<2) | ||
196 | |||
197 | /* control Reg 8 */ | ||
198 | #define PM2XXX_CH_VOLT_MASK 0x3F | ||
199 | #define PM2XXX_CH_VOLT_3_5 0x0 | ||
200 | #define PM2XXX_CH_VOLT_3_5225 0x1 | ||
201 | #define PM2XXX_CH_VOLT_3_6 0x4 | ||
202 | #define PM2XXX_CH_VOLT_3_7 0x8 | ||
203 | #define PM2XXX_CH_VOLT_4_0 0x14 | ||
204 | #define PM2XXX_CH_VOLT_4_175 0x1B | ||
205 | #define PM2XXX_CH_VOLT_4_2 0x1C | ||
206 | #define PM2XXX_CH_VOLT_4_275 0x1F | ||
207 | #define PM2XXX_CH_VOLT_4_3 0x20 | ||
208 | |||
209 | /*NTC control register 1*/ | ||
210 | #define PM2XXX_BTEMP_HIGH_TH_45 0x0 | ||
211 | #define PM2XXX_BTEMP_HIGH_TH_50 0x1 | ||
212 | #define PM2XXX_BTEMP_HIGH_TH_55 0x2 | ||
213 | #define PM2XXX_BTEMP_HIGH_TH_60 0x3 | ||
214 | #define PM2XXX_BTEMP_HIGH_TH_65 0x4 | ||
215 | |||
216 | #define PM2XXX_BTEMP_LOW_TH_N5 (0x0<<3) | ||
217 | #define PM2XXX_BTEMP_LOW_TH_0 (0x1<<3) | ||
218 | #define PM2XXX_BTEMP_LOW_TH_5 (0x2<<3) | ||
219 | #define PM2XXX_BTEMP_LOW_TH_10 (0x3<<3) | ||
220 | |||
221 | /*NTC control register 2*/ | ||
222 | #define PM2XXX_NTC_BETA_COEFF_3477 0x0 | ||
223 | #define PM2XXX_NTC_BETA_COEFF_3964 0x1 | ||
224 | |||
225 | #define PM2XXX_NTC_RES_10K (0x0<<2) | ||
226 | #define PM2XXX_NTC_RES_47K (0x1<<2) | ||
227 | #define PM2XXX_NTC_RES_100K (0x2<<2) | ||
228 | #define PM2XXX_NTC_RES_NO_NTC (0x3<<2) | ||
229 | |||
230 | /* control Reg 9 */ | ||
231 | #define PM2XXX_CH_CC_MODEDROP_EN 1 | ||
232 | #define PM2XXX_CH_CC_MODEDROP_DIS 0 | ||
233 | |||
234 | #define PM2XXX_CH_CC_REDUCED_CURRENT_100MA (0x0<<1) | ||
235 | #define PM2XXX_CH_CC_REDUCED_CURRENT_200MA (0x1<<1) | ||
236 | #define PM2XXX_CH_CC_REDUCED_CURRENT_400MA (0x2<<1) | ||
237 | #define PM2XXX_CH_CC_REDUCED_CURRENT_IDENT (0x3<<1) | ||
238 | |||
239 | #define PM2XXX_CHARCHING_INFO_DIS (0<<3) | ||
240 | #define PM2XXX_CHARCHING_INFO_EN (1<<3) | ||
241 | |||
242 | #define PM2XXX_CH_150MV_DROP_300MV (0<<4) | ||
243 | #define PM2XXX_CH_150MV_DROP_150MV (1<<4) | ||
244 | |||
245 | |||
246 | /* charger status register */ | ||
247 | #define PM2XXX_CHG_STATUS_OFF 0x0 | ||
248 | #define PM2XXX_CHG_STATUS_ON 0x1 | ||
249 | #define PM2XXX_CHG_STATUS_FULL 0x2 | ||
250 | #define PM2XXX_CHG_STATUS_ERR 0x3 | ||
251 | #define PM2XXX_CHG_STATUS_WAIT 0x4 | ||
252 | #define PM2XXX_CHG_STATUS_NOBAT 0x5 | ||
253 | |||
254 | /* Input charger voltage VPWR2 */ | ||
255 | #define PM2XXX_VPWR2_OVV_6_0 0x0 | ||
256 | #define PM2XXX_VPWR2_OVV_6_3 0x1 | ||
257 | #define PM2XXX_VPWR2_OVV_10 0x2 | ||
258 | #define PM2XXX_VPWR2_OVV_NONE 0x3 | ||
259 | |||
260 | /* Input charger voltage VPWR1 */ | ||
261 | #define PM2XXX_VPWR1_OVV_6_0 0x0 | ||
262 | #define PM2XXX_VPWR1_OVV_6_3 0x1 | ||
263 | #define PM2XXX_VPWR1_OVV_10 0x2 | ||
264 | #define PM2XXX_VPWR1_OVV_NONE 0x3 | ||
265 | |||
266 | /* Battery low level comparator control register */ | ||
267 | #define PM2XXX_VBAT_LOW_MONITORING_DIS 0x0 | ||
268 | #define PM2XXX_VBAT_LOW_MONITORING_ENA 0x1 | ||
269 | |||
270 | /* Battery low level value control register */ | ||
271 | #define PM2XXX_VBAT_LOW_LEVEL_2_3 0x0 | ||
272 | #define PM2XXX_VBAT_LOW_LEVEL_2_4 0x1 | ||
273 | #define PM2XXX_VBAT_LOW_LEVEL_2_5 0x2 | ||
274 | #define PM2XXX_VBAT_LOW_LEVEL_2_6 0x3 | ||
275 | #define PM2XXX_VBAT_LOW_LEVEL_2_7 0x4 | ||
276 | #define PM2XXX_VBAT_LOW_LEVEL_2_8 0x5 | ||
277 | #define PM2XXX_VBAT_LOW_LEVEL_2_9 0x6 | ||
278 | #define PM2XXX_VBAT_LOW_LEVEL_3_0 0x7 | ||
279 | #define PM2XXX_VBAT_LOW_LEVEL_3_1 0x8 | ||
280 | #define PM2XXX_VBAT_LOW_LEVEL_3_2 0x9 | ||
281 | #define PM2XXX_VBAT_LOW_LEVEL_3_3 0xA | ||
282 | #define PM2XXX_VBAT_LOW_LEVEL_3_4 0xB | ||
283 | #define PM2XXX_VBAT_LOW_LEVEL_3_5 0xC | ||
284 | #define PM2XXX_VBAT_LOW_LEVEL_3_6 0xD | ||
285 | #define PM2XXX_VBAT_LOW_LEVEL_3_7 0xE | ||
286 | #define PM2XXX_VBAT_LOW_LEVEL_3_8 0xF | ||
287 | #define PM2XXX_VBAT_LOW_LEVEL_3_9 0x10 | ||
288 | #define PM2XXX_VBAT_LOW_LEVEL_4_0 0x11 | ||
289 | #define PM2XXX_VBAT_LOW_LEVEL_4_1 0x12 | ||
290 | #define PM2XXX_VBAT_LOW_LEVEL_4_2 0x13 | ||
291 | |||
292 | /* SW CTRL */ | ||
293 | #define PM2XXX_SWCTRL_HW 0x0 | ||
294 | #define PM2XXX_SWCTRL_SW 0x1 | ||
295 | |||
296 | |||
297 | /* LED Driver Control */ | ||
298 | #define PM2XXX_LED_CURRENT_MASK 0x0C | ||
299 | #define PM2XXX_LED_CURRENT_2_5MA (0X0<<2) | ||
300 | #define PM2XXX_LED_CURRENT_1MA (0X1<<2) | ||
301 | #define PM2XXX_LED_CURRENT_5MA (0X2<<2) | ||
302 | #define PM2XXX_LED_CURRENT_10MA (0X3<<2) | ||
303 | |||
304 | #define PM2XXX_LED_SELECT_MASK 0x02 | ||
305 | #define PM2XXX_LED_SELECT_EN (0X0<<1) | ||
306 | #define PM2XXX_LED_SELECT_DIS (0X1<<1) | ||
307 | |||
308 | #define PM2XXX_ANTI_OVERSHOOT_MASK 0x01 | ||
309 | #define PM2XXX_ANTI_OVERSHOOT_DIS 0X0 | ||
310 | #define PM2XXX_ANTI_OVERSHOOT_EN 0X1 | ||
311 | 33 | ||
312 | #define to_pm2xxx_charger_ac_device_info(x) container_of((x), \ | 34 | #define to_pm2xxx_charger_ac_device_info(x) container_of((x), \ |
313 | struct pm2xxx_charger, ac_chg) | 35 | struct pm2xxx_charger, ac_chg) |
@@ -321,148 +43,6 @@ static int pm2xxx_interrupt_registers[] = { | |||
321 | PM2XXX_REG_INT6, | 43 | PM2XXX_REG_INT6, |
322 | }; | 44 | }; |
323 | 45 | ||
324 | enum pm2xxx_reg_int1 { | ||
325 | PM2XXX_INT1_ITVBATDISCONNECT = 0x02, | ||
326 | PM2XXX_INT1_ITVBATLOWR = 0x04, | ||
327 | PM2XXX_INT1_ITVBATLOWF = 0x08, | ||
328 | }; | ||
329 | |||
330 | enum pm2xxx_mask_reg_int1 { | ||
331 | PM2XXX_INT1_M_ITVBATDISCONNECT = 0x02, | ||
332 | PM2XXX_INT1_M_ITVBATLOWR = 0x04, | ||
333 | PM2XXX_INT1_M_ITVBATLOWF = 0x08, | ||
334 | }; | ||
335 | |||
336 | enum pm2xxx_source_reg_int1 { | ||
337 | PM2XXX_INT1_S_ITVBATDISCONNECT = 0x02, | ||
338 | PM2XXX_INT1_S_ITVBATLOWR = 0x04, | ||
339 | PM2XXX_INT1_S_ITVBATLOWF = 0x08, | ||
340 | }; | ||
341 | |||
342 | enum pm2xxx_reg_int2 { | ||
343 | PM2XXX_INT2_ITVPWR2PLUG = 0x01, | ||
344 | PM2XXX_INT2_ITVPWR2UNPLUG = 0x02, | ||
345 | PM2XXX_INT2_ITVPWR1PLUG = 0x04, | ||
346 | PM2XXX_INT2_ITVPWR1UNPLUG = 0x08, | ||
347 | }; | ||
348 | |||
349 | enum pm2xxx_mask_reg_int2 { | ||
350 | PM2XXX_INT2_M_ITVPWR2PLUG = 0x01, | ||
351 | PM2XXX_INT2_M_ITVPWR2UNPLUG = 0x02, | ||
352 | PM2XXX_INT2_M_ITVPWR1PLUG = 0x04, | ||
353 | PM2XXX_INT2_M_ITVPWR1UNPLUG = 0x08, | ||
354 | }; | ||
355 | |||
356 | enum pm2xxx_source_reg_int2 { | ||
357 | PM2XXX_INT2_S_ITVPWR2PLUG = 0x03, | ||
358 | PM2XXX_INT2_S_ITVPWR1PLUG = 0x0c, | ||
359 | }; | ||
360 | |||
361 | enum pm2xxx_reg_int3 { | ||
362 | PM2XXX_INT3_ITCHPRECHARGEWD = 0x01, | ||
363 | PM2XXX_INT3_ITCHCCWD = 0x02, | ||
364 | PM2XXX_INT3_ITCHCVWD = 0x04, | ||
365 | PM2XXX_INT3_ITAUTOTIMEOUTWD = 0x08, | ||
366 | }; | ||
367 | |||
368 | enum pm2xxx_mask_reg_int3 { | ||
369 | PM2XXX_INT3_M_ITCHPRECHARGEWD = 0x01, | ||
370 | PM2XXX_INT3_M_ITCHCCWD = 0x02, | ||
371 | PM2XXX_INT3_M_ITCHCVWD = 0x04, | ||
372 | PM2XXX_INT3_M_ITAUTOTIMEOUTWD = 0x08, | ||
373 | }; | ||
374 | |||
375 | enum pm2xxx_source_reg_int3 { | ||
376 | PM2XXX_INT3_S_ITCHPRECHARGEWD = 0x01, | ||
377 | PM2XXX_INT3_S_ITCHCCWD = 0x02, | ||
378 | PM2XXX_INT3_S_ITCHCVWD = 0x04, | ||
379 | PM2XXX_INT3_S_ITAUTOTIMEOUTWD = 0x08, | ||
380 | }; | ||
381 | |||
382 | enum pm2xxx_reg_int4 { | ||
383 | PM2XXX_INT4_ITBATTEMPCOLD = 0x01, | ||
384 | PM2XXX_INT4_ITBATTEMPHOT = 0x02, | ||
385 | PM2XXX_INT4_ITVPWR2OVV = 0x04, | ||
386 | PM2XXX_INT4_ITVPWR1OVV = 0x08, | ||
387 | PM2XXX_INT4_ITCHARGINGON = 0x10, | ||
388 | PM2XXX_INT4_ITVRESUME = 0x20, | ||
389 | PM2XXX_INT4_ITBATTFULL = 0x40, | ||
390 | PM2XXX_INT4_ITCVPHASE = 0x80, | ||
391 | }; | ||
392 | |||
393 | enum pm2xxx_mask_reg_int4 { | ||
394 | PM2XXX_INT4_M_ITBATTEMPCOLD = 0x01, | ||
395 | PM2XXX_INT4_M_ITBATTEMPHOT = 0x02, | ||
396 | PM2XXX_INT4_M_ITVPWR2OVV = 0x04, | ||
397 | PM2XXX_INT4_M_ITVPWR1OVV = 0x08, | ||
398 | PM2XXX_INT4_M_ITCHARGINGON = 0x10, | ||
399 | PM2XXX_INT4_M_ITVRESUME = 0x20, | ||
400 | PM2XXX_INT4_M_ITBATTFULL = 0x40, | ||
401 | PM2XXX_INT4_M_ITCVPHASE = 0x80, | ||
402 | }; | ||
403 | |||
404 | enum pm2xxx_source_reg_int4 { | ||
405 | PM2XXX_INT4_S_ITBATTEMPCOLD = 0x01, | ||
406 | PM2XXX_INT4_S_ITBATTEMPHOT = 0x02, | ||
407 | PM2XXX_INT4_S_ITVPWR2OVV = 0x04, | ||
408 | PM2XXX_INT4_S_ITVPWR1OVV = 0x08, | ||
409 | PM2XXX_INT4_S_ITCHARGINGON = 0x10, | ||
410 | PM2XXX_INT4_S_ITVRESUME = 0x20, | ||
411 | PM2XXX_INT4_S_ITBATTFULL = 0x40, | ||
412 | PM2XXX_INT4_S_ITCVPHASE = 0x80, | ||
413 | }; | ||
414 | |||
415 | enum pm2xxx_reg_int5 { | ||
416 | PM2XXX_INT5_ITTHERMALSHUTDOWNRISE = 0x01, | ||
417 | PM2XXX_INT5_ITTHERMALSHUTDOWNFALL = 0x02, | ||
418 | PM2XXX_INT5_ITTHERMALWARNINGRISE = 0x04, | ||
419 | PM2XXX_INT5_ITTHERMALWARNINGFALL = 0x08, | ||
420 | PM2XXX_INT5_ITVSYSTEMOVV = 0x10, | ||
421 | }; | ||
422 | |||
423 | enum pm2xxx_mask_reg_int5 { | ||
424 | PM2XXX_INT5_M_ITTHERMALSHUTDOWNRISE = 0x01, | ||
425 | PM2XXX_INT5_M_ITTHERMALSHUTDOWNFALL = 0x02, | ||
426 | PM2XXX_INT5_M_ITTHERMALWARNINGRISE = 0x04, | ||
427 | PM2XXX_INT5_M_ITTHERMALWARNINGFALL = 0x08, | ||
428 | PM2XXX_INT5_M_ITVSYSTEMOVV = 0x10, | ||
429 | }; | ||
430 | |||
431 | enum pm2xxx_source_reg_int5 { | ||
432 | PM2XXX_INT5_S_ITTHERMALSHUTDOWNRISE = 0x01, | ||
433 | PM2XXX_INT5_S_ITTHERMALSHUTDOWNFALL = 0x02, | ||
434 | PM2XXX_INT5_S_ITTHERMALWARNINGRISE = 0x04, | ||
435 | PM2XXX_INT5_S_ITTHERMALWARNINGFALL = 0x08, | ||
436 | PM2XXX_INT5_S_ITVSYSTEMOVV = 0x10, | ||
437 | }; | ||
438 | |||
439 | enum pm2xxx_reg_int6 { | ||
440 | PM2XXX_INT6_ITVPWR2DROP = 0x01, | ||
441 | PM2XXX_INT6_ITVPWR1DROP = 0x02, | ||
442 | PM2XXX_INT6_ITVPWR2VALIDRISE = 0x04, | ||
443 | PM2XXX_INT6_ITVPWR2VALIDFALL = 0x08, | ||
444 | PM2XXX_INT6_ITVPWR1VALIDRISE = 0x10, | ||
445 | PM2XXX_INT6_ITVPWR1VALIDFALL = 0x20, | ||
446 | }; | ||
447 | |||
448 | enum pm2xxx_mask_reg_int6 { | ||
449 | PM2XXX_INT6_M_ITVPWR2DROP = 0x01, | ||
450 | PM2XXX_INT6_M_ITVPWR1DROP = 0x02, | ||
451 | PM2XXX_INT6_M_ITVPWR2VALIDRISE = 0x04, | ||
452 | PM2XXX_INT6_M_ITVPWR2VALIDFALL = 0x08, | ||
453 | PM2XXX_INT6_M_ITVPWR1VALIDRISE = 0x10, | ||
454 | PM2XXX_INT6_M_ITVPWR1VALIDFALL = 0x20, | ||
455 | }; | ||
456 | |||
457 | enum pm2xxx_source_reg_int6 { | ||
458 | PM2XXX_INT6_S_ITVPWR2DROP = 0x01, | ||
459 | PM2XXX_INT6_S_ITVPWR1DROP = 0x02, | ||
460 | PM2XXX_INT6_S_ITVPWR2VALIDRISE = 0x04, | ||
461 | PM2XXX_INT6_S_ITVPWR2VALIDFALL = 0x08, | ||
462 | PM2XXX_INT6_S_ITVPWR1VALIDRISE = 0x10, | ||
463 | PM2XXX_INT6_S_ITVPWR1VALIDFALL = 0x20, | ||
464 | }; | ||
465 | |||
466 | static enum power_supply_property pm2xxx_charger_ac_props[] = { | 46 | static enum power_supply_property pm2xxx_charger_ac_props[] = { |
467 | POWER_SUPPLY_PROP_HEALTH, | 47 | POWER_SUPPLY_PROP_HEALTH, |
468 | POWER_SUPPLY_PROP_PRESENT, | 48 | POWER_SUPPLY_PROP_PRESENT, |
@@ -527,58 +107,6 @@ static int pm2xxx_charger_current_map[] = { | |||
527 | 3000, | 107 | 3000, |
528 | }; | 108 | }; |
529 | 109 | ||
530 | struct pm2xxx_irq { | ||
531 | char *name; | ||
532 | irqreturn_t (*isr)(int irq, void *data); | ||
533 | }; | ||
534 | |||
535 | struct pm2xxx_charger_info { | ||
536 | int charger_connected; | ||
537 | int charger_online; | ||
538 | int charger_voltage; | ||
539 | int cv_active; | ||
540 | bool wd_expired; | ||
541 | }; | ||
542 | |||
543 | struct pm2xxx_charger_event_flags { | ||
544 | bool mainextchnotok; | ||
545 | bool main_thermal_prot; | ||
546 | bool ovv; | ||
547 | bool chgwdexp; | ||
548 | }; | ||
549 | |||
550 | struct pm2xxx_config { | ||
551 | struct i2c_client *pm2xxx_i2c; | ||
552 | struct i2c_device_id *pm2xxx_id; | ||
553 | }; | ||
554 | |||
555 | struct pm2xxx_charger { | ||
556 | struct device *dev; | ||
557 | u8 chip_id; | ||
558 | bool vddadc_en_ac; | ||
559 | struct pm2xxx_config config; | ||
560 | bool ac_conn; | ||
561 | unsigned int gpio_irq; | ||
562 | int vbat; | ||
563 | int old_vbat; | ||
564 | int failure_case; | ||
565 | int failure_input_ovv; | ||
566 | u8 pm2_int[6]; | ||
567 | struct ab8500_gpadc *gpadc; | ||
568 | struct regulator *regu; | ||
569 | struct pm2xxx_bm_data *bat; | ||
570 | struct mutex lock; | ||
571 | struct ab8500 *parent; | ||
572 | struct pm2xxx_charger_info ac; | ||
573 | struct pm2xxx_charger_platform_data *pdata; | ||
574 | struct workqueue_struct *charger_wq; | ||
575 | struct delayed_work check_vbat_work; | ||
576 | struct work_struct ac_work; | ||
577 | struct work_struct check_main_thermal_prot_work; | ||
578 | struct ux500_charger ac_chg; | ||
579 | struct pm2xxx_charger_event_flags flags; | ||
580 | }; | ||
581 | |||
582 | static const struct i2c_device_id pm2xxx_ident[] = { | 110 | static const struct i2c_device_id pm2xxx_ident[] = { |
583 | { "pm2301", 0 }, | 111 | { "pm2301", 0 }, |
584 | { } | 112 | { } |
diff --git a/drivers/power/pm2301_charger.h b/drivers/power/pm2301_charger.h new file mode 100644 index 000000000000..bef38a3552b5 --- /dev/null +++ b/drivers/power/pm2301_charger.h | |||
@@ -0,0 +1,486 @@ | |||
1 | /* | ||
2 | * Copyright (C) ST-Ericsson SA 2012 | ||
3 | * | ||
4 | * PM2301 power supply interface | ||
5 | * | ||
6 | * License terms: GNU General Public License (GPL), version 2 | ||
7 | */ | ||
8 | |||
9 | #ifndef PM2301_CHARGER_H | ||
10 | #define PM2301_CHARGER_H | ||
11 | |||
12 | #define MAIN_WDOG_ENA 0x01 | ||
13 | #define MAIN_WDOG_KICK 0x02 | ||
14 | #define MAIN_WDOG_DIS 0x00 | ||
15 | #define CHARG_WD_KICK 0x01 | ||
16 | #define MAIN_CH_ENA 0x01 | ||
17 | #define MAIN_CH_NO_OVERSHOOT_ENA_N 0x02 | ||
18 | #define MAIN_CH_DET 0x01 | ||
19 | #define MAIN_CH_CV_ON 0x04 | ||
20 | #define OTP_ENABLE_WD 0x01 | ||
21 | |||
22 | #define MAIN_CH_INPUT_CURR_SHIFT 4 | ||
23 | |||
24 | #define LED_INDICATOR_PWM_ENA 0x01 | ||
25 | #define LED_INDICATOR_PWM_DIS 0x00 | ||
26 | #define LED_IND_CUR_5MA 0x04 | ||
27 | #define LED_INDICATOR_PWM_DUTY_252_256 0xBF | ||
28 | |||
29 | /* HW failure constants */ | ||
30 | #define MAIN_CH_TH_PROT 0x02 | ||
31 | #define MAIN_CH_NOK 0x01 | ||
32 | |||
33 | /* Watchdog timeout constant */ | ||
34 | #define WD_TIMER 0x30 /* 4min */ | ||
35 | #define WD_KICK_INTERVAL (60 * HZ) | ||
36 | |||
37 | /* Constant voltage/current */ | ||
38 | #define PM2XXX_CONST_CURR 0x0 | ||
39 | #define PM2XXX_CONST_VOLT 0x1 | ||
40 | |||
41 | /* Lowest charger voltage is 3.39V -> 0x4E */ | ||
42 | #define LOW_VOLT_REG 0x4E | ||
43 | |||
44 | #define PM2XXX_BATT_CTRL_REG1 0x00 | ||
45 | #define PM2XXX_BATT_CTRL_REG2 0x01 | ||
46 | #define PM2XXX_BATT_CTRL_REG3 0x02 | ||
47 | #define PM2XXX_BATT_CTRL_REG4 0x03 | ||
48 | #define PM2XXX_BATT_CTRL_REG5 0x04 | ||
49 | #define PM2XXX_BATT_CTRL_REG6 0x05 | ||
50 | #define PM2XXX_BATT_CTRL_REG7 0x06 | ||
51 | #define PM2XXX_BATT_CTRL_REG8 0x07 | ||
52 | #define PM2XXX_NTC_CTRL_REG1 0x08 | ||
53 | #define PM2XXX_NTC_CTRL_REG2 0x09 | ||
54 | #define PM2XXX_BATT_CTRL_REG9 0x0A | ||
55 | #define PM2XXX_BATT_STAT_REG1 0x0B | ||
56 | #define PM2XXX_INP_VOLT_VPWR2 0x11 | ||
57 | #define PM2XXX_INP_DROP_VPWR2 0x13 | ||
58 | #define PM2XXX_INP_VOLT_VPWR1 0x15 | ||
59 | #define PM2XXX_INP_DROP_VPWR1 0x17 | ||
60 | #define PM2XXX_INP_MODE_VPWR 0x18 | ||
61 | #define PM2XXX_BATT_WD_KICK 0x70 | ||
62 | #define PM2XXX_DEV_VER_STAT 0x0C | ||
63 | #define PM2XXX_THERM_WARN_CTRL_REG 0x20 | ||
64 | #define PM2XXX_BATT_DISC_REG 0x21 | ||
65 | #define PM2XXX_BATT_LOW_LEV_COMP_REG 0x22 | ||
66 | #define PM2XXX_BATT_LOW_LEV_VAL_REG 0x23 | ||
67 | #define PM2XXX_I2C_PAD_CTRL_REG 0x24 | ||
68 | #define PM2XXX_SW_CTRL_REG 0x26 | ||
69 | #define PM2XXX_LED_CTRL_REG 0x28 | ||
70 | |||
71 | #define PM2XXX_REG_INT1 0x40 | ||
72 | #define PM2XXX_MASK_REG_INT1 0x50 | ||
73 | #define PM2XXX_SRCE_REG_INT1 0x60 | ||
74 | #define PM2XXX_REG_INT2 0x41 | ||
75 | #define PM2XXX_MASK_REG_INT2 0x51 | ||
76 | #define PM2XXX_SRCE_REG_INT2 0x61 | ||
77 | #define PM2XXX_REG_INT3 0x42 | ||
78 | #define PM2XXX_MASK_REG_INT3 0x52 | ||
79 | #define PM2XXX_SRCE_REG_INT3 0x62 | ||
80 | #define PM2XXX_REG_INT4 0x43 | ||
81 | #define PM2XXX_MASK_REG_INT4 0x53 | ||
82 | #define PM2XXX_SRCE_REG_INT4 0x63 | ||
83 | #define PM2XXX_REG_INT5 0x44 | ||
84 | #define PM2XXX_MASK_REG_INT5 0x54 | ||
85 | #define PM2XXX_SRCE_REG_INT5 0x64 | ||
86 | #define PM2XXX_REG_INT6 0x45 | ||
87 | #define PM2XXX_MASK_REG_INT6 0x55 | ||
88 | #define PM2XXX_SRCE_REG_INT6 0x65 | ||
89 | |||
90 | #define VPWR_OVV 0x0 | ||
91 | #define VSYSTEM_OVV 0x1 | ||
92 | |||
93 | /* control Reg 1 */ | ||
94 | #define PM2XXX_CH_RESUME_EN 0x1 | ||
95 | #define PM2XXX_CH_RESUME_DIS 0x0 | ||
96 | |||
97 | /* control Reg 2 */ | ||
98 | #define PM2XXX_CH_AUTO_RESUME_EN 0X2 | ||
99 | #define PM2XXX_CH_AUTO_RESUME_DIS 0X0 | ||
100 | #define PM2XXX_CHARGER_ENA 0x4 | ||
101 | #define PM2XXX_CHARGER_DIS 0x0 | ||
102 | |||
103 | /* control Reg 3 */ | ||
104 | #define PM2XXX_CH_WD_CC_PHASE_OFF 0x0 | ||
105 | #define PM2XXX_CH_WD_CC_PHASE_5MIN 0x1 | ||
106 | #define PM2XXX_CH_WD_CC_PHASE_10MIN 0x2 | ||
107 | #define PM2XXX_CH_WD_CC_PHASE_30MIN 0x3 | ||
108 | #define PM2XXX_CH_WD_CC_PHASE_60MIN 0x4 | ||
109 | #define PM2XXX_CH_WD_CC_PHASE_120MIN 0x5 | ||
110 | #define PM2XXX_CH_WD_CC_PHASE_240MIN 0x6 | ||
111 | #define PM2XXX_CH_WD_CC_PHASE_360MIN 0x7 | ||
112 | |||
113 | #define PM2XXX_CH_WD_CV_PHASE_OFF (0x0<<3) | ||
114 | #define PM2XXX_CH_WD_CV_PHASE_5MIN (0x1<<3) | ||
115 | #define PM2XXX_CH_WD_CV_PHASE_10MIN (0x2<<3) | ||
116 | #define PM2XXX_CH_WD_CV_PHASE_30MIN (0x3<<3) | ||
117 | #define PM2XXX_CH_WD_CV_PHASE_60MIN (0x4<<3) | ||
118 | #define PM2XXX_CH_WD_CV_PHASE_120MIN (0x5<<3) | ||
119 | #define PM2XXX_CH_WD_CV_PHASE_240MIN (0x6<<3) | ||
120 | #define PM2XXX_CH_WD_CV_PHASE_360MIN (0x7<<3) | ||
121 | |||
122 | /* control Reg 4 */ | ||
123 | #define PM2XXX_CH_WD_PRECH_PHASE_OFF 0x0 | ||
124 | #define PM2XXX_CH_WD_PRECH_PHASE_1MIN 0x1 | ||
125 | #define PM2XXX_CH_WD_PRECH_PHASE_5MIN 0x2 | ||
126 | #define PM2XXX_CH_WD_PRECH_PHASE_10MIN 0x3 | ||
127 | #define PM2XXX_CH_WD_PRECH_PHASE_30MIN 0x4 | ||
128 | #define PM2XXX_CH_WD_PRECH_PHASE_60MIN 0x5 | ||
129 | #define PM2XXX_CH_WD_PRECH_PHASE_120MIN 0x6 | ||
130 | #define PM2XXX_CH_WD_PRECH_PHASE_240MIN 0x7 | ||
131 | |||
132 | /* control Reg 5 */ | ||
133 | #define PM2XXX_CH_WD_AUTO_TIMEOUT_NONE 0x0 | ||
134 | #define PM2XXX_CH_WD_AUTO_TIMEOUT_20MIN 0x1 | ||
135 | |||
136 | /* control Reg 6 */ | ||
137 | #define PM2XXX_DIR_CH_CC_CURRENT_MASK 0x0F | ||
138 | #define PM2XXX_DIR_CH_CC_CURRENT_200MA 0x0 | ||
139 | #define PM2XXX_DIR_CH_CC_CURRENT_400MA 0x2 | ||
140 | #define PM2XXX_DIR_CH_CC_CURRENT_600MA 0x3 | ||
141 | #define PM2XXX_DIR_CH_CC_CURRENT_800MA 0x4 | ||
142 | #define PM2XXX_DIR_CH_CC_CURRENT_1000MA 0x5 | ||
143 | #define PM2XXX_DIR_CH_CC_CURRENT_1200MA 0x6 | ||
144 | #define PM2XXX_DIR_CH_CC_CURRENT_1400MA 0x7 | ||
145 | #define PM2XXX_DIR_CH_CC_CURRENT_1600MA 0x8 | ||
146 | #define PM2XXX_DIR_CH_CC_CURRENT_1800MA 0x9 | ||
147 | #define PM2XXX_DIR_CH_CC_CURRENT_2000MA 0xA | ||
148 | #define PM2XXX_DIR_CH_CC_CURRENT_2200MA 0xB | ||
149 | #define PM2XXX_DIR_CH_CC_CURRENT_2400MA 0xC | ||
150 | #define PM2XXX_DIR_CH_CC_CURRENT_2600MA 0xD | ||
151 | #define PM2XXX_DIR_CH_CC_CURRENT_2800MA 0xE | ||
152 | #define PM2XXX_DIR_CH_CC_CURRENT_3000MA 0xF | ||
153 | |||
154 | #define PM2XXX_CH_PRECH_CURRENT_MASK 0x30 | ||
155 | #define PM2XXX_CH_PRECH_CURRENT_25MA (0x0<<4) | ||
156 | #define PM2XXX_CH_PRECH_CURRENT_50MA (0x1<<4) | ||
157 | #define PM2XXX_CH_PRECH_CURRENT_75MA (0x2<<4) | ||
158 | #define PM2XXX_CH_PRECH_CURRENT_100MA (0x3<<4) | ||
159 | |||
160 | #define PM2XXX_CH_EOC_CURRENT_MASK 0xC0 | ||
161 | #define PM2XXX_CH_EOC_CURRENT_100MA (0x0<<6) | ||
162 | #define PM2XXX_CH_EOC_CURRENT_150MA (0x1<<6) | ||
163 | #define PM2XXX_CH_EOC_CURRENT_300MA (0x2<<6) | ||
164 | #define PM2XXX_CH_EOC_CURRENT_400MA (0x3<<6) | ||
165 | |||
166 | /* control Reg 7 */ | ||
167 | #define PM2XXX_CH_PRECH_VOL_2_5 0x0 | ||
168 | #define PM2XXX_CH_PRECH_VOL_2_7 0x1 | ||
169 | #define PM2XXX_CH_PRECH_VOL_2_9 0x2 | ||
170 | #define PM2XXX_CH_PRECH_VOL_3_1 0x3 | ||
171 | |||
172 | #define PM2XXX_CH_VRESUME_VOL_3_2 (0x0<<2) | ||
173 | #define PM2XXX_CH_VRESUME_VOL_3_4 (0x1<<2) | ||
174 | #define PM2XXX_CH_VRESUME_VOL_3_6 (0x2<<2) | ||
175 | #define PM2XXX_CH_VRESUME_VOL_3_8 (0x3<<2) | ||
176 | |||
177 | /* control Reg 8 */ | ||
178 | #define PM2XXX_CH_VOLT_MASK 0x3F | ||
179 | #define PM2XXX_CH_VOLT_3_5 0x0 | ||
180 | #define PM2XXX_CH_VOLT_3_5225 0x1 | ||
181 | #define PM2XXX_CH_VOLT_3_6 0x4 | ||
182 | #define PM2XXX_CH_VOLT_3_7 0x8 | ||
183 | #define PM2XXX_CH_VOLT_4_0 0x14 | ||
184 | #define PM2XXX_CH_VOLT_4_175 0x1B | ||
185 | #define PM2XXX_CH_VOLT_4_2 0x1C | ||
186 | #define PM2XXX_CH_VOLT_4_275 0x1F | ||
187 | #define PM2XXX_CH_VOLT_4_3 0x20 | ||
188 | |||
189 | /*NTC control register 1*/ | ||
190 | #define PM2XXX_BTEMP_HIGH_TH_45 0x0 | ||
191 | #define PM2XXX_BTEMP_HIGH_TH_50 0x1 | ||
192 | #define PM2XXX_BTEMP_HIGH_TH_55 0x2 | ||
193 | #define PM2XXX_BTEMP_HIGH_TH_60 0x3 | ||
194 | #define PM2XXX_BTEMP_HIGH_TH_65 0x4 | ||
195 | |||
196 | #define PM2XXX_BTEMP_LOW_TH_N5 (0x0<<3) | ||
197 | #define PM2XXX_BTEMP_LOW_TH_0 (0x1<<3) | ||
198 | #define PM2XXX_BTEMP_LOW_TH_5 (0x2<<3) | ||
199 | #define PM2XXX_BTEMP_LOW_TH_10 (0x3<<3) | ||
200 | |||
201 | /*NTC control register 2*/ | ||
202 | #define PM2XXX_NTC_BETA_COEFF_3477 0x0 | ||
203 | #define PM2XXX_NTC_BETA_COEFF_3964 0x1 | ||
204 | |||
205 | #define PM2XXX_NTC_RES_10K (0x0<<2) | ||
206 | #define PM2XXX_NTC_RES_47K (0x1<<2) | ||
207 | #define PM2XXX_NTC_RES_100K (0x2<<2) | ||
208 | #define PM2XXX_NTC_RES_NO_NTC (0x3<<2) | ||
209 | |||
210 | /* control Reg 9 */ | ||
211 | #define PM2XXX_CH_CC_MODEDROP_EN 1 | ||
212 | #define PM2XXX_CH_CC_MODEDROP_DIS 0 | ||
213 | |||
214 | #define PM2XXX_CH_CC_REDUCED_CURRENT_100MA (0x0<<1) | ||
215 | #define PM2XXX_CH_CC_REDUCED_CURRENT_200MA (0x1<<1) | ||
216 | #define PM2XXX_CH_CC_REDUCED_CURRENT_400MA (0x2<<1) | ||
217 | #define PM2XXX_CH_CC_REDUCED_CURRENT_IDENT (0x3<<1) | ||
218 | |||
219 | #define PM2XXX_CHARCHING_INFO_DIS (0<<3) | ||
220 | #define PM2XXX_CHARCHING_INFO_EN (1<<3) | ||
221 | |||
222 | #define PM2XXX_CH_150MV_DROP_300MV (0<<4) | ||
223 | #define PM2XXX_CH_150MV_DROP_150MV (1<<4) | ||
224 | |||
225 | |||
226 | /* charger status register */ | ||
227 | #define PM2XXX_CHG_STATUS_OFF 0x0 | ||
228 | #define PM2XXX_CHG_STATUS_ON 0x1 | ||
229 | #define PM2XXX_CHG_STATUS_FULL 0x2 | ||
230 | #define PM2XXX_CHG_STATUS_ERR 0x3 | ||
231 | #define PM2XXX_CHG_STATUS_WAIT 0x4 | ||
232 | #define PM2XXX_CHG_STATUS_NOBAT 0x5 | ||
233 | |||
234 | /* Input charger voltage VPWR2 */ | ||
235 | #define PM2XXX_VPWR2_OVV_6_0 0x0 | ||
236 | #define PM2XXX_VPWR2_OVV_6_3 0x1 | ||
237 | #define PM2XXX_VPWR2_OVV_10 0x2 | ||
238 | #define PM2XXX_VPWR2_OVV_NONE 0x3 | ||
239 | |||
240 | /* Input charger voltage VPWR1 */ | ||
241 | #define PM2XXX_VPWR1_OVV_6_0 0x0 | ||
242 | #define PM2XXX_VPWR1_OVV_6_3 0x1 | ||
243 | #define PM2XXX_VPWR1_OVV_10 0x2 | ||
244 | #define PM2XXX_VPWR1_OVV_NONE 0x3 | ||
245 | |||
246 | /* Battery low level comparator control register */ | ||
247 | #define PM2XXX_VBAT_LOW_MONITORING_DIS 0x0 | ||
248 | #define PM2XXX_VBAT_LOW_MONITORING_ENA 0x1 | ||
249 | |||
250 | /* Battery low level value control register */ | ||
251 | #define PM2XXX_VBAT_LOW_LEVEL_2_3 0x0 | ||
252 | #define PM2XXX_VBAT_LOW_LEVEL_2_4 0x1 | ||
253 | #define PM2XXX_VBAT_LOW_LEVEL_2_5 0x2 | ||
254 | #define PM2XXX_VBAT_LOW_LEVEL_2_6 0x3 | ||
255 | #define PM2XXX_VBAT_LOW_LEVEL_2_7 0x4 | ||
256 | #define PM2XXX_VBAT_LOW_LEVEL_2_8 0x5 | ||
257 | #define PM2XXX_VBAT_LOW_LEVEL_2_9 0x6 | ||
258 | #define PM2XXX_VBAT_LOW_LEVEL_3_0 0x7 | ||
259 | #define PM2XXX_VBAT_LOW_LEVEL_3_1 0x8 | ||
260 | #define PM2XXX_VBAT_LOW_LEVEL_3_2 0x9 | ||
261 | #define PM2XXX_VBAT_LOW_LEVEL_3_3 0xA | ||
262 | #define PM2XXX_VBAT_LOW_LEVEL_3_4 0xB | ||
263 | #define PM2XXX_VBAT_LOW_LEVEL_3_5 0xC | ||
264 | #define PM2XXX_VBAT_LOW_LEVEL_3_6 0xD | ||
265 | #define PM2XXX_VBAT_LOW_LEVEL_3_7 0xE | ||
266 | #define PM2XXX_VBAT_LOW_LEVEL_3_8 0xF | ||
267 | #define PM2XXX_VBAT_LOW_LEVEL_3_9 0x10 | ||
268 | #define PM2XXX_VBAT_LOW_LEVEL_4_0 0x11 | ||
269 | #define PM2XXX_VBAT_LOW_LEVEL_4_1 0x12 | ||
270 | #define PM2XXX_VBAT_LOW_LEVEL_4_2 0x13 | ||
271 | |||
272 | /* SW CTRL */ | ||
273 | #define PM2XXX_SWCTRL_HW 0x0 | ||
274 | #define PM2XXX_SWCTRL_SW 0x1 | ||
275 | |||
276 | |||
277 | /* LED Driver Control */ | ||
278 | #define PM2XXX_LED_CURRENT_MASK 0x0C | ||
279 | #define PM2XXX_LED_CURRENT_2_5MA (0X0<<2) | ||
280 | #define PM2XXX_LED_CURRENT_1MA (0X1<<2) | ||
281 | #define PM2XXX_LED_CURRENT_5MA (0X2<<2) | ||
282 | #define PM2XXX_LED_CURRENT_10MA (0X3<<2) | ||
283 | |||
284 | #define PM2XXX_LED_SELECT_MASK 0x02 | ||
285 | #define PM2XXX_LED_SELECT_EN (0X0<<1) | ||
286 | #define PM2XXX_LED_SELECT_DIS (0X1<<1) | ||
287 | |||
288 | #define PM2XXX_ANTI_OVERSHOOT_MASK 0x01 | ||
289 | #define PM2XXX_ANTI_OVERSHOOT_DIS 0X0 | ||
290 | #define PM2XXX_ANTI_OVERSHOOT_EN 0X1 | ||
291 | |||
292 | enum pm2xxx_reg_int1 { | ||
293 | PM2XXX_INT1_ITVBATDISCONNECT = 0x02, | ||
294 | PM2XXX_INT1_ITVBATLOWR = 0x04, | ||
295 | PM2XXX_INT1_ITVBATLOWF = 0x08, | ||
296 | }; | ||
297 | |||
298 | enum pm2xxx_mask_reg_int1 { | ||
299 | PM2XXX_INT1_M_ITVBATDISCONNECT = 0x02, | ||
300 | PM2XXX_INT1_M_ITVBATLOWR = 0x04, | ||
301 | PM2XXX_INT1_M_ITVBATLOWF = 0x08, | ||
302 | }; | ||
303 | |||
304 | enum pm2xxx_source_reg_int1 { | ||
305 | PM2XXX_INT1_S_ITVBATDISCONNECT = 0x02, | ||
306 | PM2XXX_INT1_S_ITVBATLOWR = 0x04, | ||
307 | PM2XXX_INT1_S_ITVBATLOWF = 0x08, | ||
308 | }; | ||
309 | |||
310 | enum pm2xxx_reg_int2 { | ||
311 | PM2XXX_INT2_ITVPWR2PLUG = 0x01, | ||
312 | PM2XXX_INT2_ITVPWR2UNPLUG = 0x02, | ||
313 | PM2XXX_INT2_ITVPWR1PLUG = 0x04, | ||
314 | PM2XXX_INT2_ITVPWR1UNPLUG = 0x08, | ||
315 | }; | ||
316 | |||
317 | enum pm2xxx_mask_reg_int2 { | ||
318 | PM2XXX_INT2_M_ITVPWR2PLUG = 0x01, | ||
319 | PM2XXX_INT2_M_ITVPWR2UNPLUG = 0x02, | ||
320 | PM2XXX_INT2_M_ITVPWR1PLUG = 0x04, | ||
321 | PM2XXX_INT2_M_ITVPWR1UNPLUG = 0x08, | ||
322 | }; | ||
323 | |||
324 | enum pm2xxx_source_reg_int2 { | ||
325 | PM2XXX_INT2_S_ITVPWR2PLUG = 0x03, | ||
326 | PM2XXX_INT2_S_ITVPWR1PLUG = 0x0c, | ||
327 | }; | ||
328 | |||
329 | enum pm2xxx_reg_int3 { | ||
330 | PM2XXX_INT3_ITCHPRECHARGEWD = 0x01, | ||
331 | PM2XXX_INT3_ITCHCCWD = 0x02, | ||
332 | PM2XXX_INT3_ITCHCVWD = 0x04, | ||
333 | PM2XXX_INT3_ITAUTOTIMEOUTWD = 0x08, | ||
334 | }; | ||
335 | |||
336 | enum pm2xxx_mask_reg_int3 { | ||
337 | PM2XXX_INT3_M_ITCHPRECHARGEWD = 0x01, | ||
338 | PM2XXX_INT3_M_ITCHCCWD = 0x02, | ||
339 | PM2XXX_INT3_M_ITCHCVWD = 0x04, | ||
340 | PM2XXX_INT3_M_ITAUTOTIMEOUTWD = 0x08, | ||
341 | }; | ||
342 | |||
343 | enum pm2xxx_source_reg_int3 { | ||
344 | PM2XXX_INT3_S_ITCHPRECHARGEWD = 0x01, | ||
345 | PM2XXX_INT3_S_ITCHCCWD = 0x02, | ||
346 | PM2XXX_INT3_S_ITCHCVWD = 0x04, | ||
347 | PM2XXX_INT3_S_ITAUTOTIMEOUTWD = 0x08, | ||
348 | }; | ||
349 | |||
350 | enum pm2xxx_reg_int4 { | ||
351 | PM2XXX_INT4_ITBATTEMPCOLD = 0x01, | ||
352 | PM2XXX_INT4_ITBATTEMPHOT = 0x02, | ||
353 | PM2XXX_INT4_ITVPWR2OVV = 0x04, | ||
354 | PM2XXX_INT4_ITVPWR1OVV = 0x08, | ||
355 | PM2XXX_INT4_ITCHARGINGON = 0x10, | ||
356 | PM2XXX_INT4_ITVRESUME = 0x20, | ||
357 | PM2XXX_INT4_ITBATTFULL = 0x40, | ||
358 | PM2XXX_INT4_ITCVPHASE = 0x80, | ||
359 | }; | ||
360 | |||
361 | enum pm2xxx_mask_reg_int4 { | ||
362 | PM2XXX_INT4_M_ITBATTEMPCOLD = 0x01, | ||
363 | PM2XXX_INT4_M_ITBATTEMPHOT = 0x02, | ||
364 | PM2XXX_INT4_M_ITVPWR2OVV = 0x04, | ||
365 | PM2XXX_INT4_M_ITVPWR1OVV = 0x08, | ||
366 | PM2XXX_INT4_M_ITCHARGINGON = 0x10, | ||
367 | PM2XXX_INT4_M_ITVRESUME = 0x20, | ||
368 | PM2XXX_INT4_M_ITBATTFULL = 0x40, | ||
369 | PM2XXX_INT4_M_ITCVPHASE = 0x80, | ||
370 | }; | ||
371 | |||
372 | enum pm2xxx_source_reg_int4 { | ||
373 | PM2XXX_INT4_S_ITBATTEMPCOLD = 0x01, | ||
374 | PM2XXX_INT4_S_ITBATTEMPHOT = 0x02, | ||
375 | PM2XXX_INT4_S_ITVPWR2OVV = 0x04, | ||
376 | PM2XXX_INT4_S_ITVPWR1OVV = 0x08, | ||
377 | PM2XXX_INT4_S_ITCHARGINGON = 0x10, | ||
378 | PM2XXX_INT4_S_ITVRESUME = 0x20, | ||
379 | PM2XXX_INT4_S_ITBATTFULL = 0x40, | ||
380 | PM2XXX_INT4_S_ITCVPHASE = 0x80, | ||
381 | }; | ||
382 | |||
383 | enum pm2xxx_reg_int5 { | ||
384 | PM2XXX_INT5_ITTHERMALSHUTDOWNRISE = 0x01, | ||
385 | PM2XXX_INT5_ITTHERMALSHUTDOWNFALL = 0x02, | ||
386 | PM2XXX_INT5_ITTHERMALWARNINGRISE = 0x04, | ||
387 | PM2XXX_INT5_ITTHERMALWARNINGFALL = 0x08, | ||
388 | PM2XXX_INT5_ITVSYSTEMOVV = 0x10, | ||
389 | }; | ||
390 | |||
391 | enum pm2xxx_mask_reg_int5 { | ||
392 | PM2XXX_INT5_M_ITTHERMALSHUTDOWNRISE = 0x01, | ||
393 | PM2XXX_INT5_M_ITTHERMALSHUTDOWNFALL = 0x02, | ||
394 | PM2XXX_INT5_M_ITTHERMALWARNINGRISE = 0x04, | ||
395 | PM2XXX_INT5_M_ITTHERMALWARNINGFALL = 0x08, | ||
396 | PM2XXX_INT5_M_ITVSYSTEMOVV = 0x10, | ||
397 | }; | ||
398 | |||
399 | enum pm2xxx_source_reg_int5 { | ||
400 | PM2XXX_INT5_S_ITTHERMALSHUTDOWNRISE = 0x01, | ||
401 | PM2XXX_INT5_S_ITTHERMALSHUTDOWNFALL = 0x02, | ||
402 | PM2XXX_INT5_S_ITTHERMALWARNINGRISE = 0x04, | ||
403 | PM2XXX_INT5_S_ITTHERMALWARNINGFALL = 0x08, | ||
404 | PM2XXX_INT5_S_ITVSYSTEMOVV = 0x10, | ||
405 | }; | ||
406 | |||
407 | enum pm2xxx_reg_int6 { | ||
408 | PM2XXX_INT6_ITVPWR2DROP = 0x01, | ||
409 | PM2XXX_INT6_ITVPWR1DROP = 0x02, | ||
410 | PM2XXX_INT6_ITVPWR2VALIDRISE = 0x04, | ||
411 | PM2XXX_INT6_ITVPWR2VALIDFALL = 0x08, | ||
412 | PM2XXX_INT6_ITVPWR1VALIDRISE = 0x10, | ||
413 | PM2XXX_INT6_ITVPWR1VALIDFALL = 0x20, | ||
414 | }; | ||
415 | |||
416 | enum pm2xxx_mask_reg_int6 { | ||
417 | PM2XXX_INT6_M_ITVPWR2DROP = 0x01, | ||
418 | PM2XXX_INT6_M_ITVPWR1DROP = 0x02, | ||
419 | PM2XXX_INT6_M_ITVPWR2VALIDRISE = 0x04, | ||
420 | PM2XXX_INT6_M_ITVPWR2VALIDFALL = 0x08, | ||
421 | PM2XXX_INT6_M_ITVPWR1VALIDRISE = 0x10, | ||
422 | PM2XXX_INT6_M_ITVPWR1VALIDFALL = 0x20, | ||
423 | }; | ||
424 | |||
425 | enum pm2xxx_source_reg_int6 { | ||
426 | PM2XXX_INT6_S_ITVPWR2DROP = 0x01, | ||
427 | PM2XXX_INT6_S_ITVPWR1DROP = 0x02, | ||
428 | PM2XXX_INT6_S_ITVPWR2VALIDRISE = 0x04, | ||
429 | PM2XXX_INT6_S_ITVPWR2VALIDFALL = 0x08, | ||
430 | PM2XXX_INT6_S_ITVPWR1VALIDRISE = 0x10, | ||
431 | PM2XXX_INT6_S_ITVPWR1VALIDFALL = 0x20, | ||
432 | }; | ||
433 | |||
434 | struct pm2xxx_charger_info { | ||
435 | int charger_connected; | ||
436 | int charger_online; | ||
437 | int charger_voltage; | ||
438 | int cv_active; | ||
439 | bool wd_expired; | ||
440 | }; | ||
441 | |||
442 | struct pm2xxx_charger_event_flags { | ||
443 | bool mainextchnotok; | ||
444 | bool main_thermal_prot; | ||
445 | bool ovv; | ||
446 | bool chgwdexp; | ||
447 | }; | ||
448 | |||
449 | struct pm2xxx_config { | ||
450 | struct i2c_client *pm2xxx_i2c; | ||
451 | struct i2c_device_id *pm2xxx_id; | ||
452 | }; | ||
453 | |||
454 | struct pm2xxx_irq { | ||
455 | char *name; | ||
456 | irqreturn_t (*isr)(int irq, void *data); | ||
457 | }; | ||
458 | |||
459 | struct pm2xxx_charger { | ||
460 | struct device *dev; | ||
461 | u8 chip_id; | ||
462 | bool vddadc_en_ac; | ||
463 | struct pm2xxx_config config; | ||
464 | bool ac_conn; | ||
465 | unsigned int gpio_irq; | ||
466 | int vbat; | ||
467 | int old_vbat; | ||
468 | int failure_case; | ||
469 | int failure_input_ovv; | ||
470 | u8 pm2_int[6]; | ||
471 | struct ab8500_gpadc *gpadc; | ||
472 | struct regulator *regu; | ||
473 | struct pm2xxx_bm_data *bat; | ||
474 | struct mutex lock; | ||
475 | struct ab8500 *parent; | ||
476 | struct pm2xxx_charger_info ac; | ||
477 | struct pm2xxx_charger_platform_data *pdata; | ||
478 | struct workqueue_struct *charger_wq; | ||
479 | struct delayed_work check_vbat_work; | ||
480 | struct work_struct ac_work; | ||
481 | struct work_struct check_main_thermal_prot_work; | ||
482 | struct ux500_charger ac_chg; | ||
483 | struct pm2xxx_charger_event_flags flags; | ||
484 | }; | ||
485 | |||
486 | #endif /* PM2301_CHARGER_H */ | ||