mfd: da9063: Upgrade of register definitions to support production silicon
[firefly-linux-kernel-4.4.55.git] / include / linux / mfd / da9063 / registers.h
1 /*
2  * Registers definition for DA9063 modules
3  *
4  * Copyright 2012 Dialog Semiconductor Ltd.
5  *
6  * Author: Michal Hajduk <michal.hajduk@diasemi.com>
7  *         Krystian Garbaciak <krystian.garbaciak@diasemi.com>
8  *
9  *  This program is free software; you can redistribute  it and/or modify it
10  *  under  the terms of  the GNU General  Public License as published by the
11  *  Free Software Foundation;  either version 2 of the  License, or (at your
12  *  option) any later version.
13  *
14  */
15
16 #ifndef _DA9063_REG_H
17 #define _DA9063_REG_H
18
19 #define DA9063_I2C_PAGE_SEL_SHIFT       1
20 #define DA9063_EVENT_REG_NUM            4
21
22 /* Page selection I2C or SPI always in the begining of any page. */
23 /* Page 0 : I2C access 0x000 - 0x0FF    SPI access 0x000 - 0x07F */
24 /* Page 1 :                             SPI access 0x080 - 0x0FF */
25 /* Page 2 : I2C access 0x100 - 0x1FF    SPI access 0x100 - 0x17F */
26 /* Page 3 :                             SPI access 0x180 - 0x1FF */
27 #define DA9063_REG_PAGE_CON             0x00
28
29 /* System Control and Event Registers */
30 #define DA9063_REG_STATUS_A             0x01
31 #define DA9063_REG_STATUS_B             0x02
32 #define DA9063_REG_STATUS_C             0x03
33 #define DA9063_REG_STATUS_D             0x04
34 #define DA9063_REG_FAULT_LOG            0x05
35 #define DA9063_REG_EVENT_A              0x06
36 #define DA9063_REG_EVENT_B              0x07
37 #define DA9063_REG_EVENT_C              0x08
38 #define DA9063_REG_EVENT_D              0x09
39 #define DA9063_REG_IRQ_MASK_A           0x0A
40 #define DA9063_REG_IRQ_MASK_B           0x0B
41 #define DA9063_REG_IRQ_MASK_C           0x0C
42 #define DA9063_REG_IRQ_MASK_D           0x0D
43 #define DA9063_REG_CONTROL_A            0x0E
44 #define DA9063_REG_CONTROL_B            0x0F
45 #define DA9063_REG_CONTROL_C            0x10
46 #define DA9063_REG_CONTROL_D            0x11
47 #define DA9063_REG_CONTROL_E            0x12
48 #define DA9063_REG_CONTROL_F            0x13
49 #define DA9063_REG_PD_DIS               0x14
50
51 /* GPIO Control Registers */
52 #define DA9063_REG_GPIO_0_1             0x15
53 #define DA9063_REG_GPIO_2_3             0x16
54 #define DA9063_REG_GPIO_4_5             0x17
55 #define DA9063_REG_GPIO_6_7             0x18
56 #define DA9063_REG_GPIO_8_9             0x19
57 #define DA9063_REG_GPIO_10_11           0x1A
58 #define DA9063_REG_GPIO_12_13           0x1B
59 #define DA9063_REG_GPIO_14_15           0x1C
60 #define DA9063_REG_GPIO_MODE0_7         0x1D
61 #define DA9063_REG_GPIO_MODE8_15        0x1E
62 #define DA9063_REG_SWITCH_CONT          0x1F
63
64 /* Regulator Control Registers */
65 #define DA9063_REG_BCORE2_CONT          0x20
66 #define DA9063_REG_BCORE1_CONT          0x21
67 #define DA9063_REG_BPRO_CONT            0x22
68 #define DA9063_REG_BMEM_CONT            0x23
69 #define DA9063_REG_BIO_CONT             0x24
70 #define DA9063_REG_BPERI_CONT           0x25
71 #define DA9063_REG_LDO1_CONT            0x26
72 #define DA9063_REG_LDO2_CONT            0x27
73 #define DA9063_REG_LDO3_CONT            0x28
74 #define DA9063_REG_LDO4_CONT            0x29
75 #define DA9063_REG_LDO5_CONT            0x2A
76 #define DA9063_REG_LDO6_CONT            0x2B
77 #define DA9063_REG_LDO7_CONT            0x2C
78 #define DA9063_REG_LDO8_CONT            0x2D
79 #define DA9063_REG_LDO9_CONT            0x2E
80 #define DA9063_REG_LDO10_CONT           0x2F
81 #define DA9063_REG_LDO11_CONT           0x30
82 #define DA9063_REG_SUPPLIES             0x31
83 #define DA9063_REG_DVC_1                0x32
84 #define DA9063_REG_DVC_2                0x33
85
86 /* GP-ADC Control Registers */
87 #define DA9063_REG_ADC_MAN              0x34
88 #define DA9063_REG_ADC_CONT             0x35
89 #define DA9063_REG_VSYS_MON             0x36
90 #define DA9063_REG_ADC_RES_L            0x37
91 #define DA9063_REG_ADC_RES_H            0x38
92 #define DA9063_REG_VSYS_RES             0x39
93 #define DA9063_REG_ADCIN1_RES           0x3A
94 #define DA9063_REG_ADCIN2_RES           0x3B
95 #define DA9063_REG_ADCIN3_RES           0x3C
96 #define DA9063_REG_MON_A8_RES           0x3D
97 #define DA9063_REG_MON_A9_RES           0x3E
98 #define DA9063_REG_MON_A10_RES          0x3F
99
100 /* RTC Calendar and Alarm Registers */
101 #define DA9063_REG_COUNT_S              0x40
102 #define DA9063_REG_COUNT_MI             0x41
103 #define DA9063_REG_COUNT_H              0x42
104 #define DA9063_REG_COUNT_D              0x43
105 #define DA9063_REG_COUNT_MO             0x44
106 #define DA9063_REG_COUNT_Y              0x45
107 #define DA9063_REG_ALARM_S              0x46
108 #define DA9063_REG_ALARM_MI             0x47
109 #define DA9063_REG_ALARM_H              0x48
110 #define DA9063_REG_ALARM_D              0x49
111 #define DA9063_REG_ALARM_MO             0x4A
112 #define DA9063_REG_ALARM_Y              0x4B
113 #define DA9063_REG_SECOND_A             0x4C
114 #define DA9063_REG_SECOND_B             0x4D
115 #define DA9063_REG_SECOND_C             0x4E
116 #define DA9063_REG_SECOND_D             0x4F
117
118 /* Sequencer Control Registers */
119 #define DA9063_REG_SEQ                  0x81
120 #define DA9063_REG_SEQ_TIMER            0x82
121 #define DA9063_REG_ID_2_1               0x83
122 #define DA9063_REG_ID_4_3               0x84
123 #define DA9063_REG_ID_6_5               0x85
124 #define DA9063_REG_ID_8_7               0x86
125 #define DA9063_REG_ID_10_9              0x87
126 #define DA9063_REG_ID_12_11             0x88
127 #define DA9063_REG_ID_14_13             0x89
128 #define DA9063_REG_ID_16_15             0x8A
129 #define DA9063_REG_ID_18_17             0x8B
130 #define DA9063_REG_ID_20_19             0x8C
131 #define DA9063_REG_ID_22_21             0x8D
132 #define DA9063_REG_ID_24_23             0x8E
133 #define DA9063_REG_ID_26_25             0x8F
134 #define DA9063_REG_ID_28_27             0x90
135 #define DA9063_REG_ID_30_29             0x91
136 #define DA9063_REG_ID_32_31             0x92
137 #define DA9063_REG_SEQ_A                0x95
138 #define DA9063_REG_SEQ_B                0x96
139 #define DA9063_REG_WAIT                 0x97
140 #define DA9063_REG_EN_32K               0x98
141 #define DA9063_REG_RESET                0x99
142
143 /* Regulator Setting Registers */
144 #define DA9063_REG_BUCK_ILIM_A          0x9A
145 #define DA9063_REG_BUCK_ILIM_B          0x9B
146 #define DA9063_REG_BUCK_ILIM_C          0x9C
147 #define DA9063_REG_BCORE2_CFG           0x9D
148 #define DA9063_REG_BCORE1_CFG           0x9E
149 #define DA9063_REG_BPRO_CFG             0x9F
150 #define DA9063_REG_BIO_CFG              0xA0
151 #define DA9063_REG_BMEM_CFG             0xA1
152 #define DA9063_REG_BPERI_CFG            0xA2
153 #define DA9063_REG_VBCORE2_A            0xA3
154 #define DA9063_REG_VBCORE1_A            0xA4
155 #define DA9063_REG_VBPRO_A              0xA5
156 #define DA9063_REG_VBMEM_A              0xA6
157 #define DA9063_REG_VBIO_A               0xA7
158 #define DA9063_REG_VBPERI_A             0xA8
159 #define DA9063_REG_VLDO1_A              0xA9
160 #define DA9063_REG_VLDO2_A              0xAA
161 #define DA9063_REG_VLDO3_A              0xAB
162 #define DA9063_REG_VLDO4_A              0xAC
163 #define DA9063_REG_VLDO5_A              0xAD
164 #define DA9063_REG_VLDO6_A              0xAE
165 #define DA9063_REG_VLDO7_A              0xAF
166 #define DA9063_REG_VLDO8_A              0xB0
167 #define DA9063_REG_VLDO9_A              0xB1
168 #define DA9063_REG_VLDO10_A             0xB2
169 #define DA9063_REG_VLDO11_A             0xB3
170 #define DA9063_REG_VBCORE2_B            0xB4
171 #define DA9063_REG_VBCORE1_B            0xB5
172 #define DA9063_REG_VBPRO_B              0xB6
173 #define DA9063_REG_VBMEM_B              0xB7
174 #define DA9063_REG_VBIO_B               0xB8
175 #define DA9063_REG_VBPERI_B             0xB9
176 #define DA9063_REG_VLDO1_B              0xBA
177 #define DA9063_REG_VLDO2_B              0xBB
178 #define DA9063_REG_VLDO3_B              0xBC
179 #define DA9063_REG_VLDO4_B              0xBD
180 #define DA9063_REG_VLDO5_B              0xBE
181 #define DA9063_REG_VLDO6_B              0xBF
182 #define DA9063_REG_VLDO7_B              0xC0
183 #define DA9063_REG_VLDO8_B              0xC1
184 #define DA9063_REG_VLDO9_B              0xC2
185 #define DA9063_REG_VLDO10_B             0xC3
186 #define DA9063_REG_VLDO11_B             0xC4
187
188 /* Backup Battery Charger Control Register */
189 #define DA9063_REG_BBAT_CONT            0xC5
190
191 /* GPIO PWM (LED) */
192 #define DA9063_REG_GPO11_LED            0xC6
193 #define DA9063_REG_GPO14_LED            0xC7
194 #define DA9063_REG_GPO15_LED            0xC8
195
196 /* GP-ADC Threshold Registers */
197 #define DA9063_REG_ADC_CFG              0xC9
198 #define DA9063_REG_AUTO1_HIGH           0xCA
199 #define DA9063_REG_AUTO1_LOW            0xCB
200 #define DA9063_REG_AUTO2_HIGH           0xCC
201 #define DA9063_REG_AUTO2_LOW            0xCD
202 #define DA9063_REG_AUTO3_HIGH           0xCE
203 #define DA9063_REG_AUTO3_LOW            0xCF
204
205 /* DA9063 Configuration registers */
206 /* OTP */
207 #define DA9063_REG_OPT_COUNT            0x101
208 #define DA9063_REG_OPT_ADDR             0x102
209 #define DA9063_REG_OPT_DATA             0x103
210
211 /* Customer Trim and Configuration */
212 #define DA9063_REG_T_OFFSET             0x104
213 #define DA9063_REG_INTERFACE            0x105
214 #define DA9063_REG_CONFIG_A             0x106
215 #define DA9063_REG_CONFIG_B             0x107
216 #define DA9063_REG_CONFIG_C             0x108
217 #define DA9063_REG_CONFIG_D             0x109
218 #define DA9063_REG_CONFIG_E             0x10A
219 #define DA9063_REG_CONFIG_F             0x10B
220 #define DA9063_REG_CONFIG_G             0x10C
221 #define DA9063_REG_CONFIG_H             0x10D
222 #define DA9063_REG_CONFIG_I             0x10E
223 #define DA9063_REG_CONFIG_J             0x10F
224 #define DA9063_REG_CONFIG_K             0x110
225 #define DA9063_REG_CONFIG_L             0x111
226 #define DA9063_REG_CONFIG_M             0x112
227 #define DA9063_REG_CONFIG_N             0x113
228
229 #define DA9063_REG_MON_REG_1            0x114
230 #define DA9063_REG_MON_REG_2            0x115
231 #define DA9063_REG_MON_REG_3            0x116
232 #define DA9063_REG_MON_REG_4            0x117
233 #define DA9063_REG_MON_REG_5            0x11E
234 #define DA9063_REG_MON_REG_6            0x11F
235 #define DA9063_REG_TRIM_CLDR            0x120
236 /* General Purpose Registers */
237 #define DA9063_REG_GP_ID_0              0x121
238 #define DA9063_REG_GP_ID_1              0x122
239 #define DA9063_REG_GP_ID_2              0x123
240 #define DA9063_REG_GP_ID_3              0x124
241 #define DA9063_REG_GP_ID_4              0x125
242 #define DA9063_REG_GP_ID_5              0x126
243 #define DA9063_REG_GP_ID_6              0x127
244 #define DA9063_REG_GP_ID_7              0x128
245 #define DA9063_REG_GP_ID_8              0x129
246 #define DA9063_REG_GP_ID_9              0x12A
247 #define DA9063_REG_GP_ID_10             0x12B
248 #define DA9063_REG_GP_ID_11             0x12C
249 #define DA9063_REG_GP_ID_12             0x12D
250 #define DA9063_REG_GP_ID_13             0x12E
251 #define DA9063_REG_GP_ID_14             0x12F
252 #define DA9063_REG_GP_ID_15             0x130
253 #define DA9063_REG_GP_ID_16             0x131
254 #define DA9063_REG_GP_ID_17             0x132
255 #define DA9063_REG_GP_ID_18             0x133
256 #define DA9063_REG_GP_ID_19             0x134
257
258 /* Chip ID and variant */
259 #define DA9063_REG_CHIP_ID              0x181
260 #define DA9063_REG_CHIP_VARIANT         0x182
261
262 /*
263  * PMIC registers bits
264  */
265 /* DA9063_REG_PAGE_CON (addr=0x00) */
266 #define DA9063_PEG_PAGE_SHIFT                   0
267 #define DA9063_REG_PAGE_MASK                    0x07
268 #define         DA9063_REG_PAGE0                0x00
269 #define         DA9063_REG_PAGE2                0x02
270 #define DA9063_PAGE_WRITE_MODE                  0x00
271 #define DA9063_REPEAT_WRITE_MODE                0x40
272 #define DA9063_PAGE_REVERT                      0x80
273
274 /* DA9063_REG_STATUS_A (addr=0x01) */
275 #define DA9063_NONKEY                           0x01
276 #define DA9063_WAKE                             0x02
277 #define DA9063_DVC_BUSY                         0x04
278 #define DA9063_COMP_1V2                         0x08
279
280 /* DA9063_REG_STATUS_B (addr=0x02) */
281 #define DA9063_GPI0                             0x01
282 #define DA9063_GPI1                             0x02
283 #define DA9063_GPI2                             0x04
284 #define DA9063_GPI3                             0x08
285 #define DA9063_GPI4                             0x10
286 #define DA9063_GPI5                             0x20
287 #define DA9063_GPI6                             0x40
288 #define DA9063_GPI7                             0x80
289
290 /* DA9063_REG_STATUS_C (addr=0x03) */
291 #define DA9063_GPI8                             0x01
292 #define DA9063_GPI9                             0x02
293 #define DA9063_GPI10                            0x04
294 #define DA9063_GPI11                            0x08
295 #define DA9063_GPI12                            0x10
296 #define DA9063_GPI13                            0x20
297 #define DA9063_GPI14                            0x40
298 #define DA9063_GPI15                            0x80
299
300 /* DA9063_REG_STATUS_D (addr=0x04) */
301 #define DA9063_LDO3_LIM                         0x08
302 #define DA9063_LDO4_LIM                         0x10
303 #define DA9063_LDO7_LIM                         0x20
304 #define DA9063_LDO8_LIM                         0x40
305 #define DA9063_LDO11_LIM                        0x80
306
307 /* DA9063_REG_FAULT_LOG (addr=0x05) */
308 #define DA9063_TWD_ERROR                        0x01
309 #define DA9063_POR                              0x02
310 #define DA9063_VDD_FAULT                        0x04
311 #define DA9063_VDD_START                        0x08
312 #define DA9063_TEMP_CRIT                        0x10
313 #define DA9063_KEY_RESET                        0x20
314 #define DA9063_NSHUTDOWN                        0x40
315 #define DA9063_WAIT_SHUT                        0x80
316
317 /* DA9063_REG_EVENT_A (addr=0x06) */
318 #define DA9063_E_NONKEY                         0x01
319 #define DA9063_E_ALARM                          0x02
320 #define DA9063_E_TICK                           0x04
321 #define DA9063_E_ADC_RDY                        0x08
322 #define DA9063_E_SEQ_RDY                        0x10
323 #define DA9063_EVENTS_B                         0x20
324 #define DA9063_EVENTS_C                         0x40
325 #define DA9063_EVENTS_D                         0x80
326
327 /* DA9063_REG_EVENT_B (addr=0x07) */
328 #define DA9063_E_WAKE                           0x01
329 #define DA9063_E_TEMP                           0x02
330 #define DA9063_E_COMP_1V2                       0x04
331 #define DA9063_E_LDO_LIM                        0x08
332 #define DA9063_E_REG_UVOV                       0x10
333 #define DA9063_E_DVC_RDY                        0x20
334 #define DA9063_E_VDD_MON                        0x40
335 #define DA9063_E_VDD_WARN                       0x80
336
337 /* DA9063_REG_EVENT_C (addr=0x08) */
338 #define DA9063_E_GPI0                           0x01
339 #define DA9063_E_GPI1                           0x02
340 #define DA9063_E_GPI2                           0x04
341 #define DA9063_E_GPI3                           0x08
342 #define DA9063_E_GPI4                           0x10
343 #define DA9063_E_GPI5                           0x20
344 #define DA9063_E_GPI6                           0x40
345 #define DA9063_E_GPI7                           0x80
346
347 /* DA9063_REG_EVENT_D (addr=0x09) */
348 #define DA9063_E_GPI8                           0x01
349 #define DA9063_E_GPI9                           0x02
350 #define DA9063_E_GPI10                          0x04
351 #define DA9063_E_GPI11                          0x08
352 #define DA9063_E_GPI12                          0x10
353 #define DA9063_E_GPI13                          0x20
354 #define DA9063_E_GPI14                          0x40
355 #define DA9063_E_GPI15                          0x80
356
357 /* DA9063_REG_IRQ_MASK_A (addr=0x0A) */
358 #define DA9063_M_ONKEY                          0x01
359 #define DA9063_M_ALARM                          0x02
360 #define DA9063_M_TICK                           0x04
361 #define DA9063_M_ADC_RDY                        0x08
362 #define DA9063_M_SEQ_RDY                        0x10
363
364 /* DA9063_REG_IRQ_MASK_B (addr=0x0B) */
365 #define DA9063_M_WAKE                           0x01
366 #define DA9063_M_TEMP                           0x02
367 #define DA9063_M_COMP_1V2                       0x04
368 #define DA9063_M_LDO_LIM                        0x08
369 #define DA9063_M_UVOV                           0x10
370 #define DA9063_M_DVC_RDY                        0x20
371 #define DA9063_M_VDD_MON                        0x40
372 #define DA9063_M_VDD_WARN                       0x80
373
374 /* DA9063_REG_IRQ_MASK_C (addr=0x0C) */
375 #define DA9063_M_GPI0                           0x01
376 #define DA9063_M_GPI1                           0x02
377 #define DA9063_M_GPI2                           0x04
378 #define DA9063_M_GPI3                           0x08
379 #define DA9063_M_GPI4                           0x10
380 #define DA9063_M_GPI5                           0x20
381 #define DA9063_M_GPI6                           0x40
382 #define DA9063_M_GPI7                           0x80
383
384 /* DA9063_REG_IRQ_MASK_D (addr=0x0D) */
385 #define DA9063_M_GPI8                           0x01
386 #define DA9063_M_GPI9                           0x02
387 #define DA9063_M_GPI10                          0x04
388 #define DA9063_M_GPI11                          0x08
389 #define DA9063_M_GPI12                          0x10
390 #define DA9063_M_GPI13                          0x20
391 #define DA9063_M_GPI14                          0x40
392 #define DA9063_M_GPI15                          0x80
393
394 /* DA9063_REG_CONTROL_A (addr=0x0E) */
395 #define DA9063_SYSTEM_EN                        0x01
396 #define DA9063_POWER_EN                         0x02
397 #define DA9063_POWER1_EN                        0x04
398 #define DA9063_STANDBY                          0x08
399 #define DA9063_M_SYSTEM_EN                      0x10
400 #define DA9063_M_POWER_EN                       0x20
401 #define DA9063_M_POWER1_EN                      0x40
402 #define DA9063_CP_EN                            0x80
403
404 /* DA9063_REG_CONTROL_B (addr=0x0F) */
405 #define DA9063_CHG_SEL                          0x01
406 #define DA9063_WATCHDOG_PD                      0x02
407 #define DA9063_RESET_BLINKING                   0x04
408 #define DA9063_NRES_MODE                        0x08
409 #define DA9063_NONKEY_LOCK                      0x10
410 #define DA9063_BUCK_SLOWSTART                   0x80
411
412 /* DA9063_REG_CONTROL_C (addr=0x10) */
413 #define DA9063_DEBOUNCING_MASK                  0x07
414 #define         DA9063_DEBOUNCING_OFF           0x0
415 #define         DA9063_DEBOUNCING_0MS1          0x1
416 #define         DA9063_DEBOUNCING_1MS           0x2
417 #define         DA9063_DEBOUNCING_10MS24        0x3
418 #define         DA9063_DEBOUNCING_51MS2         0x4
419 #define         DA9063_DEBOUNCING_256MS         0x5
420 #define         DA9063_DEBOUNCING_512MS         0x6
421 #define         DA9063_DEBOUNCING_1024MS        0x7
422
423 #define DA9063_AUTO_BOOT                        0x08
424 #define DA9063_OTPREAD_EN                       0x10
425 #define DA9063_SLEW_RATE_MASK                   0x60
426 #define         DA9063_SLEW_RATE_4US            0x00
427 #define         DA9063_SLEW_RATE_3US            0x20
428 #define         DA9063_SLEW_RATE_1US            0x40
429 #define         DA9063_SLEW_RATE_0US5           0x60
430 #define DA9063_DEF_SUPPLY                       0x80
431
432 /* DA9063_REG_CONTROL_D (addr=0x11) */
433 #define DA9063_TWDSCALE_MASK                    0x07
434 #define DA9063_BLINK_FRQ_MASK                   0x38
435 #define         DA9063_BLINK_FRQ_OFF            0x00
436 #define         DA9063_BLINK_FRQ_1S0            0x08
437 #define         DA9063_BLINK_FRQ_2S0            0x10
438 #define         DA9063_BLINK_FRQ_4S0            0x18
439 #define         DA9063_BLINK_FRQ_0S18           0x20
440 #define         DA9063_BLINK_FRQ_2S0_VDD        0x28
441 #define         DA9063_BLINK_FRQ_4S0_VDD        0x30
442 #define         DA9063_BLINK_FRQ_0S18_VDD       0x38
443
444 #define DA9063_BLINK_DUR_MASK                   0xC0
445 #define         DA9063_BLINK_DUR_10MS           0x00
446 #define         DA9063_BLINK_DUR_20MS           0x40
447 #define         DA9063_BLINK_DUR_40MS           0x80
448 #define         DA9063_BLINK_DUR_20MSDBL        0xC0
449
450 /* DA9063_REG_CONTROL_E (addr=0x12) */
451 #define DA9063_RTC_MODE_PD                      0x01
452 #define DA9063_RTC_MODE_SD                      0x02
453 #define DA9063_RTC_EN                           0x04
454 #define DA9063_ECO_MODE                         0x08
455 #define DA9063_PM_FB1_PIN                       0x10
456 #define DA9063_PM_FB2_PIN                       0x20
457 #define DA9063_PM_FB3_PIN                       0x40
458 #define DA9063_V_LOCK                           0x80
459
460 /* DA9063_REG_CONTROL_F (addr=0x13) */
461 #define DA9063_WATCHDOG                         0x01
462 #define DA9063_SHUTDOWN                         0x02
463 #define DA9063_WAKE_UP                          0x04
464
465 /* DA9063_REG_PD_DIS (addr=0x14) */
466 #define DA9063_GPI_DIS                          0x01
467 #define DA9063_GPADC_PAUSE                      0x02
468 #define DA9063_PMIF_DIS                         0x04
469 #define DA9063_HS2WIRE_DIS                      0x08
470 #define DA9063_CLDR_PAUSE                       0x10
471 #define DA9063_BBAT_DIS                         0x20
472 #define DA9063_OUT_32K_PAUSE                    0x40
473 #define DA9063_PMCONT_DIS                       0x80
474
475 /* DA9063_REG_GPIO_0_1 (addr=0x15) */
476 #define DA9063_GPIO0_PIN_MASK                   0x03
477 #define         DA9063_GPIO0_PIN_ADCIN1         0x00
478 #define         DA9063_GPIO0_PIN_GPI            0x01
479 #define         DA9063_GPIO0_PIN_GPO_OD         0x02
480 #define         DA9063_GPIO0_PIN_GPO            0x03
481 #define DA9063_GPIO0_TYPE                       0x04
482 #define         DA9063_GPIO0_TYPE_GPI_ACT_LOW   0x00
483 #define         DA9063_GPIO0_TYPE_GPO_VDD_IO1   0x00
484 #define         DA9063_GPIO0_TYPE_GPI_ACT_HIGH  0x04
485 #define         DA9063_GPIO0_TYPE_GPO_VDD_IO2   0x04
486 #define DA9063_GPIO0_NO_WAKEUP                  0x08
487 #define DA9063_GPIO1_PIN_MASK                   0x30
488 #define         DA9063_GPIO1_PIN_ADCIN2_COMP    0x00
489 #define         DA9063_GPIO1_PIN_GPI            0x10
490 #define         DA9063_GPIO1_PIN_GPO_OD         0x20
491 #define         DA9063_GPIO1_PIN_GPO            0x30
492 #define DA9063_GPIO1_TYPE                       0x40
493 #define         DA9063_GPIO1_TYPE_GPI_ACT_LOW   0x00
494 #define         DA9063_GPIO1_TYPE_GPO_VDD_IO1   0x00
495 #define         DA9063_GPIO1_TYPE_GPI_ACT_HIGH  0x04
496 #define         DA9063_GPIO1_TYPE_GPO_VDD_IO2   0x04
497 #define DA9063_GPIO1_NO_WAKEUP                  0x80
498
499 /* DA9063_REG_GPIO_2_3 (addr=0x16) */
500 #define DA9063_GPIO2_PIN_MASK                   0x03
501 #define         DA9063_GPIO2_PIN_ADCIN3         0x00
502 #define         DA9063_GPIO2_PIN_GPI            0x01
503 #define         DA9063_GPIO2_PIN_GPO_PSS        0x02
504 #define         DA9063_GPIO2_PIN_GPO            0x03
505 #define DA9063_GPIO2_TYPE                       0x04
506 #define         DA9063_GPIO2_TYPE_GPI_ACT_LOW   0x00
507 #define         DA9063_GPIO2_TYPE_GPO_VDD_IO1   0x00
508 #define         DA9063_GPIO2_TYPE_GPI_ACT_HIGH  0x04
509 #define         DA9063_GPIO2_TYPE_GPO_VDD_IO2   0x04
510 #define DA9063_GPIO2_NO_WAKEUP                  0x08
511 #define DA9063_GPIO3_PIN_MASK                   0x30
512 #define         DA9063_GPIO3_PIN_CORE_SW_G      0x00
513 #define         DA9063_GPIO3_PIN_GPI            0x10
514 #define         DA9063_GPIO3_PIN_GPO_OD         0x20
515 #define         DA9063_GPIO3_PIN_GPO            0x30
516 #define DA9063_GPIO3_TYPE                       0x40
517 #define         DA9063_GPIO3_TYPE_GPI_ACT_LOW   0x00
518 #define         DA9063_GPIO3_TYPE_GPO_VDD_IO1   0x00
519 #define         DA9063_GPIO3_TYPE_GPI_ACT_HIGH  0x04
520 #define         DA9063_GPIO3_TYPE_GPO_VDD_IO2   0x04
521 #define DA9063_GPIO3_NO_WAKEUP                  0x80
522
523 /* DA9063_REG_GPIO_4_5 (addr=0x17) */
524 #define DA9063_GPIO4_PIN_MASK                   0x03
525 #define         DA9063_GPIO4_PIN_CORE_SW_S      0x00
526 #define         DA9063_GPIO4_PIN_GPI            0x01
527 #define         DA9063_GPIO4_PIN_GPO_OD         0x02
528 #define         DA9063_GPIO4_PIN_GPO            0x03
529 #define DA9063_GPIO4_TYPE                       0x04
530 #define         DA9063_GPIO4_TYPE_GPI_ACT_LOW   0x00
531 #define         DA9063_GPIO4_TYPE_GPO_VDD_IO1   0x00
532 #define         DA9063_GPIO4_TYPE_GPI_ACT_HIGH  0x04
533 #define         DA9063_GPIO4_TYPE_GPO_VDD_IO2   0x04
534 #define DA9063_GPIO4_NO_WAKEUP                  0x08
535 #define DA9063_GPIO5_PIN_MASK                   0x30
536 #define         DA9063_GPIO5_PIN_PERI_SW_G      0x00
537 #define         DA9063_GPIO5_PIN_GPI            0x10
538 #define         DA9063_GPIO5_PIN_GPO_OD         0x20
539 #define         DA9063_GPIO5_PIN_GPO            0x30
540 #define DA9063_GPIO5_TYPE                       0x40
541 #define         DA9063_GPIO5_TYPE_GPI_ACT_LOW   0x00
542 #define         DA9063_GPIO5_TYPE_GPO_VDD_IO1   0x00
543 #define         DA9063_GPIO5_TYPE_GPI_ACT_HIGH  0x04
544 #define         DA9063_GPIO5_TYPE_GPO_VDD_IO2   0x04
545 #define DA9063_GPIO5_NO_WAKEUP                  0x80
546
547 /* DA9063_REG_GPIO_6_7 (addr=0x18) */
548 #define DA9063_GPIO6_PIN_MASK                   0x03
549 #define         DA9063_GPIO6_PIN_PERI_SW_S      0x00
550 #define         DA9063_GPIO6_PIN_GPI            0x01
551 #define         DA9063_GPIO6_PIN_GPO_OD         0x02
552 #define         DA9063_GPIO6_PIN_GPO            0x03
553 #define DA9063_GPIO6_TYPE                       0x04
554 #define         DA9063_GPIO6_TYPE_GPI_ACT_LOW   0x00
555 #define         DA9063_GPIO6_TYPE_GPO_VDD_IO1   0x00
556 #define         DA9063_GPIO6_TYPE_GPI_ACT_HIGH  0x04
557 #define         DA9063_GPIO6_TYPE_GPO_VDD_IO2   0x04
558 #define DA9063_GPIO6_NO_WAKEUP                  0x08
559 #define DA9063_GPIO7_PIN_MASK                   0x30
560 #define         DA9063_GPIO7_PIN_GPI            0x10
561 #define         DA9063_GPIO7_PIN_GPO_PSS        0x20
562 #define         DA9063_GPIO7_PIN_GPO            0x30
563 #define DA9063_GPIO7_TYPE                       0x40
564 #define         DA9063_GPIO7_TYPE_GPI_ACT_LOW   0x00
565 #define         DA9063_GPIO7_TYPE_GPO_VDD_IO1   0x00
566 #define         DA9063_GPIO7_TYPE_GPI_ACT_HIGH  0x04
567 #define         DA9063_GPIO7_TYPE_GPO_VDD_IO2   0x04
568 #define DA9063_GPIO7_NO_WAKEUP                  0x80
569
570 /* DA9063_REG_GPIO_8_9 (addr=0x19) */
571 #define DA9063_GPIO8_PIN_MASK                   0x03
572 #define         DA9063_GPIO8_PIN_GPI_SYS_EN     0x00
573 #define         DA9063_GPIO8_PIN_GPI            0x01
574 #define         DA9063_GPIO8_PIN_GPO_PSS        0x02
575 #define         DA9063_GPIO8_PIN_GPO            0x03
576 #define DA9063_GPIO8_TYPE                       0x04
577 #define         DA9063_GPIO8_TYPE_GPI_ACT_LOW   0x00
578 #define         DA9063_GPIO8_TYPE_GPO_VDD_IO1   0x00
579 #define         DA9063_GPIO8_TYPE_GPI_ACT_HIGH  0x04
580 #define         DA9063_GPIO8_TYPE_GPO_VDD_IO2   0x04
581 #define DA9063_GPIO8_NO_WAKEUP                  0x08
582 #define DA9063_GPIO9_PIN_MASK                   0x30
583 #define         DA9063_GPIO9_PIN_GPI_PWR_EN     0x00
584 #define         DA9063_GPIO9_PIN_GPI            0x10
585 #define         DA9063_GPIO9_PIN_GPO_PSS        0x20
586 #define         DA9063_GPIO9_PIN_GPO            0x30
587 #define DA9063_GPIO9_TYPE                       0x40
588 #define         DA9063_GPIO9_TYPE_GPI_ACT_LOW   0x00
589 #define         DA9063_GPIO9_TYPE_GPO_VDD_IO1   0x00
590 #define         DA9063_GPIO9_TYPE_GPI_ACT_HIGH  0x04
591 #define         DA9063_GPIO9_TYPE_GPO_VDD_IO2   0x04
592 #define DA9063_GPIO9_NO_WAKEUP                  0x80
593
594 /* DA9063_REG_GPIO_10_11 (addr=0x1A) */
595 #define DA9063_GPIO10_PIN_MASK                  0x03
596 #define         DA9063_GPIO10_PIN_GPI_PWR1_EN   0x00
597 #define         DA9063_GPIO10_PIN_GPI           0x01
598 #define         DA9063_GPIO10_PIN_GPO_OD        0x02
599 #define         DA9063_GPIO10_PIN_GPO           0x03
600 #define DA9063_GPIO10_TYPE                      0x04
601 #define         DA9063_GPIO10_TYPE_GPI_ACT_LOW  0x00
602 #define         DA9063_GPIO10_TYPE_GPO_VDD_IO1  0x00
603 #define         DA9063_GPIO10_TYPE_GPI_ACT_HIGH 0x04
604 #define         DA9063_GPIO10_TYPE_GPO_VDD_IO2  0x04
605 #define DA9063_GPIO10_NO_WAKEUP                 0x08
606 #define DA9063_GPIO11_PIN_MASK                  0x30
607 #define         DA9063_GPIO11_PIN_GPO_OD        0x00
608 #define         DA9063_GPIO11_PIN_GPI           0x10
609 #define         DA9063_GPIO11_PIN_GPO_PSS       0x20
610 #define         DA9063_GPIO11_PIN_GPO           0x30
611 #define DA9063_GPIO11_TYPE                      0x40
612 #define         DA9063_GPIO11_TYPE_GPI_ACT_LOW  0x00
613 #define         DA9063_GPIO11_TYPE_GPO_VDD_IO1  0x00
614 #define         DA9063_GPIO11_TYPE_GPI_ACT_HIGH 0x04
615 #define         DA9063_GPIO11_TYPE_GPO_VDD_IO2  0x04
616 #define DA9063_GPIO11_NO_WAKEUP                 0x80
617
618 /* DA9063_REG_GPIO_12_13 (addr=0x1B) */
619 #define DA9063_GPIO12_PIN_MASK                  0x03
620 #define         DA9063_GPIO12_PIN_NVDDFLT_OUT   0x00
621 #define         DA9063_GPIO12_PIN_GPI           0x01
622 #define         DA9063_GPIO12_PIN_VSYSMON_OUT   0x02
623 #define         DA9063_GPIO12_PIN_GPO           0x03
624 #define DA9063_GPIO12_TYPE                      0x04
625 #define         DA9063_GPIO12_TYPE_GPI_ACT_LOW  0x00
626 #define         DA9063_GPIO12_TYPE_GPO_VDD_IO1  0x00
627 #define         DA9063_GPIO12_TYPE_GPI_ACT_HIGH 0x04
628 #define         DA9063_GPIO12_TYPE_GPO_VDD_IO2  0x04
629 #define DA9063_GPIO12_NO_WAKEUP                 0x08
630 #define DA9063_GPIO13_PIN_MASK                  0x30
631 #define         DA9063_GPIO13_PIN_GPFB1_OUT     0x00
632 #define         DA9063_GPIO13_PIN_GPI           0x10
633 #define         DA9063_GPIO13_PIN_GPFB1_OUTOD   0x20
634 #define         DA9063_GPIO13_PIN_GPO           0x30
635 #define DA9063_GPIO13_TYPE                      0x40
636 #define         DA9063_GPIO13_TYPE_GPFB1_OUT    0x00
637 #define         DA9063_GPIO13_TYPE_GPI          0x00
638 #define         DA9063_GPIO13_TYPE_GPFB1_OUTOD  0x04
639 #define         DA9063_GPIO13_TYPE_GPO          0x04
640 #define DA9063_GPIO13_NO_WAKEUP                 0x80
641
642 /* DA9063_REG_GPIO_14_15 (addr=0x1C) */
643 #define DA9063_GPIO14_PIN_MASK                  0x03
644 #define         DA9063_GPIO14_PIN_GPO_OD        0x00
645 #define         DA9063_GPIO14_PIN_GPI           0x01
646 #define         DA9063_GPIO14_PIN_HS2DATA       0x02
647 #define         DA9063_GPIO14_PIN_GPO           0x03
648 #define DA9063_GPIO14_TYPE                      0x04
649 #define         DA9063_GPIO14_TYPE_GPI_ACT_LOW  0x00
650 #define         DA9063_GPIO14_TYPE_GPO_VDD_IO1  0x00
651 #define         DA9063_GPIO14_TYPE_GPI_ACT_HIGH 0x04
652 #define         DA9063_GPIO14_TYPE_GPO_VDD_IO2  0x04
653 #define DA9063_GPIO14_NO_WAKEUP                 0x08
654 #define DA9063_GPIO15_PIN_MASK                  0x30
655 #define         DA9063_GPIO15_PIN_GPO_OD        0x00
656 #define         DA9063_GPIO15_PIN_GPI           0x10
657 #define         DA9063_GPIO15_PIN_GPO           0x30
658 #define DA9063_GPIO15_TYPE                      0x40
659 #define         DA9063_GPIO15_TYPE_GPFB1_OUT    0x00
660 #define         DA9063_GPIO15_TYPE_GPI          0x00
661 #define         DA9063_GPIO15_TYPE_GPFB1_OUTOD  0x04
662 #define         DA9063_GPIO15_TYPE_GPO          0x04
663 #define DA9063_GPIO15_NO_WAKEUP                 0x80
664
665 /* DA9063_REG_GPIO_MODE0_7 (addr=0x1D) */
666 #define DA9063_GPIO0_MODE                       0x01
667 #define DA9063_GPIO1_MODE                       0x02
668 #define DA9063_GPIO2_MODE                       0x04
669 #define DA9063_GPIO3_MODE                       0x08
670 #define DA9063_GPIO4_MODE                       0x10
671 #define DA9063_GPIO5_MODE                       0x20
672 #define DA9063_GPIO6_MODE                       0x40
673 #define DA9063_GPIO7_MODE                       0x80
674
675 /* DA9063_REG_GPIO_MODE8_15 (addr=0x1E) */
676 #define DA9063_GPIO8_MODE                       0x01
677 #define DA9063_GPIO9_MODE                       0x02
678 #define DA9063_GPIO10_MODE                      0x04
679 #define DA9063_GPIO11_MODE                      0x08
680 #define         DA9063_GPIO11_MODE_LED_ACT_HIGH 0x00
681 #define         DA9063_GPIO11_MODE_LED_ACT_LOW  0x08
682 #define DA9063_GPIO12_MODE                      0x10
683 #define DA9063_GPIO13_MODE                      0x20
684 #define DA9063_GPIO14_MODE                      0x40
685 #define         DA9063_GPIO14_MODE_LED_ACT_HIGH 0x00
686 #define         DA9063_GPIO14_MODE_LED_ACT_LOW  0x40
687 #define DA9063_GPIO15_MODE                      0x80
688 #define         DA9063_GPIO15_MODE_LED_ACT_HIGH 0x00
689 #define         DA9063_GPIO15_MODE_LED_ACT_LOW  0x80
690
691 /* DA9063_REG_SWITCH_CONT (addr=0x1F) */
692 #define DA9063_CORE_SW_GPI_MASK                 0x03
693 #define         DA9063_CORE_SW_GPI_OFF          0x00
694 #define         DA9063_CORE_SW_GPI_GPIO1        0x01
695 #define         DA9063_CORE_SW_GPI_GPIO2        0x02
696 #define         DA9063_CORE_SW_GPI_GPIO13       0x03
697 #define DA9063_PERI_SW_GPI_MASK                 0x0C
698 #define         DA9063_PERI_SW_GPI_OFF          0x00
699 #define         DA9063_PERI_SW_GPI_GPIO1        0x04
700 #define         DA9063_PERI_SW_GPI_GPIO2        0x08
701 #define         DA9063_PERI_SW_GPI_GPIO13       0x0C
702 #define DA9063_SWITCH_SR_MASK                   0x30
703 #define         DA9063_SWITCH_SR_1MV            0x00
704 #define         DA9063_SWITCH_SR_5MV            0x10
705 #define         DA9063_SWITCH_SR_10MV           0x20
706 #define         DA9063_SWITCH_SR_50MV           0x30
707 #define DA9063_CORE_SW_INTERNAL                 0x40
708 #define DA9063_CP_EN_MODE                       0x80
709
710 /* DA9063_REGL_Bxxxx_CONT common bits (addr=0x20-0x25) */
711 #define DA9063_BUCK_EN                          0x01
712 #define DA9063_BUCK_GPI_MASK                    0x06
713 #define         DA9063_BUCK_GPI_OFF             0x00
714 #define         DA9063_BUCK_GPI_GPIO1           0x02
715 #define         DA9063_BUCK_GPI_GPIO2           0x04
716 #define         DA9063_BUCK_GPI_GPIO13          0x06
717 #define DA9063_BUCK_CONF                        0x08
718 #define DA9063_VBUCK_GPI_MASK                   0x60
719 #define         DA9063_VBUCK_GPI_OFF            0x00
720 #define         DA9063_VBUCK_GPI_GPIO1          0x20
721 #define         DA9063_VBUCK_GPI_GPIO2          0x40
722 #define         DA9063_VBUCK_GPI_GPIO13         0x60
723
724 /* DA9063_REG_BCORE1_CONT specific bits (addr=0x21) */
725 #define DA9063_CORE_SW_EN                       0x10
726 #define DA9063_CORE_SW_CONF                     0x80
727
728 /* DA9063_REG_BPERI_CONT specific bits (addr=0x25) */
729 #define DA9063_PERI_SW_EN                       0x10
730 #define DA9063_PERI_SW_CONF                     0x80
731
732 /* DA9063_REG_LDOx_CONT common bits (addr=0x26-0x30) */
733 #define DA9063_LDO_EN                           0x01
734 #define DA9063_LDO_GPI_MASK                     0x06
735 #define         DA9063_LDO_GPI_OFF              0x00
736 #define         DA9063_LDO_GPI_GPIO1            0x02
737 #define         DA9063_LDO_GPI_GPIO2            0x04
738 #define         DA9063_LDO_GPI_GPIO13           0x06
739 #define DA9063_LDO_PD_DIS                       0x08
740 #define DA9063_VLDO_GPI_MASK                    0x60
741 #define         DA9063_VLDO_GPI_OFF             0x00
742 #define         DA9063_VLDO_GPI_GPIO1           0x20
743 #define         DA9063_VLDO_GPI_GPIO2           0x40
744 #define         DA9063_VLDO_GPI_GPIO13          0x60
745 #define DA9063_LDO_CONF                         0x80
746
747 /* DA9063_REG_LDO5_CONT specific bits (addr=0x2A) */
748 #define DA9063_VLDO5_SEL                        0x10
749
750 /* DA9063_REG_LDO6_CONT specific bits (addr=0x2B) */
751 #define DA9063_VLDO6_SEL                        0x10
752
753 /* DA9063_REG_LDO7_CONT specific bits (addr=0x2C) */
754 #define DA9063_VLDO7_SEL                        0x10
755
756 /* DA9063_REG_LDO8_CONT specific bits (addr=0x2D) */
757 #define DA9063_VLDO8_SEL                        0x10
758
759 /* DA9063_REG_LDO9_CONT specific bits (addr=0x2E) */
760 #define DA9063_VLDO9_SEL                        0x10
761
762 /* DA9063_REG_LDO10_CONT specific bits (addr=0x2F) */
763 #define DA9063_VLDO10_SEL                       0x10
764
765 /* DA9063_REG_LDO11_CONT specific bits (addr=0x30) */
766 #define DA9063_VLDO11_SEL                       0x10
767
768 /* DA9063_REG_VIB (addr=0x31) */
769 #define DA9063_VIB_SET_MASK                     0x3F
770 #define         DA9063_VIB_SET_OFF              0
771 #define         DA9063_VIB_SET_MAX              0x3F
772
773 /* DA9063_REG_DVC_1 (addr=0x32) */
774 #define DA9063_VBCORE1_SEL                      0x01
775 #define DA9063_VBCORE2_SEL                      0x02
776 #define DA9063_VBPRO_SEL                        0x04
777 #define DA9063_VBMEM_SEL                        0x08
778 #define DA9063_VBPERI_SEL                       0x10
779 #define DA9063_VLDO1_SEL                        0x20
780 #define DA9063_VLDO2_SEL                        0x40
781 #define DA9063_VLDO3_SEL                        0x80
782
783 /* DA9063_REG_DVC_2 (addr=0x33) */
784 #define DA9063_VBIO_SEL                         0x01
785 #define DA9063_VLDO4_SEL                        0x80
786
787 /* DA9063_REG_ADC_MAN (addr=0x34) */
788 #define DA9063_ADC_MUX_MASK                     0x0F
789 #define         DA9063_ADC_MUX_VSYS             0x00
790 #define         DA9063_ADC_MUX_ADCIN1           0x01
791 #define         DA9063_ADC_MUX_ADCIN2           0x02
792 #define         DA9063_ADC_MUX_ADCIN3           0x03
793 #define         DA9063_ADC_MUX_T_SENSE          0x04
794 #define         DA9063_ADC_MUX_VBBAT            0x05
795 #define         DA9063_ADC_MUX_LDO_G1           0x08
796 #define         DA9063_ADC_MUX_LDO_G2           0x09
797 #define         DA9063_ADC_MUX_LDO_G3           0x0A
798 #define DA9063_ADC_MAN                          0x10
799 #define DA9063_ADC_MODE                         0x20
800
801 /* DA9063_REG_ADC_CONT (addr=0x35) */
802 #define DA9063_ADC_AUTO_VSYS_EN                 0x01
803 #define DA9063_ADC_AUTO_AD1_EN                  0x02
804 #define DA9063_ADC_AUTO_AD2_EN                  0x04
805 #define DA9063_ADC_AUTO_AD3_EN                  0x08
806 #define DA9063_ADC_AD1_ISRC_EN                  0x10
807 #define DA9063_ADC_AD2_ISRC_EN                  0x20
808 #define DA9063_ADC_AD3_ISRC_EN                  0x40
809 #define DA9063_COMP1V2_EN                       0x80
810
811 /* DA9063_REG_VSYS_MON (addr=0x36) */
812 #define DA9063_VSYS_VAL_MASK                    0xFF
813 #define DA9063_VSYS_VAL_BASE                    0x00
814
815 /* DA9063_REG_ADC_RES_L (addr=0x37) */
816 #define DA9063_ADC_RES_L_BITS                   2
817 #define DA9063_ADC_RES_L_MASK                   0xC0
818
819 /* DA9063_REG_ADC_RES_H (addr=0x38) */
820 #define DA9063_ADC_RES_M_BITS                   8
821 #define DA9063_ADC_RES_M_MASK                   0xFF
822
823 /* DA9063_REG_(xxx_RES/ADC_RES_H) (addr=0x39-0x3F) */
824 #define DA9063_ADC_VAL_MASK                     0xFF
825
826 /* DA9063_REG_COUNT_S (addr=0x40) */
827 #define DA9063_RTC_READ                         0x80
828 #define DA9063_COUNT_SEC_MASK                   0x3F
829
830 /* DA9063_REG_COUNT_MI (addr=0x41) */
831 #define DA9063_COUNT_MIN_MASK                   0x3F
832
833 /* DA9063_REG_COUNT_H (addr=0x42) */
834 #define DA9063_COUNT_HOUR_MASK                  0x1F
835
836 /* DA9063_REG_COUNT_D (addr=0x43) */
837 #define DA9063_COUNT_DAY_MASK                   0x1F
838
839 /* DA9063_REG_COUNT_MO (addr=0x44) */
840 #define DA9063_COUNT_MONTH_MASK                 0x0F
841
842 /* DA9063_REG_COUNT_Y (addr=0x45) */
843 #define DA9063_COUNT_YEAR_MASK                  0x3F
844 #define DA9063_MONITOR                          0x40
845
846 /* DA9063_REG_ALARM_S (addr=0x46) */
847 #define DA9063_ALARM_S_MASK                     0x3F
848 #define DA9063_ALARM_STATUS_ALARM               0x80
849 #define DA9063_ALARM_STATUS_TICK                0x40
850 /* DA9063_REG_ALARM_MI (addr=0x47) */
851 #define DA9063_ALARM_MIN_MASK                   0x3F
852
853 /* DA9063_REG_ALARM_H (addr=0x48) */
854 #define DA9063_ALARM_HOUR_MASK                  0x1F
855
856 /* DA9063_REG_ALARM_D (addr=0x49) */
857 #define DA9063_ALARM_DAY_MASK                   0x1F
858
859 /* DA9063_REG_ALARM_MO (addr=0x4A) */
860 #define DA9063_TICK_WAKE                        0x20
861 #define DA9063_TICK_TYPE                        0x10
862 #define         DA9063_TICK_TYPE_SEC            0x00
863 #define         DA9063_TICK_TYPE_MIN            0x10
864 #define DA9063_ALARM_MONTH_MASK                 0x0F
865
866 /* DA9063_REG_ALARM_Y (addr=0x4B) */
867 #define DA9063_TICK_ON                          0x80
868 #define DA9063_ALARM_ON                         0x40
869 #define DA9063_ALARM_YEAR_MASK                  0x3F
870
871 /* DA9063_REG_WAIT (addr=0x97)*/
872 #define DA9063_REG_WAIT_TIME_MASK               0xF
873 #define DA9063_WAIT_TIME_0_US                   0x0
874 #define DA9063_WAIT_TIME_512_US                 0x1
875 #define DA9063_WAIT_TIME_1_MS                   0x2
876 #define DA9063_WAIT_TIME_2_MS                   0x3
877 #define DA9063_WAIT_TIME_4_1_MS                 0x4
878 #define DA9063_WAIT_TIME_8_2_MS                 0x5
879 #define DA9063_WAIT_TIME_16_4_MS                0x6
880 #define DA9063_WAIT_TIME_32_8_MS                0x7
881 #define DA9063_WAIT_TIME_65_5_MS                0x8
882 #define DA9063_WAIT_TIME_128_MS                 0x9
883 #define DA9063_WAIT_TIME_256_MS                 0xA
884 #define DA9063_WAIT_TIME_512_MS                 0xB
885 #define DA9063_WAIT_TIME_1_S                    0xC
886 #define DA9063_WAIT_TIME_2_1_S                  0xD
887
888 /* DA9063_REG_EN_32K  (addr=0x98)*/
889 #define DA9063_STABILIZ_TIME_MASK               0x7
890 #define DA9063_CRYSTAL                          0x08
891 #define DA9063_DELAY_MODE                       0x10
892 #define DA9063_OUT_CLOCK                        0x20
893 #define DA9063_RTC_CLOCK                        0x40
894 #define DA9063_OUT_32K_EN                       0x80
895
896 /* DA9063_REG_CHIP_VARIANT */
897 #define DA9063_CHIP_VARIANT_SHIFT               4
898
899 /* DA9063_REG_BUCK_ILIM_A (addr=0x9A) */
900 #define DA9063_BIO_ILIM_MASK                    0x0F
901 #define DA9063_BMEM_ILIM_MASK                   0xF0
902
903 /* DA9063_REG_BUCK_ILIM_B (addr=0x9B) */
904 #define DA9063_BPRO_ILIM_MASK                   0x0F
905 #define DA9063_BPERI_ILIM_MASK                  0xF0
906
907 /* DA9063_REG_BUCK_ILIM_C (addr=0x9C) */
908 #define DA9063_BCORE1_ILIM_MASK                 0x0F
909 #define DA9063_BCORE2_ILIM_MASK                 0xF0
910
911 /* DA9063_REG_Bxxxx_CFG common bits (addr=0x9D-0xA2) */
912 #define DA9063_BUCK_FB_MASK                     0x07
913 #define DA9063_BUCK_PD_DIS_MASK         0x20
914 #define DA9063_BUCK_MODE_MASK                   0xC0
915 #define         DA9063_BUCK_MODE_MANUAL         0x00
916 #define         DA9063_BUCK_MODE_SLEEP          0x40
917 #define         DA9063_BUCK_MODE_SYNC           0x80
918 #define         DA9063_BUCK_MODE_AUTO           0xC0
919
920 /* DA9063_REG_BPRO_CFG (addr=0x9F) */
921 #define DA9063_BPRO_VTTR_EN                     0x08
922 #define DA9063_BPRO_VTT_EN                      0x10
923
924 /* DA9063_REG_VBxxxx_A/B (addr=0xA3-0xA8, 0xB4-0xB9) */
925 #define DA9063_VBUCK_MASK                       0x7F
926 #define DA9063_VBUCK_BIAS                       0
927 #define DA9063_BUCK_SL                          0x80
928
929 /* DA9063_REG_VLDOx_A/B (addr=0xA9-0x3, 0xBA-0xC4) */
930 #define DA9063_LDO_SL                           0x80
931
932 /* DA9063_REG_VLDO1_A/B (addr=0xA9, 0xBA) */
933 #define DA9063_VLDO1_MASK                       0x3F
934 #define DA9063_VLDO1_BIAS                       0
935
936 /* DA9063_REG_VLDO2_A/B (addr=0xAA, 0xBB) */
937 #define DA9063_VLDO2_MASK                       0x3F
938 #define DA9063_VLDO2_BIAS                       0
939
940 /* DA9063_REG_VLDO3_A/B (addr=0xAB, 0xBC) */
941 #define DA9063_VLDO3_MASK                       0x7F
942 #define DA9063_VLDO3_BIAS                       0
943
944 /* DA9063_REG_VLDO4_A/B (addr=0xAC, 0xBD) */
945 #define DA9063_VLDO4_MASK                       0x7F
946 #define DA9063_VLDO4_BIAS                       0
947
948 /* DA9063_REG_VLDO5_A/B (addr=0xAD, 0xBE) */
949 #define DA9063_VLDO5_MASK                       0x3F
950 #define DA9063_VLDO5_BIAS                       2
951
952 /* DA9063_REG_VLDO6_A/B (addr=0xAE, 0xBF) */
953 #define DA9063_VLDO6_MASK                       0x3F
954 #define DA9063_VLDO6_BIAS                       2
955
956 /* DA9063_REG_VLDO7_A/B (addr=0xAF, 0xC0) */
957 #define DA9063_VLDO7_MASK                       0x3F
958 #define DA9063_VLDO7_BIAS                       2
959
960 /* DA9063_REG_VLDO8_A/B (addr=0xB0, 0xC1) */
961 #define DA9063_VLDO8_MASK                       0x3F
962 #define DA9063_VLDO8_BIAS                       2
963
964 /* DA9063_REG_VLDO9_A/B (addr=0xB1, 0xC2) */
965 #define DA9063_VLDO9_MASK                       0x3F
966 #define DA9063_VLDO9_BIAS                       3
967
968 /* DA9063_REG_VLDO10_A/B (addr=0xB2, 0xC3) */
969 #define DA9063_VLDO10_MASK                      0x3F
970 #define DA9063_VLDO10_BIAS                      2
971
972 /* DA9063_REG_VLDO11_A/B (addr=0xB3, 0xC4) */
973 #define DA9063_VLDO11_MASK                      0x3F
974 #define DA9063_VLDO11_BIAS                      2
975
976 /* DA9063_REG_GPO11_LED (addr=0xC6) */
977 /* DA9063_REG_GPO14_LED (addr=0xC7) */
978 /* DA9063_REG_GPO15_LED (addr=0xC8) */
979 #define DA9063_GPIO_DIM                         0x80
980 #define DA9063_GPIO_PWM_MASK                    0x7F
981
982 /* DA9063_REG_CONFIG_H (addr=0x10D) */
983 #define DA9063_PWM_CLK_MASK                     0x01
984 #define         DA9063_PWM_CLK_PWM2MHZ          0x00
985 #define         DA9063_PWM_CLK_PWM1MHZ          0x01
986 #define DA9063_LDO8_MODE_MASK                   0x02
987 #define         DA9063_LDO8_MODE_LDO            0
988 #define         DA9063_LDO8_MODE_VIBR           0x02
989 #define DA9063_MERGE_SENSE_MASK                 0x04
990 #define         DA9063_MERGE_SENSE_GP_FB2       0x00
991 #define         DA9063_MERGE_SENSE_GPIO4        0x04
992 #define DA9063_BCORE_MERGE                      0x08
993 #define DA9063_BPRO_OD                          0x10
994 #define DA9063_BCORE2_OD                        0x20
995 #define DA9063_BCORE1_OD                        0x40
996 #define DA9063_BUCK_MERGE                       0x80
997
998 /* DA9063_REG_CONFIG_I (addr=0x10E) */
999 #define DA9063_NONKEY_PIN_MASK                  0x03
1000 #define         DA9063_NONKEY_PIN_PORT          0x00
1001 #define         DA9063_NONKEY_PIN_SWDOWN        0x01
1002 #define         DA9063_NONKEY_PIN_AUTODOWN      0x02
1003 #define         DA9063_NONKEY_PIN_AUTOFLPRT     0x03
1004
1005 /* DA9063_REG_MON_REG_5 (addr=0x116) */
1006 #define DA9063_MON_A8_IDX_MASK                  0x07
1007 #define         DA9063_MON_A8_IDX_NONE          0x00
1008 #define         DA9063_MON_A8_IDX_BCORE1        0x01
1009 #define         DA9063_MON_A8_IDX_BCORE2        0x02
1010 #define         DA9063_MON_A8_IDX_BPRO          0x03
1011 #define         DA9063_MON_A8_IDX_LDO3          0x04
1012 #define         DA9063_MON_A8_IDX_LDO4          0x05
1013 #define         DA9063_MON_A8_IDX_LDO11         0x06
1014 #define DA9063_MON_A9_IDX_MASK                  0x70
1015 #define         DA9063_MON_A9_IDX_NONE          0x00
1016 #define         DA9063_MON_A9_IDX_BIO           0x01
1017 #define         DA9063_MON_A9_IDX_BMEM          0x02
1018 #define         DA9063_MON_A9_IDX_BPERI         0x03
1019 #define         DA9063_MON_A9_IDX_LDO1          0x04
1020 #define         DA9063_MON_A9_IDX_LDO2          0x05
1021 #define         DA9063_MON_A9_IDX_LDO5          0x06
1022
1023 /* DA9063_REG_MON_REG_6 (addr=0x117) */
1024 #define DA9063_MON_A10_IDX_MASK                 0x07
1025 #define         DA9063_MON_A10_IDX_NONE         0x00
1026 #define         DA9063_MON_A10_IDX_LDO6         0x01
1027 #define         DA9063_MON_A10_IDX_LDO7         0x02
1028 #define         DA9063_MON_A10_IDX_LDO8         0x03
1029 #define         DA9063_MON_A10_IDX_LDO9         0x04
1030 #define         DA9063_MON_A10_IDX_LDO10        0x05
1031
1032 #endif /* _DA9063_REG_H */