hc
2024-03-22 ac5f19e89dcbd5c7428fcc78a0d407c887564466
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
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
/* SPDX-License-Identifier: GPL-2.0-or-later */
/* Copyright (C) 2019 ROHM Semiconductors */
 
#ifndef __LINUX_MFD_BD71828_H__
#define __LINUX_MFD_BD71828_H__
 
#include <linux/mfd/rohm-generic.h>
#include <linux/mfd/rohm-shared.h>
 
/* Regulator IDs */
enum {
   BD71828_BUCK1,
   BD71828_BUCK2,
   BD71828_BUCK3,
   BD71828_BUCK4,
   BD71828_BUCK5,
   BD71828_BUCK6,
   BD71828_BUCK7,
   BD71828_LDO1,
   BD71828_LDO2,
   BD71828_LDO3,
   BD71828_LDO4,
   BD71828_LDO5,
   BD71828_LDO6,
   BD71828_LDO_SNVS,
   BD71828_REGULATOR_AMOUNT,
};
 
#define BD71828_BUCK1267_VOLTS        0x100
#define BD71828_BUCK3_VOLTS        0x20
#define BD71828_BUCK4_VOLTS        0x40
#define BD71828_BUCK5_VOLTS        0x20
#define BD71828_LDO_VOLTS        0x40
/* LDO6 is fixed 1.8V voltage */
#define BD71828_LDO_6_VOLTAGE        1800000
 
/* Registers and masks*/
 
/* MODE control */
#define BD71828_REG_PS_CTRL_1        0x04
#define BD71828_REG_PS_CTRL_2        0x05
#define BD71828_REG_PS_CTRL_3        0x06
 
//#define BD71828_REG_SWRESET        0x06
#define BD71828_MASK_RUN_LVL_CTRL    0x30
 
/* Regulator control masks */
 
#define BD71828_MASK_RAMP_DELAY        0x6
 
#define BD71828_MASK_RUN_EN        0x08
#define BD71828_MASK_SUSP_EN        0x04
#define BD71828_MASK_IDLE_EN        0x02
#define BD71828_MASK_LPSR_EN        0x01
 
#define BD71828_MASK_RUN0_EN        0x01
#define BD71828_MASK_RUN1_EN        0x02
#define BD71828_MASK_RUN2_EN        0x04
#define BD71828_MASK_RUN3_EN        0x08
 
#define BD71828_MASK_DVS_BUCK1_CTRL    0x10
#define BD71828_DVS_BUCK1_CTRL_I2C    0
#define BD71828_DVS_BUCK1_USE_RUNLVL    0x10
 
#define BD71828_MASK_DVS_BUCK2_CTRL    0x20
#define BD71828_DVS_BUCK2_CTRL_I2C    0
#define BD71828_DVS_BUCK2_USE_RUNLVL    0x20
 
#define BD71828_MASK_DVS_BUCK6_CTRL    0x40
#define BD71828_DVS_BUCK6_CTRL_I2C    0
#define BD71828_DVS_BUCK6_USE_RUNLVL    0x40
 
#define BD71828_MASK_DVS_BUCK7_CTRL    0x80
#define BD71828_DVS_BUCK7_CTRL_I2C    0
#define BD71828_DVS_BUCK7_USE_RUNLVL    0x80
 
#define BD71828_MASK_BUCK1267_VOLT    0xff
#define BD71828_MASK_BUCK3_VOLT        0x1f
#define BD71828_MASK_BUCK4_VOLT        0x3f
#define BD71828_MASK_BUCK5_VOLT        0x1f
#define BD71828_MASK_LDO_VOLT        0x3f
 
/* Regulator control regs */
#define BD71828_REG_BUCK1_EN        0x08
#define BD71828_REG_BUCK1_CTRL        0x09
#define BD71828_REG_BUCK1_MODE        0x0a
#define BD71828_REG_BUCK1_IDLE_VOLT    0x0b
#define BD71828_REG_BUCK1_SUSP_VOLT    0x0c
#define BD71828_REG_BUCK1_VOLT        0x0d
 
#define BD71828_REG_BUCK2_EN        0x12
#define BD71828_REG_BUCK2_CTRL        0x13
#define BD71828_REG_BUCK2_MODE        0x14
#define BD71828_REG_BUCK2_IDLE_VOLT    0x15
#define BD71828_REG_BUCK2_SUSP_VOLT    0x16
#define BD71828_REG_BUCK2_VOLT        0x17
 
#define BD71828_REG_BUCK3_EN        0x1c
#define BD71828_REG_BUCK3_MODE        0x1d
#define BD71828_REG_BUCK3_VOLT        0x1e
 
#define BD71828_REG_BUCK4_EN        0x1f
#define BD71828_REG_BUCK4_MODE        0x20
#define BD71828_REG_BUCK4_VOLT        0x21
 
#define BD71828_REG_BUCK5_EN        0x22
#define BD71828_REG_BUCK5_MODE        0x23
#define BD71828_REG_BUCK5_VOLT        0x24
 
#define BD71828_REG_BUCK6_EN        0x25
#define BD71828_REG_BUCK6_CTRL        0x26
#define BD71828_REG_BUCK6_MODE        0x27
#define BD71828_REG_BUCK6_IDLE_VOLT    0x28
#define BD71828_REG_BUCK6_SUSP_VOLT    0x29
#define BD71828_REG_BUCK6_VOLT        0x2a
 
#define BD71828_REG_BUCK7_EN        0x2f
#define BD71828_REG_BUCK7_CTRL        0x30
#define BD71828_REG_BUCK7_MODE        0x31
#define BD71828_REG_BUCK7_IDLE_VOLT    0x32
#define BD71828_REG_BUCK7_SUSP_VOLT    0x33
#define BD71828_REG_BUCK7_VOLT        0x34
 
#define BD71828_REG_LDO1_EN        0x39
#define BD71828_REG_LDO1_VOLT        0x3a
#define BD71828_REG_LDO2_EN        0x3b
#define BD71828_REG_LDO2_VOLT        0x3c
#define BD71828_REG_LDO3_EN        0x3d
#define BD71828_REG_LDO3_VOLT        0x3e
#define BD71828_REG_LDO4_EN        0x3f
#define BD71828_REG_LDO4_VOLT        0x40
#define BD71828_REG_LDO5_EN        0x41
#define BD71828_REG_LDO5_VOLT        0x43
#define BD71828_REG_LDO5_VOLT_OPT    0x42
#define BD71828_REG_LDO6_EN        0x44
//#define BD71828_REG_LDO6_VOLT        0x4
#define BD71828_REG_LDO7_EN        0x45
#define BD71828_REG_LDO7_VOLT        0x46
 
/* GPIO */
 
#define BD71828_GPIO_DRIVE_MASK        0x2
#define BD71828_GPIO_OPEN_DRAIN        0x0
#define BD71828_GPIO_PUSH_PULL        0x2
#define BD71828_GPIO_OUT_HI        0x1
#define BD71828_GPIO_OUT_LO        0x0
#define BD71828_GPIO_OUT_MASK        0x1
 
#define BD71828_REG_GPIO_CTRL1        0x47
#define BD71828_REG_GPIO_CTRL2        0x48
#define BD71828_REG_GPIO_CTRL3        0x49
#define BD71828_REG_IO_STAT        0xed
 
/* RTC */
#define BD71828_REG_RTC_SEC        0x4c
#define BD71828_REG_RTC_MINUTE        0x4d
#define BD71828_REG_RTC_HOUR        0x4e
#define BD71828_REG_RTC_WEEK        0x4f
#define BD71828_REG_RTC_DAY        0x50
#define BD71828_REG_RTC_MONTH        0x51
#define BD71828_REG_RTC_YEAR        0x52
 
#define BD71828_REG_RTC_ALM0_SEC    0x53
#define BD71828_REG_RTC_ALM_START    BD71828_REG_RTC_ALM0_SEC
#define BD71828_REG_RTC_ALM0_MINUTE    0x54
#define BD71828_REG_RTC_ALM0_HOUR    0x55
#define BD71828_REG_RTC_ALM0_WEEK    0x56
#define BD71828_REG_RTC_ALM0_DAY    0x57
#define BD71828_REG_RTC_ALM0_MONTH    0x58
#define BD71828_REG_RTC_ALM0_YEAR    0x59
#define BD71828_REG_RTC_ALM0_MASK    0x61
 
#define BD71828_REG_RTC_ALM1_SEC    0x5a
#define BD71828_REG_RTC_ALM1_MINUTE    0x5b
#define BD71828_REG_RTC_ALM1_HOUR    0x5c
#define BD71828_REG_RTC_ALM1_WEEK    0x5d
#define BD71828_REG_RTC_ALM1_DAY    0x5e
#define BD71828_REG_RTC_ALM1_MONTH    0x5f
#define BD71828_REG_RTC_ALM1_YEAR    0x60
#define BD71828_REG_RTC_ALM1_MASK    0x62
 
#define BD71828_REG_RTC_ALM2        0x63
#define BD71828_REG_RTC_START        BD71828_REG_RTC_SEC
 
/* Charger/Battey */
#define BD71828_REG_CHG_STATE        0x65
#define BD71828_REG_CHG_FULL        0xd2
 
/* LEDs */
#define BD71828_REG_LED_CTRL        0x4A
#define BD71828_MASK_LED_AMBER        0x80
#define BD71828_MASK_LED_GREEN        0x40
#define BD71828_LED_ON            0xff
#define BD71828_LED_OFF            0x0
 
/* IRQ registers */
#define BD71828_REG_INT_MASK_BUCK    0xd3
#define BD71828_REG_INT_MASK_DCIN1    0xd4
#define BD71828_REG_INT_MASK_DCIN2    0xd5
#define BD71828_REG_INT_MASK_VSYS    0xd6
#define BD71828_REG_INT_MASK_CHG    0xd7
#define BD71828_REG_INT_MASK_BAT    0xd8
#define BD71828_REG_INT_MASK_BAT_MON1    0xd9
#define BD71828_REG_INT_MASK_BAT_MON2    0xda
#define BD71828_REG_INT_MASK_BAT_MON3    0xdb
#define BD71828_REG_INT_MASK_BAT_MON4    0xdc
#define BD71828_REG_INT_MASK_TEMP    0xdd
#define BD71828_REG_INT_MASK_RTC    0xde
 
#define BD71828_REG_INT_MAIN        0xdf
#define BD71828_REG_INT_BUCK        0xe0
#define BD71828_REG_INT_DCIN1        0xe1
#define BD71828_REG_INT_DCIN2        0xe2
#define BD71828_REG_INT_VSYS        0xe3
#define BD71828_REG_INT_CHG        0xe4
#define BD71828_REG_INT_BAT        0xe5
#define BD71828_REG_INT_BAT_MON1    0xe6
#define BD71828_REG_INT_BAT_MON2    0xe7
#define BD71828_REG_INT_BAT_MON3    0xe8
#define BD71828_REG_INT_BAT_MON4    0xe9
#define BD71828_REG_INT_TEMP        0xea
#define BD71828_REG_INT_RTC        0xeb
#define BD71828_REG_INT_UPDATE        0xec
 
#define BD71828_MAX_REGISTER BD71828_REG_IO_STAT
 
/* Masks for main IRQ register bits */
enum {
   BD71828_INT_BUCK,
#define BD71828_INT_BUCK_MASK BIT(BD71828_INT_BUCK)
   BD71828_INT_DCIN,
#define BD71828_INT_DCIN_MASK BIT(BD71828_INT_DCIN)
   BD71828_INT_VSYS,
#define BD71828_INT_VSYS_MASK BIT(BD71828_INT_VSYS)
   BD71828_INT_CHG,
#define BD71828_INT_CHG_MASK BIT(BD71828_INT_CHG)
   BD71828_INT_BAT,
#define BD71828_INT_BAT_MASK BIT(BD71828_INT_BAT)
   BD71828_INT_BAT_MON,
#define BD71828_INT_BAT_MON_MASK BIT(BD71828_INT_BAT_MON)
   BD71828_INT_TEMP,
#define BD71828_INT_TEMP_MASK BIT(BD71828_INT_TEMP)
   BD71828_INT_RTC,
#define BD71828_INT_RTC_MASK BIT(BD71828_INT_RTC)
};
 
/* Interrupts */
enum {
   /* BUCK reg interrupts */
   BD71828_INT_BUCK1_OCP,
   BD71828_INT_BUCK2_OCP,
   BD71828_INT_BUCK3_OCP,
   BD71828_INT_BUCK4_OCP,
   BD71828_INT_BUCK5_OCP,
   BD71828_INT_BUCK6_OCP,
   BD71828_INT_BUCK7_OCP,
   BD71828_INT_PGFAULT,
   /* DCIN1 interrupts */
   BD71828_INT_DCIN_DET,
   BD71828_INT_DCIN_RMV,
   BD71828_INT_CLPS_OUT,
   BD71828_INT_CLPS_IN,
   /* DCIN2 interrupts */
   BD71828_INT_DCIN_MON_RES,
   BD71828_INT_DCIN_MON_DET,
   BD71828_INT_LONGPUSH,
   BD71828_INT_MIDPUSH,
   BD71828_INT_SHORTPUSH,
   BD71828_INT_PUSH,
   BD71828_INT_WDOG,
   BD71828_INT_SWRESET,
   /* Vsys */
   BD71828_INT_VSYS_UV_RES,
   BD71828_INT_VSYS_UV_DET,
   BD71828_INT_VSYS_LOW_RES,
   BD71828_INT_VSYS_LOW_DET,
   BD71828_INT_VSYS_HALL_IN,
   BD71828_INT_VSYS_HALL_TOGGLE,
   BD71828_INT_VSYS_MON_RES,
   BD71828_INT_VSYS_MON_DET,
   /* Charger */
   BD71828_INT_CHG_DCIN_ILIM,
   BD71828_INT_CHG_TOPOFF_TO_DONE,
   BD71828_INT_CHG_WDG_TEMP,
   BD71828_INT_CHG_WDG_TIME,
   BD71828_INT_CHG_RECHARGE_RES,
   BD71828_INT_CHG_RECHARGE_DET,
   BD71828_INT_CHG_RANGED_TEMP_TRANSITION,
   BD71828_INT_CHG_STATE_TRANSITION,
   /* Battery */
   BD71828_INT_BAT_TEMP_NORMAL,
   BD71828_INT_BAT_TEMP_ERANGE,
   BD71828_INT_BAT_TEMP_WARN,
   BD71828_INT_BAT_REMOVED,
   BD71828_INT_BAT_DETECTED,
   BD71828_INT_THERM_REMOVED,
   BD71828_INT_THERM_DETECTED,
   /* Battery Mon 1 */
   BD71828_INT_BAT_DEAD,
   BD71828_INT_BAT_SHORTC_RES,
   BD71828_INT_BAT_SHORTC_DET,
   BD71828_INT_BAT_LOW_VOLT_RES,
   BD71828_INT_BAT_LOW_VOLT_DET,
   BD71828_INT_BAT_OVER_VOLT_RES,
   BD71828_INT_BAT_OVER_VOLT_DET,
   /* Battery Mon 2 */
   BD71828_INT_BAT_MON_RES,
   BD71828_INT_BAT_MON_DET,
   /* Battery Mon 3 (Coulomb counter) */
   BD71828_INT_BAT_CC_MON1,
   BD71828_INT_BAT_CC_MON2,
   BD71828_INT_BAT_CC_MON3,
   /* Battery Mon 4 */
   BD71828_INT_BAT_OVER_CURR_1_RES,
   BD71828_INT_BAT_OVER_CURR_1_DET,
   BD71828_INT_BAT_OVER_CURR_2_RES,
   BD71828_INT_BAT_OVER_CURR_2_DET,
   BD71828_INT_BAT_OVER_CURR_3_RES,
   BD71828_INT_BAT_OVER_CURR_3_DET,
   /* Temperature */
   BD71828_INT_TEMP_BAT_LOW_RES,
   BD71828_INT_TEMP_BAT_LOW_DET,
   BD71828_INT_TEMP_BAT_HI_RES,
   BD71828_INT_TEMP_BAT_HI_DET,
   BD71828_INT_TEMP_CHIP_OVER_125_RES,
   BD71828_INT_TEMP_CHIP_OVER_125_DET,
   BD71828_INT_TEMP_CHIP_OVER_VF_DET,
   BD71828_INT_TEMP_CHIP_OVER_VF_RES,
   /* RTC Alarm */
   BD71828_INT_RTC0,
   BD71828_INT_RTC1,
   BD71828_INT_RTC2,
};
 
#define BD71828_INT_BUCK1_OCP_MASK            0x1
#define BD71828_INT_BUCK2_OCP_MASK            0x2
#define BD71828_INT_BUCK3_OCP_MASK            0x4
#define BD71828_INT_BUCK4_OCP_MASK            0x8
#define BD71828_INT_BUCK5_OCP_MASK            0x10
#define BD71828_INT_BUCK6_OCP_MASK            0x20
#define BD71828_INT_BUCK7_OCP_MASK            0x40
#define BD71828_INT_PGFAULT_MASK            0x80
 
#define BD71828_INT_DCIN_DET_MASK            0x1
#define BD71828_INT_DCIN_RMV_MASK            0x2
#define BD71828_INT_CLPS_OUT_MASK            0x4
#define BD71828_INT_CLPS_IN_MASK            0x8
   /* DCIN2 interrupts */
#define BD71828_INT_DCIN_MON_RES_MASK            0x1
#define BD71828_INT_DCIN_MON_DET_MASK            0x2
#define BD71828_INT_LONGPUSH_MASK            0x4
#define BD71828_INT_MIDPUSH_MASK            0x8
#define BD71828_INT_SHORTPUSH_MASK            0x10
#define BD71828_INT_PUSH_MASK                0x20
#define BD71828_INT_WDOG_MASK                0x40
#define BD71828_INT_SWRESET_MASK            0x80
   /* Vsys */
#define BD71828_INT_VSYS_UV_RES_MASK            0x1
#define BD71828_INT_VSYS_UV_DET_MASK            0x2
#define BD71828_INT_VSYS_LOW_RES_MASK            0x4
#define BD71828_INT_VSYS_LOW_DET_MASK            0x8
#define BD71828_INT_VSYS_HALL_IN_MASK            0x10
#define BD71828_INT_VSYS_HALL_TOGGLE_MASK        0x20
#define BD71828_INT_VSYS_MON_RES_MASK            0x40
#define BD71828_INT_VSYS_MON_DET_MASK            0x80
   /* Charger */
#define BD71828_INT_CHG_DCIN_ILIM_MASK            0x1
#define BD71828_INT_CHG_TOPOFF_TO_DONE_MASK        0x2
#define BD71828_INT_CHG_WDG_TEMP_MASK            0x4
#define BD71828_INT_CHG_WDG_TIME_MASK            0x8
#define BD71828_INT_CHG_RECHARGE_RES_MASK        0x10
#define BD71828_INT_CHG_RECHARGE_DET_MASK        0x20
#define BD71828_INT_CHG_RANGED_TEMP_TRANSITION_MASK    0x40
#define BD71828_INT_CHG_STATE_TRANSITION_MASK        0x80
   /* Battery */
#define BD71828_INT_BAT_TEMP_NORMAL_MASK        0x1
#define BD71828_INT_BAT_TEMP_ERANGE_MASK        0x2
#define BD71828_INT_BAT_TEMP_WARN_MASK            0x4
#define BD71828_INT_BAT_REMOVED_MASK            0x10
#define BD71828_INT_BAT_DETECTED_MASK            0x20
#define BD71828_INT_THERM_REMOVED_MASK            0x40
#define BD71828_INT_THERM_DETECTED_MASK            0x80
   /* Battery Mon 1 */
#define BD71828_INT_BAT_DEAD_MASK            0x2
#define BD71828_INT_BAT_SHORTC_RES_MASK            0x4
#define BD71828_INT_BAT_SHORTC_DET_MASK            0x8
#define BD71828_INT_BAT_LOW_VOLT_RES_MASK        0x10
#define BD71828_INT_BAT_LOW_VOLT_DET_MASK        0x20
#define BD71828_INT_BAT_OVER_VOLT_RES_MASK        0x40
#define BD71828_INT_BAT_OVER_VOLT_DET_MASK        0x80
   /* Battery Mon 2 */
#define BD71828_INT_BAT_MON_RES_MASK            0x1
#define BD71828_INT_BAT_MON_DET_MASK            0x2
   /* Battery Mon 3 (Coulomb counter) */
#define BD71828_INT_BAT_CC_MON1_MASK            0x1
#define BD71828_INT_BAT_CC_MON2_MASK            0x2
#define BD71828_INT_BAT_CC_MON3_MASK            0x4
   /* Battery Mon 4 */
#define BD71828_INT_BAT_OVER_CURR_1_RES_MASK        0x1
#define BD71828_INT_BAT_OVER_CURR_1_DET_MASK        0x2
#define BD71828_INT_BAT_OVER_CURR_2_RES_MASK        0x4
#define BD71828_INT_BAT_OVER_CURR_2_DET_MASK        0x8
#define BD71828_INT_BAT_OVER_CURR_3_RES_MASK        0x10
#define BD71828_INT_BAT_OVER_CURR_3_DET_MASK        0x20
   /* Temperature */
#define BD71828_INT_TEMP_BAT_LOW_RES_MASK        0x1
#define BD71828_INT_TEMP_BAT_LOW_DET_MASK        0x2
#define BD71828_INT_TEMP_BAT_HI_RES_MASK        0x4
#define BD71828_INT_TEMP_BAT_HI_DET_MASK        0x8
#define BD71828_INT_TEMP_CHIP_OVER_125_RES_MASK        0x10
#define BD71828_INT_TEMP_CHIP_OVER_125_DET_MASK        0x20
#define BD71828_INT_TEMP_CHIP_OVER_VF_RES_MASK        0x40
#define BD71828_INT_TEMP_CHIP_OVER_VF_DET_MASK        0x80
   /* RTC Alarm */
#define BD71828_INT_RTC0_MASK                0x1
#define BD71828_INT_RTC1_MASK                0x2
#define BD71828_INT_RTC2_MASK                0x4
 
#define BD71828_OUT_TYPE_MASK                0x2
#define BD71828_OUT_TYPE_OPEN_DRAIN            0x0
#define BD71828_OUT_TYPE_CMOS                0x2
 
#endif /* __LINUX_MFD_BD71828_H__ */