1 /***************************************************************************
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
10 * Copyright (c) 2008 by Michael Sevakis
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation; either version 2
15 * of the License, or (at your option) any later version.
17 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18 * KIND, either express or implied.
20 ****************************************************************************/
24 enum mc13783_regs_enum
26 MC13783_INTERRUPT_STATUS0
= 0,
27 MC13783_INTERRUPT_MASK0
= 1,
28 MC13783_INTERRUPT_SENSE0
= 2,
29 MC13783_INTERRUPT_STATUS1
= 3,
30 MC13783_INTERRUPT_MASK1
= 4,
31 MC13783_INTERRUPT_SENSE1
= 5,
32 MC13783_POWER_UP_MODE_SENSE
= 6,
33 MC13783_IDENTIFICATION
= 7,
34 MC13783_SEMAPHORE
= 8,
35 MC13783_ARBITRATION_PERIPHERAL_AUDIO
= 9,
36 MC13783_ARBITRATION_SWITCHERS
= 10,
37 MC13783_ARBITRATION_REGULATORS0
= 11,
38 MC13783_ARBITRATION_REGULATORS1
= 12,
39 MC13783_POWER_CONTROL0
= 13,
40 MC13783_POWER_CONTROL1
= 14,
41 MC13783_POWER_CONTROL2
= 15,
42 MC13783_REGEN_ASSIGNMENT
= 16,
43 MC13783_CONTROL_SPARE
= 17, /* x */
46 MC13783_RTC_TIME
= 20,
47 MC13783_RTC_ALARM
= 21,
49 MC13783_RTC_DAY_ALARM
= 23,
50 MC13783_SWITCHERS0
= 24,
51 MC13783_SWITCHERS1
= 25,
52 MC13783_SWITCHERS2
= 26,
53 MC13783_SWITCHERS3
= 27,
54 MC13783_SWITCHERS4
= 28,
55 MC13783_SWITCHERS5
= 29,
56 MC13783_REGULATOR_SETTING0
= 30,
57 MC13783_REGULATOR_SETTING1
= 31,
58 MC13783_REGULATOR_MODE0
= 32,
59 MC13783_REGULATOR_MODE1
= 33,
60 MC13783_POWER_MISCELLANEOUS
= 34,
61 MC13783_POWER_SPARE
= 35, /* x */
62 MC13783_AUDIO_RX0
= 36,
63 MC13783_AUDIO_RX1
= 37,
64 MC13783_AUDIO_TX
= 38,
65 MC13783_SSI_NETWORK
= 39,
66 MC13783_AUDIO_CODEC
= 40,
67 MC13783_AUDIO_STEREO_DAC
= 41,
68 MC13783_AUDIO_SPARE
= 42, /* x */
76 MC13783_CHARGER_USB1
= 50,
77 MC13783_LED_CONTROL0
= 51,
78 MC13783_LED_CONTROL1
= 52,
79 MC13783_LED_CONTROL2
= 53,
80 MC13783_LED_CONTROL3
= 54,
81 MC13783_LED_CONTROL4
= 55,
82 MC13783_LED_CONTROL5
= 56,
83 MC13783_SPARE
= 57, /* x */
84 MC13783_TRIM0
= 58, /* x */
85 MC13783_TRIM1
= 59, /* x */
86 MC13783_TEST0
= 60, /* x */
87 MC13783_TEST1
= 61, /* x */
88 MC13783_TEST2
= 62, /* x */
89 MC13783_TEST3
= 63, /* x */
90 MC13783_NUM_REGS
= 64,
92 /* x = unused/reserved/not implemented */
94 /* INTERRUPT_STATUS0 (0) */
95 #define MC13783_ADCDONEI (0x1 << 0)
96 #define MC13783_ADCBISDONEI (0x1 << 1)
97 #define MC13783_TSI (0x1 << 2)
98 #define MC13783_WHIGHI (0x1 << 3)
99 #define MC13783_WLOWI (0x1 << 4)
100 #define MC13783_CHGDETI (0x1 << 6)
101 #define MC13783_CHGOVI (0x1 << 7)
102 #define MC13783_CHGREVI (0x1 << 8)
103 #define MC13783_CHGSHORTI (0x1 << 9)
104 #define MC13783_CCCVI (0x1 << 10)
105 #define MC13783_CHGCURRI (0x1 << 11)
106 #define MC13783_BPONII (0x1 << 12)
107 #define MC13783_LOBATLI (0x1 << 13)
108 #define MC13783_LOBATHI (0x1 << 14)
109 #define MC13783_UDPI (0x1 << 15)
110 #define MC13783_USBI (0x1 << 16)
111 #define MC13783_IDFLOATI (0x1 << 19)
112 #define MC13783_SE1I (0x1 << 21)
113 #define MC13783_CKDETI (0x1 << 22)
114 #define MC13783_UDMI (0x1 << 23)
116 /* INTERRUPT_MASK0 (1) */
117 #define MC13783_ADCDONEM (0x1 << 0)
118 #define MC13783_ADCBISDONEM (0x1 << 1)
119 #define MC13783_TSM (0x1 << 2)
120 #define MC13783_WHIGHM (0x1 << 3)
121 #define MC13783_WLOWM (0x1 << 4)
122 #define MC13783_CHGDETM (0x1 << 6)
123 #define MC13783_CHGOVM (0x1 << 7)
124 #define MC13783_CHGREVM (0x1 << 8)
125 #define MC13783_CHGSHORTM (0x1 << 9)
126 #define MC13783_CCCVM (0x1 << 10)
127 #define MC13783_CHGCURRM (0x1 << 11)
128 #define MC13783_BPONIM (0x1 << 12)
129 #define MC13783_LOBATLM (0x1 << 13)
130 #define MC13783_LOBATHM (0x1 << 14)
131 #define MC13783_UDPM (0x1 << 15)
132 #define MC13783_USBM (0x1 << 16)
133 #define MC13783_IDFLOATM (0x1 << 19)
134 #define MC13783_SE1M (0x1 << 21)
135 #define MC13783_CKDETM (0x1 << 22)
136 #define MC13783_UDMM (0x1 << 23)
138 /* INTERRUPT_SENSE0 (2) */
139 #define MC13783_CHGDETS (0x1 << 6)
140 #define MC13783_CHGOVS (0x1 << 7)
141 #define MC13783_CHGREVS (0x1 << 8)
142 #define MC13783_CHGSHORTS (0x1 << 9)
143 #define MC13783_CCCVS (0x1 << 10)
144 #define MC13783_CHGCURRS (0x1 << 11)
145 #define MC13783_BPONIS (0x1 << 12)
146 #define MC13783_LOBATLS (0x1 << 13)
147 #define MC13783_LOBATHS (0x1 << 14)
148 #define MC13783_UDPS (0x1 << 15)
149 #define MC13783_USB4V4S (0x1 << 16)
150 #define MC13783_USB2V0S (0x1 << 17)
151 #define MC13783_USB0V8S (0x1 << 18)
152 #define MC13783_IDFLOATS (0x1 << 19)
153 #define MC13783_SE1S (0x1 << 21)
154 #define MC13783_CKDETS (0x1 << 22)
155 #define MC13783_UDMS (0x1 << 23)
157 /* INTERRUPT_STATUS1 (3) */
158 #define MC13783_1HZI (0x1 << 0)
159 #define MC13783_TODAI (0x1 << 1)
160 #define MC13783_ONOFD1I (0x1 << 3) /* ON1B */
161 #define MC13783_ONOFD2I (0x1 << 4) /* ON2B */
162 #define MC13783_ONOFD3I (0x1 << 5) /* ON3B */
163 #define MC13783_SYSRSTI (0x1 << 6)
164 #define MC13783_RTCRSTI (0x1 << 7)
165 #define MC13783_PCII (0x1 << 8)
166 #define MC13783_WARMI (0x1 << 9)
167 #define MC13783_MEMHLDI (0x1 << 10)
168 #define MC13783_PWRRDYI (0x1 << 11)
169 #define MC13783_THWARNLI (0x1 << 12)
170 #define MC13783_THWARNHI (0x1 << 13)
171 #define MC13783_CLKI (0x1 << 14)
172 #define MC13783_SEMAFI (0x1 << 15)
173 #define MC13783_MC2BI (0x1 << 17)
174 #define MC13783_HSDETI (0x1 << 18)
175 #define MC13783_HSLI (0x1 << 19)
176 #define MC13783_ALSPTHI (0x1 << 20)
177 #define MC13783_AHSSHORTI (0x1 << 21)
179 /* INTERRUPT_MASK1 (4) */
180 #define MC13783_1HZM (0x1 << 0)
181 #define MC13783_TODAM (0x1 << 1)
182 #define MC13783_ONOFD1M (0x1 << 3) /* ON1B */
183 #define MC13783_ONOFD2M (0x1 << 4) /* ON2B */
184 #define MC13783_ONOFD3M (0x1 << 5) /* ON3B */
185 #define MC13783_SYSRSTM (0x1 << 6)
186 #define MC13783_RTCRSTM (0x1 << 7)
187 #define MC13783_PCIM (0x1 << 8)
188 #define MC13783_WARMM (0x1 << 9)
189 #define MC13783_MEMHLDM (0x1 << 10)
190 #define MC13783_PWRRDYM (0x1 << 11)
191 #define MC13783_THWARNLM (0x1 << 12)
192 #define MC13783_THWARNHM (0x1 << 13)
193 #define MC13783_CLKM (0x1 << 14)
194 #define MC13783_SEMAFM (0x1 << 15)
195 #define MC13783_MC2BM (0x1 << 17)
196 #define MC13783_HSDETM (0x1 << 18)
197 #define MC13783_HSLM (0x1 << 19)
198 #define MC13783_ALSPTHM (0x1 << 20)
199 #define MC13783_AHSSHORTM (0x1 << 21)
201 /* INTERRUPT_SENSE1 (5) */
202 #define MC13783_ONOFD1S (0x1 << 3) /* ON1B */
203 #define MC13783_ONOFD2S (0x1 << 4) /* ON2B */
204 #define MC13783_ONOFD3S (0x1 << 5) /* ON3B */
205 #define MC13783_PWRRDYS (0x1 << 11)
206 #define MC13783_THWARNLS (0x1 << 12)
207 #define MC13783_THWARNHS (0x1 << 13)
208 #define MC13783_CLKS (0x1 << 14)
209 #define MC13783_MC2BS (0x1 << 17)
210 #define MC13783_HSDETS (0x1 << 18)
211 #define MC13783_HSLS (0x1 << 19)
212 #define MC13783_ALSPTHS (0x1 << 20)
213 #define MC13783_AHSSHORTS (0x1 << 21)
215 /* POWER_UP_MODE_SENSE (6) */
216 #define MC13783_ICTESTS (0x1 << 0)
217 #define MC13783_CLKSELS (0x1 << 1)
218 #define MC13783_PUMS1S (0x3 << 2)
219 #define MC13783_PUMS1S_LOW (0x0 << 2)
220 #define MC13783_PUMS1S_OPEN (0x1 << 2)
221 #define MC13783_PUMS1S_HIGH (0x2 << 2)
222 #define MC13783_PUMS2S (0x3 << 4)
223 #define MC13783_PUMS2S_LOW (0x0 << 4)
224 #define MC13783_PUMS2S_OPEN (0x1 << 4)
225 #define MC13783_PUMS2S_HIGH (0x2 << 4)
226 #define MC13783_PUMS3S (0x3 << 6)
227 #define MC13783_PUMS3S_LOW (0x0 << 6)
228 #define MC13783_PUMS3S_OPEN (0x1 << 6)
229 #define MC13783_PUMS3S_HIGH (0x2 << 6)
230 #define MC13783_CHRGMOD0S (0x3 << 8)
231 #define MC13783_CHRGMOD0S_LOW (0x0 << 8)
232 #define MC13783_CHRGMOD0S_OPEN (0x1 << 8)
233 #define MC13783_CHRGMOD0S_HIGH (0x3 << 8)
234 #define MC13783_CHRGMOD1S (0x3 << 10)
235 #define MC13783_CHRGMOD1S_LOW (0x0 << 10)
236 #define MC13783_CHRGMOD1S_OPEN (0x1 << 10)
237 #define MC13783_CHRGMOD1S_HIGH (0x3 << 10)
238 #define MC13783_UMODS (0x3 << 12)
239 #define MC13783_UMODS_LOW_UMODS1_LOW (0x0 << 12)
240 #define MC13783_UMODS_OPEN_UMODS1_LOW (0x1 << 12)
241 #define MC13783_UMODS_DONTCARE_UMODS1_HIGH (0x2 << 12)
242 #define MC13783_UMODS_HIGH_UMODS1_LOW (0x3 << 12)
243 #define MC13783_USBENS (0x1 << 14)
244 #define MC13783_SW1ABS (0x1 << 15)
245 #define MC13783_SW2ABS (0x1 << 16)
247 /* IDENTIFICATION (7) */
248 #define MC13783_REVISION (0x1f << 0)
249 #define MC13783_REVISION_POS (0)
250 #define MC13783_ICID (0x7 << 6)
251 #define MC13783_ICID_POS (6)
252 #define MC13783_FIN (0x3 << 9)
253 #define MC13783_FIN_POS (9)
254 #define MC13783_FAB (0x3 << 12)
255 #define MC13783_FAB_POS (12)
258 #define MC13783_SEMCTRLA (0x1 << 0)
259 #define MC13783_SEMCTRLB (0x1 << 2)
260 #define MC13783_SEMWRTA (0xf << 4)
261 #define MC13783_SEMWRTA_POS (4)
262 #define MC13783_SEMWRTB (0x3f << 8)
263 #define MC13783_SEMWRTB_POS (8)
264 #define MC13783_SEMRDA (0xf << 14)
265 #define MC13783_SEMRDA_POS (14)
266 #define MC13783_SEMRDB (0x3f << 18)
267 #define MC13783_SEMRDB_POS (18)
269 /* ARBITRATION_PERIPHERAL_AUDIO (9) */
270 #define MC13783_AUDIOTXSEL (0x3 << 0)
271 #define MC13783_AUDIOTXSEL_PRI_SPI (0x0 << 0)
272 #define MC13783_AUDIOTXSEL_SEC_SPI (0x1 << 0)
273 #define MC13783_AUDIOTXSEL_OR_SPI (0x2 << 0)
274 #define MC13783_AUDIOTXSEL_AND_SPI (0x3 << 0)
275 #define MC13783_TXGAINSEL (0x1 << 2)
276 #define MC13783_AUDIORXSEL (0x3 << 3)
277 #define MC13783_AUDIORXSEL_PRI_SPI (0x0 << 3)
278 #define MC13783_AUDIORXSEL_SEC_SPI (0x1 << 3)
279 #define MC13783_AUDIORXSEL_OR_SPI (0x2 << 3)
280 #define MC13783_AUDIORXSEL_AND_SPI (0x3 << 3)
281 #define MC13783_RXGAINSEL (0x1 << 5)
282 #define MC13783_AUDIOCDCSEL (0x1 << 6)
283 #define MC13783_AUDIOSTDCSEL (0x1 << 7)
284 #define MC13783_BIASSEL (0x3 << 8)
285 #define MC13783_BIASSEL_PRI_SPI (0x0 << 8)
286 #define MC13783_BIASSEL_SEC_SPI (0x1 << 8)
287 #define MC13783_BIASSEL_OR_SPI (0x2 << 8)
288 #define MC13783_BIASSEL_AND_SPI (0x3 << 8)
289 #define MC13783_RTCSEL (0x1 << 11)
290 #define MC13783_ADCSEL (0x3 << 12)
291 #define MC13783_ADCSEL_PRI1_SEC1 (0x0 << 12)
292 #define MC13783_ADCSEL_PRI2_SEC0 (0x1 << 12)
293 #define MC13783_ADCSEL_PRI0_SEC2 (0x2 << 12)
294 /* 0x3 = same as 0x0 */
295 #define MC13783_USBSEL (0x1 << 14)
296 #define MC13783_CHRGSEL (0x1 << 15)
297 #define MC13783_BLLEDSEL (0x1 << 16)
298 #define MC13783_TCLEDSEL (0x1 << 17)
299 #define MC13783_ADAPTSEL (0x1 << 18)
301 /* ARBITRATION_SWITCHERS (10) */
302 #define MC13783_SW1ASTBYAND (0x1 << 0)
303 #define MC13783_SW1BSTBYAND (0x1 << 1)
304 #define MC13783_SW2ASTBYAND (0x1 << 2)
305 #define MC13783_SW2BSTBYAND (0x1 << 3)
306 #define MC13783_SW3SEL0 (0x1 << 4)
307 #define MC13783_SW1ABDVS (0x1 << 5)
308 #define MC13783_SW2ABDVS (0x1 << 6)
309 #define MC13783_SW1ASEL (0x1 << 7)
310 #define MC13783_SW1BSEL (0x1 << 8)
311 #define MC13783_SW2ASEL (0x1 << 9)
312 #define MC13783_SW2BSEL (0x1 << 10)
313 #define MC13783_PLLSEL (0x1 << 12)
314 #define MC13783_PWGT1SEL (0x1 << 14)
315 #define MC13783_PWGT2SEL (0x1 << 15)
317 /* ARBITRATION_REGULATORS0 (11) */
318 #define MC13783_VAUDIOSEL (0x3 << 0)
319 #define MC13783_VAUDIOSEL_PRI (0x0 << 0)
320 #define MC13783_VIOHISEL (0x3 << 2)
321 #define MC13783_VIOHISEL_PRI (0x0 << 2)
322 #define MC13783_VIOLOSEL (0x3 << 4)
323 #define MC13783_VIOLOSEL_PRI (0x0 << 4)
324 #define MC13783_VDIGSEL (0x3 << 6)
325 #define MC13783_VDIGSEL_PRI (0x0 << 6)
326 #define MC13783_VGENSEL (0x3 << 8)
327 #define MC13783_VGENSEL_PRI (0x0 << 8)
328 #define MC13783_VRFDIGSEL (0x3 << 10)
329 #define MC13783_VRFDIGSEL_PRI (0x0 << 10)
330 #define MC13783_VRFREFSEL (0x3 << 12)
331 #define MC13783_VRFREFSEL_PRI (0x0 << 12)
332 #define MC13783_VRFCPSEL (0x3 << 14)
333 #define MC13783_VRFCPSEL_PRI (0x0 << 14)
334 #define MC13783_VSIMSEL (0x3 << 16)
335 #define MC13783_VSIMSEL_PRI (0x0 << 16)
336 #define MC13783_VESIMSEL (0x3 << 18)
337 #define MC13783_VESIMSEL_PRI (0x0 << 18)
338 #define MC13783_VCAMSEL (0x3 << 20)
339 #define MC13783_VCAMSEL_PRI (0x0 << 20)
340 #define MC13783_VRFBGSEL (0x3 << 22)
341 #define MC13783_VRFBGSEL_PRI (0x0 << 22)
343 /* ARBITRATION_REGULATORS1 (12) */
344 #define MC13783_VVIBSEL (0x3 << 0)
345 #define MC13783_VVIBSEL_PRI (0x0 << 0)
346 #define MC13783_VRF1SEL (0x3 << 2)
347 #define MC13783_VRF1SEL_PRI (0x0 << 2)
348 #define MC13783_VRF2SEL (0x3 << 4)
349 #define MC13783_VRF2SEL_PRI (0x0 << 4)
350 #define MC13783_VMMC1SEL (0x3 << 6)
351 #define MC13783_VMMC1SEL_PRI (0x0 << 6)
352 #define MC13783_VMMC2SEL (0x3 << 8)
353 #define MC13783_VMMC2SEL_PRI (0x0 << 8)
354 #define MC13783_GPO1SEL (0x3 << 14)
355 #define MC13783_GPO1SEL_PRI (0x0 << 14)
356 #define MC13783_GPO1SEL_BOTH (0x1 << 14)
357 #define MC13783_GPO1SEL_AND (0x3 << 14)
358 #define MC13783_GPO2SEL (0x3 << 16)
359 #define MC13783_GPO2SEL_PRI (0x0 << 16)
360 #define MC13783_GPO2SEL_BOTH (0x1 << 16)
361 #define MC13783_GPO2SEL_AND (0x3 << 16)
362 #define MC13783_GPO3SEL (0x3 << 18)
363 #define MC13783_GPO3SEL_PRI (0x0 << 18)
364 #define MC13783_GPO3SEL_BOTH (0x1 << 18)
365 #define MC13783_GPO3SEL_AND (0x3 << 18)
366 #define MC13783_GPO4SEL (0x3 << 20)
367 #define MC13783_GPO4SEL_PRI (0x0 << 20)
368 #define MC13783_GPO4SEL_BOTH (0x1 << 20)
369 #define MC13783_GPO4SEL_AND (0x3 << 20)
371 /* POWER_CONTROL0 (13) */
372 #define MC13783_PCEN (0x1 << 0)
373 #define MC13783_PCCOUNTEN (0x1 << 1)
374 #define MC13783_WARMEN (0x1 << 2)
375 #define MC13783_USEROFFSPI (0x1 << 3)
376 #define MC13783_USEROFFPC (0x1 << 4)
377 #define MC13783_USEROFFCLK (0x1 << 5)
378 #define MC13783_CLK32KMCUEN (0x1 << 6)
379 #define MC13783_VBKUP2AUTOMH (0x1 << 7)
380 #define MC13783_VBKUP1EN (0x1 << 8)
381 #define MC13783_VBKUPAUTO (0x1 << 9)
382 #define MC13783_VBKUP1 (0x3 << 10)
383 #define MC13783_VBKUP1_1_0V (0x0 << 10)
384 #define MC13783_VBKUP1_1_2V (0x1 << 10)
385 #define MC13783_VBKUP1_1_575V (0x2 << 10)
386 #define MC13783_VBKUP1_1_8V (0x3 << 10)
387 #define MC13783_VBKUP2EN (0x1 << 12)
388 #define MC13783_VBKUP2AUTO (0x1 << 13)
389 #define MC13783_VBKUP2 (0x3 << 14)
390 #define MC13783_VBKUP2_1_0V (0x0 << 14)
391 #define MC13783_VBKUP2_1_2V (0x1 << 14)
392 #define MC13783_VBKUP2_1_5V (0x2 << 14)
393 #define MC13783_VBKUP2_1_8V (0x3 << 14)
394 #define MC13783_BPDET (0x3 << 16)
395 /* 00: UVDET 2.6, LOBATL UVDET+0.2, LOBATH UVDET+0.4 BPON 3.2 */
396 #define MC13783_BPDET_2_4 (0x0 << 16)
397 /* 01: UVDET 2.6, LOBATL UVDET+0.3, LOBATH UVDET+0.5 BPON 3.2 */
398 #define MC13783_BPDET_3_5 (0x1 << 16)
399 /* 10: UVDET 2.6, LOBATL UVDET+0.4, LOBATH UVDET+0.7 BPON 3.2 */
400 #define MC13783_BPDET_4_7 (0x2 << 16)
401 /* 11: UVDET 2.6, LOBATL UVDET+0.5, LOBATH UVDET+0.8 BPON 3.2 */
402 #define MC13783_BPDET_5_8 (0x3 << 16)
403 #define MC13783_EOLSEL (0x1 << 18)
404 #define MC13783_BATTDETEN (0x1 << 19)
405 #define MC13783_VCOIN (0x7 << 20)
406 #define MC13783_VCOIN_2_50V (0x0 << 20)
407 #define MC13783_VCOIN_2_70V (0x1 << 20)
408 #define MC13783_VCOIN_2_80V (0x2 << 20)
409 #define MC13783_VCOIN_2_90V (0x3 << 20)
410 #define MC13783_VCOIN_3_00V (0x4 << 20)
411 #define MC13783_VCOIN_3_10V (0x5 << 20)
412 #define MC13783_VCOIN_3_20V (0x6 << 20)
413 #define MC13783_VCOIN_3_30V (0x7 << 20)
414 #define MC13783_COINCHEN (0x1 << 23)
416 /* POWER_CONTROL1 (14) */
417 /* Up to 8 seconds */
418 #define MC13783_PCT (0xff << 0)
419 #define MC13783_PCT_POS (0)
420 #define MC13783_PCCOUNT (0xf << 8)
421 #define MC13783_PCCOUNT_POS (8)
422 #define MC13783_PCMAXCNT (0xf << 12)
423 #define MC13783_PCMAXCNT_POS (12)
424 /* Up to 8 minutes with MEMALLON=0, <> 0 + MEMALLON=1: infinite */
425 #define MC13783_MEMTMR (0xf << 16)
426 #define MC13783_MEMTMR_POS (16)
427 #define MC13783_MEMALLON (0x1 << 20)
429 /* POWER_CONTROL2 (15) */
430 #define MC13783_RESTARTEN (0x1 << 0)
431 #define MC13783_ON1BRSTEN (0x1 << 1)
432 #define MC13783_ON2BRSTEN (0x1 << 2)
433 #define MC13783_ON3BTSTEN (0x1 << 3)
434 #define MC13783_ON1BDBNC (0x3 << 4)
435 #define MC13783_ON1BDBNC_0MS (0x0 << 4)
436 #define MC13783_ON1BDBNC_30MS (0x1 << 4)
437 #define MC13783_ON1BDBNC_150MS (0x2 << 4)
438 #define MC13783_ON1BDBNC_750MS (0x3 << 4)
439 #define MC13783_ON2BDBNC (0x3 << 6)
440 #define MC13783_ON2BDBNC_0MS (0x0 << 6)
441 #define MC13783_ON2BDBNC_30MS (0x1 << 6)
442 #define MC13783_ON2BDBNC_150MS (0x2 << 6)
443 #define MC13783_ON2BDBNC_750MS (0x3 << 6)
444 #define MC13783_ON3BDBNC (0x3 << 8)
445 #define MC13783_ON3BDBNC_0MS (0x0 << 8)
446 #define MC13783_ON3BDBNC_30MS (0x1 << 8)
447 #define MC13783_ON3BDBNC_150MS (0x2 << 8)
448 #define MC13783_ON3BDBNC_750MS (0x3 << 8)
449 #define MC13783_STANDBYPRIINV (0x1 << 10)
450 #define MC13783_STANDBYSECINV (0x1 << 11)
452 /* REGEN_ASSIGNMENT (16) */
453 #define MC13783_VAUDIOREGEN (0x1 << 0)
454 #define MC13783_VIOHIREGEN (0x1 << 1)
455 #define MC13783_VIOLOREGEN (0x1 << 2)
456 #define MC13783_VDIGREGEN (0x1 << 3)
457 #define MC13783_VGENREGEN (0x1 << 4)
458 #define MC13783_VRFDIGREGEN (0x1 << 5)
459 #define MC13783_VRFREFREGEN (0x1 << 6)
460 #define MC13783_VRFCPREGEN (0x1 << 7)
461 #define MC13783_VCAMREGEN (0x1 << 8)
462 #define MC13783_VRFBGREGEN (0x1 << 9)
463 #define MC13783_VRF1REGEN (0x1 << 10)
464 #define MC13783_VRF2REGEN (0x1 << 11)
465 #define MC13783_VMMC1REGEN (0x1 << 12)
466 #define MC13783_VMMC2REGEN (0x1 << 13)
467 #define MC13783_GPO1REGEN (0x1 << 16)
468 #define MC13783_GPO2REGEN (0x1 << 17)
469 #define MC13783_GPO3REGEN (0x1 << 18)
470 #define MC13783_GPO4REGEN (0x1 << 19)
471 #define MC13783_REGENINV (0x1 << 20)
472 #define MC13783_VESIMESIMEN (0x1 << 21)
473 #define MC13783_VMMC1ESIMEN (0x1 << 22)
474 #define MC13783_VMMC2ESIMEN (0x1 << 23)
477 #define MC13783_MEMORYA_MASK (0xffffff)
480 #define MC13783_MEMORYB_MASK (0xffffff)
483 #define MC13783_RTC_TIME_MASK (0x1ffff)
486 #define MC13783_RTC_ALARM_MASK (0x1ffff)
489 #define MC13783_RTC_DAY_MASK (0x7fff)
491 /* RTC_DAY_ALARM (23) */
492 #define MC13783_RTC_DAY_ALARM_MASK (0x7fff)
494 /* SWITCHERS0 (24) */
495 #define MC13783_SW1A (0x3f << 0)
496 #define MC13783_SW1A_POS (0)
497 #define MC13783_SW1ADVS (0x3f << 6)
498 #define MC13783_SW1ADVS_POS (6)
499 #define MC13783_SW1ASTBY (0x3f << 12)
500 #define MC13783_SW1ASTBY_POS (12)
502 /* SWITCHERS1 (25) */
503 #define MC13783_SW1B (0x3f << 0)
504 #define MC13783_SW1B_POS (0)
505 #define MC13783_SW1BDVS (0x3f << 6)
506 #define MC13783_SW1BDVS_POS (6)
507 #define MC13783_SW1BSTBY (0x3f << 12)
508 #define MC13783_SW1BSTBY_POS (12)
510 /* SWITCHERS2 (26) */
511 #define MC13783_SW2A (0x3f << 0)
512 #define MC13783_SW2A_POS (0)
513 #define MC13783_SW2ADVS (0x3f << 6)
514 #define MC13783_SW2ADVS_POS (6)
515 #define MC13783_SW2ASTBY (0x3f << 12)
516 #define MC13783_SW2ASTBY_POS (12)
518 /* SWITCHERS3 (27) */
519 #define MC13783_SW2B (0x3f << 0)
520 #define MC13783_SW2B_POS (0)
521 #define MC13783_SW2BDVS (0x3f << 6)
522 #define MC13783_SW2BDVS_POS (6)
523 #define MC13783_SW2BSTBY (0x3f << 12)
524 #define MC13783_SW2BSTBY_POS (12)
526 /* SWITCHERS4 (28) */
527 #define MC13783_SW1AMODE (0x3 << 0)
528 #define MC13783_SW1AMODE_OFF (0x0 << 0)
529 #define MC13783_SW1AMODE_PWM (0x1 << 0)
530 #define MC13783_SW1AMODE_PWM_SKIP (0x2 << 0)
531 #define MC13783_SW1AMODE_PFM (0x3 << 0)
532 #define MC13783_SW1ASTBYMODE (0x3 << 2)
533 #define MC13783_SW1ASTBYMODE_OFF (0x0 << 2)
534 #define MC13783_SW1ASTBYMODE_PWM (0x1 << 2)
535 #define MC13783_SW1ASTBYMODE_PWM_SKIP (0x2 << 2)
536 #define MC13783_SW1ASTBYMODE_PFM (0x3 << 2)
537 #define MC13783_SW1ADVSSPEED (0x3 << 6)
539 #define MC13783_SW1ADVSSPEED_4US_NO_PWR_RDY (0x0 << 6)
540 #define MC13783_SW1ADVSSPEED_4US (0x1 << 6)
541 #define MC13783_SW1ADVSSPEED_8US (0x2 << 6)
542 #define MC13783_SW1ADVSSPEED_16US (0x3 << 6)
543 #define MC13783_SW1APANIC (0x1 << 8)
544 #define MC13783_SW1ASFST (0x1 << 9)
545 #define MC13783_SW1BMODE (0x3 << 10)
546 #define MC13783_SW1BMODE_OFF (0x0 << 10)
547 #define MC13783_SW1BMODE_PWM (0x1 << 10)
548 #define MC13783_SW1BMODE_PWM_SKIP (0x2 << 10)
549 #define MC13783_SW1BMODE_PFM (0x3 << 10)
550 #define MC13783_SW1BSTBYMODE (0x3 << 12)
551 #define MC13783_SW1BSTBYMODE_OFF (0x0 << 12)
552 #define MC13783_SW1BSTBYMODE_PWM (0x1 << 12)
553 #define MC13783_SW1BSTBYMODE_PWM_SKIP (0x2 << 12)
554 #define MC13783_SW1BSTBYMODE_PFM (0x3 << 12)
555 #define MC13783_SW1BDVSSPEED (0x3 << 14)
557 #define MC13783_SW1BDVSSPEED_4US_NO_PWR_RDY (0x0 << 14)
558 #define MC13783_SW1BDVSSPEED_4US (0x1 << 14)
559 #define MC13783_SW1BDVSSPEED_8US (0x2 << 14)
560 #define MC13783_SW1BDVSSPEED_16US (0x3 << 14)
561 #define MC13783_SW1BPANIC (0x1 << 16)
562 #define MC13783_SW1BSFST (0x1 << 17)
563 #define MC13783_PLLEN (0x1 << 18)
564 #define MC13783_PLLX (0x7 << 19)
565 #define MC13783_PLLX_28 (0x0 << 19)
566 #define MC13783_PLLX_29 (0x1 << 19)
567 #define MC13783_PLLX_30 (0x2 << 19)
568 #define MC13783_PLLX_31 (0x3 << 19)
569 #define MC13783_PLLX_32 (0x4 << 19)
570 #define MC13783_PLLX_33 (0x5 << 19)
571 #define MC13783_PLLX_34 (0x6 << 19)
572 #define MC13783_PLLX_35 (0x7 << 19)
574 /* SWITCHERS5 (29) */
575 #define MC13783_SW2AMODE (0x3 << 0)
576 #define MC13783_SW2AMODE_OFF (0x0 << 0)
577 #define MC13783_SW2AMODE_PWM (0x1 << 0)
578 #define MC13783_SW2AMODE_PWM_SKIP (0x2 << 0)
579 #define MC13783_SW2AMODE_PFM (0x3 << 0)
580 #define MC13783_SW2ASTBYMODE (0x3 << 2)
581 #define MC13783_SW2ASTBYMODE_OFF (0x0 << 2)
582 #define MC13783_SW2ASTBYMODE_PWM (0x1 << 2)
583 #define MC13783_SW2ASTBYMODE_PWM_SKIP (0x2 << 2)
584 #define MC13783_SW2ASTBYMODE_PFM (0x3 << 2)
585 #define MC13783_SW2ADVSSPEED (0x3 << 6)
586 #define MC13783_SW2ADVSSPEED_4US_NO_PWR_RDY (0x0 << 6)
587 #define MC13783_SW2ADVSSPEED_4US (0x1 << 6)
588 #define MC13783_SW2ADVSSPEED_8US (0x2 << 6)
589 #define MC13783_SW2ADVSSPEED_16US (0x3 << 6)
590 #define MC13783_SW2APANIC (0x1 << 8)
591 #define MC13783_SW2ASFST (0x1 << 9)
592 #define MC13783_SW2BMODE (0x3 << 10)
593 #define MC13783_SW2BMODE_OFF (0x0 << 10)
594 #define MC13783_SW2BMODE_PWM (0x1 << 10)
595 #define MC13783_SW2BMODE_PWM_SKIP (0x2 << 10)
596 #define MC13783_SW2BMODE_PFM (0x3 << 10)
597 #define MC13783_SW2BSTBYMODE (0x3 << 12)
598 #define MC13783_SW2BSTBYMODE_OFF (0x0 << 12)
599 #define MC13783_SW2BSTBYMODE_PWM (0x1 << 12)
600 #define MC13783_SW2BSTBYMODE_PWM_SKIP (0x2 << 12)
601 #define MC13783_SW2BSTBYMODE_PFM (0x3 << 12)
602 #define MC13783_SW2BDVSSPEED (0x3 << 14)
603 #define MC13783_SW2BDVSSPEED_4US_NO_PWR_RDY (0x0 << 14)
604 #define MC13783_SW2BDVSSPEED_4US (0x1 << 14)
605 #define MC13783_SW2BDVSSPEED_8US (0x2 << 14)
606 #define MC13783_SW2BDVSSPEED_16US (0x3 << 14)
607 #define MC13783_SW2BPANIC (0x1 << 16)
608 #define MC13783_SW2BSFST (0x1 << 17)
609 #define MC13783_SW3 (0x3 << 18)
610 #define MC13783_SW3_5_0V (0x0 << 18)
611 /* 0x1...0x2 same as 0x0 */
612 #define MC13783_SW3_5_5V (0x3 << 18)
613 #define MC13783_SW3EN (0x1 << 20)
614 #define MC13783_SW3STBY (0x1 << 21)
615 #define MC13783_SW3MODE (0x1 << 22)
617 /* REGULATOR_SETTING0 (30) */
618 #define MC13783_VIOLO (0x3 << 2)
619 #define MC13783_VIOLO_1_20V (0x0 << 2)
620 #define MC13783_VIOLO_1_30V (0x1 << 2)
621 #define MC13783_VIOLO_1_50V (0x2 << 2)
622 #define MC13783_VIOLO_1_80V (0x3 << 2)
623 #define MC13783_VDIG (0x3 << 4)
624 #define MC13783_VDIG_1_20V (0x0 << 4)
625 #define MC13783_VDIG_1_30V (0x1 << 4)
626 #define MC13783_VDIG_1_50V (0x2 << 4)
627 #define MC13783_VDIG_1_80V (0x3 << 4)
628 #define MC13783_VGEN (0x7 << 6)
629 #define MC13783_VGEN_1_20V (0x0 << 6)
630 #define MC13783_VGEN_1_30V (0x1 << 6)
631 #define MC13783_VGEN_1_50V (0x2 << 6)
632 #define MC13783_VGEN_1_80V (0x3 << 6)
633 #define MC13783_VGEN_1_10V (0x4 << 6)
634 #define MC13783_VGEN_2_00V (0x5 << 6)
635 #define MC13783_VGEN_2_775V (0x6 << 6)
636 #define MC13783_VGEN_2_40V (0x7 << 6)
637 #define MC13783_VRFDIG (0x3 << 9)
638 #define MC13783_VREFDIG_1_20V (0x0 << 9)
639 #define MC13783_VREFDIG_1_30V (0x1 << 9)
640 #define MC13783_VREFDIG_1_80V (0x2 << 9)
641 #define MC13783_VREFDIG_1_875V (0x3 << 9)
642 #define MC13783_VRFREF (0x3 << 11)
643 #define MC13783_VRFREF_2_475V (0x0 << 11)
644 #define MC13783_VRFREF_2_600V (0x1 << 11)
645 #define MC13783_VRFREF_2_700V (0x2 << 11)
646 #define MC13783_VRFREF_2_775V (0x3 << 11)
647 #define MC13783_VRFCP (0x1 << 13)
648 #define MC13783_VSIM (0x1 << 14)
649 #define MC13783_VESIM (0x1 << 15)
650 #define MC13783_VCAM (0x7 << 16)
651 #define MC13783_VCAM_1_50V (0x0 << 16)
652 #define MC13783_VCAM_1_80V (0x1 << 16)
653 #define MC13783_VCAM_2_50V (0x2 << 16)
654 #define MC13783_VCAM_2_55V (0x3 << 16)
655 #define MC13783_VCAM_2_60V (0x4 << 16)
656 #define MC13783_VCAM_2_75V (0x5 << 16)
657 #define MC13783_VCAM_2_80V (0x6 << 16)
658 #define MC13783_VCAM_3_00V (0x7 << 16)
660 /* REGULATOR_SETTING1 (31) */
661 #define MC13783_VVIB (0x3 << 0)
662 #define MC13783_VVIB_1_30V (0x0 << 0)
663 #define MC13783_VVIB_1_80V (0x1 << 0)
664 #define MC13783_VVIB_2_00V (0x2 << 0)
665 #define MC13783_VVIB_3_00V (0x3 << 0)
666 #define MC13783_VRF1 (0x3 << 2)
667 #define MC13783_VRF1_1_500V (0x0 << 2)
668 #define MC13783_VRF1_1_875V (0x1 << 2)
669 #define MC13783_VRF1_2_700V (0x2 << 2)
670 #define MC13783_VRF1_2_775V (0x3 << 2)
671 #define MC13783_VRF2 (0x3 << 4)
672 #define MC13783_VRF2_1_500V (0x0 << 4)
673 #define MC13783_VRF2_1_875V (0x1 << 4)
674 #define MC13783_VRF2_2_700V (0x2 << 4)
675 #define MC13783_VRF2_2_775V (0x3 << 4)
676 #define MC13783_VMMC1 (0x7 << 6)
677 #define MC13783_VMMC1_1_60V (0x0 << 6)
678 #define MC13783_VMMC1_1_80V (0x1 << 6)
679 #define MC13783_VMMC1_2_00V (0x2 << 6)
680 #define MC13783_VMMC1_2_60V (0x3 << 6)
681 #define MC13783_VMMC1_2_70V (0x4 << 6)
682 #define MC13783_VMMC1_2_80V (0x5 << 6)
683 #define MC13783_VMMC1_2_90V (0x6 << 6)
684 #define MC13783_VMMC1_3_00V (0x7 << 6)
685 #define MC13783_VMMC2 (0x7 << 9)
686 #define MC13783_VMMC2_1_60V (0x0 << 9)
687 #define MC13783_VMMC2_1_80V (0x1 << 9)
688 #define MC13783_VMMC2_2_00V (0x2 << 9)
689 #define MC13783_VMMC2_2_60V (0x3 << 9)
690 #define MC13783_VMMC2_2_70V (0x4 << 9)
691 #define MC13783_VMMC2_2_80V (0x5 << 9)
692 #define MC13783_VMMC2_2_90V (0x6 << 9)
693 #define MC13783_VMMC2_3_00V (0x7 << 9)
695 /* REGULATOR_MODE0 (32) */
696 #define MC13783_VAUDIOEN (0x1 << 0)
697 #define MC13783_VAUDIOSTBY (0x1 << 1)
698 #define MC13783_VAUDIOMODE (0x1 << 2)
699 #define MC13783_VIOHIEN (0x1 << 3)
700 #define MC13783_VIOHISTBY (0x1 << 4)
701 #define MC13783_VIOHIMODE (0x1 << 5)
702 #define MC13783_VIOLOEN (0x1 << 6)
703 #define MC13783_VIOLOSTBY (0x1 << 7)
704 #define MC13783_VIOLOMODE (0x1 << 8)
705 #define MC13783_VDIGEN (0x1 << 9)
706 #define MC13783_VDIGSTBY (0x1 << 10)
707 #define MC13783_VDIGMODE (0x1 << 11)
708 #define MC13783_VGENEN (0x1 << 12)
709 #define MC13783_VGENSTBY (0x1 << 13)
710 #define MC13783_VGENMODE (0x1 << 14)
711 #define MC13783_VRFDIGEN (0x1 << 15)
712 #define MC13783_VRFDIGSTBY (0x1 << 16)
713 #define MC13783_VRFDIGMODE (0x1 << 17)
714 #define MC13783_VRFREFEN (0x1 << 18)
715 #define MC13783_VRFREFSTBY (0x1 << 19)
716 #define MC13783_VRFREFMODE (0x1 << 20)
717 #define MC13783_VRFCPEN (0x1 << 21)
718 #define MC13783_VRFCPSTBY (0x1 << 22)
719 #define MC13783_VRFCPMODE (0x1 << 23)
721 /* REGULATOR_MODE1 (33) */
722 #define MC13783_VSIMEN (0x1 << 0)
723 #define MC13783_VSIMSTBY (0x1 << 1)
724 #define MC13783_VSIMMODE (0x1 << 2)
725 #define MC13783_VESIMEN (0x1 << 3)
726 #define MC13783_VESIMSTBY (0x1 << 4)
727 #define MC13783_VESIMMODE (0x1 << 5)
728 #define MC13783_VCAMEN (0x1 << 6)
729 #define MC13783_VCAMSTBY (0x1 << 7)
730 #define MC13783_VCAMMODE (0x1 << 8)
731 #define MC13783_VRFBGEN (0x1 << 9)
732 #define MC13783_VRFBGSTBY (0x1 << 10)
733 #define MC13783_VVIBEN (0x1 << 11)
734 #define MC13783_VRF1EN (0x1 << 12)
735 #define MC13783_VRF1STBY (0x1 << 13)
736 #define MC13783_VRF1MODE (0x1 << 14)
737 #define MC13783_VRF2EN (0x1 << 15)
738 #define MC13783_VRF2STBY (0x1 << 16)
739 #define MC13783_VRF2MODE (0x1 << 17)
740 #define MC13783_VMMC1EN (0x1 << 18)
741 #define MC13783_VMMC1STBY (0x1 << 19)
742 #define MC13783_VMMC1MODE (0x1 << 20)
743 #define MC13783_VMMC2EN (0x1 << 21)
744 #define MC13783_VMMC2STBY (0x1 << 22)
745 #define MC13783_VMMC2MODE (0x1 << 23)
747 /* POWER_MISCELLANEOUS (34) */
748 #define MC13783_GPO1EN (0x1 << 6)
749 #define MC13783_GPO1STBY (0x1 << 7)
750 #define MC13783_GPO2EN (0x1 << 8)
751 #define MC13783_GPO2STBY (0x1 << 9)
752 #define MC13783_GPO3EN (0x1 << 10)
753 #define MC13783_GPO3STBY (0x1 << 11)
754 #define MC13783_GPO4EN (0x1 << 12)
755 #define MC13783_GPO4STBY (0x1 << 13)
756 #define MC13783_VIBPINCTRL (0x1 << 14)
757 #define MC13783_PWGT1SPIEN (0x1 << 15)
758 #define MC13783_PWGT2SPIEN (0x1 << 16)
761 #define MC13783_VAUDIOON (0x1 << 0)
762 #define MC13783_BIASEN (0x1 << 1)
763 #define MC13783_BIASSPEED (0x1 << 2)
764 #define MC13783_ASPEN (0x1 << 3)
765 #define MC13783_ASPSEL (0x1 << 4)
766 #define MC13783_ALSPEN (0x1 << 5)
767 #define MC13783_ALSPREF (0x1 << 6)
768 #define MC13783_ALSPSEL (0x1 << 7)
769 #define MC13783_LSPLEN (0x1 << 8)
770 #define MC13783_AHSREN (0x1 << 9)
771 #define MC13783_AHSLEN (0x1 << 10)
772 #define MC13783_AHSSEL (0x1 << 11)
773 #define MC13783_HSPGDIS (0x1 << 12)
774 #define MC13783_HSDETEN (0x1 << 13)
775 #define MC13783_HSDETAUTOB (0x1 << 14)
776 #define MC13783_ARXOUTREN (0x1 << 15)
777 #define MC13783_ARXOUTLEN (0x1 << 16)
778 #define MC13783_ARXOUTSEL (0x1 << 17)
779 #define MC13783_CDCOUTEN (0x1 << 18)
780 #define MC13783_HSLDETEN (0x1 << 19)
781 #define MC13783_ADDCDC (0x1 << 21)
782 #define MC13783_ADDSTDC (0x1 << 22)
783 #define MC13783_ADDRXIN (0x1 << 23)
786 #define MC13783_PGARXEN (0x1 << 0)
787 /* <=0010=-33dB...1101=0dB...1111=+6dB in 3dB steps */
788 #define MC13783_PGARX (0xf << 1)
789 #define MC13783_PGARX_POS (1)
790 #define MC13783_PGASTEN (0x1 << 5)
791 /* <=0010=-33dB...1101=0dB...1111=+6dB in 3dB steps */
792 #define MC13783_PGAST (0xf << 6)
793 #define MC13783_PGAST_POS (6)
794 #define MC13783_ARXINEN (0x1 << 10)
795 #define MC13783_ARXIN (0x1 << 11)
796 /* <=0010=-33dB...1101=0dB...1111=+6dB in 3dB steps */
797 #define MC13783_PGARXIN (0xf << 12)
798 #define MC13783_PGARXIN_POS (12)
799 #define MC13783_MONO (0x3 << 16)
800 #define MC13783_MONO_LR_INDEPENDENT (0x0 << 16)
801 #define MC13783_MONO_ST_OPPOSITE (0x1 << 16)
802 #define MC13783_MONO_ST_TO_MONO (0x2 << 16)
803 #define MC13783_MONO_MONO_OPPOSITE (0x3 << 16)
804 /* 000=-21dB...3dB steps...111=0dB: left or right */
805 #define MC13783_BAL (0x7 << 18)
806 #define MC13783_BAL_POS (18)
807 #define MC13783_BALLR (0x1 << 21)
810 #define MC13783_MC1BEN (0x1 << 0)
811 #define MC13783_MC2BEN (0x1 << 1)
812 #define MC13783_MC2BDETDBNC (0x1 << 2)
813 #define MC13783_MC2BDETEN (0x1 << 3)
814 #define MC13783_AMC1REN (0x1 << 5)
815 #define MC13783_AMC1RITOV (0x1 << 6)
816 #define MC13783_AMC1LEN (0x1 << 7)
817 #define MC13783_AMC1LITOV (0x1 << 8)
818 #define MC13783_AMC2EN (0x1 << 9)
819 #define MC13783_AMC2ITOV (0x1 << 10)
820 #define MC13783_ATXINEN (0x1 << 11)
821 #define MC13783_ATXOUTEN (0x1 << 12)
822 #define MC13783_RXINREC (0x1 << 13)
823 /* 00000=-8dB...01000=0dB...11111=+23dB */
824 #define MC13783_PGATXR (0x1f << 14)
825 #define MC13783_PGATXR_POS (14)
826 /* 00000=-8dB...01000=0dB...11111=+23dB */
827 #define MC13783_PGATXL (0x1f << 19)
828 #define MC13783_PGATXL_POS (19)
830 /* SSI_NETWORK (39) */
831 #define MC13783_CDCTXRXSLOT (0x3 << 2)
832 #define MC13783_CDCTXRXSLOT_TS0 (0x0 << 2)
833 #define MC13783_CDCTXRXSLOT_TS1 (0x1 << 2)
834 #define MC13783_CDCTXRXSLOT_TS2 (0x2 << 2)
835 #define MC13783_CDCTXRXSLOT_TS3 (0x3 << 2)
836 #define MC13783_CDCTXSECSLOT (0x3 << 4)
837 #define MC13783_CDCTXSECSLOT_TS0 (0x0 << 4)
838 #define MC13783_CDCTXSECSLOT_TS1 (0x1 << 4)
839 #define MC13783_CDCTXSECSLOT_TS2 (0x2 << 4)
840 #define MC13783_CDCTXSECSLOT_TS3 (0x3 << 4)
841 #define MC13783_CDCRXSECSLOT (0x3 << 6)
842 #define MC13783_CDCRXSECSLOT_TS0 (0x0 << 6)
843 #define MC13783_CDCRXSECSLOT_TS1 (0x1 << 6)
844 #define MC13783_CDCRXSECSLOT_TS2 (0x2 << 6)
845 #define MC13783_CDCRXSECSLOT_TS3 (0x3 << 6)
846 /* -inf, -0dB, -6dB, -12dB */
847 #define MC13783_CDCRXSECGAIN (0x3 << 8)
848 #define MC13783_CDCRXSECGAIN_POS (8)
849 #define MC13783_CDCSUMGAIN (0x1 << 10)
850 #define MC13783_CDCFSDLY (0x1 << 11)
851 #define MC13783_STDCSLOTS (0x3 << 12)
852 #define MC13783_STDCSLOTS_8 (0x0 << 12)
853 #define MC13783_STDCSLOTS_LR6 (0x1 << 12)
854 #define MC13783_STDCSLOTS_LR2 (0x2 << 12)
855 #define MC13783_STDCSLOTS_LR (0x3 << 12)
856 #define MC13783_STDCRXSLOT (0x3 << 14)
857 #define MC13783_STDCRXSLOT_TS0_TS1 (0x0 << 14)
858 #define MC13783_STDCRXSLOT_TS2_TS3 (0x1 << 14)
859 #define MC13783_STDCRXSLOT_TS4_TS5 (0x2 << 14)
860 #define MC13783_STDCRXSLOT_TS6_TS7 (0x3 << 14)
861 #define MC13783_STDCRXSECSLOT (0x3 << 16)
862 #define MC13783_STDCRXSECSLOT_TS0_TS1 (0x0 << 16)
863 #define MC13783_STDCRXSECSLOT_TS2_TS3 (0x1 << 16)
864 #define MC13783_STDCRXSECSLOT_TS4_TS5 (0x2 << 16)
865 #define MC13783_STDCRXSECSLOT_TS6_TS7 (0x3 << 16)
866 /* -inf, -0dB, -6dB, -12dB */
867 #define MC13783_STDCRXSECGAIN (0x3 << 18)
868 #define MC13783_STDCRXSECGAIN_POS (18)
869 #define MC13783_STDSUMGAIN (0x1 << 20)
871 /* AUDIO_CODEC (40) */
872 #define MC13783_CDCSSISEL (0x1 << 0)
873 #define MC13783_CDCCLKSEL (0x1 << 1)
874 #define MC13783_CDCSM (0x1 << 2)
875 #define MC13783_CDCBCLINV (0x1 << 3)
876 #define MC13783_CDCFSINV (0x1 << 4)
877 #define MC13783_CDCFS (0x3 << 5)
878 #define MC13783_CDCFS_NET (0x1 << 5)
879 #define MC13783_CDCFS_I2S (0x2 << 5)
880 #define MC13783_CDCCLK (0x7 << 7)
881 #define MC13783_CDCFS8K16K (0x1 << 10)
882 #define MC13783_CDCEN (0x1 << 11)
883 #define MC13783_CDCCLKEN (0x1 << 12)
884 #define MC13783_CDCTS (0x1 << 13)
885 #define MC13783_CDCDITH (0x1 << 14)
886 #define MC13783_CDCRESET (0x1 << 15)
887 #define MC13783_CDCBYP (0x1 << 16)
888 #define MC13783_CDCALM (0x1 << 17)
889 #define MC13783_CDCDLM (0x1 << 18)
890 #define MC13783_AUDIHPF (0x1 << 19)
891 #define MC13783_AUDOHPF (0x1 << 20)
893 /* AUDIO_STEREO_DAC (41) */
894 #define MC13783_STDCSSISEL (0x1 << 0)
895 #define MC13783_STDCCLKSEL (0x1 << 1)
896 #define MC13783_STDCSM (0x1 << 2)
897 #define MC13783_STDCBCLINV (0x1 << 3)
898 #define MC13783_STDCFSINV (0x1 << 4)
899 #define MC13783_STDCFS (0x3 << 5)
900 #define MC13783_STDCFS_NORMAL (0x0 << 5)
901 #define MC13783_STDCFS_NET (0x1 << 5)
902 #define MC13783_STDCFS_I2S (0x2 << 5)
903 #define MC13783_STDCCLK (0x7 << 7)
905 #define MC13783_STDCCLK_13_0MHZ (0x0 << 7)
906 #define MC13783_STDCCLK_15_36MHZ (0x1 << 7)
907 #define MC13783_STDCCLK_16_8MHZ (0x2 << 7)
908 #define MC13783_STDCCLK_26_0MHZ (0x4 << 7)
909 #define MC13783_STDCCLK_12_0MHZ (0x5 << 7)
910 #define MC13783_STDCCLK_3_6864MHZ (0x6 << 7)
911 #define MC13783_STDCCLK_33_6MHZ (0x7 << 7)
913 #define MC13783_STDCCLK_CLIMCL (0x5 << 7)
914 #define MC13783_STDCCLK_FS (0x6 << 7)
915 #define MC13783_STDCCLK_BCL (0x7 << 7)
916 #define MC13783_STDCFSDLYB (0x1 << 10)
917 #define MC13783_STDCEN (0x1 << 11)
918 #define MC13783_STDCCLKEN (0x1 << 12)
919 #define MC13783_STDCRESET (0x1 << 15)
920 #define MC13783_SPDIF (0x1 << 16)
921 #define MC13783_SR (0xf << 17)
922 #define MC13783_SR_8000 (0x0 << 17)
923 #define MC13783_SR_11025 (0x1 << 17)
924 #define MC13783_SR_12000 (0x2 << 17)
925 #define MC13783_SR_16000 (0x3 << 17)
926 #define MC13783_SR_22050 (0x4 << 17)
927 #define MC13783_SR_24000 (0x5 << 17)
928 #define MC13783_SR_32000 (0x6 << 17)
929 #define MC13783_SR_44100 (0x7 << 17)
930 #define MC13783_SR_48000 (0x8 << 17)
931 #define MC13783_SR_64000 (0x9 << 17)
932 #define MC13783_SR_96000 (0xa << 17)
935 #define MC13783_LICELLCON (0x1 << 0)
936 #define MC13783_CHRGICON (0x1 << 1)
937 #define MC13783_BATICON (0x1 << 2)
938 #define MC13783_RTHEN (0x1 << 3)
939 #define MC13783_DTHEN (0x1 << 4)
940 #define MC13783_UIDEN (0x1 << 5)
941 #define MC13783_ADOUTEN (0x1 << 6)
942 #define MC13783_ADOUTPER (0x1 << 7)
943 #define MC13783_ADREFEN (0x1 << 10)
944 #define MC13783_ADREFMODE (0x1 << 11)
945 #define MC13783_TSMOD (0x7 << 12)
946 #define MC13783_TSMOD_INACTIVE (0x0 << 12)
947 #define MC13783_TSMOD_INTERRUPT (0x1 << 12)
948 #define MC13783_TSMOD_RESISTIVE (0x2 << 12)
949 #define MC13783_TSMOD_POSITION (0x3 << 12)
950 /* 0x4 - 0x7 = Inactive (same as 0x0) */
951 #define MC13783_CHRGRAWDIV (0x1 << 15)
952 #define MC13783_ADINC1 (0x1 << 16)
953 #define MC13783_ADINC2 (0x1 << 17)
954 #define MC13783_WCOMP (0x1 << 18)
955 #define MC13783_ADCBIS0_ACCESS (0x1 << 23)
958 #define MC13783_ADEN (0x1 << 0)
959 #define MC13783_RAND (0x1 << 1)
960 #define MC13783_ADSEL (0x1 << 3)
961 #define MC13783_TRIGMASK (0x1 << 4)
962 #define MC13783_ADA1 (0x7 << 5)
963 #define MC13783_ADA1_POS (5)
964 #define MC13783_ADA2 (0x7 << 8)
965 #define MC13783_ADA2_POS (8)
966 #define MC13783_ATO (0xff << 11)
967 #define MC13783_ATO_POS (11)
968 #define MC13783_ATOX (0x1 << 19)
969 #define MC13783_ASC (0x1 << 20)
970 #define MC13783_ADTRIGIGN (0x1 << 21)
971 #define MC13783_ADONESHOT (0x1 << 22)
972 #define MC13783_ADCBIS1_ACCESS (0x1 << 23)
975 #define MC13783_ADD1 (0x3ff << 2)
976 #define MC13783_ADD1_POS (2)
977 #define MC13783_ADD2 (0x3ff << 14)
978 #define MC13783_ADD2_POS (14)
981 #define MC13783_WHIGH (0x3f << 0)
982 #define MC13783_WHIGH_POS (0)
983 #define MC13783_ICID (0x7 << 6)
984 #define MC13783_ICID_POS (6)
985 #define MC13783_WLOW (0x3f << 9)
986 #define MC13783_WLOW_POS (9)
987 #define MC13783_ADCBIS2_ACCESS (0x1 << 23)
990 #define MC13783_ADCBIS1 (0x3ff << 2)
991 #define MC13783_ADCBIS1_POS (2)
992 #define MC13783_ADCBIS2 (0x3ff << 14)
993 #define MC13783_ADCBIS2_POS (14)
996 #define MC13783_VCHRG (0x7 << 0)
997 #define MC13783_VCHRG_4_050V (0x0 << 0)
998 #define MC13783_VCHRG_4_375V (0x1 << 0)
999 #define MC13783_VCHRG_4_150V (0x2 << 0)
1000 #define MC13783_VCHRG_4_200V (0x3 << 0)
1001 #define MC13783_VCHRG_4_250V (0x4 << 0)
1002 #define MC13783_VCHRG_4_300V (0x5 << 0)
1003 #define MC13783_VCHRG_3_800V (0x6 << 0)
1004 #define MC13783_VCHRG_4_500V (0x7 << 0)
1005 #define MC13783_ICHRG (0xf << 3) /* Min Nom Max */
1006 #define MC13783_ICHRG_POS (3)
1007 #define MC13783_ICHRG_0MA (0x0 << 3) /* 0 0 0 */
1008 #define MC13783_ICHRG_70MA (0x1 << 3) /* 55 70 85 */
1009 #define MC13783_ICHRG_177MA (0x2 << 3) /* 161 177 195 */
1010 #define MC13783_ICHRG_266MA (0x3 << 3) /* 242 266 293 */
1011 #define MC13783_ICHRG_355MA (0x4 << 3) /* 322 355 390 */
1012 #define MC13783_ICHRG_443MA (0x5 << 3) /* 403 443 488 */
1013 #define MC13783_ICHRG_532MA (0x6 << 3) /* 484 532 585 */
1014 #define MC13783_ICHRG_621MA (0x7 << 3) /* 564 621 683 */
1015 #define MC13783_ICHRG_709MA (0x8 << 3) /* 645 709 780 */
1016 #define MC13783_ICHRG_798MA (0x9 << 3) /* 725 798 878 */
1017 #define MC13783_ICHRG_886MA (0xa << 3) /* 806 886 975 */
1018 #define MC13783_ICHRG_975MA (0xb << 3) /* 886 975 1073 */
1019 #define MC13783_ICHRG_1064MA (0xc << 3) /* 967 1064 1170 */
1020 #define MC13783_ICHRG_1152MA (0xd << 3) /* 1048 1152 1268 */
1021 #define MC13783_ICHRG_1596MA (0xe << 3) /* 1450 1596 1755 */
1022 #define MC13783_ICHRG_FULLY_ON (0xf << 3) /* Disallow HW FET turn on */
1023 #define MC13783_ICHRGTR (0x7 << 7) /* Min Nom Max */
1024 #define MC13783_ICHRGTR_POS (7)
1025 #define MC13783_ICHRGTR_0MA (0x0 << 7) /* 0 0 0 */
1026 #define MC13783_ICHRGTR_9MA (0x1 << 7) /* 6 9 12 */
1027 #define MC13783_ICHRGTR_20MA (0x2 << 7) /* 14 20 26 */
1028 #define MC13783_ICHRGTR_36MA (0x3 << 7) /* 25 36 47 */
1029 #define MC13783_ICHRGTR_42MA (0x4 << 7) /* 29 42 55 */
1030 #define MC13783_ICHRGTR_50MA (0x5 << 7) /* 35 50 65 */
1031 #define MC13783_ICHRGTR_59MA (0x6 << 7) /* 41 59 77 */
1032 #define MC13783_ICHRGTR_68MA (0x7 << 7) /* 50 68 86 */
1033 #define MC13783_FETOVRD (0x1 << 10)
1034 #define MC13783_FETCTRL (0x1 << 11)
1035 #define MC13783_RVRSMODE (0x1 << 13)
1036 #define MC13783_OVCTRL (0x3 << 15)
1037 #define MC13783_OVCTRL_5_83V (0x0 << 15) /* Not for separate! */
1038 #define MC13783_OVCTRL_6_90V (0x1 << 15)
1039 #define MC13783_OVCTRL_9_80V (0x2 << 15)
1040 #define MC13783_OVCTRL_19_6V (0x3 << 15)
1041 #define MC13783_UCHEN (0x1 << 17)
1042 #define MC13783_CHRGLEDEN (0x1 << 18)
1043 #define MC13783_CHRGRAWPDEN (0x1 << 19)
1046 #define MC13783_FSENB (0x1 << 0)
1047 #define MC13783_USBSUSPEND (0x1 << 1)
1048 #define MC13783_USBPU (0x1 << 2)
1049 #define MC13783_UDPPD (0x1 << 3)
1050 #define MC13783_UDMPD (0x1 << 4)
1051 #define MC13783_DP150KPU (0x1 << 5)
1052 #define MC13783_VBUS70KPDENB (0x1 << 6)
1053 #define MC13783_VBUSPULSETMR (0x7 << 7)
1054 #define MC13783_VBUSPULSETMR_NA (0x0 << 7)
1055 #define MC13783_VBUSPULSETMR_10MS (0x1 << 7)
1056 #define MC13783_VBUSPULSETMR_20MS (0x2 << 7)
1057 #define MC13783_VBUSPULSETMR_30MS (0x3 << 7)
1058 #define MC13783_VBUSPULSETMR_40MS (0x4 << 7)
1059 #define MC13783_VBUSPULSETMR_50MS (0x5 << 7)
1060 #define MC13783_VBUSPULSETMR_60MS (0x6 << 7)
1061 #define MC13783_VBUSPULSETMR_INF (0x7 << 7)
1062 #define MC13783_DLPSRP (0x1 << 10)
1063 #define MC13783_SE0CONN (0x1 << 11)
1064 #define MC13783_USBXCVREN (0x1 << 12)
1065 #define MC13783_CONMODE (0x7 << 14)
1066 #define MC13783_CONMODE_USB (0x0 << 14)
1067 #define MC13783_CONMODE_RS232 (0x1 << 14) /* and 0x2 */
1068 #define MC13783_CONMODE_CEA_936_A (0x4 << 14) /* and 0x5...0x7 */
1069 #define MC13783_DATSE0 (0x1 << 17)
1070 #define MC13783_BIDIR (0x1 << 18)
1071 #define MC13783_USBCNTRL (0x1 << 19)
1072 #define MC13783_IDPD (0x1 << 20)
1073 #define MC13783_IDPULSE (0x1 << 21)
1074 #define MC13783_IDPUCNTRL (0x1 << 22)
1075 #define MC13783_DMPULSE (0x1 << 23)
1077 /* CHARGER_USB1 (50) */
1078 #define MC13783_USBIN (0x3 << 0)
1079 #define MC13783_USBIN_BOOST_VINBUS (0x0 << 0)
1080 #define MC13783_USBIN_VBUS (0x1 << 0) /* and 0x3 */
1081 #define MC13783_USBIN_BP (0x2 << 0) /* VINVIB */
1082 #define MC13783_VUSB (0x1 << 2) /* 0=3.2V, 1=3.3V */
1083 #define MC13783_VUSBEN (0x1 << 3)
1084 #define MC13783_VBUSEN (0x1 << 5)
1085 #define MC13783_RSPOL (0x1 << 6)
1086 #define MC13783_RSTRI (0x1 << 7)
1087 #define MC13783_ID100KPU (0x1 << 8)
1089 /* LED_CONTROL0 (51) */
1090 #define MC13783_LEDEN (0x1 << 0)
1091 #define MC13783_LEDMDRAMPUP (0x1 << 1)
1092 #define MC13783_LEDADRAMPUP (0x1 << 2)
1093 #define MC13783_LEDKDRAMPUP (0x1 << 3)
1094 #define MC13783_LEDMDRAMPDOWN (0x1 << 4)
1095 #define MC13783_LEDADRAMPDOWN (0x1 << 5)
1096 #define MC13783_LEDKDRAMPDOWN (0x1 << 6)
1097 #define MC13783_TRIODEMD (0x1 << 7)
1098 #define MC13783_TRIODEAD (0x1 << 8)
1099 #define MC13783_TRIODEKD (0x1 << 9)
1100 #define MC13783_BOOSTEN (0x1 << 10)
1101 #define MC13783_ABMODE (0x7 << 11)
1102 #define MC13783_ABMODE_ADAPTIVE_BOOST_DISABLED (0x0 << 11)
1103 #define MC13783_ABMODE_MONCH_LEDMD1 (0x1 << 11)
1104 #define MC13783_ABMODE_MONCH_LEDMD12 (0x2 << 11)
1105 #define MC13783_ABMODE_MONCH_LEDMD123 (0x3 << 11)
1106 #define MC13783_ABMODE_MONCH_LEDMD1234 (0x4 << 11)
1107 #define MC13783_ABMODE_MONCH_LEDMD1234_LEADAD1 (0x5 << 11)
1108 #define MC13783_ABMODE_MONCH_LEDMD1234_LEADAD12 (0x6 << 11)
1109 #define MC13783_ABMODE_MONCH_LEDMD1_LEDAD_ACT (0x7 << 11)
1110 #define MC13783_ABREF (0x3 << 14)
1111 #define MC13783_ABREF_200MV (0x0 << 14)
1112 #define MC13783_ABREF_400MV (0x1 << 14)
1113 #define MC13783_ABREF_600MV (0x2 << 14)
1114 #define MC13783_ABREF_800MV (0x3 << 14)
1115 #define MC13783_FLPATTRN (0xf << 17)
1116 #define MC13783_FLPATTRN_POS (17)
1117 #define MC13783_FLBANK1 (0x1 << 21)
1118 #define MC13783_FLBANK2 (0x1 << 22)
1119 #define MC13783_FLBANK3 (0x1 << 23)
1121 /* LED_CONTROL1 (52) */
1122 #define MC13783_LEDR1RAMPUP (0x1 << 0)
1123 #define MC13783_LEDG1RAMPUP (0x1 << 1)
1124 #define MC13783_LEDB1RAMPUP (0x1 << 2)
1125 #define MC13783_LEDR1RAMPDOWN (0x1 << 3)
1126 #define MC13783_LEDG1RAMPDOWN (0x1 << 4)
1127 #define MC13783_LEDB1RAMPDOWN (0x1 << 5)
1128 #define MC13783_LEDR2RAMPUP (0x1 << 6)
1129 #define MC13783_LEDG2RAMPUP (0x1 << 7)
1130 #define MC13783_LEDB2RAMPUP (0x1 << 8)
1131 #define MC13783_LEDR2RAMPDOWN (0x1 << 9)
1132 #define MC13783_LEDG2RAMPDOWN (0x1 << 10)
1133 #define MC13783_LEDB2RAMPDOWN (0x1 << 11)
1134 #define MC13783_LEDR3RAMPUP (0x1 << 12)
1135 #define MC13783_LEDG3RAMPUP (0x1 << 13)
1136 #define MC13783_LEDB3RAMPUP (0x1 << 14)
1137 #define MC13783_LEDR3RAMPDOWN (0x1 << 15)
1138 #define MC13783_LEDG3RAMPDOWN (0x1 << 16)
1139 #define MC13783_LEDB3RAMPDOWN (0x1 << 17)
1140 #define MC13783_TC1HALF (0x1 << 18)
1141 #define MC13783_SLEWLIMTC (0x1 << 23)
1143 /* LED_CONTROL2 (53) */
1144 #define MC13783_LEDMD (0x7 << 0)
1145 #define MC13783_LEDMD_POS (0)
1146 #define MC13783_LEDAD (0x7 << 3)
1147 #define MC13783_LEDAD_POS (3)
1148 #define MC13783_LEDKP (0x7 << 6)
1149 #define MC13783_LEDKP_POS (6)
1150 #define MC13783_LEDMDDC (0xf << 9)
1151 #define MC13783_LEDMDDC_POS (9)
1152 #define MC13783_LEDADDC (0xf << 13)
1153 #define MC13783_LEDADDC_POS (13)
1154 #define MC13783_LEDKPDC (0xf << 17)
1155 #define MC13783_LEDKPDC_POS (17)
1156 #define MC13783_BLPERIOD (0x1 << 21)
1157 #define MC13783_BLPERIOD_POS (21)
1158 #define MC13783_SLEWLIMBL (0x1 << 23)
1160 /* LED_CONTROL3 (54) */
1161 #define MC13783_LEDR1 (0x3 << 0)
1162 #define MC13783_LEDR1_POS (0)
1163 #define MC13783_LEDG1 (0x3 << 2)
1164 #define MC13783_LEDG1_POS (2)
1165 #define MC13783_LEDB1 (0x3 << 4)
1166 #define MC13783_LEDB1_POS (4)
1167 #define MC13783_LEDR1DC (0x1f << 6)
1168 #define MC13783_LEDR1DC_POS (6)
1169 #define MC13783_LEDG1DC (0x1f << 11)
1170 #define MC13783_LEDG1DC_POS (11)
1171 #define MC13783_LEDB1DC (0x1f << 16)
1172 #define MC13783_LEDB1DC_POS (16)
1173 #define MC13783_TC1PERIOD (0x3 << 21)
1174 #define MC13783_TC1PERIOD_POS (21)
1175 #define MC13783_TC1TRIODE (0x1 << 23)
1177 /* LED_CONTROL4 (55) */
1178 #define MC13783_LEDR2 (0x3 << 0)
1179 #define MC13783_LEDR2_POS (0)
1180 #define MC13783_LEDG2 (0x3 << 2)
1181 #define MC13783_LEDG2_POS (2)
1182 #define MC13783_LEDB2 (0x3 << 4)
1183 #define MC13783_LEDB2_POS (4)
1184 #define MC13783_LEDR2DC (0x1f << 6)
1185 #define MC13783_LEDR2DC_POS (6)
1186 #define MC13783_LEDG2DC (0x1f << 11)
1187 #define MC13783_LEDG2DC_POS (11)
1188 #define MC13783_LEDB2DC (0x1f << 16)
1189 #define MC13783_LEDB2DC_POS (16)
1190 #define MC13783_TC2PERIOD (0x3 << 21)
1191 #define MC13783_TC2PERIOD_POS (21)
1192 #define MC13783_TC2TRIODE (0x1 << 23)
1194 /* LED_CONTROL5 (56) */
1195 #define MC13783_LEDR3 (0x3 << 0)
1196 #define MC13783_LEDR3_POS (0)
1197 #define MC13783_LEDG3 (0x3 << 2)
1198 #define MC13783_LEDG3_POS (2)
1199 #define MC13783_LEDB3 (0x3 << 4)
1200 #define MC13783_LEDB3_POS (4)
1201 #define MC13783_LEDR3DC (0x1f << 6)
1202 #define MC13783_LEDR3DC_POS (6)
1203 #define MC13783_LEDG3DC (0x1f << 11)
1204 #define MC13783_LEDG3DC_POS (11)
1205 #define MC13783_LEDB3DC (0x1f << 16)
1206 #define MC13783_LEDB3DC_POS (16)
1207 #define MC13783_TC3PERIOD (0x3 << 21)
1208 #define MC13783_TC3PERIOD_POS (21)
1209 #define MC13783_TC3TRIODE (0x1 << 23)
1211 /* For event enum values which are target-defined */
1212 #include "mc13783-target.h"
1214 void mc13783_init(void);
1215 void mc13783_close(void);
1216 uint32_t mc13783_set(unsigned address
, uint32_t bits
);
1217 uint32_t mc13783_clear(unsigned address
, uint32_t bits
);
1218 int mc13783_write(unsigned address
, uint32_t data
);
1219 uint32_t mc13783_write_masked(unsigned address
, uint32_t data
, uint32_t mask
);
1220 int mc13783_write_regset(const unsigned char *regs
, const uint32_t *data
, int count
);
1221 uint32_t mc13783_read(unsigned address
);
1222 int mc13783_read_regset(const unsigned char *regs
, uint32_t *buffer
, int count
);
1224 #define MC13783_DATA_ERROR UINT32_MAX
1226 /* Statically-registered event enable/disable */
1227 enum mc13783_event_sets
1229 MC13783_EVENT_SET0
= 0, /* *STATUS0/MASK0/SENSE0 */
1230 MC13783_EVENT_SET1
= 1, /* *STATUS1/MASK1/SENSE1 */
1233 struct mc13783_event
1235 enum mc13783_event_sets set
: 8;
1237 void (*callback
)(void);
1240 struct mc13783_event_list
1243 const struct mc13783_event
*events
;
1246 bool mc13783_enable_event(enum mc13783_event_ids event
);
1247 void mc13783_disable_event(enum mc13783_event_ids event
);
1249 #endif /* _MC13783_H_ */