1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
|
/*
* max8998.h - Voltage regulator driver for the Maxim 8998
*
* Copyright (C) 2009-2010 Samsung Electrnoics
* Kyungmin Park <kyungmin.park@samsung.com>
* Marek Szyprowski <m.szyprowski@samsung.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef __LINUX_MFD_MAX8998_PRIV_H
#define __LINUX_MFD_MAX8998_PRIV_H
#define MAX8998_NUM_IRQ_REGS 4
/* MAX 8998 registers */
enum {
MAX8998_REG_IRQ1,
MAX8998_REG_IRQ2,
MAX8998_REG_IRQ3,
MAX8998_REG_IRQ4,
MAX8998_REG_IRQM1,
MAX8998_REG_IRQM2,
MAX8998_REG_IRQM3,
MAX8998_REG_IRQM4,
MAX8998_REG_STATUS1,
MAX8998_REG_STATUS2,
MAX8998_REG_STATUSM1,
MAX8998_REG_STATUSM2,
MAX8998_REG_CHGR1,
MAX8998_REG_CHGR2,
MAX8998_REG_LDO_ACTIVE_DISCHARGE1,
MAX8998_REG_LDO_ACTIVE_DISCHARGE2,
MAX8998_REG_BUCK_ACTIVE_DISCHARGE3,
MAX8998_REG_ONOFF1,
MAX8998_REG_ONOFF2,
MAX8998_REG_ONOFF3,
MAX8998_REG_ONOFF4,
#ifdef CONFIG_MACH_ARIES
MAX8998_REG_BUCK1_VOLTAGE1,
MAX8998_REG_BUCK1_VOLTAGE2,
MAX8998_REG_BUCK1_VOLTAGE3,
MAX8998_REG_BUCK1_VOLTAGE4,
MAX8998_REG_BUCK2_VOLTAGE1,
MAX8998_REG_BUCK2_VOLTAGE2,
#else // CONFIG_MACH_P1
MAX8998_REG_BUCK1_DVSARM1,
MAX8998_REG_BUCK1_DVSARM2,
MAX8998_REG_BUCK1_DVSARM3,
MAX8998_REG_BUCK1_DVSARM4,
MAX8998_REG_BUCK2_DVSINT1,
MAX8998_REG_BUCK2_DVSINT2,
#endif
MAX8998_REG_BUCK3,
MAX8998_REG_BUCK4,
MAX8998_REG_LDO2_LDO3,
MAX8998_REG_LDO4,
MAX8998_REG_LDO5,
MAX8998_REG_LDO6,
MAX8998_REG_LDO7,
MAX8998_REG_LDO8_LDO9,
MAX8998_REG_LDO10_LDO11,
MAX8998_REG_LDO12,
MAX8998_REG_LDO13,
MAX8998_REG_LDO14,
MAX8998_REG_LDO15,
MAX8998_REG_LDO16,
MAX8998_REG_LDO17,
MAX8998_REG_BKCHR,
MAX8998_REG_LBCNFG1,
MAX8998_REG_LBCNFG2,
};
/* IRQ definitions */
enum {
MAX8998_IRQ_DCINF,
MAX8998_IRQ_DCINR,
MAX8998_IRQ_JIGF,
MAX8998_IRQ_JIGR,
MAX8998_IRQ_PWRONF,
MAX8998_IRQ_PWRONR,
MAX8998_IRQ_WTSREVNT,
MAX8998_IRQ_SMPLEVNT,
MAX8998_IRQ_ALARM1,
MAX8998_IRQ_ALARM0,
MAX8998_IRQ_ONKEY1S,
MAX8998_IRQ_TOPOFFR,
MAX8998_IRQ_DCINOVPR,
MAX8998_IRQ_CHGRSTF,
MAX8998_IRQ_DONER,
MAX8998_IRQ_CHGFAULT,
MAX8998_IRQ_LOBAT1,
MAX8998_IRQ_LOBAT2,
MAX8998_IRQ_NR,
};
/* MAX8998 various variants */
enum {
TYPE_MAX8998 = 0, /* Default */
TYPE_LP3974, /* National version of MAX8998 */
TYPE_LP3979, /* Added AVS */
};
#define MAX8998_IRQ_DCINF_MASK (1 << 2)
#define MAX8998_IRQ_DCINR_MASK (1 << 3)
#define MAX8998_IRQ_JIGF_MASK (1 << 4)
#define MAX8998_IRQ_JIGR_MASK (1 << 5)
#define MAX8998_IRQ_PWRONF_MASK (1 << 6)
#define MAX8998_IRQ_PWRONR_MASK (1 << 7)
#define MAX8998_IRQ_WTSREVNT_MASK (1 << 0)
#define MAX8998_IRQ_SMPLEVNT_MASK (1 << 1)
#define MAX8998_IRQ_ALARM1_MASK (1 << 2)
#define MAX8998_IRQ_ALARM0_MASK (1 << 3)
#define MAX8998_IRQ_ONKEY1S_MASK (1 << 0)
#define MAX8998_IRQ_TOPOFFR_MASK (1 << 2)
#define MAX8998_IRQ_DCINOVPR_MASK (1 << 3)
#define MAX8998_IRQ_CHGRSTF_MASK (1 << 4)
#define MAX8998_IRQ_DONER_MASK (1 << 5)
#define MAX8998_IRQ_CHGFAULT_MASK (1 << 7)
#define MAX8998_IRQ_LOBAT1_MASK (1 << 0)
#define MAX8998_IRQ_LOBAT2_MASK (1 << 1)
#define MAX8998_ENRAMP (1 << 4)
/* IRQ1 */
#define MAX8998_SHIFT_PWRONR 7
#define MAX8998_SHIFT_PWRONF 6
#define MAX8998_SHIFT_JIGR 5
#define MAX8998_SHIFT_JIGF 4
#define MAX8998_SHIFT_DCINR 3
#define MAX8998_SHIFT_DCINF 2
#define MAX8998_MASK_PWRONR (0x1 << MAX8998_SHIFT_PWRONR)
#define MAX8998_MASK_PWRONF (0x1 << MAX8998_SHIFT_PWRONF)
#define MAX8998_MASK_JIGR (0x1 << MAX8998_SHIFT_JIGR)
#define MAX8998_MASK_JIGF (0x1 << MAX8998_SHIFT_JIGF)
#define MAX8998_MASK_DCINR (0x1 << MAX8998_SHIFT_DCINR)
#define MAX8998_MASK_DCINF (0x1 << MAX8998_SHIFT_DCINF)
/* STATUS1 */
#define MAX8998_SHIFT_ENDKEY 7
#define MAX8998_SHIFT_JIGON 6
#define MAX8998_SHIFT_ALARM0 5
#define MAX8998_SHIFT_ALARM1 4
#define MAX8998_SHIFT_SMPL 3
#define MAX8998_SHIFT_WTSR 2
#define MAX8998_SHIFT_LOWBAT2 1
#define MAX8998_SHIFT_LOWBAT1 0
#define MAX8998_MASK_ENDKEY (0x1 << MAX8998_SHIFT_ENDKEY)
#define MAX8998_MASK_JIGON (0x1 << MAX8998_SHIFT_JIGON)
#define MAX8998_MASK_ALARM0 (0x1 << MAX8998_SHIFT_ALARM0)
#define MAX8998_MASK_ALARM1 (0x1 << MAX8998_SHIFT_ALARM1)
#define MAX8998_MASK_SMPL (0x1 << MAX8998_SHIFT_SMPL)
#define MAX8998_MASK_WTSR (0x1 << MAX8998_SHIFT_WTSR)
#define MAX8998_MASK_LOWBAT2 (0x1 << MAX8998_SHIFT_LOWBAT2)
#define MAX8998_MASK_LOWBAT1 (0x1 << MAX8998_SHIFT_LOWBAT1)
/* STATUS2 */
#define MAX8998_SHIFT_CHGDONE 6
#define MAX8998_SHIFT_VDCIN 5
#define MAX8998_SHIFT_DETBAT 4
#define MAX8998_SHIFT_CHGON 3
#define MAX8998_SHIFT_FCHG 2
#define MAX8998_SHIFT_PQL 1
#define MAX8998_MASK_CHGDONE (0x1 << MAX8998_SHIFT_CHGDONE)
#define MAX8998_MASK_VDCIN (0x1 << MAX8998_SHIFT_VDCIN)
#define MAX8998_MASK_DETBAT (0x1 << MAX8998_SHIFT_DETBAT)
#define MAX8998_MASK_CHGON (0x1 << MAX8998_SHIFT_CHGON)
#define MAX8998_MASK_FCHG (0x1 << MAX8998_SHIFT_FCHG)
#define MAX8998_MASK_PQL (0x1 << MAX8998_SHIFT_PQL)
/* CHGR1 */
#define MAX8998_SHIFT_TOPOFF 5
#define MAX8998_SHIFT_RSTR 3
#define MAX8998_SHIFT_ICHG 0
#define MAX8998_MASK_TOPOFF (0x7 << MAX8998_SHIFT_TOPOFF)
#define MAX8998_MASK_RSTR (0x3 << MAX8998_SHIFT_RSTR)
#define MAX8998_MASK_ICHG (0x7 << MAX8998_SHIFT_ICHG)
/* CHGR2 */
#define MAX8998_SHIFT_ESAFEOUT 6
#define MAX8998_SHIFT_FT 4
#define MAX8998_SHIFT_BATTSL 3
#define MAX8998_SHIFT_TMP 1
#define MAX8998_SHIFT_CHGEN 0
#define MAX8998_MASK_ESAFEOUT (0x3 << MAX8998_SHIFT_ESAFEOUT)
#define MAX8998_MASK_FT (0x3 << MAX8998_SHIFT_FT)
#define MAX8998_MASK_BATTSL (0x1 << MAX8998_SHIFT_BATTSL)
#define MAX8998_MASK_TMP (0x3 << MAX8998_SHIFT_TMP)
#define MAX8998_MASK_CHGEN (0x1 << MAX8998_SHIFT_CHGEN)
/* ONOFF1 */
#define MAX8998_SHIFT_EN1 7
#define MAX8998_SHIFT_EN2 6
#define MAX8998_SHIFT_EN3 5
#define MAX8998_SHIFT_EN4 4
#define MAX8998_SHIFT_ELDO2 3
#define MAX8998_SHIFT_ELDO3 2
#define MAX8998_SHIFT_ELDO4 1
#define MAX8998_SHIFT_ELDO5 0
#define MAX8998_MASK_EN1 (0x1 << MAX8998_SHIFT_EN1)
#define MAX8998_MASK_EN2 (0x1 << MAX8998_SHIFT_EN2)
#define MAX8998_MASK_EN3 (0x1 << MAX8998_SHIFT_EN3)
#define MAX8998_MASK_EN4 (0x1 << MAX8998_SHIFT_EN4)
#define MAX8998_MASK_ELDO2 (0x1 << MAX8998_SHIFT_ELDO2)
#define MAX8998_MASK_ELDO3 (0x1 << MAX8998_SHIFT_ELDO3)
#define MAX8998_MASK_ELDO4 (0x1 << MAX8998_SHIFT_ELDO4)
#define MAX8998_MASK_ELDO5 (0x1 << MAX8998_SHIFT_ELDO5)
/* ONOFF2 */
#define MAX8998_SHIFT_ELDO6 7
#define MAX8998_SHIFT_ELDO7 6
#define MAX8998_SHIFT_ELDO8 5
#define MAX8998_SHIFT_ELDO9 4
#define MAX8998_SHIFT_ELDO10 3
#define MAX8998_SHIFT_ELDO11 2
#define MAX8998_SHIFT_ELDO12 1
#define MAX8998_SHIFT_ELDO13 0
#define MAX8998_MASK_ELDO6 (0x1 << MAX8998_SHIFT_ELDO6)
#define MAX8998_MASK_ELDO7 (0x1 << MAX8998_SHIFT_ELDO7)
#define MAX8998_MASK_ELDO8 (0x1 << MAX8998_SHIFT_ELDO8)
#define MAX8998_MASK_ELDO9 (0x1 << MAX8998_SHIFT_ELDO9)
#define MAX8998_MASK_ELDO10 (0x1 << MAX8998_SHIFT_ELDO10)
#define MAX8998_MASK_ELDO11 (0x1 << MAX8998_SHIFT_ELDO11)
#define MAX8998_MASK_ELDO12 (0x1 << MAX8998_SHIFT_ELDO12)
#define MAX8998_MASK_ELDO13 (0x1 << MAX8998_SHIFT_ELDO13)
/* ONOFF3 */
#define MAX8998_SHIFT_ELDO14 7
#define MAX8998_SHIFT_ELDO15 6
#define MAX8998_SHIFT_ELDO16 5
#define MAX8998_SHIFT_ELDO17 4
#define MAX8998_SHIFT_EPWRHOLD 3
#define MAX8998_SHIFT_ENBATTMON 2
#define MAX8998_SHIFT_ELBCNFG2 1
#define MAX8998_SHIFT_ELBCNFG1 0
#define MAX8998_MASK_ELDO14 (0x1 << MAX8998_SHIFT_ELDO14)
#define MAX8998_MASK_ELDO15 (0x1 << MAX8998_SHIFT_ELDO15)
#define MAX8998_MASK_ELDO16 (0x1 << MAX8998_SHIFT_ELDO16)
#define MAX8998_MASK_ELDO17 (0x1 << MAX8998_SHIFT_ELDO17)
#define MAX8998_MASK_EPWRHOLD (0x1 << MAX8998_SHIFT_EPWRHOLD)
#define MAX8998_MASK_ENBATTMON (0x1 << MAX8998_SHIFT_ENBATTMON)
#define MAX8998_MASK_ELBCNFG2 (0x1 << MAX8998_SHIFT_ELBCNFG2)
#define MAX8998_MASK_ELBCNFG1 (0x1 << MAX8998_SHIFT_ELBCNFG1)
/* ONOFF4 */
#define MAX8998_SHIFT_EN32KHZAP 7
#define MAX8998_SHIFT_EN32KHZCP 6
#define MAX8998_SHIFT_ENVICHG 5
#define MAX8998_SHIFT_ENRAMP 4
#define MAX8998_SHIFT_RAMP 0
#define MAX8998_MASK_EN32KHZAP (0x1 << MAX8998_SHIFT_EN32KHZAP)
#define MAX8998_MASK_EN32KHZCP (0x1 << MAX8998_SHIFT_EN32KHZCP)
#define MAX8998_MASK_ENVICHG (0x1 << MAX8998_SHIFT_ENVICHG)
#define MAX8998_MASK_ENRAMP (0x1 << MAX8998_SHIFT_ENRAMP)
#define MAX8998_MASK_RAMP (0xF << MAX8998_SHIFT_RAMP)
/**
* struct max8998_dev - max8998 master device for sub-drivers
* @dev: master device of the chip (can be used to access platform data)
* @i2c: i2c client private data for regulator
* @rtc: i2c client private data for rtc
* @dev_read(): chip register read function
* @dev_write(): chip register write function
* @dev_update(): chip register update function
* @iolock: mutex for serializing io access
* @irqlock: mutex for buslock
* @irq_base: base IRQ number for max8998, required for IRQs
* @irq: generic IRQ number for max8998
* @ono: power onoff IRQ number for max8998
* @irq_masks_cur: currently active value
* @irq_masks_cache: cached hardware value
* @type: indicate which max8998 "variant" is used
*/
struct max8998_dev {
struct device *dev;
struct i2c_client *i2c;
struct i2c_client *rtc;
#ifdef CONFIG_MACH_P1
int (*dev_read)(struct max8998_dev *max8998, u8 reg, u8 *dest);
int (*dev_write)(struct max8998_dev *max8998, u8 reg, u8 val);
int (*dev_update)(struct max8998_dev *max8998, u8 reg, u8 val, u8 mask);
#endif
struct mutex iolock;
struct mutex irqlock;
int irq_base;
int irq;
int ono;
u8 irq_masks_cur[MAX8998_NUM_IRQ_REGS];
u8 irq_masks_cache[MAX8998_NUM_IRQ_REGS];
#ifdef CONFIG_MACH_ARIES
int type;
bool wakeup;
#endif
};
int max8998_irq_init(struct max8998_dev *max8998);
void max8998_irq_exit(struct max8998_dev *max8998);
int max8998_irq_resume(struct max8998_dev *max8998);
extern int max8998_bulk_read(struct i2c_client *i2c, u8 reg, int count, u8 *buf);
#ifdef CONFIG_MACH_ARIES
extern int max8998_read_reg(struct i2c_client *i2c, u8 reg, u8 *dest);
extern int max8998_write_reg(struct i2c_client *i2c, u8 reg, u8 value);
extern int max8998_bulk_write(struct i2c_client *i2c, u8 reg, int count, u8 *buf);
extern int max8998_update_reg(struct i2c_client *i2c, u8 reg, u8 val, u8 mask);
#else // CONFIG_MACH_P1
static inline int max8998_read_reg(struct max8998_dev *max8998, u8 reg, u8 *value)
{
return max8998->dev_read(max8998, reg, value);
}
static inline int max8998_write_reg(struct max8998_dev *max8998, u8 reg, u8 value)
{
return max8998->dev_write(max8998, reg, value);
}
static inline int max8998_update_reg(struct max8998_dev *max8998, u8 reg, u8 value, u8 mask)
{
return max8998->dev_update(max8998, reg, value, mask);
}
#endif
#endif /* __LINUX_MFD_MAX8998_PRIV_H */
|