struct / union in initializer, RFE #901.
[sdcc.git] / sdcc / device / non-free / include / pic14 / pic16f1705.h
blob7f1385370dcd235159051241595f6ae1c3c2cc42
1 /*
2 * This declarations of the PIC16F1705 MCU.
4 * This file is part of the GNU PIC library for SDCC, originally
5 * created by Molnar Karoly <molnarkaroly@users.sf.net> 2016.
7 * This file is generated automatically by the cinc2h.pl, 2016-04-13 17:23:11 UTC.
9 * SDCC is licensed under the GNU Public license (GPL) v2. Note that
10 * this license covers the code to the compiler and other executables,
11 * but explicitly does not cover any code or objects generated by sdcc.
13 * For pic device libraries and header files which are derived from
14 * Microchip header (.inc) and linker script (.lkr) files Microchip
15 * requires that "The header files should state that they are only to be
16 * used with authentic Microchip devices" which makes them incompatible
17 * with the GPL. Pic device libraries and header files are located at
18 * non-free/lib and non-free/include directories respectively.
19 * Sdcc should be run with the --use-non-free command line option in
20 * order to include non-free header files and libraries.
22 * See http://sdcc.sourceforge.net/ for the latest information on sdcc.
25 #ifndef __PIC16F1705_H__
26 #define __PIC16F1705_H__
28 //==============================================================================
30 // Register Addresses
32 //==============================================================================
34 #ifndef NO_ADDR_DEFINES
36 #define INDF0_ADDR 0x0000
37 #define INDF1_ADDR 0x0001
38 #define PCL_ADDR 0x0002
39 #define STATUS_ADDR 0x0003
40 #define FSR0_ADDR 0x0004
41 #define FSR0L_ADDR 0x0004
42 #define FSR0H_ADDR 0x0005
43 #define FSR1_ADDR 0x0006
44 #define FSR1L_ADDR 0x0006
45 #define FSR1H_ADDR 0x0007
46 #define BSR_ADDR 0x0008
47 #define WREG_ADDR 0x0009
48 #define PCLATH_ADDR 0x000A
49 #define INTCON_ADDR 0x000B
50 #define PORTA_ADDR 0x000C
51 #define PORTC_ADDR 0x000E
52 #define PIR1_ADDR 0x0011
53 #define PIR2_ADDR 0x0012
54 #define PIR3_ADDR 0x0013
55 #define TMR0_ADDR 0x0015
56 #define TMR1_ADDR 0x0016
57 #define TMR1L_ADDR 0x0016
58 #define TMR1H_ADDR 0x0017
59 #define T1CON_ADDR 0x0018
60 #define T1GCON_ADDR 0x0019
61 #define TMR2_ADDR 0x001A
62 #define PR2_ADDR 0x001B
63 #define T2CON_ADDR 0x001C
64 #define TRISA_ADDR 0x008C
65 #define TRISC_ADDR 0x008E
66 #define PIE1_ADDR 0x0091
67 #define PIE2_ADDR 0x0092
68 #define PIE3_ADDR 0x0093
69 #define OPTION_REG_ADDR 0x0095
70 #define PCON_ADDR 0x0096
71 #define WDTCON_ADDR 0x0097
72 #define OSCTUNE_ADDR 0x0098
73 #define OSCCON_ADDR 0x0099
74 #define OSCSTAT_ADDR 0x009A
75 #define ADRES_ADDR 0x009B
76 #define ADRESL_ADDR 0x009B
77 #define ADRESH_ADDR 0x009C
78 #define ADCON0_ADDR 0x009D
79 #define ADCON1_ADDR 0x009E
80 #define ADCON2_ADDR 0x009F
81 #define LATA_ADDR 0x010C
82 #define LATC_ADDR 0x010E
83 #define CM1CON0_ADDR 0x0111
84 #define CM1CON1_ADDR 0x0112
85 #define CM2CON0_ADDR 0x0113
86 #define CM2CON1_ADDR 0x0114
87 #define CMOUT_ADDR 0x0115
88 #define BORCON_ADDR 0x0116
89 #define FVRCON_ADDR 0x0117
90 #define DAC1CON0_ADDR 0x0118
91 #define DAC1CON1_ADDR 0x0119
92 #define ZCD1CON_ADDR 0x011C
93 #define ANSELA_ADDR 0x018C
94 #define ANSELC_ADDR 0x018E
95 #define PMADR_ADDR 0x0191
96 #define PMADRL_ADDR 0x0191
97 #define PMADRH_ADDR 0x0192
98 #define PMDAT_ADDR 0x0193
99 #define PMDATL_ADDR 0x0193
100 #define PMDATH_ADDR 0x0194
101 #define PMCON1_ADDR 0x0195
102 #define PMCON2_ADDR 0x0196
103 #define VREGCON_ADDR 0x0197
104 #define RC1REG_ADDR 0x0199
105 #define RCREG_ADDR 0x0199
106 #define RCREG1_ADDR 0x0199
107 #define TX1REG_ADDR 0x019A
108 #define TXREG_ADDR 0x019A
109 #define TXREG1_ADDR 0x019A
110 #define SP1BRG_ADDR 0x019B
111 #define SP1BRGL_ADDR 0x019B
112 #define SPBRG_ADDR 0x019B
113 #define SPBRG1_ADDR 0x019B
114 #define SPBRGL_ADDR 0x019B
115 #define SP1BRGH_ADDR 0x019C
116 #define SPBRGH_ADDR 0x019C
117 #define SPBRGH1_ADDR 0x019C
118 #define RC1STA_ADDR 0x019D
119 #define RCSTA_ADDR 0x019D
120 #define RCSTA1_ADDR 0x019D
121 #define TX1STA_ADDR 0x019E
122 #define TXSTA_ADDR 0x019E
123 #define TXSTA1_ADDR 0x019E
124 #define BAUD1CON_ADDR 0x019F
125 #define BAUDCON_ADDR 0x019F
126 #define BAUDCON1_ADDR 0x019F
127 #define BAUDCTL_ADDR 0x019F
128 #define BAUDCTL1_ADDR 0x019F
129 #define WPUA_ADDR 0x020C
130 #define WPUC_ADDR 0x020E
131 #define SSP1BUF_ADDR 0x0211
132 #define SSPBUF_ADDR 0x0211
133 #define SSP1ADD_ADDR 0x0212
134 #define SSPADD_ADDR 0x0212
135 #define SSP1MSK_ADDR 0x0213
136 #define SSPMSK_ADDR 0x0213
137 #define SSP1STAT_ADDR 0x0214
138 #define SSPSTAT_ADDR 0x0214
139 #define SSP1CON_ADDR 0x0215
140 #define SSP1CON1_ADDR 0x0215
141 #define SSPCON_ADDR 0x0215
142 #define SSPCON1_ADDR 0x0215
143 #define SSP1CON2_ADDR 0x0216
144 #define SSPCON2_ADDR 0x0216
145 #define SSP1CON3_ADDR 0x0217
146 #define SSPCON3_ADDR 0x0217
147 #define ODCONA_ADDR 0x028C
148 #define ODCONC_ADDR 0x028E
149 #define CCPR1_ADDR 0x0291
150 #define CCPR1L_ADDR 0x0291
151 #define CCPR1H_ADDR 0x0292
152 #define CCP1CON_ADDR 0x0293
153 #define ECCP1CON_ADDR 0x0293
154 #define CCPR2_ADDR 0x0298
155 #define CCPR2L_ADDR 0x0298
156 #define CCPR2H_ADDR 0x0299
157 #define CCP2CON_ADDR 0x029A
158 #define ECCP2CON_ADDR 0x029A
159 #define CCPTMRS_ADDR 0x029E
160 #define SLRCONA_ADDR 0x030C
161 #define SLRCONC_ADDR 0x030E
162 #define INLVLA_ADDR 0x038C
163 #define INLVLC_ADDR 0x038E
164 #define IOCAP_ADDR 0x0391
165 #define IOCAN_ADDR 0x0392
166 #define IOCAF_ADDR 0x0393
167 #define IOCCP_ADDR 0x0397
168 #define IOCCN_ADDR 0x0398
169 #define IOCCF_ADDR 0x0399
170 #define TMR4_ADDR 0x0415
171 #define PR4_ADDR 0x0416
172 #define T4CON_ADDR 0x0417
173 #define TMR6_ADDR 0x041C
174 #define PR6_ADDR 0x041D
175 #define T6CON_ADDR 0x041E
176 #define OPA1CON_ADDR 0x0511
177 #define OPA2CON_ADDR 0x0515
178 #define PWM3DCL_ADDR 0x0617
179 #define PWM3DCH_ADDR 0x0618
180 #define PWM3CON_ADDR 0x0619
181 #define PWM3CON0_ADDR 0x0619
182 #define PWM4DCL_ADDR 0x061A
183 #define PWM4DCH_ADDR 0x061B
184 #define PWM4CON_ADDR 0x061C
185 #define PWM4CON0_ADDR 0x061C
186 #define COG1PHR_ADDR 0x0691
187 #define COG1PHF_ADDR 0x0692
188 #define COG1BLKR_ADDR 0x0693
189 #define COG1BLKF_ADDR 0x0694
190 #define COG1DBR_ADDR 0x0695
191 #define COG1DBF_ADDR 0x0696
192 #define COG1CON0_ADDR 0x0697
193 #define COG1CON1_ADDR 0x0698
194 #define COG1RIS_ADDR 0x0699
195 #define COG1RSIM_ADDR 0x069A
196 #define COG1FIS_ADDR 0x069B
197 #define COG1FSIM_ADDR 0x069C
198 #define COG1ASD0_ADDR 0x069D
199 #define COG1ASD1_ADDR 0x069E
200 #define COG1STR_ADDR 0x069F
201 #define PPSLOCK_ADDR 0x0E0F
202 #define INTPPS_ADDR 0x0E10
203 #define T0CKIPPS_ADDR 0x0E11
204 #define T1CKIPPS_ADDR 0x0E12
205 #define T1GPPS_ADDR 0x0E13
206 #define CCP1PPS_ADDR 0x0E14
207 #define CCP2PPS_ADDR 0x0E15
208 #define COGINPPS_ADDR 0x0E17
209 #define SSPCLKPPS_ADDR 0x0E20
210 #define SSPDATPPS_ADDR 0x0E21
211 #define SSPSSPPS_ADDR 0x0E22
212 #define RXPPS_ADDR 0x0E24
213 #define CKPPS_ADDR 0x0E25
214 #define CLCIN0PPS_ADDR 0x0E28
215 #define CLCIN1PPS_ADDR 0x0E29
216 #define CLCIN2PPS_ADDR 0x0E2A
217 #define CLCIN3PPS_ADDR 0x0E2B
218 #define RA0PPS_ADDR 0x0E90
219 #define RA1PPS_ADDR 0x0E91
220 #define RA2PPS_ADDR 0x0E92
221 #define RA4PPS_ADDR 0x0E94
222 #define RA5PPS_ADDR 0x0E95
223 #define RC0PPS_ADDR 0x0EA0
224 #define RC1PPS_ADDR 0x0EA1
225 #define RC2PPS_ADDR 0x0EA2
226 #define RC3PPS_ADDR 0x0EA3
227 #define RC4PPS_ADDR 0x0EA4
228 #define RC5PPS_ADDR 0x0EA5
229 #define CLCDATA_ADDR 0x0F0F
230 #define CLC1CON_ADDR 0x0F10
231 #define CLC1POL_ADDR 0x0F11
232 #define CLC1SEL0_ADDR 0x0F12
233 #define CLC1SEL1_ADDR 0x0F13
234 #define CLC1SEL2_ADDR 0x0F14
235 #define CLC1SEL3_ADDR 0x0F15
236 #define CLC1GLS0_ADDR 0x0F16
237 #define CLC1GLS1_ADDR 0x0F17
238 #define CLC1GLS2_ADDR 0x0F18
239 #define CLC1GLS3_ADDR 0x0F19
240 #define CLC2CON_ADDR 0x0F1A
241 #define CLC2POL_ADDR 0x0F1B
242 #define CLC2SEL0_ADDR 0x0F1C
243 #define CLC2SEL1_ADDR 0x0F1D
244 #define CLC2SEL2_ADDR 0x0F1E
245 #define CLC2SEL3_ADDR 0x0F1F
246 #define CLC2GLS0_ADDR 0x0F20
247 #define CLC2GLS1_ADDR 0x0F21
248 #define CLC2GLS2_ADDR 0x0F22
249 #define CLC2GLS3_ADDR 0x0F23
250 #define CLC3CON_ADDR 0x0F24
251 #define CLC3POL_ADDR 0x0F25
252 #define CLC3SEL0_ADDR 0x0F26
253 #define CLC3SEL1_ADDR 0x0F27
254 #define CLC3SEL2_ADDR 0x0F28
255 #define CLC3SEL3_ADDR 0x0F29
256 #define CLC3GLS0_ADDR 0x0F2A
257 #define CLC3GLS1_ADDR 0x0F2B
258 #define CLC3GLS2_ADDR 0x0F2C
259 #define CLC3GLS3_ADDR 0x0F2D
260 #define ICDBK0H_ADDR 0x0F9E
261 #define STATUS_SHAD_ADDR 0x0FE4
262 #define WREG_SHAD_ADDR 0x0FE5
263 #define BSR_SHAD_ADDR 0x0FE6
264 #define PCLATH_SHAD_ADDR 0x0FE7
265 #define FSR0L_SHAD_ADDR 0x0FE8
266 #define FSR0H_SHAD_ADDR 0x0FE9
267 #define FSR1L_SHAD_ADDR 0x0FEA
268 #define FSR1H_SHAD_ADDR 0x0FEB
269 #define STKPTR_ADDR 0x0FED
270 #define TOSL_ADDR 0x0FEE
271 #define TOSH_ADDR 0x0FEF
273 #endif // #ifndef NO_ADDR_DEFINES
275 //==============================================================================
277 // Register Definitions
279 //==============================================================================
281 extern __at(0x0000) __sfr INDF0;
282 extern __at(0x0001) __sfr INDF1;
283 extern __at(0x0002) __sfr PCL;
285 //==============================================================================
286 // STATUS Bits
288 extern __at(0x0003) __sfr STATUS;
290 typedef struct
292 unsigned C : 1;
293 unsigned DC : 1;
294 unsigned Z : 1;
295 unsigned NOT_PD : 1;
296 unsigned NOT_TO : 1;
297 unsigned : 1;
298 unsigned : 1;
299 unsigned : 1;
300 } __STATUSbits_t;
302 extern __at(0x0003) volatile __STATUSbits_t STATUSbits;
304 #define _C 0x01
305 #define _DC 0x02
306 #define _Z 0x04
307 #define _NOT_PD 0x08
308 #define _NOT_TO 0x10
310 //==============================================================================
312 extern __at(0x0004) __sfr FSR0;
313 extern __at(0x0004) __sfr FSR0L;
314 extern __at(0x0005) __sfr FSR0H;
315 extern __at(0x0006) __sfr FSR1;
316 extern __at(0x0006) __sfr FSR1L;
317 extern __at(0x0007) __sfr FSR1H;
319 //==============================================================================
320 // BSR Bits
322 extern __at(0x0008) __sfr BSR;
324 typedef union
326 struct
328 unsigned BSR0 : 1;
329 unsigned BSR1 : 1;
330 unsigned BSR2 : 1;
331 unsigned BSR3 : 1;
332 unsigned BSR4 : 1;
333 unsigned : 1;
334 unsigned : 1;
335 unsigned : 1;
338 struct
340 unsigned BSR : 5;
341 unsigned : 3;
343 } __BSRbits_t;
345 extern __at(0x0008) volatile __BSRbits_t BSRbits;
347 #define _BSR0 0x01
348 #define _BSR1 0x02
349 #define _BSR2 0x04
350 #define _BSR3 0x08
351 #define _BSR4 0x10
353 //==============================================================================
355 extern __at(0x0009) __sfr WREG;
356 extern __at(0x000A) __sfr PCLATH;
358 //==============================================================================
359 // INTCON Bits
361 extern __at(0x000B) __sfr INTCON;
363 typedef union
365 struct
367 unsigned IOCIF : 1;
368 unsigned INTF : 1;
369 unsigned TMR0IF : 1;
370 unsigned IOCIE : 1;
371 unsigned INTE : 1;
372 unsigned TMR0IE : 1;
373 unsigned PEIE : 1;
374 unsigned GIE : 1;
377 struct
379 unsigned : 1;
380 unsigned : 1;
381 unsigned T0IF : 1;
382 unsigned : 1;
383 unsigned : 1;
384 unsigned T0IE : 1;
385 unsigned : 1;
386 unsigned : 1;
388 } __INTCONbits_t;
390 extern __at(0x000B) volatile __INTCONbits_t INTCONbits;
392 #define _IOCIF 0x01
393 #define _INTF 0x02
394 #define _TMR0IF 0x04
395 #define _T0IF 0x04
396 #define _IOCIE 0x08
397 #define _INTE 0x10
398 #define _TMR0IE 0x20
399 #define _T0IE 0x20
400 #define _PEIE 0x40
401 #define _GIE 0x80
403 //==============================================================================
406 //==============================================================================
407 // PORTA Bits
409 extern __at(0x000C) __sfr PORTA;
411 typedef union
413 struct
415 unsigned RA0 : 1;
416 unsigned RA1 : 1;
417 unsigned RA2 : 1;
418 unsigned RA3 : 1;
419 unsigned RA4 : 1;
420 unsigned RA5 : 1;
421 unsigned : 1;
422 unsigned : 1;
425 struct
427 unsigned RA : 6;
428 unsigned : 2;
430 } __PORTAbits_t;
432 extern __at(0x000C) volatile __PORTAbits_t PORTAbits;
434 #define _RA0 0x01
435 #define _RA1 0x02
436 #define _RA2 0x04
437 #define _RA3 0x08
438 #define _RA4 0x10
439 #define _RA5 0x20
441 //==============================================================================
444 //==============================================================================
445 // PORTC Bits
447 extern __at(0x000E) __sfr PORTC;
449 typedef union
451 struct
453 unsigned RC0 : 1;
454 unsigned RC1 : 1;
455 unsigned RC2 : 1;
456 unsigned RC3 : 1;
457 unsigned RC4 : 1;
458 unsigned RC5 : 1;
459 unsigned : 1;
460 unsigned : 1;
463 struct
465 unsigned RC : 6;
466 unsigned : 2;
468 } __PORTCbits_t;
470 extern __at(0x000E) volatile __PORTCbits_t PORTCbits;
472 #define _RC0 0x01
473 #define _RC1 0x02
474 #define _RC2 0x04
475 #define _RC3 0x08
476 #define _RC4 0x10
477 #define _RC5 0x20
479 //==============================================================================
482 //==============================================================================
483 // PIR1 Bits
485 extern __at(0x0011) __sfr PIR1;
487 typedef union
489 struct
491 unsigned TMR1IF : 1;
492 unsigned TMR2IF : 1;
493 unsigned CCP1IF : 1;
494 unsigned SSP1IF : 1;
495 unsigned TXIF : 1;
496 unsigned RCIF : 1;
497 unsigned ADIF : 1;
498 unsigned TMR1GIF : 1;
501 struct
503 unsigned : 1;
504 unsigned : 1;
505 unsigned CCPIF : 1;
506 unsigned : 1;
507 unsigned : 1;
508 unsigned : 1;
509 unsigned : 1;
510 unsigned : 1;
512 } __PIR1bits_t;
514 extern __at(0x0011) volatile __PIR1bits_t PIR1bits;
516 #define _TMR1IF 0x01
517 #define _TMR2IF 0x02
518 #define _CCP1IF 0x04
519 #define _CCPIF 0x04
520 #define _SSP1IF 0x08
521 #define _TXIF 0x10
522 #define _RCIF 0x20
523 #define _ADIF 0x40
524 #define _TMR1GIF 0x80
526 //==============================================================================
529 //==============================================================================
530 // PIR2 Bits
532 extern __at(0x0012) __sfr PIR2;
534 typedef struct
536 unsigned CCP2IF : 1;
537 unsigned TMR4IF : 1;
538 unsigned TMR6IF : 1;
539 unsigned BCL1IF : 1;
540 unsigned : 1;
541 unsigned C1IF : 1;
542 unsigned C2IF : 1;
543 unsigned OSFIF : 1;
544 } __PIR2bits_t;
546 extern __at(0x0012) volatile __PIR2bits_t PIR2bits;
548 #define _CCP2IF 0x01
549 #define _TMR4IF 0x02
550 #define _TMR6IF 0x04
551 #define _BCL1IF 0x08
552 #define _C1IF 0x20
553 #define _C2IF 0x40
554 #define _OSFIF 0x80
556 //==============================================================================
559 //==============================================================================
560 // PIR3 Bits
562 extern __at(0x0013) __sfr PIR3;
564 typedef struct
566 unsigned CLC1IF : 1;
567 unsigned CLC2IF : 1;
568 unsigned CLC3IF : 1;
569 unsigned : 1;
570 unsigned ZCDIF : 1;
571 unsigned COGIF : 1;
572 unsigned : 1;
573 unsigned : 1;
574 } __PIR3bits_t;
576 extern __at(0x0013) volatile __PIR3bits_t PIR3bits;
578 #define _CLC1IF 0x01
579 #define _CLC2IF 0x02
580 #define _CLC3IF 0x04
581 #define _ZCDIF 0x10
582 #define _COGIF 0x20
584 //==============================================================================
586 extern __at(0x0015) __sfr TMR0;
587 extern __at(0x0016) __sfr TMR1;
588 extern __at(0x0016) __sfr TMR1L;
589 extern __at(0x0017) __sfr TMR1H;
591 //==============================================================================
592 // T1CON Bits
594 extern __at(0x0018) __sfr T1CON;
596 typedef union
598 struct
600 unsigned TMR1ON : 1;
601 unsigned : 1;
602 unsigned NOT_T1SYNC : 1;
603 unsigned T1OSCEN : 1;
604 unsigned T1CKPS0 : 1;
605 unsigned T1CKPS1 : 1;
606 unsigned TMR1CS0 : 1;
607 unsigned TMR1CS1 : 1;
610 struct
612 unsigned : 4;
613 unsigned T1CKPS : 2;
614 unsigned : 2;
617 struct
619 unsigned : 6;
620 unsigned TMR1CS : 2;
622 } __T1CONbits_t;
624 extern __at(0x0018) volatile __T1CONbits_t T1CONbits;
626 #define _TMR1ON 0x01
627 #define _NOT_T1SYNC 0x04
628 #define _T1OSCEN 0x08
629 #define _T1CKPS0 0x10
630 #define _T1CKPS1 0x20
631 #define _TMR1CS0 0x40
632 #define _TMR1CS1 0x80
634 //==============================================================================
637 //==============================================================================
638 // T1GCON Bits
640 extern __at(0x0019) __sfr T1GCON;
642 typedef union
644 struct
646 unsigned T1GSS0 : 1;
647 unsigned T1GSS1 : 1;
648 unsigned T1GVAL : 1;
649 unsigned T1GGO_NOT_DONE : 1;
650 unsigned T1GSPM : 1;
651 unsigned T1GTM : 1;
652 unsigned T1GPOL : 1;
653 unsigned TMR1GE : 1;
656 struct
658 unsigned T1GSS : 2;
659 unsigned : 6;
661 } __T1GCONbits_t;
663 extern __at(0x0019) volatile __T1GCONbits_t T1GCONbits;
665 #define _T1GSS0 0x01
666 #define _T1GSS1 0x02
667 #define _T1GVAL 0x04
668 #define _T1GGO_NOT_DONE 0x08
669 #define _T1GSPM 0x10
670 #define _T1GTM 0x20
671 #define _T1GPOL 0x40
672 #define _TMR1GE 0x80
674 //==============================================================================
676 extern __at(0x001A) __sfr TMR2;
677 extern __at(0x001B) __sfr PR2;
679 //==============================================================================
680 // T2CON Bits
682 extern __at(0x001C) __sfr T2CON;
684 typedef union
686 struct
688 unsigned T2CKPS0 : 1;
689 unsigned T2CKPS1 : 1;
690 unsigned TMR2ON : 1;
691 unsigned T2OUTPS0 : 1;
692 unsigned T2OUTPS1 : 1;
693 unsigned T2OUTPS2 : 1;
694 unsigned T2OUTPS3 : 1;
695 unsigned : 1;
698 struct
700 unsigned T2CKPS : 2;
701 unsigned : 6;
704 struct
706 unsigned : 3;
707 unsigned T2OUTPS : 4;
708 unsigned : 1;
710 } __T2CONbits_t;
712 extern __at(0x001C) volatile __T2CONbits_t T2CONbits;
714 #define _T2CKPS0 0x01
715 #define _T2CKPS1 0x02
716 #define _TMR2ON 0x04
717 #define _T2OUTPS0 0x08
718 #define _T2OUTPS1 0x10
719 #define _T2OUTPS2 0x20
720 #define _T2OUTPS3 0x40
722 //==============================================================================
725 //==============================================================================
726 // TRISA Bits
728 extern __at(0x008C) __sfr TRISA;
730 typedef struct
732 unsigned TRISA0 : 1;
733 unsigned TRISA1 : 1;
734 unsigned TRISA2 : 1;
735 unsigned : 1;
736 unsigned TRISA4 : 1;
737 unsigned TRISA5 : 1;
738 unsigned : 1;
739 unsigned : 1;
740 } __TRISAbits_t;
742 extern __at(0x008C) volatile __TRISAbits_t TRISAbits;
744 #define _TRISA0 0x01
745 #define _TRISA1 0x02
746 #define _TRISA2 0x04
747 #define _TRISA4 0x10
748 #define _TRISA5 0x20
750 //==============================================================================
753 //==============================================================================
754 // TRISC Bits
756 extern __at(0x008E) __sfr TRISC;
758 typedef union
760 struct
762 unsigned TRISC0 : 1;
763 unsigned TRISC1 : 1;
764 unsigned TRISC2 : 1;
765 unsigned TRISC3 : 1;
766 unsigned TRISC4 : 1;
767 unsigned TRISC5 : 1;
768 unsigned : 1;
769 unsigned : 1;
772 struct
774 unsigned TRISC : 6;
775 unsigned : 2;
777 } __TRISCbits_t;
779 extern __at(0x008E) volatile __TRISCbits_t TRISCbits;
781 #define _TRISC0 0x01
782 #define _TRISC1 0x02
783 #define _TRISC2 0x04
784 #define _TRISC3 0x08
785 #define _TRISC4 0x10
786 #define _TRISC5 0x20
788 //==============================================================================
791 //==============================================================================
792 // PIE1 Bits
794 extern __at(0x0091) __sfr PIE1;
796 typedef union
798 struct
800 unsigned TMR1IE : 1;
801 unsigned TMR2IE : 1;
802 unsigned CCP1IE : 1;
803 unsigned SSP1IE : 1;
804 unsigned TXIE : 1;
805 unsigned RCIE : 1;
806 unsigned ADIE : 1;
807 unsigned TMR1GIE : 1;
810 struct
812 unsigned : 1;
813 unsigned : 1;
814 unsigned CCPIE : 1;
815 unsigned : 1;
816 unsigned : 1;
817 unsigned : 1;
818 unsigned : 1;
819 unsigned : 1;
821 } __PIE1bits_t;
823 extern __at(0x0091) volatile __PIE1bits_t PIE1bits;
825 #define _TMR1IE 0x01
826 #define _TMR2IE 0x02
827 #define _CCP1IE 0x04
828 #define _CCPIE 0x04
829 #define _SSP1IE 0x08
830 #define _TXIE 0x10
831 #define _RCIE 0x20
832 #define _ADIE 0x40
833 #define _TMR1GIE 0x80
835 //==============================================================================
838 //==============================================================================
839 // PIE2 Bits
841 extern __at(0x0092) __sfr PIE2;
843 typedef struct
845 unsigned CCP2IE : 1;
846 unsigned TMR4IE : 1;
847 unsigned TMR6IE : 1;
848 unsigned BCL1IE : 1;
849 unsigned : 1;
850 unsigned C1IE : 1;
851 unsigned C2IE : 1;
852 unsigned OSFIE : 1;
853 } __PIE2bits_t;
855 extern __at(0x0092) volatile __PIE2bits_t PIE2bits;
857 #define _CCP2IE 0x01
858 #define _TMR4IE 0x02
859 #define _TMR6IE 0x04
860 #define _BCL1IE 0x08
861 #define _C1IE 0x20
862 #define _C2IE 0x40
863 #define _OSFIE 0x80
865 //==============================================================================
868 //==============================================================================
869 // PIE3 Bits
871 extern __at(0x0093) __sfr PIE3;
873 typedef struct
875 unsigned CLC1IE : 1;
876 unsigned CLC2IE : 1;
877 unsigned CLC3IE : 1;
878 unsigned : 1;
879 unsigned ZCDIE : 1;
880 unsigned COGIE : 1;
881 unsigned : 1;
882 unsigned : 1;
883 } __PIE3bits_t;
885 extern __at(0x0093) volatile __PIE3bits_t PIE3bits;
887 #define _CLC1IE 0x01
888 #define _CLC2IE 0x02
889 #define _CLC3IE 0x04
890 #define _ZCDIE 0x10
891 #define _COGIE 0x20
893 //==============================================================================
896 //==============================================================================
897 // OPTION_REG Bits
899 extern __at(0x0095) __sfr OPTION_REG;
901 typedef union
903 struct
905 unsigned PS0 : 1;
906 unsigned PS1 : 1;
907 unsigned PS2 : 1;
908 unsigned PSA : 1;
909 unsigned TMR0SE : 1;
910 unsigned TMR0CS : 1;
911 unsigned INTEDG : 1;
912 unsigned NOT_WPUEN : 1;
915 struct
917 unsigned : 1;
918 unsigned : 1;
919 unsigned : 1;
920 unsigned : 1;
921 unsigned T0SE : 1;
922 unsigned T0CS : 1;
923 unsigned : 1;
924 unsigned : 1;
927 struct
929 unsigned PS : 3;
930 unsigned : 5;
932 } __OPTION_REGbits_t;
934 extern __at(0x0095) volatile __OPTION_REGbits_t OPTION_REGbits;
936 #define _PS0 0x01
937 #define _PS1 0x02
938 #define _PS2 0x04
939 #define _PSA 0x08
940 #define _TMR0SE 0x10
941 #define _T0SE 0x10
942 #define _TMR0CS 0x20
943 #define _T0CS 0x20
944 #define _INTEDG 0x40
945 #define _NOT_WPUEN 0x80
947 //==============================================================================
950 //==============================================================================
951 // PCON Bits
953 extern __at(0x0096) __sfr PCON;
955 typedef struct
957 unsigned NOT_BOR : 1;
958 unsigned NOT_POR : 1;
959 unsigned NOT_RI : 1;
960 unsigned NOT_RMCLR : 1;
961 unsigned NOT_RWDT : 1;
962 unsigned : 1;
963 unsigned STKUNF : 1;
964 unsigned STKOVF : 1;
965 } __PCONbits_t;
967 extern __at(0x0096) volatile __PCONbits_t PCONbits;
969 #define _NOT_BOR 0x01
970 #define _NOT_POR 0x02
971 #define _NOT_RI 0x04
972 #define _NOT_RMCLR 0x08
973 #define _NOT_RWDT 0x10
974 #define _STKUNF 0x40
975 #define _STKOVF 0x80
977 //==============================================================================
980 //==============================================================================
981 // WDTCON Bits
983 extern __at(0x0097) __sfr WDTCON;
985 typedef union
987 struct
989 unsigned SWDTEN : 1;
990 unsigned WDTPS0 : 1;
991 unsigned WDTPS1 : 1;
992 unsigned WDTPS2 : 1;
993 unsigned WDTPS3 : 1;
994 unsigned WDTPS4 : 1;
995 unsigned : 1;
996 unsigned : 1;
999 struct
1001 unsigned : 1;
1002 unsigned WDTPS : 5;
1003 unsigned : 2;
1005 } __WDTCONbits_t;
1007 extern __at(0x0097) volatile __WDTCONbits_t WDTCONbits;
1009 #define _SWDTEN 0x01
1010 #define _WDTPS0 0x02
1011 #define _WDTPS1 0x04
1012 #define _WDTPS2 0x08
1013 #define _WDTPS3 0x10
1014 #define _WDTPS4 0x20
1016 //==============================================================================
1019 //==============================================================================
1020 // OSCTUNE Bits
1022 extern __at(0x0098) __sfr OSCTUNE;
1024 typedef union
1026 struct
1028 unsigned TUN0 : 1;
1029 unsigned TUN1 : 1;
1030 unsigned TUN2 : 1;
1031 unsigned TUN3 : 1;
1032 unsigned TUN4 : 1;
1033 unsigned TUN5 : 1;
1034 unsigned : 1;
1035 unsigned : 1;
1038 struct
1040 unsigned TUN : 6;
1041 unsigned : 2;
1043 } __OSCTUNEbits_t;
1045 extern __at(0x0098) volatile __OSCTUNEbits_t OSCTUNEbits;
1047 #define _TUN0 0x01
1048 #define _TUN1 0x02
1049 #define _TUN2 0x04
1050 #define _TUN3 0x08
1051 #define _TUN4 0x10
1052 #define _TUN5 0x20
1054 //==============================================================================
1057 //==============================================================================
1058 // OSCCON Bits
1060 extern __at(0x0099) __sfr OSCCON;
1062 typedef union
1064 struct
1066 unsigned SCS0 : 1;
1067 unsigned SCS1 : 1;
1068 unsigned : 1;
1069 unsigned IRCF0 : 1;
1070 unsigned IRCF1 : 1;
1071 unsigned IRCF2 : 1;
1072 unsigned IRCF3 : 1;
1073 unsigned SPLLEN : 1;
1076 struct
1078 unsigned SCS : 2;
1079 unsigned : 6;
1082 struct
1084 unsigned : 3;
1085 unsigned IRCF : 4;
1086 unsigned : 1;
1088 } __OSCCONbits_t;
1090 extern __at(0x0099) volatile __OSCCONbits_t OSCCONbits;
1092 #define _SCS0 0x01
1093 #define _SCS1 0x02
1094 #define _IRCF0 0x08
1095 #define _IRCF1 0x10
1096 #define _IRCF2 0x20
1097 #define _IRCF3 0x40
1098 #define _SPLLEN 0x80
1100 //==============================================================================
1103 //==============================================================================
1104 // OSCSTAT Bits
1106 extern __at(0x009A) __sfr OSCSTAT;
1108 typedef struct
1110 unsigned HFIOFS : 1;
1111 unsigned LFIOFR : 1;
1112 unsigned MFIOFR : 1;
1113 unsigned HFIOFL : 1;
1114 unsigned HFIOFR : 1;
1115 unsigned OSTS : 1;
1116 unsigned PLLR : 1;
1117 unsigned SOSCR : 1;
1118 } __OSCSTATbits_t;
1120 extern __at(0x009A) volatile __OSCSTATbits_t OSCSTATbits;
1122 #define _HFIOFS 0x01
1123 #define _LFIOFR 0x02
1124 #define _MFIOFR 0x04
1125 #define _HFIOFL 0x08
1126 #define _HFIOFR 0x10
1127 #define _OSTS 0x20
1128 #define _PLLR 0x40
1129 #define _SOSCR 0x80
1131 //==============================================================================
1133 extern __at(0x009B) __sfr ADRES;
1134 extern __at(0x009B) __sfr ADRESL;
1135 extern __at(0x009C) __sfr ADRESH;
1137 //==============================================================================
1138 // ADCON0 Bits
1140 extern __at(0x009D) __sfr ADCON0;
1142 typedef union
1144 struct
1146 unsigned ADON : 1;
1147 unsigned GO_NOT_DONE : 1;
1148 unsigned CHS0 : 1;
1149 unsigned CHS1 : 1;
1150 unsigned CHS2 : 1;
1151 unsigned CHS3 : 1;
1152 unsigned CHS4 : 1;
1153 unsigned : 1;
1156 struct
1158 unsigned : 1;
1159 unsigned ADGO : 1;
1160 unsigned : 1;
1161 unsigned : 1;
1162 unsigned : 1;
1163 unsigned : 1;
1164 unsigned : 1;
1165 unsigned : 1;
1168 struct
1170 unsigned : 1;
1171 unsigned GO : 1;
1172 unsigned : 1;
1173 unsigned : 1;
1174 unsigned : 1;
1175 unsigned : 1;
1176 unsigned : 1;
1177 unsigned : 1;
1180 struct
1182 unsigned : 2;
1183 unsigned CHS : 5;
1184 unsigned : 1;
1186 } __ADCON0bits_t;
1188 extern __at(0x009D) volatile __ADCON0bits_t ADCON0bits;
1190 #define _ADON 0x01
1191 #define _GO_NOT_DONE 0x02
1192 #define _ADGO 0x02
1193 #define _GO 0x02
1194 #define _CHS0 0x04
1195 #define _CHS1 0x08
1196 #define _CHS2 0x10
1197 #define _CHS3 0x20
1198 #define _CHS4 0x40
1200 //==============================================================================
1203 //==============================================================================
1204 // ADCON1 Bits
1206 extern __at(0x009E) __sfr ADCON1;
1208 typedef union
1210 struct
1212 unsigned ADPREF0 : 1;
1213 unsigned ADPREF1 : 1;
1214 unsigned ADNREF : 1;
1215 unsigned : 1;
1216 unsigned : 1;
1217 unsigned : 1;
1218 unsigned : 1;
1219 unsigned ADFM : 1;
1222 struct
1224 unsigned ADPREF : 2;
1225 unsigned : 6;
1227 } __ADCON1bits_t;
1229 extern __at(0x009E) volatile __ADCON1bits_t ADCON1bits;
1231 #define _ADPREF0 0x01
1232 #define _ADPREF1 0x02
1233 #define _ADNREF 0x04
1234 #define _ADFM 0x80
1236 //==============================================================================
1239 //==============================================================================
1240 // ADCON2 Bits
1242 extern __at(0x009F) __sfr ADCON2;
1244 typedef union
1246 struct
1248 unsigned : 1;
1249 unsigned : 1;
1250 unsigned : 1;
1251 unsigned : 1;
1252 unsigned TRIGSEL0 : 1;
1253 unsigned TRIGSEL1 : 1;
1254 unsigned TRIGSEL2 : 1;
1255 unsigned TRIGSEL3 : 1;
1258 struct
1260 unsigned : 4;
1261 unsigned TRIGSEL : 4;
1263 } __ADCON2bits_t;
1265 extern __at(0x009F) volatile __ADCON2bits_t ADCON2bits;
1267 #define _TRIGSEL0 0x10
1268 #define _TRIGSEL1 0x20
1269 #define _TRIGSEL2 0x40
1270 #define _TRIGSEL3 0x80
1272 //==============================================================================
1275 //==============================================================================
1276 // LATA Bits
1278 extern __at(0x010C) __sfr LATA;
1280 typedef struct
1282 unsigned LATA0 : 1;
1283 unsigned LATA1 : 1;
1284 unsigned LATA2 : 1;
1285 unsigned : 1;
1286 unsigned LATA4 : 1;
1287 unsigned LATA5 : 1;
1288 unsigned : 1;
1289 unsigned : 1;
1290 } __LATAbits_t;
1292 extern __at(0x010C) volatile __LATAbits_t LATAbits;
1294 #define _LATA0 0x01
1295 #define _LATA1 0x02
1296 #define _LATA2 0x04
1297 #define _LATA4 0x10
1298 #define _LATA5 0x20
1300 //==============================================================================
1303 //==============================================================================
1304 // LATC Bits
1306 extern __at(0x010E) __sfr LATC;
1308 typedef union
1310 struct
1312 unsigned LATC0 : 1;
1313 unsigned LATC1 : 1;
1314 unsigned LATC2 : 1;
1315 unsigned LATC3 : 1;
1316 unsigned LATC4 : 1;
1317 unsigned LATC5 : 1;
1318 unsigned : 1;
1319 unsigned : 1;
1322 struct
1324 unsigned LATC : 6;
1325 unsigned : 2;
1327 } __LATCbits_t;
1329 extern __at(0x010E) volatile __LATCbits_t LATCbits;
1331 #define _LATC0 0x01
1332 #define _LATC1 0x02
1333 #define _LATC2 0x04
1334 #define _LATC3 0x08
1335 #define _LATC4 0x10
1336 #define _LATC5 0x20
1338 //==============================================================================
1341 //==============================================================================
1342 // CM1CON0 Bits
1344 extern __at(0x0111) __sfr CM1CON0;
1346 typedef struct
1348 unsigned C1SYNC : 1;
1349 unsigned C1HYS : 1;
1350 unsigned C1SP : 1;
1351 unsigned C1ZLF : 1;
1352 unsigned C1POL : 1;
1353 unsigned : 1;
1354 unsigned C1OUT : 1;
1355 unsigned C1ON : 1;
1356 } __CM1CON0bits_t;
1358 extern __at(0x0111) volatile __CM1CON0bits_t CM1CON0bits;
1360 #define _C1SYNC 0x01
1361 #define _C1HYS 0x02
1362 #define _C1SP 0x04
1363 #define _C1ZLF 0x08
1364 #define _C1POL 0x10
1365 #define _C1OUT 0x40
1366 #define _C1ON 0x80
1368 //==============================================================================
1371 //==============================================================================
1372 // CM1CON1 Bits
1374 extern __at(0x0112) __sfr CM1CON1;
1376 typedef union
1378 struct
1380 unsigned C1NCH0 : 1;
1381 unsigned C1NCH1 : 1;
1382 unsigned C1NCH2 : 1;
1383 unsigned C1PCH0 : 1;
1384 unsigned C1PCH1 : 1;
1385 unsigned C1PCH2 : 1;
1386 unsigned C1INTN : 1;
1387 unsigned C1INTP : 1;
1390 struct
1392 unsigned C1NCH : 3;
1393 unsigned : 5;
1396 struct
1398 unsigned : 3;
1399 unsigned C1PCH : 3;
1400 unsigned : 2;
1402 } __CM1CON1bits_t;
1404 extern __at(0x0112) volatile __CM1CON1bits_t CM1CON1bits;
1406 #define _C1NCH0 0x01
1407 #define _C1NCH1 0x02
1408 #define _C1NCH2 0x04
1409 #define _C1PCH0 0x08
1410 #define _C1PCH1 0x10
1411 #define _C1PCH2 0x20
1412 #define _C1INTN 0x40
1413 #define _C1INTP 0x80
1415 //==============================================================================
1418 //==============================================================================
1419 // CM2CON0 Bits
1421 extern __at(0x0113) __sfr CM2CON0;
1423 typedef struct
1425 unsigned C2SYNC : 1;
1426 unsigned C2HYS : 1;
1427 unsigned C2SP : 1;
1428 unsigned C2ZLF : 1;
1429 unsigned C2POL : 1;
1430 unsigned : 1;
1431 unsigned C2OUT : 1;
1432 unsigned C2ON : 1;
1433 } __CM2CON0bits_t;
1435 extern __at(0x0113) volatile __CM2CON0bits_t CM2CON0bits;
1437 #define _C2SYNC 0x01
1438 #define _C2HYS 0x02
1439 #define _C2SP 0x04
1440 #define _C2ZLF 0x08
1441 #define _C2POL 0x10
1442 #define _C2OUT 0x40
1443 #define _C2ON 0x80
1445 //==============================================================================
1448 //==============================================================================
1449 // CM2CON1 Bits
1451 extern __at(0x0114) __sfr CM2CON1;
1453 typedef union
1455 struct
1457 unsigned C2NCH0 : 1;
1458 unsigned C2NCH1 : 1;
1459 unsigned C2NCH2 : 1;
1460 unsigned C2PCH0 : 1;
1461 unsigned C2PCH1 : 1;
1462 unsigned C2PCH2 : 1;
1463 unsigned C2INTN : 1;
1464 unsigned C2INTP : 1;
1467 struct
1469 unsigned C2NCH : 3;
1470 unsigned : 5;
1473 struct
1475 unsigned : 3;
1476 unsigned C2PCH : 3;
1477 unsigned : 2;
1479 } __CM2CON1bits_t;
1481 extern __at(0x0114) volatile __CM2CON1bits_t CM2CON1bits;
1483 #define _C2NCH0 0x01
1484 #define _C2NCH1 0x02
1485 #define _C2NCH2 0x04
1486 #define _C2PCH0 0x08
1487 #define _C2PCH1 0x10
1488 #define _C2PCH2 0x20
1489 #define _C2INTN 0x40
1490 #define _C2INTP 0x80
1492 //==============================================================================
1495 //==============================================================================
1496 // CMOUT Bits
1498 extern __at(0x0115) __sfr CMOUT;
1500 typedef struct
1502 unsigned MC1OUT : 1;
1503 unsigned MC2OUT : 1;
1504 unsigned : 1;
1505 unsigned : 1;
1506 unsigned : 1;
1507 unsigned : 1;
1508 unsigned : 1;
1509 unsigned : 1;
1510 } __CMOUTbits_t;
1512 extern __at(0x0115) volatile __CMOUTbits_t CMOUTbits;
1514 #define _MC1OUT 0x01
1515 #define _MC2OUT 0x02
1517 //==============================================================================
1520 //==============================================================================
1521 // BORCON Bits
1523 extern __at(0x0116) __sfr BORCON;
1525 typedef struct
1527 unsigned BORRDY : 1;
1528 unsigned : 1;
1529 unsigned : 1;
1530 unsigned : 1;
1531 unsigned : 1;
1532 unsigned : 1;
1533 unsigned BORFS : 1;
1534 unsigned SBOREN : 1;
1535 } __BORCONbits_t;
1537 extern __at(0x0116) volatile __BORCONbits_t BORCONbits;
1539 #define _BORRDY 0x01
1540 #define _BORFS 0x40
1541 #define _SBOREN 0x80
1543 //==============================================================================
1546 //==============================================================================
1547 // FVRCON Bits
1549 extern __at(0x0117) __sfr FVRCON;
1551 typedef union
1553 struct
1555 unsigned ADFVR0 : 1;
1556 unsigned ADFVR1 : 1;
1557 unsigned CDAFVR0 : 1;
1558 unsigned CDAFVR1 : 1;
1559 unsigned TSRNG : 1;
1560 unsigned TSEN : 1;
1561 unsigned FVRRDY : 1;
1562 unsigned FVREN : 1;
1565 struct
1567 unsigned ADFVR : 2;
1568 unsigned : 6;
1571 struct
1573 unsigned : 2;
1574 unsigned CDAFVR : 2;
1575 unsigned : 4;
1577 } __FVRCONbits_t;
1579 extern __at(0x0117) volatile __FVRCONbits_t FVRCONbits;
1581 #define _ADFVR0 0x01
1582 #define _ADFVR1 0x02
1583 #define _CDAFVR0 0x04
1584 #define _CDAFVR1 0x08
1585 #define _TSRNG 0x10
1586 #define _TSEN 0x20
1587 #define _FVRRDY 0x40
1588 #define _FVREN 0x80
1590 //==============================================================================
1593 //==============================================================================
1594 // DAC1CON0 Bits
1596 extern __at(0x0118) __sfr DAC1CON0;
1598 typedef union
1600 struct
1602 unsigned DAC1NSS : 1;
1603 unsigned : 1;
1604 unsigned DAC1PSS0 : 1;
1605 unsigned DAC1PSS1 : 1;
1606 unsigned DAC1OE2 : 1;
1607 unsigned DAC1OE1 : 1;
1608 unsigned : 1;
1609 unsigned DAC1EN : 1;
1612 struct
1614 unsigned DACNSS : 1;
1615 unsigned : 1;
1616 unsigned DACPSS0 : 1;
1617 unsigned DACPSS1 : 1;
1618 unsigned DACOE0 : 1;
1619 unsigned DACOE1 : 1;
1620 unsigned : 1;
1621 unsigned DACEN : 1;
1624 struct
1626 unsigned : 2;
1627 unsigned DAC1PSS : 2;
1628 unsigned : 4;
1631 struct
1633 unsigned : 2;
1634 unsigned DACPSS : 2;
1635 unsigned : 4;
1638 struct
1640 unsigned : 4;
1641 unsigned DACOE : 2;
1642 unsigned : 2;
1644 } __DAC1CON0bits_t;
1646 extern __at(0x0118) volatile __DAC1CON0bits_t DAC1CON0bits;
1648 #define _DAC1NSS 0x01
1649 #define _DACNSS 0x01
1650 #define _DAC1PSS0 0x04
1651 #define _DACPSS0 0x04
1652 #define _DAC1PSS1 0x08
1653 #define _DACPSS1 0x08
1654 #define _DAC1OE2 0x10
1655 #define _DACOE0 0x10
1656 #define _DAC1OE1 0x20
1657 #define _DACOE1 0x20
1658 #define _DAC1EN 0x80
1659 #define _DACEN 0x80
1661 //==============================================================================
1664 //==============================================================================
1665 // DAC1CON1 Bits
1667 extern __at(0x0119) __sfr DAC1CON1;
1669 typedef union
1671 struct
1673 unsigned DAC1R0 : 1;
1674 unsigned DAC1R1 : 1;
1675 unsigned DAC1R2 : 1;
1676 unsigned DAC1R3 : 1;
1677 unsigned DAC1R4 : 1;
1678 unsigned DAC1R5 : 1;
1679 unsigned DAC1R6 : 1;
1680 unsigned DAC1R7 : 1;
1683 struct
1685 unsigned DACR0 : 1;
1686 unsigned DACR1 : 1;
1687 unsigned DACR2 : 1;
1688 unsigned DACR3 : 1;
1689 unsigned DACR4 : 1;
1690 unsigned DACR5 : 1;
1691 unsigned DACR6 : 1;
1692 unsigned DACR7 : 1;
1694 } __DAC1CON1bits_t;
1696 extern __at(0x0119) volatile __DAC1CON1bits_t DAC1CON1bits;
1698 #define _DAC1R0 0x01
1699 #define _DACR0 0x01
1700 #define _DAC1R1 0x02
1701 #define _DACR1 0x02
1702 #define _DAC1R2 0x04
1703 #define _DACR2 0x04
1704 #define _DAC1R3 0x08
1705 #define _DACR3 0x08
1706 #define _DAC1R4 0x10
1707 #define _DACR4 0x10
1708 #define _DAC1R5 0x20
1709 #define _DACR5 0x20
1710 #define _DAC1R6 0x40
1711 #define _DACR6 0x40
1712 #define _DAC1R7 0x80
1713 #define _DACR7 0x80
1715 //==============================================================================
1718 //==============================================================================
1719 // ZCD1CON Bits
1721 extern __at(0x011C) __sfr ZCD1CON;
1723 typedef struct
1725 unsigned ZCD1INTN : 1;
1726 unsigned ZCD1INTP : 1;
1727 unsigned : 1;
1728 unsigned : 1;
1729 unsigned ZCD1POL : 1;
1730 unsigned ZCD1OUT : 1;
1731 unsigned : 1;
1732 unsigned ZCD1EN : 1;
1733 } __ZCD1CONbits_t;
1735 extern __at(0x011C) volatile __ZCD1CONbits_t ZCD1CONbits;
1737 #define _ZCD1INTN 0x01
1738 #define _ZCD1INTP 0x02
1739 #define _ZCD1POL 0x10
1740 #define _ZCD1OUT 0x20
1741 #define _ZCD1EN 0x80
1743 //==============================================================================
1746 //==============================================================================
1747 // ANSELA Bits
1749 extern __at(0x018C) __sfr ANSELA;
1751 typedef struct
1753 unsigned ANSA0 : 1;
1754 unsigned ANSA1 : 1;
1755 unsigned ANSA2 : 1;
1756 unsigned : 1;
1757 unsigned ANSA4 : 1;
1758 unsigned ANS5 : 1;
1759 unsigned : 1;
1760 unsigned : 1;
1761 } __ANSELAbits_t;
1763 extern __at(0x018C) volatile __ANSELAbits_t ANSELAbits;
1765 #define _ANSA0 0x01
1766 #define _ANSA1 0x02
1767 #define _ANSA2 0x04
1768 #define _ANSA4 0x10
1769 #define _ANS5 0x20
1771 //==============================================================================
1774 //==============================================================================
1775 // ANSELC Bits
1777 extern __at(0x018E) __sfr ANSELC;
1779 typedef union
1781 struct
1783 unsigned ANSC0 : 1;
1784 unsigned ANSC1 : 1;
1785 unsigned ANSC2 : 1;
1786 unsigned ANSC3 : 1;
1787 unsigned ANSC4 : 1;
1788 unsigned ANSC5 : 1;
1789 unsigned : 1;
1790 unsigned : 1;
1793 struct
1795 unsigned ANSC : 6;
1796 unsigned : 2;
1798 } __ANSELCbits_t;
1800 extern __at(0x018E) volatile __ANSELCbits_t ANSELCbits;
1802 #define _ANSC0 0x01
1803 #define _ANSC1 0x02
1804 #define _ANSC2 0x04
1805 #define _ANSC3 0x08
1806 #define _ANSC4 0x10
1807 #define _ANSC5 0x20
1809 //==============================================================================
1811 extern __at(0x0191) __sfr PMADR;
1812 extern __at(0x0191) __sfr PMADRL;
1813 extern __at(0x0192) __sfr PMADRH;
1814 extern __at(0x0193) __sfr PMDAT;
1815 extern __at(0x0193) __sfr PMDATL;
1816 extern __at(0x0194) __sfr PMDATH;
1818 //==============================================================================
1819 // PMCON1 Bits
1821 extern __at(0x0195) __sfr PMCON1;
1823 typedef struct
1825 unsigned RD : 1;
1826 unsigned WR : 1;
1827 unsigned WREN : 1;
1828 unsigned WRERR : 1;
1829 unsigned FREE : 1;
1830 unsigned LWLO : 1;
1831 unsigned CFGS : 1;
1832 unsigned : 1;
1833 } __PMCON1bits_t;
1835 extern __at(0x0195) volatile __PMCON1bits_t PMCON1bits;
1837 #define _RD 0x01
1838 #define _WR 0x02
1839 #define _WREN 0x04
1840 #define _WRERR 0x08
1841 #define _FREE 0x10
1842 #define _LWLO 0x20
1843 #define _CFGS 0x40
1845 //==============================================================================
1847 extern __at(0x0196) __sfr PMCON2;
1849 //==============================================================================
1850 // VREGCON Bits
1852 extern __at(0x0197) __sfr VREGCON;
1854 typedef struct
1856 unsigned Reserved : 1;
1857 unsigned VREGPM : 1;
1858 unsigned : 1;
1859 unsigned : 1;
1860 unsigned : 1;
1861 unsigned : 1;
1862 unsigned : 1;
1863 unsigned : 1;
1864 } __VREGCONbits_t;
1866 extern __at(0x0197) volatile __VREGCONbits_t VREGCONbits;
1868 #define _Reserved 0x01
1869 #define _VREGPM 0x02
1871 //==============================================================================
1873 extern __at(0x0199) __sfr RC1REG;
1874 extern __at(0x0199) __sfr RCREG;
1875 extern __at(0x0199) __sfr RCREG1;
1876 extern __at(0x019A) __sfr TX1REG;
1877 extern __at(0x019A) __sfr TXREG;
1878 extern __at(0x019A) __sfr TXREG1;
1879 extern __at(0x019B) __sfr SP1BRG;
1880 extern __at(0x019B) __sfr SP1BRGL;
1881 extern __at(0x019B) __sfr SPBRG;
1882 extern __at(0x019B) __sfr SPBRG1;
1883 extern __at(0x019B) __sfr SPBRGL;
1884 extern __at(0x019C) __sfr SP1BRGH;
1885 extern __at(0x019C) __sfr SPBRGH;
1886 extern __at(0x019C) __sfr SPBRGH1;
1888 //==============================================================================
1889 // RC1STA Bits
1891 extern __at(0x019D) __sfr RC1STA;
1893 typedef struct
1895 unsigned RX9D : 1;
1896 unsigned OERR : 1;
1897 unsigned FERR : 1;
1898 unsigned ADDEN : 1;
1899 unsigned CREN : 1;
1900 unsigned SREN : 1;
1901 unsigned RX9 : 1;
1902 unsigned SPEN : 1;
1903 } __RC1STAbits_t;
1905 extern __at(0x019D) volatile __RC1STAbits_t RC1STAbits;
1907 #define _RX9D 0x01
1908 #define _OERR 0x02
1909 #define _FERR 0x04
1910 #define _ADDEN 0x08
1911 #define _CREN 0x10
1912 #define _SREN 0x20
1913 #define _RX9 0x40
1914 #define _SPEN 0x80
1916 //==============================================================================
1919 //==============================================================================
1920 // RCSTA Bits
1922 extern __at(0x019D) __sfr RCSTA;
1924 typedef struct
1926 unsigned RX9D : 1;
1927 unsigned OERR : 1;
1928 unsigned FERR : 1;
1929 unsigned ADDEN : 1;
1930 unsigned CREN : 1;
1931 unsigned SREN : 1;
1932 unsigned RX9 : 1;
1933 unsigned SPEN : 1;
1934 } __RCSTAbits_t;
1936 extern __at(0x019D) volatile __RCSTAbits_t RCSTAbits;
1938 #define _RCSTA_RX9D 0x01
1939 #define _RCSTA_OERR 0x02
1940 #define _RCSTA_FERR 0x04
1941 #define _RCSTA_ADDEN 0x08
1942 #define _RCSTA_CREN 0x10
1943 #define _RCSTA_SREN 0x20
1944 #define _RCSTA_RX9 0x40
1945 #define _RCSTA_SPEN 0x80
1947 //==============================================================================
1950 //==============================================================================
1951 // RCSTA1 Bits
1953 extern __at(0x019D) __sfr RCSTA1;
1955 typedef struct
1957 unsigned RX9D : 1;
1958 unsigned OERR : 1;
1959 unsigned FERR : 1;
1960 unsigned ADDEN : 1;
1961 unsigned CREN : 1;
1962 unsigned SREN : 1;
1963 unsigned RX9 : 1;
1964 unsigned SPEN : 1;
1965 } __RCSTA1bits_t;
1967 extern __at(0x019D) volatile __RCSTA1bits_t RCSTA1bits;
1969 #define _RCSTA1_RX9D 0x01
1970 #define _RCSTA1_OERR 0x02
1971 #define _RCSTA1_FERR 0x04
1972 #define _RCSTA1_ADDEN 0x08
1973 #define _RCSTA1_CREN 0x10
1974 #define _RCSTA1_SREN 0x20
1975 #define _RCSTA1_RX9 0x40
1976 #define _RCSTA1_SPEN 0x80
1978 //==============================================================================
1981 //==============================================================================
1982 // TX1STA Bits
1984 extern __at(0x019E) __sfr TX1STA;
1986 typedef struct
1988 unsigned TX9D : 1;
1989 unsigned TRMT : 1;
1990 unsigned BRGH : 1;
1991 unsigned SENDB : 1;
1992 unsigned SYNC : 1;
1993 unsigned TXEN : 1;
1994 unsigned TX9 : 1;
1995 unsigned CSRC : 1;
1996 } __TX1STAbits_t;
1998 extern __at(0x019E) volatile __TX1STAbits_t TX1STAbits;
2000 #define _TX9D 0x01
2001 #define _TRMT 0x02
2002 #define _BRGH 0x04
2003 #define _SENDB 0x08
2004 #define _SYNC 0x10
2005 #define _TXEN 0x20
2006 #define _TX9 0x40
2007 #define _CSRC 0x80
2009 //==============================================================================
2012 //==============================================================================
2013 // TXSTA Bits
2015 extern __at(0x019E) __sfr TXSTA;
2017 typedef struct
2019 unsigned TX9D : 1;
2020 unsigned TRMT : 1;
2021 unsigned BRGH : 1;
2022 unsigned SENDB : 1;
2023 unsigned SYNC : 1;
2024 unsigned TXEN : 1;
2025 unsigned TX9 : 1;
2026 unsigned CSRC : 1;
2027 } __TXSTAbits_t;
2029 extern __at(0x019E) volatile __TXSTAbits_t TXSTAbits;
2031 #define _TXSTA_TX9D 0x01
2032 #define _TXSTA_TRMT 0x02
2033 #define _TXSTA_BRGH 0x04
2034 #define _TXSTA_SENDB 0x08
2035 #define _TXSTA_SYNC 0x10
2036 #define _TXSTA_TXEN 0x20
2037 #define _TXSTA_TX9 0x40
2038 #define _TXSTA_CSRC 0x80
2040 //==============================================================================
2043 //==============================================================================
2044 // TXSTA1 Bits
2046 extern __at(0x019E) __sfr TXSTA1;
2048 typedef struct
2050 unsigned TX9D : 1;
2051 unsigned TRMT : 1;
2052 unsigned BRGH : 1;
2053 unsigned SENDB : 1;
2054 unsigned SYNC : 1;
2055 unsigned TXEN : 1;
2056 unsigned TX9 : 1;
2057 unsigned CSRC : 1;
2058 } __TXSTA1bits_t;
2060 extern __at(0x019E) volatile __TXSTA1bits_t TXSTA1bits;
2062 #define _TXSTA1_TX9D 0x01
2063 #define _TXSTA1_TRMT 0x02
2064 #define _TXSTA1_BRGH 0x04
2065 #define _TXSTA1_SENDB 0x08
2066 #define _TXSTA1_SYNC 0x10
2067 #define _TXSTA1_TXEN 0x20
2068 #define _TXSTA1_TX9 0x40
2069 #define _TXSTA1_CSRC 0x80
2071 //==============================================================================
2074 //==============================================================================
2075 // BAUD1CON Bits
2077 extern __at(0x019F) __sfr BAUD1CON;
2079 typedef struct
2081 unsigned ABDEN : 1;
2082 unsigned WUE : 1;
2083 unsigned : 1;
2084 unsigned BRG16 : 1;
2085 unsigned SCKP : 1;
2086 unsigned : 1;
2087 unsigned RCIDL : 1;
2088 unsigned ABDOVF : 1;
2089 } __BAUD1CONbits_t;
2091 extern __at(0x019F) volatile __BAUD1CONbits_t BAUD1CONbits;
2093 #define _ABDEN 0x01
2094 #define _WUE 0x02
2095 #define _BRG16 0x08
2096 #define _SCKP 0x10
2097 #define _RCIDL 0x40
2098 #define _ABDOVF 0x80
2100 //==============================================================================
2103 //==============================================================================
2104 // BAUDCON Bits
2106 extern __at(0x019F) __sfr BAUDCON;
2108 typedef struct
2110 unsigned ABDEN : 1;
2111 unsigned WUE : 1;
2112 unsigned : 1;
2113 unsigned BRG16 : 1;
2114 unsigned SCKP : 1;
2115 unsigned : 1;
2116 unsigned RCIDL : 1;
2117 unsigned ABDOVF : 1;
2118 } __BAUDCONbits_t;
2120 extern __at(0x019F) volatile __BAUDCONbits_t BAUDCONbits;
2122 #define _BAUDCON_ABDEN 0x01
2123 #define _BAUDCON_WUE 0x02
2124 #define _BAUDCON_BRG16 0x08
2125 #define _BAUDCON_SCKP 0x10
2126 #define _BAUDCON_RCIDL 0x40
2127 #define _BAUDCON_ABDOVF 0x80
2129 //==============================================================================
2132 //==============================================================================
2133 // BAUDCON1 Bits
2135 extern __at(0x019F) __sfr BAUDCON1;
2137 typedef struct
2139 unsigned ABDEN : 1;
2140 unsigned WUE : 1;
2141 unsigned : 1;
2142 unsigned BRG16 : 1;
2143 unsigned SCKP : 1;
2144 unsigned : 1;
2145 unsigned RCIDL : 1;
2146 unsigned ABDOVF : 1;
2147 } __BAUDCON1bits_t;
2149 extern __at(0x019F) volatile __BAUDCON1bits_t BAUDCON1bits;
2151 #define _BAUDCON1_ABDEN 0x01
2152 #define _BAUDCON1_WUE 0x02
2153 #define _BAUDCON1_BRG16 0x08
2154 #define _BAUDCON1_SCKP 0x10
2155 #define _BAUDCON1_RCIDL 0x40
2156 #define _BAUDCON1_ABDOVF 0x80
2158 //==============================================================================
2161 //==============================================================================
2162 // BAUDCTL Bits
2164 extern __at(0x019F) __sfr BAUDCTL;
2166 typedef struct
2168 unsigned ABDEN : 1;
2169 unsigned WUE : 1;
2170 unsigned : 1;
2171 unsigned BRG16 : 1;
2172 unsigned SCKP : 1;
2173 unsigned : 1;
2174 unsigned RCIDL : 1;
2175 unsigned ABDOVF : 1;
2176 } __BAUDCTLbits_t;
2178 extern __at(0x019F) volatile __BAUDCTLbits_t BAUDCTLbits;
2180 #define _BAUDCTL_ABDEN 0x01
2181 #define _BAUDCTL_WUE 0x02
2182 #define _BAUDCTL_BRG16 0x08
2183 #define _BAUDCTL_SCKP 0x10
2184 #define _BAUDCTL_RCIDL 0x40
2185 #define _BAUDCTL_ABDOVF 0x80
2187 //==============================================================================
2190 //==============================================================================
2191 // BAUDCTL1 Bits
2193 extern __at(0x019F) __sfr BAUDCTL1;
2195 typedef struct
2197 unsigned ABDEN : 1;
2198 unsigned WUE : 1;
2199 unsigned : 1;
2200 unsigned BRG16 : 1;
2201 unsigned SCKP : 1;
2202 unsigned : 1;
2203 unsigned RCIDL : 1;
2204 unsigned ABDOVF : 1;
2205 } __BAUDCTL1bits_t;
2207 extern __at(0x019F) volatile __BAUDCTL1bits_t BAUDCTL1bits;
2209 #define _BAUDCTL1_ABDEN 0x01
2210 #define _BAUDCTL1_WUE 0x02
2211 #define _BAUDCTL1_BRG16 0x08
2212 #define _BAUDCTL1_SCKP 0x10
2213 #define _BAUDCTL1_RCIDL 0x40
2214 #define _BAUDCTL1_ABDOVF 0x80
2216 //==============================================================================
2219 //==============================================================================
2220 // WPUA Bits
2222 extern __at(0x020C) __sfr WPUA;
2224 typedef union
2226 struct
2228 unsigned WPUA0 : 1;
2229 unsigned WPUA1 : 1;
2230 unsigned WPUA2 : 1;
2231 unsigned WPUA3 : 1;
2232 unsigned WPUA4 : 1;
2233 unsigned WPUA5 : 1;
2234 unsigned : 1;
2235 unsigned : 1;
2238 struct
2240 unsigned WPUA : 6;
2241 unsigned : 2;
2243 } __WPUAbits_t;
2245 extern __at(0x020C) volatile __WPUAbits_t WPUAbits;
2247 #define _WPUA0 0x01
2248 #define _WPUA1 0x02
2249 #define _WPUA2 0x04
2250 #define _WPUA3 0x08
2251 #define _WPUA4 0x10
2252 #define _WPUA5 0x20
2254 //==============================================================================
2257 //==============================================================================
2258 // WPUC Bits
2260 extern __at(0x020E) __sfr WPUC;
2262 typedef union
2264 struct
2266 unsigned WPUC0 : 1;
2267 unsigned WPUC1 : 1;
2268 unsigned WPUC2 : 1;
2269 unsigned WPUC3 : 1;
2270 unsigned WPUC4 : 1;
2271 unsigned WPUC5 : 1;
2272 unsigned : 1;
2273 unsigned : 1;
2276 struct
2278 unsigned WPUC : 6;
2279 unsigned : 2;
2281 } __WPUCbits_t;
2283 extern __at(0x020E) volatile __WPUCbits_t WPUCbits;
2285 #define _WPUC0 0x01
2286 #define _WPUC1 0x02
2287 #define _WPUC2 0x04
2288 #define _WPUC3 0x08
2289 #define _WPUC4 0x10
2290 #define _WPUC5 0x20
2292 //==============================================================================
2295 //==============================================================================
2296 // SSP1BUF Bits
2298 extern __at(0x0211) __sfr SSP1BUF;
2300 typedef union
2302 struct
2304 unsigned SSP1BUF0 : 1;
2305 unsigned SSP1BUF1 : 1;
2306 unsigned SSP1BUF2 : 1;
2307 unsigned SSP1BUF3 : 1;
2308 unsigned SSP1BUF4 : 1;
2309 unsigned SSP1BUF5 : 1;
2310 unsigned SSP1BUF6 : 1;
2311 unsigned SSP1BUF7 : 1;
2314 struct
2316 unsigned BUF0 : 1;
2317 unsigned BUF1 : 1;
2318 unsigned BUF2 : 1;
2319 unsigned BUF3 : 1;
2320 unsigned BUF4 : 1;
2321 unsigned BUF5 : 1;
2322 unsigned BUF6 : 1;
2323 unsigned BUF7 : 1;
2325 } __SSP1BUFbits_t;
2327 extern __at(0x0211) volatile __SSP1BUFbits_t SSP1BUFbits;
2329 #define _SSP1BUF0 0x01
2330 #define _BUF0 0x01
2331 #define _SSP1BUF1 0x02
2332 #define _BUF1 0x02
2333 #define _SSP1BUF2 0x04
2334 #define _BUF2 0x04
2335 #define _SSP1BUF3 0x08
2336 #define _BUF3 0x08
2337 #define _SSP1BUF4 0x10
2338 #define _BUF4 0x10
2339 #define _SSP1BUF5 0x20
2340 #define _BUF5 0x20
2341 #define _SSP1BUF6 0x40
2342 #define _BUF6 0x40
2343 #define _SSP1BUF7 0x80
2344 #define _BUF7 0x80
2346 //==============================================================================
2349 //==============================================================================
2350 // SSPBUF Bits
2352 extern __at(0x0211) __sfr SSPBUF;
2354 typedef union
2356 struct
2358 unsigned SSP1BUF0 : 1;
2359 unsigned SSP1BUF1 : 1;
2360 unsigned SSP1BUF2 : 1;
2361 unsigned SSP1BUF3 : 1;
2362 unsigned SSP1BUF4 : 1;
2363 unsigned SSP1BUF5 : 1;
2364 unsigned SSP1BUF6 : 1;
2365 unsigned SSP1BUF7 : 1;
2368 struct
2370 unsigned BUF0 : 1;
2371 unsigned BUF1 : 1;
2372 unsigned BUF2 : 1;
2373 unsigned BUF3 : 1;
2374 unsigned BUF4 : 1;
2375 unsigned BUF5 : 1;
2376 unsigned BUF6 : 1;
2377 unsigned BUF7 : 1;
2379 } __SSPBUFbits_t;
2381 extern __at(0x0211) volatile __SSPBUFbits_t SSPBUFbits;
2383 #define _SSPBUF_SSP1BUF0 0x01
2384 #define _SSPBUF_BUF0 0x01
2385 #define _SSPBUF_SSP1BUF1 0x02
2386 #define _SSPBUF_BUF1 0x02
2387 #define _SSPBUF_SSP1BUF2 0x04
2388 #define _SSPBUF_BUF2 0x04
2389 #define _SSPBUF_SSP1BUF3 0x08
2390 #define _SSPBUF_BUF3 0x08
2391 #define _SSPBUF_SSP1BUF4 0x10
2392 #define _SSPBUF_BUF4 0x10
2393 #define _SSPBUF_SSP1BUF5 0x20
2394 #define _SSPBUF_BUF5 0x20
2395 #define _SSPBUF_SSP1BUF6 0x40
2396 #define _SSPBUF_BUF6 0x40
2397 #define _SSPBUF_SSP1BUF7 0x80
2398 #define _SSPBUF_BUF7 0x80
2400 //==============================================================================
2403 //==============================================================================
2404 // SSP1ADD Bits
2406 extern __at(0x0212) __sfr SSP1ADD;
2408 typedef union
2410 struct
2412 unsigned SSP1ADD0 : 1;
2413 unsigned SSP1ADD1 : 1;
2414 unsigned SSP1ADD2 : 1;
2415 unsigned SSP1ADD3 : 1;
2416 unsigned SSP1ADD4 : 1;
2417 unsigned SSP1ADD5 : 1;
2418 unsigned SSP1ADD6 : 1;
2419 unsigned SSP1ADD7 : 1;
2422 struct
2424 unsigned ADD0 : 1;
2425 unsigned ADD1 : 1;
2426 unsigned ADD2 : 1;
2427 unsigned ADD3 : 1;
2428 unsigned ADD4 : 1;
2429 unsigned ADD5 : 1;
2430 unsigned ADD6 : 1;
2431 unsigned ADD7 : 1;
2433 } __SSP1ADDbits_t;
2435 extern __at(0x0212) volatile __SSP1ADDbits_t SSP1ADDbits;
2437 #define _SSP1ADD0 0x01
2438 #define _ADD0 0x01
2439 #define _SSP1ADD1 0x02
2440 #define _ADD1 0x02
2441 #define _SSP1ADD2 0x04
2442 #define _ADD2 0x04
2443 #define _SSP1ADD3 0x08
2444 #define _ADD3 0x08
2445 #define _SSP1ADD4 0x10
2446 #define _ADD4 0x10
2447 #define _SSP1ADD5 0x20
2448 #define _ADD5 0x20
2449 #define _SSP1ADD6 0x40
2450 #define _ADD6 0x40
2451 #define _SSP1ADD7 0x80
2452 #define _ADD7 0x80
2454 //==============================================================================
2457 //==============================================================================
2458 // SSPADD Bits
2460 extern __at(0x0212) __sfr SSPADD;
2462 typedef union
2464 struct
2466 unsigned SSP1ADD0 : 1;
2467 unsigned SSP1ADD1 : 1;
2468 unsigned SSP1ADD2 : 1;
2469 unsigned SSP1ADD3 : 1;
2470 unsigned SSP1ADD4 : 1;
2471 unsigned SSP1ADD5 : 1;
2472 unsigned SSP1ADD6 : 1;
2473 unsigned SSP1ADD7 : 1;
2476 struct
2478 unsigned ADD0 : 1;
2479 unsigned ADD1 : 1;
2480 unsigned ADD2 : 1;
2481 unsigned ADD3 : 1;
2482 unsigned ADD4 : 1;
2483 unsigned ADD5 : 1;
2484 unsigned ADD6 : 1;
2485 unsigned ADD7 : 1;
2487 } __SSPADDbits_t;
2489 extern __at(0x0212) volatile __SSPADDbits_t SSPADDbits;
2491 #define _SSPADD_SSP1ADD0 0x01
2492 #define _SSPADD_ADD0 0x01
2493 #define _SSPADD_SSP1ADD1 0x02
2494 #define _SSPADD_ADD1 0x02
2495 #define _SSPADD_SSP1ADD2 0x04
2496 #define _SSPADD_ADD2 0x04
2497 #define _SSPADD_SSP1ADD3 0x08
2498 #define _SSPADD_ADD3 0x08
2499 #define _SSPADD_SSP1ADD4 0x10
2500 #define _SSPADD_ADD4 0x10
2501 #define _SSPADD_SSP1ADD5 0x20
2502 #define _SSPADD_ADD5 0x20
2503 #define _SSPADD_SSP1ADD6 0x40
2504 #define _SSPADD_ADD6 0x40
2505 #define _SSPADD_SSP1ADD7 0x80
2506 #define _SSPADD_ADD7 0x80
2508 //==============================================================================
2511 //==============================================================================
2512 // SSP1MSK Bits
2514 extern __at(0x0213) __sfr SSP1MSK;
2516 typedef union
2518 struct
2520 unsigned SSP1MSK0 : 1;
2521 unsigned SSP1MSK1 : 1;
2522 unsigned SSP1MSK2 : 1;
2523 unsigned SSP1MSK3 : 1;
2524 unsigned SSP1MSK4 : 1;
2525 unsigned SSP1MSK5 : 1;
2526 unsigned SSP1MSK6 : 1;
2527 unsigned SSP1MSK7 : 1;
2530 struct
2532 unsigned MSK0 : 1;
2533 unsigned MSK1 : 1;
2534 unsigned MSK2 : 1;
2535 unsigned MSK3 : 1;
2536 unsigned MSK4 : 1;
2537 unsigned MSK5 : 1;
2538 unsigned MSK6 : 1;
2539 unsigned MSK7 : 1;
2541 } __SSP1MSKbits_t;
2543 extern __at(0x0213) volatile __SSP1MSKbits_t SSP1MSKbits;
2545 #define _SSP1MSK0 0x01
2546 #define _MSK0 0x01
2547 #define _SSP1MSK1 0x02
2548 #define _MSK1 0x02
2549 #define _SSP1MSK2 0x04
2550 #define _MSK2 0x04
2551 #define _SSP1MSK3 0x08
2552 #define _MSK3 0x08
2553 #define _SSP1MSK4 0x10
2554 #define _MSK4 0x10
2555 #define _SSP1MSK5 0x20
2556 #define _MSK5 0x20
2557 #define _SSP1MSK6 0x40
2558 #define _MSK6 0x40
2559 #define _SSP1MSK7 0x80
2560 #define _MSK7 0x80
2562 //==============================================================================
2565 //==============================================================================
2566 // SSPMSK Bits
2568 extern __at(0x0213) __sfr SSPMSK;
2570 typedef union
2572 struct
2574 unsigned SSP1MSK0 : 1;
2575 unsigned SSP1MSK1 : 1;
2576 unsigned SSP1MSK2 : 1;
2577 unsigned SSP1MSK3 : 1;
2578 unsigned SSP1MSK4 : 1;
2579 unsigned SSP1MSK5 : 1;
2580 unsigned SSP1MSK6 : 1;
2581 unsigned SSP1MSK7 : 1;
2584 struct
2586 unsigned MSK0 : 1;
2587 unsigned MSK1 : 1;
2588 unsigned MSK2 : 1;
2589 unsigned MSK3 : 1;
2590 unsigned MSK4 : 1;
2591 unsigned MSK5 : 1;
2592 unsigned MSK6 : 1;
2593 unsigned MSK7 : 1;
2595 } __SSPMSKbits_t;
2597 extern __at(0x0213) volatile __SSPMSKbits_t SSPMSKbits;
2599 #define _SSPMSK_SSP1MSK0 0x01
2600 #define _SSPMSK_MSK0 0x01
2601 #define _SSPMSK_SSP1MSK1 0x02
2602 #define _SSPMSK_MSK1 0x02
2603 #define _SSPMSK_SSP1MSK2 0x04
2604 #define _SSPMSK_MSK2 0x04
2605 #define _SSPMSK_SSP1MSK3 0x08
2606 #define _SSPMSK_MSK3 0x08
2607 #define _SSPMSK_SSP1MSK4 0x10
2608 #define _SSPMSK_MSK4 0x10
2609 #define _SSPMSK_SSP1MSK5 0x20
2610 #define _SSPMSK_MSK5 0x20
2611 #define _SSPMSK_SSP1MSK6 0x40
2612 #define _SSPMSK_MSK6 0x40
2613 #define _SSPMSK_SSP1MSK7 0x80
2614 #define _SSPMSK_MSK7 0x80
2616 //==============================================================================
2619 //==============================================================================
2620 // SSP1STAT Bits
2622 extern __at(0x0214) __sfr SSP1STAT;
2624 typedef struct
2626 unsigned BF : 1;
2627 unsigned UA : 1;
2628 unsigned R_NOT_W : 1;
2629 unsigned S : 1;
2630 unsigned P : 1;
2631 unsigned D_NOT_A : 1;
2632 unsigned CKE : 1;
2633 unsigned SMP : 1;
2634 } __SSP1STATbits_t;
2636 extern __at(0x0214) volatile __SSP1STATbits_t SSP1STATbits;
2638 #define _BF 0x01
2639 #define _UA 0x02
2640 #define _R_NOT_W 0x04
2641 #define _S 0x08
2642 #define _P 0x10
2643 #define _D_NOT_A 0x20
2644 #define _CKE 0x40
2645 #define _SMP 0x80
2647 //==============================================================================
2650 //==============================================================================
2651 // SSPSTAT Bits
2653 extern __at(0x0214) __sfr SSPSTAT;
2655 typedef struct
2657 unsigned BF : 1;
2658 unsigned UA : 1;
2659 unsigned R_NOT_W : 1;
2660 unsigned S : 1;
2661 unsigned P : 1;
2662 unsigned D_NOT_A : 1;
2663 unsigned CKE : 1;
2664 unsigned SMP : 1;
2665 } __SSPSTATbits_t;
2667 extern __at(0x0214) volatile __SSPSTATbits_t SSPSTATbits;
2669 #define _SSPSTAT_BF 0x01
2670 #define _SSPSTAT_UA 0x02
2671 #define _SSPSTAT_R_NOT_W 0x04
2672 #define _SSPSTAT_S 0x08
2673 #define _SSPSTAT_P 0x10
2674 #define _SSPSTAT_D_NOT_A 0x20
2675 #define _SSPSTAT_CKE 0x40
2676 #define _SSPSTAT_SMP 0x80
2678 //==============================================================================
2681 //==============================================================================
2682 // SSP1CON Bits
2684 extern __at(0x0215) __sfr SSP1CON;
2686 typedef union
2688 struct
2690 unsigned SSPM0 : 1;
2691 unsigned SSPM1 : 1;
2692 unsigned SSPM2 : 1;
2693 unsigned SSPM3 : 1;
2694 unsigned CKP : 1;
2695 unsigned SSPEN : 1;
2696 unsigned SSPOV : 1;
2697 unsigned WCOL : 1;
2700 struct
2702 unsigned SSPM : 4;
2703 unsigned : 4;
2705 } __SSP1CONbits_t;
2707 extern __at(0x0215) volatile __SSP1CONbits_t SSP1CONbits;
2709 #define _SSPM0 0x01
2710 #define _SSPM1 0x02
2711 #define _SSPM2 0x04
2712 #define _SSPM3 0x08
2713 #define _CKP 0x10
2714 #define _SSPEN 0x20
2715 #define _SSPOV 0x40
2716 #define _WCOL 0x80
2718 //==============================================================================
2721 //==============================================================================
2722 // SSP1CON1 Bits
2724 extern __at(0x0215) __sfr SSP1CON1;
2726 typedef union
2728 struct
2730 unsigned SSPM0 : 1;
2731 unsigned SSPM1 : 1;
2732 unsigned SSPM2 : 1;
2733 unsigned SSPM3 : 1;
2734 unsigned CKP : 1;
2735 unsigned SSPEN : 1;
2736 unsigned SSPOV : 1;
2737 unsigned WCOL : 1;
2740 struct
2742 unsigned SSPM : 4;
2743 unsigned : 4;
2745 } __SSP1CON1bits_t;
2747 extern __at(0x0215) volatile __SSP1CON1bits_t SSP1CON1bits;
2749 #define _SSP1CON1_SSPM0 0x01
2750 #define _SSP1CON1_SSPM1 0x02
2751 #define _SSP1CON1_SSPM2 0x04
2752 #define _SSP1CON1_SSPM3 0x08
2753 #define _SSP1CON1_CKP 0x10
2754 #define _SSP1CON1_SSPEN 0x20
2755 #define _SSP1CON1_SSPOV 0x40
2756 #define _SSP1CON1_WCOL 0x80
2758 //==============================================================================
2761 //==============================================================================
2762 // SSPCON Bits
2764 extern __at(0x0215) __sfr SSPCON;
2766 typedef union
2768 struct
2770 unsigned SSPM0 : 1;
2771 unsigned SSPM1 : 1;
2772 unsigned SSPM2 : 1;
2773 unsigned SSPM3 : 1;
2774 unsigned CKP : 1;
2775 unsigned SSPEN : 1;
2776 unsigned SSPOV : 1;
2777 unsigned WCOL : 1;
2780 struct
2782 unsigned SSPM : 4;
2783 unsigned : 4;
2785 } __SSPCONbits_t;
2787 extern __at(0x0215) volatile __SSPCONbits_t SSPCONbits;
2789 #define _SSPCON_SSPM0 0x01
2790 #define _SSPCON_SSPM1 0x02
2791 #define _SSPCON_SSPM2 0x04
2792 #define _SSPCON_SSPM3 0x08
2793 #define _SSPCON_CKP 0x10
2794 #define _SSPCON_SSPEN 0x20
2795 #define _SSPCON_SSPOV 0x40
2796 #define _SSPCON_WCOL 0x80
2798 //==============================================================================
2801 //==============================================================================
2802 // SSPCON1 Bits
2804 extern __at(0x0215) __sfr SSPCON1;
2806 typedef union
2808 struct
2810 unsigned SSPM0 : 1;
2811 unsigned SSPM1 : 1;
2812 unsigned SSPM2 : 1;
2813 unsigned SSPM3 : 1;
2814 unsigned CKP : 1;
2815 unsigned SSPEN : 1;
2816 unsigned SSPOV : 1;
2817 unsigned WCOL : 1;
2820 struct
2822 unsigned SSPM : 4;
2823 unsigned : 4;
2825 } __SSPCON1bits_t;
2827 extern __at(0x0215) volatile __SSPCON1bits_t SSPCON1bits;
2829 #define _SSPCON1_SSPM0 0x01
2830 #define _SSPCON1_SSPM1 0x02
2831 #define _SSPCON1_SSPM2 0x04
2832 #define _SSPCON1_SSPM3 0x08
2833 #define _SSPCON1_CKP 0x10
2834 #define _SSPCON1_SSPEN 0x20
2835 #define _SSPCON1_SSPOV 0x40
2836 #define _SSPCON1_WCOL 0x80
2838 //==============================================================================
2841 //==============================================================================
2842 // SSP1CON2 Bits
2844 extern __at(0x0216) __sfr SSP1CON2;
2846 typedef struct
2848 unsigned SEN : 1;
2849 unsigned RSEN : 1;
2850 unsigned PEN : 1;
2851 unsigned RCEN : 1;
2852 unsigned ACKEN : 1;
2853 unsigned ACKDT : 1;
2854 unsigned ACKSTAT : 1;
2855 unsigned GCEN : 1;
2856 } __SSP1CON2bits_t;
2858 extern __at(0x0216) volatile __SSP1CON2bits_t SSP1CON2bits;
2860 #define _SEN 0x01
2861 #define _RSEN 0x02
2862 #define _PEN 0x04
2863 #define _RCEN 0x08
2864 #define _ACKEN 0x10
2865 #define _ACKDT 0x20
2866 #define _ACKSTAT 0x40
2867 #define _GCEN 0x80
2869 //==============================================================================
2872 //==============================================================================
2873 // SSPCON2 Bits
2875 extern __at(0x0216) __sfr SSPCON2;
2877 typedef struct
2879 unsigned SEN : 1;
2880 unsigned RSEN : 1;
2881 unsigned PEN : 1;
2882 unsigned RCEN : 1;
2883 unsigned ACKEN : 1;
2884 unsigned ACKDT : 1;
2885 unsigned ACKSTAT : 1;
2886 unsigned GCEN : 1;
2887 } __SSPCON2bits_t;
2889 extern __at(0x0216) volatile __SSPCON2bits_t SSPCON2bits;
2891 #define _SSPCON2_SEN 0x01
2892 #define _SSPCON2_RSEN 0x02
2893 #define _SSPCON2_PEN 0x04
2894 #define _SSPCON2_RCEN 0x08
2895 #define _SSPCON2_ACKEN 0x10
2896 #define _SSPCON2_ACKDT 0x20
2897 #define _SSPCON2_ACKSTAT 0x40
2898 #define _SSPCON2_GCEN 0x80
2900 //==============================================================================
2903 //==============================================================================
2904 // SSP1CON3 Bits
2906 extern __at(0x0217) __sfr SSP1CON3;
2908 typedef struct
2910 unsigned DHEN : 1;
2911 unsigned AHEN : 1;
2912 unsigned SBCDE : 1;
2913 unsigned SDAHT : 1;
2914 unsigned BOEN : 1;
2915 unsigned SCIE : 1;
2916 unsigned PCIE : 1;
2917 unsigned ACKTIM : 1;
2918 } __SSP1CON3bits_t;
2920 extern __at(0x0217) volatile __SSP1CON3bits_t SSP1CON3bits;
2922 #define _DHEN 0x01
2923 #define _AHEN 0x02
2924 #define _SBCDE 0x04
2925 #define _SDAHT 0x08
2926 #define _BOEN 0x10
2927 #define _SCIE 0x20
2928 #define _PCIE 0x40
2929 #define _ACKTIM 0x80
2931 //==============================================================================
2934 //==============================================================================
2935 // SSPCON3 Bits
2937 extern __at(0x0217) __sfr SSPCON3;
2939 typedef struct
2941 unsigned DHEN : 1;
2942 unsigned AHEN : 1;
2943 unsigned SBCDE : 1;
2944 unsigned SDAHT : 1;
2945 unsigned BOEN : 1;
2946 unsigned SCIE : 1;
2947 unsigned PCIE : 1;
2948 unsigned ACKTIM : 1;
2949 } __SSPCON3bits_t;
2951 extern __at(0x0217) volatile __SSPCON3bits_t SSPCON3bits;
2953 #define _SSPCON3_DHEN 0x01
2954 #define _SSPCON3_AHEN 0x02
2955 #define _SSPCON3_SBCDE 0x04
2956 #define _SSPCON3_SDAHT 0x08
2957 #define _SSPCON3_BOEN 0x10
2958 #define _SSPCON3_SCIE 0x20
2959 #define _SSPCON3_PCIE 0x40
2960 #define _SSPCON3_ACKTIM 0x80
2962 //==============================================================================
2965 //==============================================================================
2966 // ODCONA Bits
2968 extern __at(0x028C) __sfr ODCONA;
2970 typedef struct
2972 unsigned ODA0 : 1;
2973 unsigned ODA1 : 1;
2974 unsigned ODA2 : 1;
2975 unsigned : 1;
2976 unsigned ODA4 : 1;
2977 unsigned ODA5 : 1;
2978 unsigned : 1;
2979 unsigned : 1;
2980 } __ODCONAbits_t;
2982 extern __at(0x028C) volatile __ODCONAbits_t ODCONAbits;
2984 #define _ODA0 0x01
2985 #define _ODA1 0x02
2986 #define _ODA2 0x04
2987 #define _ODA4 0x10
2988 #define _ODA5 0x20
2990 //==============================================================================
2993 //==============================================================================
2994 // ODCONC Bits
2996 extern __at(0x028E) __sfr ODCONC;
2998 typedef union
3000 struct
3002 unsigned ODC0 : 1;
3003 unsigned ODC1 : 1;
3004 unsigned ODC2 : 1;
3005 unsigned ODC3 : 1;
3006 unsigned ODC4 : 1;
3007 unsigned ODC5 : 1;
3008 unsigned : 1;
3009 unsigned : 1;
3012 struct
3014 unsigned ODC : 6;
3015 unsigned : 2;
3017 } __ODCONCbits_t;
3019 extern __at(0x028E) volatile __ODCONCbits_t ODCONCbits;
3021 #define _ODC0 0x01
3022 #define _ODC1 0x02
3023 #define _ODC2 0x04
3024 #define _ODC3 0x08
3025 #define _ODC4 0x10
3026 #define _ODC5 0x20
3028 //==============================================================================
3030 extern __at(0x0291) __sfr CCPR1;
3031 extern __at(0x0291) __sfr CCPR1L;
3032 extern __at(0x0292) __sfr CCPR1H;
3034 //==============================================================================
3035 // CCP1CON Bits
3037 extern __at(0x0293) __sfr CCP1CON;
3039 typedef union
3041 struct
3043 unsigned CCP1M0 : 1;
3044 unsigned CCP1M1 : 1;
3045 unsigned CCP1M2 : 1;
3046 unsigned CCP1M3 : 1;
3047 unsigned DC1B0 : 1;
3048 unsigned DC1B1 : 1;
3049 unsigned : 1;
3050 unsigned : 1;
3053 struct
3055 unsigned : 1;
3056 unsigned : 1;
3057 unsigned : 1;
3058 unsigned : 1;
3059 unsigned CCP1Y : 1;
3060 unsigned CCP1X : 1;
3061 unsigned : 1;
3062 unsigned : 1;
3065 struct
3067 unsigned CCP1M : 4;
3068 unsigned : 4;
3071 struct
3073 unsigned : 4;
3074 unsigned DC1B : 2;
3075 unsigned : 2;
3077 } __CCP1CONbits_t;
3079 extern __at(0x0293) volatile __CCP1CONbits_t CCP1CONbits;
3081 #define _CCP1M0 0x01
3082 #define _CCP1M1 0x02
3083 #define _CCP1M2 0x04
3084 #define _CCP1M3 0x08
3085 #define _DC1B0 0x10
3086 #define _CCP1Y 0x10
3087 #define _DC1B1 0x20
3088 #define _CCP1X 0x20
3090 //==============================================================================
3093 //==============================================================================
3094 // ECCP1CON Bits
3096 extern __at(0x0293) __sfr ECCP1CON;
3098 typedef union
3100 struct
3102 unsigned CCP1M0 : 1;
3103 unsigned CCP1M1 : 1;
3104 unsigned CCP1M2 : 1;
3105 unsigned CCP1M3 : 1;
3106 unsigned DC1B0 : 1;
3107 unsigned DC1B1 : 1;
3108 unsigned : 1;
3109 unsigned : 1;
3112 struct
3114 unsigned : 1;
3115 unsigned : 1;
3116 unsigned : 1;
3117 unsigned : 1;
3118 unsigned CCP1Y : 1;
3119 unsigned CCP1X : 1;
3120 unsigned : 1;
3121 unsigned : 1;
3124 struct
3126 unsigned CCP1M : 4;
3127 unsigned : 4;
3130 struct
3132 unsigned : 4;
3133 unsigned DC1B : 2;
3134 unsigned : 2;
3136 } __ECCP1CONbits_t;
3138 extern __at(0x0293) volatile __ECCP1CONbits_t ECCP1CONbits;
3140 #define _ECCP1CON_CCP1M0 0x01
3141 #define _ECCP1CON_CCP1M1 0x02
3142 #define _ECCP1CON_CCP1M2 0x04
3143 #define _ECCP1CON_CCP1M3 0x08
3144 #define _ECCP1CON_DC1B0 0x10
3145 #define _ECCP1CON_CCP1Y 0x10
3146 #define _ECCP1CON_DC1B1 0x20
3147 #define _ECCP1CON_CCP1X 0x20
3149 //==============================================================================
3151 extern __at(0x0298) __sfr CCPR2;
3152 extern __at(0x0298) __sfr CCPR2L;
3153 extern __at(0x0299) __sfr CCPR2H;
3155 //==============================================================================
3156 // CCP2CON Bits
3158 extern __at(0x029A) __sfr CCP2CON;
3160 typedef union
3162 struct
3164 unsigned CCP2M0 : 1;
3165 unsigned CCP2M1 : 1;
3166 unsigned CCP2M2 : 1;
3167 unsigned CCP2M3 : 1;
3168 unsigned DC2B0 : 1;
3169 unsigned DC2B1 : 1;
3170 unsigned : 1;
3171 unsigned : 1;
3174 struct
3176 unsigned : 1;
3177 unsigned : 1;
3178 unsigned : 1;
3179 unsigned : 1;
3180 unsigned CCP2Y : 1;
3181 unsigned CCP2X : 1;
3182 unsigned : 1;
3183 unsigned : 1;
3186 struct
3188 unsigned CCP2M : 4;
3189 unsigned : 4;
3192 struct
3194 unsigned : 4;
3195 unsigned DC2B : 2;
3196 unsigned : 2;
3198 } __CCP2CONbits_t;
3200 extern __at(0x029A) volatile __CCP2CONbits_t CCP2CONbits;
3202 #define _CCP2M0 0x01
3203 #define _CCP2M1 0x02
3204 #define _CCP2M2 0x04
3205 #define _CCP2M3 0x08
3206 #define _DC2B0 0x10
3207 #define _CCP2Y 0x10
3208 #define _DC2B1 0x20
3209 #define _CCP2X 0x20
3211 //==============================================================================
3214 //==============================================================================
3215 // ECCP2CON Bits
3217 extern __at(0x029A) __sfr ECCP2CON;
3219 typedef union
3221 struct
3223 unsigned CCP2M0 : 1;
3224 unsigned CCP2M1 : 1;
3225 unsigned CCP2M2 : 1;
3226 unsigned CCP2M3 : 1;
3227 unsigned DC2B0 : 1;
3228 unsigned DC2B1 : 1;
3229 unsigned : 1;
3230 unsigned : 1;
3233 struct
3235 unsigned : 1;
3236 unsigned : 1;
3237 unsigned : 1;
3238 unsigned : 1;
3239 unsigned CCP2Y : 1;
3240 unsigned CCP2X : 1;
3241 unsigned : 1;
3242 unsigned : 1;
3245 struct
3247 unsigned CCP2M : 4;
3248 unsigned : 4;
3251 struct
3253 unsigned : 4;
3254 unsigned DC2B : 2;
3255 unsigned : 2;
3257 } __ECCP2CONbits_t;
3259 extern __at(0x029A) volatile __ECCP2CONbits_t ECCP2CONbits;
3261 #define _ECCP2CON_CCP2M0 0x01
3262 #define _ECCP2CON_CCP2M1 0x02
3263 #define _ECCP2CON_CCP2M2 0x04
3264 #define _ECCP2CON_CCP2M3 0x08
3265 #define _ECCP2CON_DC2B0 0x10
3266 #define _ECCP2CON_CCP2Y 0x10
3267 #define _ECCP2CON_DC2B1 0x20
3268 #define _ECCP2CON_CCP2X 0x20
3270 //==============================================================================
3273 //==============================================================================
3274 // CCPTMRS Bits
3276 extern __at(0x029E) __sfr CCPTMRS;
3278 typedef union
3280 struct
3282 unsigned C1TSEL0 : 1;
3283 unsigned C1TSEL1 : 1;
3284 unsigned C2TSEL0 : 1;
3285 unsigned C2TSEL1 : 1;
3286 unsigned P3TSEL0 : 1;
3287 unsigned P3TSEL1 : 1;
3288 unsigned P4TSEL0 : 1;
3289 unsigned P4TSEL1 : 1;
3292 struct
3294 unsigned C1TSEL : 2;
3295 unsigned : 6;
3298 struct
3300 unsigned : 2;
3301 unsigned C2TSEL : 2;
3302 unsigned : 4;
3305 struct
3307 unsigned : 4;
3308 unsigned P3TSEL : 2;
3309 unsigned : 2;
3312 struct
3314 unsigned : 6;
3315 unsigned P4TSEL : 2;
3317 } __CCPTMRSbits_t;
3319 extern __at(0x029E) volatile __CCPTMRSbits_t CCPTMRSbits;
3321 #define _C1TSEL0 0x01
3322 #define _C1TSEL1 0x02
3323 #define _C2TSEL0 0x04
3324 #define _C2TSEL1 0x08
3325 #define _P3TSEL0 0x10
3326 #define _P3TSEL1 0x20
3327 #define _P4TSEL0 0x40
3328 #define _P4TSEL1 0x80
3330 //==============================================================================
3333 //==============================================================================
3334 // SLRCONA Bits
3336 extern __at(0x030C) __sfr SLRCONA;
3338 typedef struct
3340 unsigned SLRA0 : 1;
3341 unsigned SLRA1 : 1;
3342 unsigned SLRA2 : 1;
3343 unsigned : 1;
3344 unsigned SLRA4 : 1;
3345 unsigned SLRA5 : 1;
3346 unsigned : 1;
3347 unsigned : 1;
3348 } __SLRCONAbits_t;
3350 extern __at(0x030C) volatile __SLRCONAbits_t SLRCONAbits;
3352 #define _SLRA0 0x01
3353 #define _SLRA1 0x02
3354 #define _SLRA2 0x04
3355 #define _SLRA4 0x10
3356 #define _SLRA5 0x20
3358 //==============================================================================
3361 //==============================================================================
3362 // SLRCONC Bits
3364 extern __at(0x030E) __sfr SLRCONC;
3366 typedef union
3368 struct
3370 unsigned SLRC0 : 1;
3371 unsigned SLRC1 : 1;
3372 unsigned SLRC2 : 1;
3373 unsigned SLRC3 : 1;
3374 unsigned SLRC4 : 1;
3375 unsigned SLRC5 : 1;
3376 unsigned : 1;
3377 unsigned : 1;
3380 struct
3382 unsigned SLRC : 6;
3383 unsigned : 2;
3385 } __SLRCONCbits_t;
3387 extern __at(0x030E) volatile __SLRCONCbits_t SLRCONCbits;
3389 #define _SLRC0 0x01
3390 #define _SLRC1 0x02
3391 #define _SLRC2 0x04
3392 #define _SLRC3 0x08
3393 #define _SLRC4 0x10
3394 #define _SLRC5 0x20
3396 //==============================================================================
3399 //==============================================================================
3400 // INLVLA Bits
3402 extern __at(0x038C) __sfr INLVLA;
3404 typedef union
3406 struct
3408 unsigned INLVLA0 : 1;
3409 unsigned INLVLA1 : 1;
3410 unsigned INLVLA2 : 1;
3411 unsigned INLVLA3 : 1;
3412 unsigned INLVLA4 : 1;
3413 unsigned INLVLA5 : 1;
3414 unsigned : 1;
3415 unsigned : 1;
3418 struct
3420 unsigned INLVLA : 6;
3421 unsigned : 2;
3423 } __INLVLAbits_t;
3425 extern __at(0x038C) volatile __INLVLAbits_t INLVLAbits;
3427 #define _INLVLA0 0x01
3428 #define _INLVLA1 0x02
3429 #define _INLVLA2 0x04
3430 #define _INLVLA3 0x08
3431 #define _INLVLA4 0x10
3432 #define _INLVLA5 0x20
3434 //==============================================================================
3437 //==============================================================================
3438 // INLVLC Bits
3440 extern __at(0x038E) __sfr INLVLC;
3442 typedef union
3444 struct
3446 unsigned INLVLC0 : 1;
3447 unsigned INLVLC1 : 1;
3448 unsigned INLVLC2 : 1;
3449 unsigned INLVLC3 : 1;
3450 unsigned INLVLC4 : 1;
3451 unsigned INLVLC5 : 1;
3452 unsigned : 1;
3453 unsigned : 1;
3456 struct
3458 unsigned INLVLC : 6;
3459 unsigned : 2;
3461 } __INLVLCbits_t;
3463 extern __at(0x038E) volatile __INLVLCbits_t INLVLCbits;
3465 #define _INLVLC0 0x01
3466 #define _INLVLC1 0x02
3467 #define _INLVLC2 0x04
3468 #define _INLVLC3 0x08
3469 #define _INLVLC4 0x10
3470 #define _INLVLC5 0x20
3472 //==============================================================================
3475 //==============================================================================
3476 // IOCAP Bits
3478 extern __at(0x0391) __sfr IOCAP;
3480 typedef union
3482 struct
3484 unsigned IOCAP0 : 1;
3485 unsigned IOCAP1 : 1;
3486 unsigned IOCAP2 : 1;
3487 unsigned IOCAP3 : 1;
3488 unsigned IOCAP4 : 1;
3489 unsigned IOCAP5 : 1;
3490 unsigned : 1;
3491 unsigned : 1;
3494 struct
3496 unsigned IOCAP : 6;
3497 unsigned : 2;
3499 } __IOCAPbits_t;
3501 extern __at(0x0391) volatile __IOCAPbits_t IOCAPbits;
3503 #define _IOCAP0 0x01
3504 #define _IOCAP1 0x02
3505 #define _IOCAP2 0x04
3506 #define _IOCAP3 0x08
3507 #define _IOCAP4 0x10
3508 #define _IOCAP5 0x20
3510 //==============================================================================
3513 //==============================================================================
3514 // IOCAN Bits
3516 extern __at(0x0392) __sfr IOCAN;
3518 typedef union
3520 struct
3522 unsigned IOCAN0 : 1;
3523 unsigned IOCAN1 : 1;
3524 unsigned IOCAN2 : 1;
3525 unsigned IOCAN3 : 1;
3526 unsigned IOCAN4 : 1;
3527 unsigned IOCAN5 : 1;
3528 unsigned : 1;
3529 unsigned : 1;
3532 struct
3534 unsigned IOCAN : 6;
3535 unsigned : 2;
3537 } __IOCANbits_t;
3539 extern __at(0x0392) volatile __IOCANbits_t IOCANbits;
3541 #define _IOCAN0 0x01
3542 #define _IOCAN1 0x02
3543 #define _IOCAN2 0x04
3544 #define _IOCAN3 0x08
3545 #define _IOCAN4 0x10
3546 #define _IOCAN5 0x20
3548 //==============================================================================
3551 //==============================================================================
3552 // IOCAF Bits
3554 extern __at(0x0393) __sfr IOCAF;
3556 typedef union
3558 struct
3560 unsigned IOCAF0 : 1;
3561 unsigned IOCAF1 : 1;
3562 unsigned IOCAF2 : 1;
3563 unsigned IOCAF3 : 1;
3564 unsigned IOCAF4 : 1;
3565 unsigned IOCAF5 : 1;
3566 unsigned : 1;
3567 unsigned : 1;
3570 struct
3572 unsigned IOCAF : 6;
3573 unsigned : 2;
3575 } __IOCAFbits_t;
3577 extern __at(0x0393) volatile __IOCAFbits_t IOCAFbits;
3579 #define _IOCAF0 0x01
3580 #define _IOCAF1 0x02
3581 #define _IOCAF2 0x04
3582 #define _IOCAF3 0x08
3583 #define _IOCAF4 0x10
3584 #define _IOCAF5 0x20
3586 //==============================================================================
3589 //==============================================================================
3590 // IOCCP Bits
3592 extern __at(0x0397) __sfr IOCCP;
3594 typedef union
3596 struct
3598 unsigned IOCCP0 : 1;
3599 unsigned IOCCP1 : 1;
3600 unsigned IOCCP2 : 1;
3601 unsigned IOCCP3 : 1;
3602 unsigned IOCCP4 : 1;
3603 unsigned IOCCP5 : 1;
3604 unsigned : 1;
3605 unsigned : 1;
3608 struct
3610 unsigned IOCCP : 6;
3611 unsigned : 2;
3613 } __IOCCPbits_t;
3615 extern __at(0x0397) volatile __IOCCPbits_t IOCCPbits;
3617 #define _IOCCP0 0x01
3618 #define _IOCCP1 0x02
3619 #define _IOCCP2 0x04
3620 #define _IOCCP3 0x08
3621 #define _IOCCP4 0x10
3622 #define _IOCCP5 0x20
3624 //==============================================================================
3627 //==============================================================================
3628 // IOCCN Bits
3630 extern __at(0x0398) __sfr IOCCN;
3632 typedef union
3634 struct
3636 unsigned IOCCN0 : 1;
3637 unsigned IOCCN1 : 1;
3638 unsigned IOCCN2 : 1;
3639 unsigned IOCCN3 : 1;
3640 unsigned IOCCN4 : 1;
3641 unsigned IOCCN5 : 1;
3642 unsigned : 1;
3643 unsigned : 1;
3646 struct
3648 unsigned IOCCN : 6;
3649 unsigned : 2;
3651 } __IOCCNbits_t;
3653 extern __at(0x0398) volatile __IOCCNbits_t IOCCNbits;
3655 #define _IOCCN0 0x01
3656 #define _IOCCN1 0x02
3657 #define _IOCCN2 0x04
3658 #define _IOCCN3 0x08
3659 #define _IOCCN4 0x10
3660 #define _IOCCN5 0x20
3662 //==============================================================================
3665 //==============================================================================
3666 // IOCCF Bits
3668 extern __at(0x0399) __sfr IOCCF;
3670 typedef union
3672 struct
3674 unsigned IOCCF0 : 1;
3675 unsigned IOCCF1 : 1;
3676 unsigned IOCCF2 : 1;
3677 unsigned IOCCF3 : 1;
3678 unsigned IOCCF4 : 1;
3679 unsigned IOCCF5 : 1;
3680 unsigned : 1;
3681 unsigned : 1;
3684 struct
3686 unsigned IOCCF : 6;
3687 unsigned : 2;
3689 } __IOCCFbits_t;
3691 extern __at(0x0399) volatile __IOCCFbits_t IOCCFbits;
3693 #define _IOCCF0 0x01
3694 #define _IOCCF1 0x02
3695 #define _IOCCF2 0x04
3696 #define _IOCCF3 0x08
3697 #define _IOCCF4 0x10
3698 #define _IOCCF5 0x20
3700 //==============================================================================
3702 extern __at(0x0415) __sfr TMR4;
3703 extern __at(0x0416) __sfr PR4;
3705 //==============================================================================
3706 // T4CON Bits
3708 extern __at(0x0417) __sfr T4CON;
3710 typedef union
3712 struct
3714 unsigned T4CKPS0 : 1;
3715 unsigned T4CKPS1 : 1;
3716 unsigned TMR4ON : 1;
3717 unsigned T4OUTPS0 : 1;
3718 unsigned T4OUTPS1 : 1;
3719 unsigned T4OUTPS2 : 1;
3720 unsigned T4OUTPS3 : 1;
3721 unsigned : 1;
3724 struct
3726 unsigned T4CKPS : 2;
3727 unsigned : 6;
3730 struct
3732 unsigned : 3;
3733 unsigned T4OUTPS : 4;
3734 unsigned : 1;
3736 } __T4CONbits_t;
3738 extern __at(0x0417) volatile __T4CONbits_t T4CONbits;
3740 #define _T4CKPS0 0x01
3741 #define _T4CKPS1 0x02
3742 #define _TMR4ON 0x04
3743 #define _T4OUTPS0 0x08
3744 #define _T4OUTPS1 0x10
3745 #define _T4OUTPS2 0x20
3746 #define _T4OUTPS3 0x40
3748 //==============================================================================
3750 extern __at(0x041C) __sfr TMR6;
3751 extern __at(0x041D) __sfr PR6;
3753 //==============================================================================
3754 // T6CON Bits
3756 extern __at(0x041E) __sfr T6CON;
3758 typedef union
3760 struct
3762 unsigned T6CKPS0 : 1;
3763 unsigned T6CKPS1 : 1;
3764 unsigned TMR6ON : 1;
3765 unsigned T6OUTPS0 : 1;
3766 unsigned T6OUTPS1 : 1;
3767 unsigned T6OUTPS2 : 1;
3768 unsigned T6OUTPS3 : 1;
3769 unsigned : 1;
3772 struct
3774 unsigned T6CKPS : 2;
3775 unsigned : 6;
3778 struct
3780 unsigned : 3;
3781 unsigned T6OUTPS : 4;
3782 unsigned : 1;
3784 } __T6CONbits_t;
3786 extern __at(0x041E) volatile __T6CONbits_t T6CONbits;
3788 #define _T6CKPS0 0x01
3789 #define _T6CKPS1 0x02
3790 #define _TMR6ON 0x04
3791 #define _T6OUTPS0 0x08
3792 #define _T6OUTPS1 0x10
3793 #define _T6OUTPS2 0x20
3794 #define _T6OUTPS3 0x40
3796 //==============================================================================
3799 //==============================================================================
3800 // OPA1CON Bits
3802 extern __at(0x0511) __sfr OPA1CON;
3804 typedef union
3806 struct
3808 unsigned OPA1PCH0 : 1;
3809 unsigned OPA1PCH1 : 1;
3810 unsigned : 1;
3811 unsigned : 1;
3812 unsigned OPA1UG : 1;
3813 unsigned : 1;
3814 unsigned OPA1SP : 1;
3815 unsigned OPA1EN : 1;
3818 struct
3820 unsigned OPA1PCH : 2;
3821 unsigned : 6;
3823 } __OPA1CONbits_t;
3825 extern __at(0x0511) volatile __OPA1CONbits_t OPA1CONbits;
3827 #define _OPA1PCH0 0x01
3828 #define _OPA1PCH1 0x02
3829 #define _OPA1UG 0x10
3830 #define _OPA1SP 0x40
3831 #define _OPA1EN 0x80
3833 //==============================================================================
3836 //==============================================================================
3837 // OPA2CON Bits
3839 extern __at(0x0515) __sfr OPA2CON;
3841 typedef union
3843 struct
3845 unsigned OPA2PCH0 : 1;
3846 unsigned OPA2PCH1 : 1;
3847 unsigned : 1;
3848 unsigned : 1;
3849 unsigned OPA2UG : 1;
3850 unsigned : 1;
3851 unsigned OPA2SP : 1;
3852 unsigned OPA2EN : 1;
3855 struct
3857 unsigned OPA2PCH : 2;
3858 unsigned : 6;
3860 } __OPA2CONbits_t;
3862 extern __at(0x0515) volatile __OPA2CONbits_t OPA2CONbits;
3864 #define _OPA2PCH0 0x01
3865 #define _OPA2PCH1 0x02
3866 #define _OPA2UG 0x10
3867 #define _OPA2SP 0x40
3868 #define _OPA2EN 0x80
3870 //==============================================================================
3873 //==============================================================================
3874 // PWM3DCL Bits
3876 extern __at(0x0617) __sfr PWM3DCL;
3878 typedef union
3880 struct
3882 unsigned : 1;
3883 unsigned : 1;
3884 unsigned : 1;
3885 unsigned : 1;
3886 unsigned : 1;
3887 unsigned : 1;
3888 unsigned PWM3DCL0 : 1;
3889 unsigned PWM3DCL1 : 1;
3892 struct
3894 unsigned : 6;
3895 unsigned PWM3DCL : 2;
3897 } __PWM3DCLbits_t;
3899 extern __at(0x0617) volatile __PWM3DCLbits_t PWM3DCLbits;
3901 #define _PWM3DCL0 0x40
3902 #define _PWM3DCL1 0x80
3904 //==============================================================================
3907 //==============================================================================
3908 // PWM3DCH Bits
3910 extern __at(0x0618) __sfr PWM3DCH;
3912 typedef struct
3914 unsigned PWM3DCH0 : 1;
3915 unsigned PWM3DCH1 : 1;
3916 unsigned PWM3DCH2 : 1;
3917 unsigned PWM3DCH3 : 1;
3918 unsigned PWM3DCH4 : 1;
3919 unsigned PWM3DCH5 : 1;
3920 unsigned PWM3DCH6 : 1;
3921 unsigned PWM3DCH7 : 1;
3922 } __PWM3DCHbits_t;
3924 extern __at(0x0618) volatile __PWM3DCHbits_t PWM3DCHbits;
3926 #define _PWM3DCH0 0x01
3927 #define _PWM3DCH1 0x02
3928 #define _PWM3DCH2 0x04
3929 #define _PWM3DCH3 0x08
3930 #define _PWM3DCH4 0x10
3931 #define _PWM3DCH5 0x20
3932 #define _PWM3DCH6 0x40
3933 #define _PWM3DCH7 0x80
3935 //==============================================================================
3938 //==============================================================================
3939 // PWM3CON Bits
3941 extern __at(0x0619) __sfr PWM3CON;
3943 typedef struct
3945 unsigned : 1;
3946 unsigned : 1;
3947 unsigned : 1;
3948 unsigned : 1;
3949 unsigned PWM3POL : 1;
3950 unsigned PWM3OUT : 1;
3951 unsigned : 1;
3952 unsigned PWM3EN : 1;
3953 } __PWM3CONbits_t;
3955 extern __at(0x0619) volatile __PWM3CONbits_t PWM3CONbits;
3957 #define _PWM3POL 0x10
3958 #define _PWM3OUT 0x20
3959 #define _PWM3EN 0x80
3961 //==============================================================================
3964 //==============================================================================
3965 // PWM3CON0 Bits
3967 extern __at(0x0619) __sfr PWM3CON0;
3969 typedef struct
3971 unsigned : 1;
3972 unsigned : 1;
3973 unsigned : 1;
3974 unsigned : 1;
3975 unsigned PWM3POL : 1;
3976 unsigned PWM3OUT : 1;
3977 unsigned : 1;
3978 unsigned PWM3EN : 1;
3979 } __PWM3CON0bits_t;
3981 extern __at(0x0619) volatile __PWM3CON0bits_t PWM3CON0bits;
3983 #define _PWM3CON0_PWM3POL 0x10
3984 #define _PWM3CON0_PWM3OUT 0x20
3985 #define _PWM3CON0_PWM3EN 0x80
3987 //==============================================================================
3990 //==============================================================================
3991 // PWM4DCL Bits
3993 extern __at(0x061A) __sfr PWM4DCL;
3995 typedef union
3997 struct
3999 unsigned : 1;
4000 unsigned : 1;
4001 unsigned : 1;
4002 unsigned : 1;
4003 unsigned : 1;
4004 unsigned : 1;
4005 unsigned PWM4DCL0 : 1;
4006 unsigned PWM4DCL1 : 1;
4009 struct
4011 unsigned : 6;
4012 unsigned PWM4DCL : 2;
4014 } __PWM4DCLbits_t;
4016 extern __at(0x061A) volatile __PWM4DCLbits_t PWM4DCLbits;
4018 #define _PWM4DCL0 0x40
4019 #define _PWM4DCL1 0x80
4021 //==============================================================================
4024 //==============================================================================
4025 // PWM4DCH Bits
4027 extern __at(0x061B) __sfr PWM4DCH;
4029 typedef struct
4031 unsigned PWM4DCH0 : 1;
4032 unsigned PWM4DCH1 : 1;
4033 unsigned PWM4DCH2 : 1;
4034 unsigned PWM4DCH3 : 1;
4035 unsigned PWM4DCH4 : 1;
4036 unsigned PWM4DCH5 : 1;
4037 unsigned PWM4DCH6 : 1;
4038 unsigned PWM4DCH7 : 1;
4039 } __PWM4DCHbits_t;
4041 extern __at(0x061B) volatile __PWM4DCHbits_t PWM4DCHbits;
4043 #define _PWM4DCH0 0x01
4044 #define _PWM4DCH1 0x02
4045 #define _PWM4DCH2 0x04
4046 #define _PWM4DCH3 0x08
4047 #define _PWM4DCH4 0x10
4048 #define _PWM4DCH5 0x20
4049 #define _PWM4DCH6 0x40
4050 #define _PWM4DCH7 0x80
4052 //==============================================================================
4055 //==============================================================================
4056 // PWM4CON Bits
4058 extern __at(0x061C) __sfr PWM4CON;
4060 typedef struct
4062 unsigned : 1;
4063 unsigned : 1;
4064 unsigned : 1;
4065 unsigned : 1;
4066 unsigned PWM4POL : 1;
4067 unsigned PWM4OUT : 1;
4068 unsigned : 1;
4069 unsigned PWM4EN : 1;
4070 } __PWM4CONbits_t;
4072 extern __at(0x061C) volatile __PWM4CONbits_t PWM4CONbits;
4074 #define _PWM4POL 0x10
4075 #define _PWM4OUT 0x20
4076 #define _PWM4EN 0x80
4078 //==============================================================================
4081 //==============================================================================
4082 // PWM4CON0 Bits
4084 extern __at(0x061C) __sfr PWM4CON0;
4086 typedef struct
4088 unsigned : 1;
4089 unsigned : 1;
4090 unsigned : 1;
4091 unsigned : 1;
4092 unsigned PWM4POL : 1;
4093 unsigned PWM4OUT : 1;
4094 unsigned : 1;
4095 unsigned PWM4EN : 1;
4096 } __PWM4CON0bits_t;
4098 extern __at(0x061C) volatile __PWM4CON0bits_t PWM4CON0bits;
4100 #define _PWM4CON0_PWM4POL 0x10
4101 #define _PWM4CON0_PWM4OUT 0x20
4102 #define _PWM4CON0_PWM4EN 0x80
4104 //==============================================================================
4107 //==============================================================================
4108 // COG1PHR Bits
4110 extern __at(0x0691) __sfr COG1PHR;
4112 typedef union
4114 struct
4116 unsigned G1PHR0 : 1;
4117 unsigned G1PHR1 : 1;
4118 unsigned G1PHR2 : 1;
4119 unsigned G1PHR3 : 1;
4120 unsigned G1PHR4 : 1;
4121 unsigned G1PHR5 : 1;
4122 unsigned : 1;
4123 unsigned : 1;
4126 struct
4128 unsigned G1PHR : 6;
4129 unsigned : 2;
4131 } __COG1PHRbits_t;
4133 extern __at(0x0691) volatile __COG1PHRbits_t COG1PHRbits;
4135 #define _G1PHR0 0x01
4136 #define _G1PHR1 0x02
4137 #define _G1PHR2 0x04
4138 #define _G1PHR3 0x08
4139 #define _G1PHR4 0x10
4140 #define _G1PHR5 0x20
4142 //==============================================================================
4145 //==============================================================================
4146 // COG1PHF Bits
4148 extern __at(0x0692) __sfr COG1PHF;
4150 typedef union
4152 struct
4154 unsigned G1PHF0 : 1;
4155 unsigned G1PHF1 : 1;
4156 unsigned G1PHF2 : 1;
4157 unsigned G1PHF3 : 1;
4158 unsigned G1PHF4 : 1;
4159 unsigned G1PHF5 : 1;
4160 unsigned : 1;
4161 unsigned : 1;
4164 struct
4166 unsigned G1PHF : 6;
4167 unsigned : 2;
4169 } __COG1PHFbits_t;
4171 extern __at(0x0692) volatile __COG1PHFbits_t COG1PHFbits;
4173 #define _G1PHF0 0x01
4174 #define _G1PHF1 0x02
4175 #define _G1PHF2 0x04
4176 #define _G1PHF3 0x08
4177 #define _G1PHF4 0x10
4178 #define _G1PHF5 0x20
4180 //==============================================================================
4183 //==============================================================================
4184 // COG1BLKR Bits
4186 extern __at(0x0693) __sfr COG1BLKR;
4188 typedef union
4190 struct
4192 unsigned G1BLKR0 : 1;
4193 unsigned G1BLKR1 : 1;
4194 unsigned G1BLKR2 : 1;
4195 unsigned G1BLKR3 : 1;
4196 unsigned G1BLKR4 : 1;
4197 unsigned G1BLKR5 : 1;
4198 unsigned : 1;
4199 unsigned : 1;
4202 struct
4204 unsigned G1BLKR : 6;
4205 unsigned : 2;
4207 } __COG1BLKRbits_t;
4209 extern __at(0x0693) volatile __COG1BLKRbits_t COG1BLKRbits;
4211 #define _G1BLKR0 0x01
4212 #define _G1BLKR1 0x02
4213 #define _G1BLKR2 0x04
4214 #define _G1BLKR3 0x08
4215 #define _G1BLKR4 0x10
4216 #define _G1BLKR5 0x20
4218 //==============================================================================
4221 //==============================================================================
4222 // COG1BLKF Bits
4224 extern __at(0x0694) __sfr COG1BLKF;
4226 typedef union
4228 struct
4230 unsigned G1BLKF0 : 1;
4231 unsigned G1BLKF1 : 1;
4232 unsigned G1BLKF2 : 1;
4233 unsigned G1BLKF3 : 1;
4234 unsigned G1BLKF4 : 1;
4235 unsigned G1BLKF5 : 1;
4236 unsigned : 1;
4237 unsigned : 1;
4240 struct
4242 unsigned G1BLKF : 6;
4243 unsigned : 2;
4245 } __COG1BLKFbits_t;
4247 extern __at(0x0694) volatile __COG1BLKFbits_t COG1BLKFbits;
4249 #define _G1BLKF0 0x01
4250 #define _G1BLKF1 0x02
4251 #define _G1BLKF2 0x04
4252 #define _G1BLKF3 0x08
4253 #define _G1BLKF4 0x10
4254 #define _G1BLKF5 0x20
4256 //==============================================================================
4259 //==============================================================================
4260 // COG1DBR Bits
4262 extern __at(0x0695) __sfr COG1DBR;
4264 typedef union
4266 struct
4268 unsigned G1DBR0 : 1;
4269 unsigned G1DBR1 : 1;
4270 unsigned G1DBR2 : 1;
4271 unsigned G1DBR3 : 1;
4272 unsigned G1DBR4 : 1;
4273 unsigned G1DBR5 : 1;
4274 unsigned : 1;
4275 unsigned : 1;
4278 struct
4280 unsigned G1DBR : 6;
4281 unsigned : 2;
4283 } __COG1DBRbits_t;
4285 extern __at(0x0695) volatile __COG1DBRbits_t COG1DBRbits;
4287 #define _G1DBR0 0x01
4288 #define _G1DBR1 0x02
4289 #define _G1DBR2 0x04
4290 #define _G1DBR3 0x08
4291 #define _G1DBR4 0x10
4292 #define _G1DBR5 0x20
4294 //==============================================================================
4297 //==============================================================================
4298 // COG1DBF Bits
4300 extern __at(0x0696) __sfr COG1DBF;
4302 typedef union
4304 struct
4306 unsigned G1DBF0 : 1;
4307 unsigned G1DBF1 : 1;
4308 unsigned G1DBF2 : 1;
4309 unsigned G1DBF3 : 1;
4310 unsigned G1DBF4 : 1;
4311 unsigned G1DBF5 : 1;
4312 unsigned : 1;
4313 unsigned : 1;
4316 struct
4318 unsigned G1DBF : 6;
4319 unsigned : 2;
4321 } __COG1DBFbits_t;
4323 extern __at(0x0696) volatile __COG1DBFbits_t COG1DBFbits;
4325 #define _G1DBF0 0x01
4326 #define _G1DBF1 0x02
4327 #define _G1DBF2 0x04
4328 #define _G1DBF3 0x08
4329 #define _G1DBF4 0x10
4330 #define _G1DBF5 0x20
4332 //==============================================================================
4335 //==============================================================================
4336 // COG1CON0 Bits
4338 extern __at(0x0697) __sfr COG1CON0;
4340 typedef union
4342 struct
4344 unsigned G1MD0 : 1;
4345 unsigned G1MD1 : 1;
4346 unsigned G1MD2 : 1;
4347 unsigned G1CS0 : 1;
4348 unsigned G1CS1 : 1;
4349 unsigned : 1;
4350 unsigned G1LD : 1;
4351 unsigned G1EN : 1;
4354 struct
4356 unsigned G1MD : 3;
4357 unsigned : 5;
4360 struct
4362 unsigned : 3;
4363 unsigned G1CS : 2;
4364 unsigned : 3;
4366 } __COG1CON0bits_t;
4368 extern __at(0x0697) volatile __COG1CON0bits_t COG1CON0bits;
4370 #define _G1MD0 0x01
4371 #define _G1MD1 0x02
4372 #define _G1MD2 0x04
4373 #define _G1CS0 0x08
4374 #define _G1CS1 0x10
4375 #define _G1LD 0x40
4376 #define _G1EN 0x80
4378 //==============================================================================
4381 //==============================================================================
4382 // COG1CON1 Bits
4384 extern __at(0x0698) __sfr COG1CON1;
4386 typedef struct
4388 unsigned G1POLA : 1;
4389 unsigned G1POLB : 1;
4390 unsigned G1POLC : 1;
4391 unsigned G1POLD : 1;
4392 unsigned : 1;
4393 unsigned : 1;
4394 unsigned G1FDBS : 1;
4395 unsigned G1RDBS : 1;
4396 } __COG1CON1bits_t;
4398 extern __at(0x0698) volatile __COG1CON1bits_t COG1CON1bits;
4400 #define _G1POLA 0x01
4401 #define _G1POLB 0x02
4402 #define _G1POLC 0x04
4403 #define _G1POLD 0x08
4404 #define _G1FDBS 0x40
4405 #define _G1RDBS 0x80
4407 //==============================================================================
4410 //==============================================================================
4411 // COG1RIS Bits
4413 extern __at(0x0699) __sfr COG1RIS;
4415 typedef union
4417 struct
4419 unsigned G1RIS0 : 1;
4420 unsigned G1RIS1 : 1;
4421 unsigned G1RIS2 : 1;
4422 unsigned G1RIS3 : 1;
4423 unsigned G1RIS4 : 1;
4424 unsigned G1RIS5 : 1;
4425 unsigned G1RIS6 : 1;
4426 unsigned : 1;
4429 struct
4431 unsigned G1RIS : 7;
4432 unsigned : 1;
4434 } __COG1RISbits_t;
4436 extern __at(0x0699) volatile __COG1RISbits_t COG1RISbits;
4438 #define _G1RIS0 0x01
4439 #define _G1RIS1 0x02
4440 #define _G1RIS2 0x04
4441 #define _G1RIS3 0x08
4442 #define _G1RIS4 0x10
4443 #define _G1RIS5 0x20
4444 #define _G1RIS6 0x40
4446 //==============================================================================
4449 //==============================================================================
4450 // COG1RSIM Bits
4452 extern __at(0x069A) __sfr COG1RSIM;
4454 typedef union
4456 struct
4458 unsigned G1RSIM0 : 1;
4459 unsigned G1RSIM1 : 1;
4460 unsigned G1RSIM2 : 1;
4461 unsigned G1RSIM3 : 1;
4462 unsigned G1RSIM4 : 1;
4463 unsigned G1RSIM5 : 1;
4464 unsigned G1RSIM6 : 1;
4465 unsigned : 1;
4468 struct
4470 unsigned G1RSIM : 7;
4471 unsigned : 1;
4473 } __COG1RSIMbits_t;
4475 extern __at(0x069A) volatile __COG1RSIMbits_t COG1RSIMbits;
4477 #define _G1RSIM0 0x01
4478 #define _G1RSIM1 0x02
4479 #define _G1RSIM2 0x04
4480 #define _G1RSIM3 0x08
4481 #define _G1RSIM4 0x10
4482 #define _G1RSIM5 0x20
4483 #define _G1RSIM6 0x40
4485 //==============================================================================
4488 //==============================================================================
4489 // COG1FIS Bits
4491 extern __at(0x069B) __sfr COG1FIS;
4493 typedef union
4495 struct
4497 unsigned G1FIS0 : 1;
4498 unsigned G1FIS1 : 1;
4499 unsigned G1FIS2 : 1;
4500 unsigned G1FIS3 : 1;
4501 unsigned G1FIS4 : 1;
4502 unsigned G1FIS5 : 1;
4503 unsigned G1FIS6 : 1;
4504 unsigned : 1;
4507 struct
4509 unsigned G1FIS : 7;
4510 unsigned : 1;
4512 } __COG1FISbits_t;
4514 extern __at(0x069B) volatile __COG1FISbits_t COG1FISbits;
4516 #define _G1FIS0 0x01
4517 #define _G1FIS1 0x02
4518 #define _G1FIS2 0x04
4519 #define _G1FIS3 0x08
4520 #define _G1FIS4 0x10
4521 #define _G1FIS5 0x20
4522 #define _G1FIS6 0x40
4524 //==============================================================================
4527 //==============================================================================
4528 // COG1FSIM Bits
4530 extern __at(0x069C) __sfr COG1FSIM;
4532 typedef union
4534 struct
4536 unsigned G1FSIM0 : 1;
4537 unsigned G1FSIM1 : 1;
4538 unsigned G1FSIM2 : 1;
4539 unsigned G1FSIM3 : 1;
4540 unsigned G1FSIM4 : 1;
4541 unsigned G1FSIM5 : 1;
4542 unsigned G1FSIM6 : 1;
4543 unsigned : 1;
4546 struct
4548 unsigned G1FSIM : 7;
4549 unsigned : 1;
4551 } __COG1FSIMbits_t;
4553 extern __at(0x069C) volatile __COG1FSIMbits_t COG1FSIMbits;
4555 #define _G1FSIM0 0x01
4556 #define _G1FSIM1 0x02
4557 #define _G1FSIM2 0x04
4558 #define _G1FSIM3 0x08
4559 #define _G1FSIM4 0x10
4560 #define _G1FSIM5 0x20
4561 #define _G1FSIM6 0x40
4563 //==============================================================================
4566 //==============================================================================
4567 // COG1ASD0 Bits
4569 extern __at(0x069D) __sfr COG1ASD0;
4571 typedef union
4573 struct
4575 unsigned : 1;
4576 unsigned : 1;
4577 unsigned G1ASDAC0 : 1;
4578 unsigned G1ASDAC1 : 1;
4579 unsigned G1ASDBD0 : 1;
4580 unsigned G1ASDBD1 : 1;
4581 unsigned G1ARSEN : 1;
4582 unsigned G1ASE : 1;
4585 struct
4587 unsigned : 2;
4588 unsigned G1ASDAC : 2;
4589 unsigned : 4;
4592 struct
4594 unsigned : 4;
4595 unsigned G1ASDBD : 2;
4596 unsigned : 2;
4598 } __COG1ASD0bits_t;
4600 extern __at(0x069D) volatile __COG1ASD0bits_t COG1ASD0bits;
4602 #define _G1ASDAC0 0x04
4603 #define _G1ASDAC1 0x08
4604 #define _G1ASDBD0 0x10
4605 #define _G1ASDBD1 0x20
4606 #define _G1ARSEN 0x40
4607 #define _G1ASE 0x80
4609 //==============================================================================
4612 //==============================================================================
4613 // COG1ASD1 Bits
4615 extern __at(0x069E) __sfr COG1ASD1;
4617 typedef struct
4619 unsigned G1AS0E : 1;
4620 unsigned G1AS1E : 1;
4621 unsigned G1AS2E : 1;
4622 unsigned G1AS3E : 1;
4623 unsigned : 1;
4624 unsigned : 1;
4625 unsigned : 1;
4626 unsigned : 1;
4627 } __COG1ASD1bits_t;
4629 extern __at(0x069E) volatile __COG1ASD1bits_t COG1ASD1bits;
4631 #define _G1AS0E 0x01
4632 #define _G1AS1E 0x02
4633 #define _G1AS2E 0x04
4634 #define _G1AS3E 0x08
4636 //==============================================================================
4639 //==============================================================================
4640 // COG1STR Bits
4642 extern __at(0x069F) __sfr COG1STR;
4644 typedef struct
4646 unsigned G1STRA : 1;
4647 unsigned G1STRB : 1;
4648 unsigned G1STRC : 1;
4649 unsigned G1STRD : 1;
4650 unsigned G1SDATA : 1;
4651 unsigned G1SDATB : 1;
4652 unsigned G1SDATC : 1;
4653 unsigned G1SDATD : 1;
4654 } __COG1STRbits_t;
4656 extern __at(0x069F) volatile __COG1STRbits_t COG1STRbits;
4658 #define _G1STRA 0x01
4659 #define _G1STRB 0x02
4660 #define _G1STRC 0x04
4661 #define _G1STRD 0x08
4662 #define _G1SDATA 0x10
4663 #define _G1SDATB 0x20
4664 #define _G1SDATC 0x40
4665 #define _G1SDATD 0x80
4667 //==============================================================================
4670 //==============================================================================
4671 // PPSLOCK Bits
4673 extern __at(0x0E0F) __sfr PPSLOCK;
4675 typedef struct
4677 unsigned PPSLOCKED : 1;
4678 unsigned : 1;
4679 unsigned : 1;
4680 unsigned : 1;
4681 unsigned : 1;
4682 unsigned : 1;
4683 unsigned : 1;
4684 unsigned : 1;
4685 } __PPSLOCKbits_t;
4687 extern __at(0x0E0F) volatile __PPSLOCKbits_t PPSLOCKbits;
4689 #define _PPSLOCKED 0x01
4691 //==============================================================================
4693 extern __at(0x0E10) __sfr INTPPS;
4694 extern __at(0x0E11) __sfr T0CKIPPS;
4695 extern __at(0x0E12) __sfr T1CKIPPS;
4696 extern __at(0x0E13) __sfr T1GPPS;
4697 extern __at(0x0E14) __sfr CCP1PPS;
4698 extern __at(0x0E15) __sfr CCP2PPS;
4699 extern __at(0x0E17) __sfr COGINPPS;
4700 extern __at(0x0E20) __sfr SSPCLKPPS;
4701 extern __at(0x0E21) __sfr SSPDATPPS;
4702 extern __at(0x0E22) __sfr SSPSSPPS;
4703 extern __at(0x0E24) __sfr RXPPS;
4704 extern __at(0x0E25) __sfr CKPPS;
4705 extern __at(0x0E28) __sfr CLCIN0PPS;
4706 extern __at(0x0E29) __sfr CLCIN1PPS;
4707 extern __at(0x0E2A) __sfr CLCIN2PPS;
4708 extern __at(0x0E2B) __sfr CLCIN3PPS;
4709 extern __at(0x0E90) __sfr RA0PPS;
4710 extern __at(0x0E91) __sfr RA1PPS;
4711 extern __at(0x0E92) __sfr RA2PPS;
4712 extern __at(0x0E94) __sfr RA4PPS;
4713 extern __at(0x0E95) __sfr RA5PPS;
4714 extern __at(0x0EA0) __sfr RC0PPS;
4715 extern __at(0x0EA1) __sfr RC1PPS;
4716 extern __at(0x0EA2) __sfr RC2PPS;
4717 extern __at(0x0EA3) __sfr RC3PPS;
4718 extern __at(0x0EA4) __sfr RC4PPS;
4719 extern __at(0x0EA5) __sfr RC5PPS;
4721 //==============================================================================
4722 // CLCDATA Bits
4724 extern __at(0x0F0F) __sfr CLCDATA;
4726 typedef struct
4728 unsigned MCLC1OUT : 1;
4729 unsigned MCLC2OUT : 1;
4730 unsigned MCLC3OUT : 1;
4731 unsigned : 1;
4732 unsigned : 1;
4733 unsigned : 1;
4734 unsigned : 1;
4735 unsigned : 1;
4736 } __CLCDATAbits_t;
4738 extern __at(0x0F0F) volatile __CLCDATAbits_t CLCDATAbits;
4740 #define _MCLC1OUT 0x01
4741 #define _MCLC2OUT 0x02
4742 #define _MCLC3OUT 0x04
4744 //==============================================================================
4747 //==============================================================================
4748 // CLC1CON Bits
4750 extern __at(0x0F10) __sfr CLC1CON;
4752 typedef union
4754 struct
4756 unsigned LC1MODE0 : 1;
4757 unsigned LC1MODE1 : 1;
4758 unsigned LC1MODE2 : 1;
4759 unsigned LC1INTN : 1;
4760 unsigned LC1INTP : 1;
4761 unsigned LC1OUT : 1;
4762 unsigned : 1;
4763 unsigned LC1EN : 1;
4766 struct
4768 unsigned MODE0 : 1;
4769 unsigned MODE1 : 1;
4770 unsigned MODE2 : 1;
4771 unsigned INTN : 1;
4772 unsigned INTP : 1;
4773 unsigned OUT : 1;
4774 unsigned : 1;
4775 unsigned EN : 1;
4778 struct
4780 unsigned LC1MODE : 3;
4781 unsigned : 5;
4784 struct
4786 unsigned MODE : 3;
4787 unsigned : 5;
4789 } __CLC1CONbits_t;
4791 extern __at(0x0F10) volatile __CLC1CONbits_t CLC1CONbits;
4793 #define _LC1MODE0 0x01
4794 #define _MODE0 0x01
4795 #define _LC1MODE1 0x02
4796 #define _MODE1 0x02
4797 #define _LC1MODE2 0x04
4798 #define _MODE2 0x04
4799 #define _LC1INTN 0x08
4800 #define _INTN 0x08
4801 #define _LC1INTP 0x10
4802 #define _INTP 0x10
4803 #define _LC1OUT 0x20
4804 #define _OUT 0x20
4805 #define _LC1EN 0x80
4806 #define _EN 0x80
4808 //==============================================================================
4811 //==============================================================================
4812 // CLC1POL Bits
4814 extern __at(0x0F11) __sfr CLC1POL;
4816 typedef union
4818 struct
4820 unsigned LC1G1POL : 1;
4821 unsigned LC1G2POL : 1;
4822 unsigned LC1G3POL : 1;
4823 unsigned LC1G4POL : 1;
4824 unsigned : 1;
4825 unsigned : 1;
4826 unsigned : 1;
4827 unsigned LC1POL : 1;
4830 struct
4832 unsigned G1POL : 1;
4833 unsigned G2POL : 1;
4834 unsigned G3POL : 1;
4835 unsigned G4POL : 1;
4836 unsigned : 1;
4837 unsigned : 1;
4838 unsigned : 1;
4839 unsigned POL : 1;
4841 } __CLC1POLbits_t;
4843 extern __at(0x0F11) volatile __CLC1POLbits_t CLC1POLbits;
4845 #define _LC1G1POL 0x01
4846 #define _G1POL 0x01
4847 #define _LC1G2POL 0x02
4848 #define _G2POL 0x02
4849 #define _LC1G3POL 0x04
4850 #define _G3POL 0x04
4851 #define _LC1G4POL 0x08
4852 #define _G4POL 0x08
4853 #define _LC1POL 0x80
4854 #define _POL 0x80
4856 //==============================================================================
4859 //==============================================================================
4860 // CLC1SEL0 Bits
4862 extern __at(0x0F12) __sfr CLC1SEL0;
4864 typedef union
4866 struct
4868 unsigned LC1D1S0 : 1;
4869 unsigned LC1D1S1 : 1;
4870 unsigned LC1D1S2 : 1;
4871 unsigned LC1D1S3 : 1;
4872 unsigned LC1D1S4 : 1;
4873 unsigned : 1;
4874 unsigned : 1;
4875 unsigned : 1;
4878 struct
4880 unsigned D1S0 : 1;
4881 unsigned D1S1 : 1;
4882 unsigned D1S2 : 1;
4883 unsigned D1S3 : 1;
4884 unsigned D1S4 : 1;
4885 unsigned : 1;
4886 unsigned : 1;
4887 unsigned : 1;
4890 struct
4892 unsigned D1S : 5;
4893 unsigned : 3;
4896 struct
4898 unsigned LC1D1S : 5;
4899 unsigned : 3;
4901 } __CLC1SEL0bits_t;
4903 extern __at(0x0F12) volatile __CLC1SEL0bits_t CLC1SEL0bits;
4905 #define _LC1D1S0 0x01
4906 #define _D1S0 0x01
4907 #define _LC1D1S1 0x02
4908 #define _D1S1 0x02
4909 #define _LC1D1S2 0x04
4910 #define _D1S2 0x04
4911 #define _LC1D1S3 0x08
4912 #define _D1S3 0x08
4913 #define _LC1D1S4 0x10
4914 #define _D1S4 0x10
4916 //==============================================================================
4919 //==============================================================================
4920 // CLC1SEL1 Bits
4922 extern __at(0x0F13) __sfr CLC1SEL1;
4924 typedef union
4926 struct
4928 unsigned LC1D2S0 : 1;
4929 unsigned LC1D2S1 : 1;
4930 unsigned LC1D2S2 : 1;
4931 unsigned LC1D2S3 : 1;
4932 unsigned LC1D2S4 : 1;
4933 unsigned : 1;
4934 unsigned : 1;
4935 unsigned : 1;
4938 struct
4940 unsigned D2S0 : 1;
4941 unsigned D2S1 : 1;
4942 unsigned D2S2 : 1;
4943 unsigned D2S3 : 1;
4944 unsigned D2S4 : 1;
4945 unsigned : 1;
4946 unsigned : 1;
4947 unsigned : 1;
4950 struct
4952 unsigned LC1D2S : 5;
4953 unsigned : 3;
4956 struct
4958 unsigned D2S : 5;
4959 unsigned : 3;
4961 } __CLC1SEL1bits_t;
4963 extern __at(0x0F13) volatile __CLC1SEL1bits_t CLC1SEL1bits;
4965 #define _LC1D2S0 0x01
4966 #define _D2S0 0x01
4967 #define _LC1D2S1 0x02
4968 #define _D2S1 0x02
4969 #define _LC1D2S2 0x04
4970 #define _D2S2 0x04
4971 #define _LC1D2S3 0x08
4972 #define _D2S3 0x08
4973 #define _LC1D2S4 0x10
4974 #define _D2S4 0x10
4976 //==============================================================================
4979 //==============================================================================
4980 // CLC1SEL2 Bits
4982 extern __at(0x0F14) __sfr CLC1SEL2;
4984 typedef union
4986 struct
4988 unsigned LC1D3S0 : 1;
4989 unsigned LC1D3S1 : 1;
4990 unsigned LC1D3S2 : 1;
4991 unsigned LC1D3S3 : 1;
4992 unsigned LC1D3S4 : 1;
4993 unsigned : 1;
4994 unsigned : 1;
4995 unsigned : 1;
4998 struct
5000 unsigned D3S0 : 1;
5001 unsigned D3S1 : 1;
5002 unsigned D3S2 : 1;
5003 unsigned D3S3 : 1;
5004 unsigned D3S4 : 1;
5005 unsigned : 1;
5006 unsigned : 1;
5007 unsigned : 1;
5010 struct
5012 unsigned LC1D3S : 5;
5013 unsigned : 3;
5016 struct
5018 unsigned D3S : 5;
5019 unsigned : 3;
5021 } __CLC1SEL2bits_t;
5023 extern __at(0x0F14) volatile __CLC1SEL2bits_t CLC1SEL2bits;
5025 #define _LC1D3S0 0x01
5026 #define _D3S0 0x01
5027 #define _LC1D3S1 0x02
5028 #define _D3S1 0x02
5029 #define _LC1D3S2 0x04
5030 #define _D3S2 0x04
5031 #define _LC1D3S3 0x08
5032 #define _D3S3 0x08
5033 #define _LC1D3S4 0x10
5034 #define _D3S4 0x10
5036 //==============================================================================
5039 //==============================================================================
5040 // CLC1SEL3 Bits
5042 extern __at(0x0F15) __sfr CLC1SEL3;
5044 typedef union
5046 struct
5048 unsigned LC1D4S0 : 1;
5049 unsigned LC1D4S1 : 1;
5050 unsigned LC1D4S2 : 1;
5051 unsigned LC1D4S3 : 1;
5052 unsigned LC1D4S4 : 1;
5053 unsigned : 1;
5054 unsigned : 1;
5055 unsigned : 1;
5058 struct
5060 unsigned D4S0 : 1;
5061 unsigned D4S1 : 1;
5062 unsigned D4S2 : 1;
5063 unsigned D4S3 : 1;
5064 unsigned D4S4 : 1;
5065 unsigned : 1;
5066 unsigned : 1;
5067 unsigned : 1;
5070 struct
5072 unsigned D4S : 5;
5073 unsigned : 3;
5076 struct
5078 unsigned LC1D4S : 5;
5079 unsigned : 3;
5081 } __CLC1SEL3bits_t;
5083 extern __at(0x0F15) volatile __CLC1SEL3bits_t CLC1SEL3bits;
5085 #define _LC1D4S0 0x01
5086 #define _D4S0 0x01
5087 #define _LC1D4S1 0x02
5088 #define _D4S1 0x02
5089 #define _LC1D4S2 0x04
5090 #define _D4S2 0x04
5091 #define _LC1D4S3 0x08
5092 #define _D4S3 0x08
5093 #define _LC1D4S4 0x10
5094 #define _D4S4 0x10
5096 //==============================================================================
5099 //==============================================================================
5100 // CLC1GLS0 Bits
5102 extern __at(0x0F16) __sfr CLC1GLS0;
5104 typedef union
5106 struct
5108 unsigned LC1G1D1N : 1;
5109 unsigned LC1G1D1T : 1;
5110 unsigned LC1G1D2N : 1;
5111 unsigned LC1G1D2T : 1;
5112 unsigned LC1G1D3N : 1;
5113 unsigned LC1G1D3T : 1;
5114 unsigned LC1G1D4N : 1;
5115 unsigned LC1G1D4T : 1;
5118 struct
5120 unsigned D1N : 1;
5121 unsigned D1T : 1;
5122 unsigned D2N : 1;
5123 unsigned D2T : 1;
5124 unsigned D3N : 1;
5125 unsigned D3T : 1;
5126 unsigned D4N : 1;
5127 unsigned D4T : 1;
5129 } __CLC1GLS0bits_t;
5131 extern __at(0x0F16) volatile __CLC1GLS0bits_t CLC1GLS0bits;
5133 #define _LC1G1D1N 0x01
5134 #define _D1N 0x01
5135 #define _LC1G1D1T 0x02
5136 #define _D1T 0x02
5137 #define _LC1G1D2N 0x04
5138 #define _D2N 0x04
5139 #define _LC1G1D2T 0x08
5140 #define _D2T 0x08
5141 #define _LC1G1D3N 0x10
5142 #define _D3N 0x10
5143 #define _LC1G1D3T 0x20
5144 #define _D3T 0x20
5145 #define _LC1G1D4N 0x40
5146 #define _D4N 0x40
5147 #define _LC1G1D4T 0x80
5148 #define _D4T 0x80
5150 //==============================================================================
5153 //==============================================================================
5154 // CLC1GLS1 Bits
5156 extern __at(0x0F17) __sfr CLC1GLS1;
5158 typedef union
5160 struct
5162 unsigned LC1G2D1N : 1;
5163 unsigned LC1G2D1T : 1;
5164 unsigned LC1G2D2N : 1;
5165 unsigned LC1G2D2T : 1;
5166 unsigned LC1G2D3N : 1;
5167 unsigned LC1G2D3T : 1;
5168 unsigned LC1G2D4N : 1;
5169 unsigned LC1G2D4T : 1;
5172 struct
5174 unsigned D1N : 1;
5175 unsigned D1T : 1;
5176 unsigned D2N : 1;
5177 unsigned D2T : 1;
5178 unsigned D3N : 1;
5179 unsigned D3T : 1;
5180 unsigned D4N : 1;
5181 unsigned D4T : 1;
5183 } __CLC1GLS1bits_t;
5185 extern __at(0x0F17) volatile __CLC1GLS1bits_t CLC1GLS1bits;
5187 #define _CLC1GLS1_LC1G2D1N 0x01
5188 #define _CLC1GLS1_D1N 0x01
5189 #define _CLC1GLS1_LC1G2D1T 0x02
5190 #define _CLC1GLS1_D1T 0x02
5191 #define _CLC1GLS1_LC1G2D2N 0x04
5192 #define _CLC1GLS1_D2N 0x04
5193 #define _CLC1GLS1_LC1G2D2T 0x08
5194 #define _CLC1GLS1_D2T 0x08
5195 #define _CLC1GLS1_LC1G2D3N 0x10
5196 #define _CLC1GLS1_D3N 0x10
5197 #define _CLC1GLS1_LC1G2D3T 0x20
5198 #define _CLC1GLS1_D3T 0x20
5199 #define _CLC1GLS1_LC1G2D4N 0x40
5200 #define _CLC1GLS1_D4N 0x40
5201 #define _CLC1GLS1_LC1G2D4T 0x80
5202 #define _CLC1GLS1_D4T 0x80
5204 //==============================================================================
5207 //==============================================================================
5208 // CLC1GLS2 Bits
5210 extern __at(0x0F18) __sfr CLC1GLS2;
5212 typedef union
5214 struct
5216 unsigned LC1G3D1N : 1;
5217 unsigned LC1G3D1T : 1;
5218 unsigned LC1G3D2N : 1;
5219 unsigned LC1G3D2T : 1;
5220 unsigned LC1G3D3N : 1;
5221 unsigned LC1G3D3T : 1;
5222 unsigned LC1G3D4N : 1;
5223 unsigned LC1G3D4T : 1;
5226 struct
5228 unsigned D1N : 1;
5229 unsigned D1T : 1;
5230 unsigned D2N : 1;
5231 unsigned D2T : 1;
5232 unsigned D3N : 1;
5233 unsigned D3T : 1;
5234 unsigned D4N : 1;
5235 unsigned D4T : 1;
5237 } __CLC1GLS2bits_t;
5239 extern __at(0x0F18) volatile __CLC1GLS2bits_t CLC1GLS2bits;
5241 #define _CLC1GLS2_LC1G3D1N 0x01
5242 #define _CLC1GLS2_D1N 0x01
5243 #define _CLC1GLS2_LC1G3D1T 0x02
5244 #define _CLC1GLS2_D1T 0x02
5245 #define _CLC1GLS2_LC1G3D2N 0x04
5246 #define _CLC1GLS2_D2N 0x04
5247 #define _CLC1GLS2_LC1G3D2T 0x08
5248 #define _CLC1GLS2_D2T 0x08
5249 #define _CLC1GLS2_LC1G3D3N 0x10
5250 #define _CLC1GLS2_D3N 0x10
5251 #define _CLC1GLS2_LC1G3D3T 0x20
5252 #define _CLC1GLS2_D3T 0x20
5253 #define _CLC1GLS2_LC1G3D4N 0x40
5254 #define _CLC1GLS2_D4N 0x40
5255 #define _CLC1GLS2_LC1G3D4T 0x80
5256 #define _CLC1GLS2_D4T 0x80
5258 //==============================================================================
5261 //==============================================================================
5262 // CLC1GLS3 Bits
5264 extern __at(0x0F19) __sfr CLC1GLS3;
5266 typedef union
5268 struct
5270 unsigned LC1G4D1N : 1;
5271 unsigned LC1G4D1T : 1;
5272 unsigned LC1G4D2N : 1;
5273 unsigned LC1G4D2T : 1;
5274 unsigned LC1G4D3N : 1;
5275 unsigned LC1G4D3T : 1;
5276 unsigned LC1G4D4N : 1;
5277 unsigned LC1G4D4T : 1;
5280 struct
5282 unsigned G4D1N : 1;
5283 unsigned G4D1T : 1;
5284 unsigned G4D2N : 1;
5285 unsigned G4D2T : 1;
5286 unsigned G4D3N : 1;
5287 unsigned G4D3T : 1;
5288 unsigned G4D4N : 1;
5289 unsigned G4D4T : 1;
5291 } __CLC1GLS3bits_t;
5293 extern __at(0x0F19) volatile __CLC1GLS3bits_t CLC1GLS3bits;
5295 #define _LC1G4D1N 0x01
5296 #define _G4D1N 0x01
5297 #define _LC1G4D1T 0x02
5298 #define _G4D1T 0x02
5299 #define _LC1G4D2N 0x04
5300 #define _G4D2N 0x04
5301 #define _LC1G4D2T 0x08
5302 #define _G4D2T 0x08
5303 #define _LC1G4D3N 0x10
5304 #define _G4D3N 0x10
5305 #define _LC1G4D3T 0x20
5306 #define _G4D3T 0x20
5307 #define _LC1G4D4N 0x40
5308 #define _G4D4N 0x40
5309 #define _LC1G4D4T 0x80
5310 #define _G4D4T 0x80
5312 //==============================================================================
5315 //==============================================================================
5316 // CLC2CON Bits
5318 extern __at(0x0F1A) __sfr CLC2CON;
5320 typedef union
5322 struct
5324 unsigned LC2MODE0 : 1;
5325 unsigned LC2MODE1 : 1;
5326 unsigned LC2MODE2 : 1;
5327 unsigned LC2INTN : 1;
5328 unsigned LC2INTP : 1;
5329 unsigned LC2OUT : 1;
5330 unsigned : 1;
5331 unsigned LC2EN : 1;
5334 struct
5336 unsigned MODE0 : 1;
5337 unsigned MODE1 : 1;
5338 unsigned MODE2 : 1;
5339 unsigned INTN : 1;
5340 unsigned INTP : 1;
5341 unsigned OUT : 1;
5342 unsigned : 1;
5343 unsigned EN : 1;
5346 struct
5348 unsigned MODE : 3;
5349 unsigned : 5;
5352 struct
5354 unsigned LC2MODE : 3;
5355 unsigned : 5;
5357 } __CLC2CONbits_t;
5359 extern __at(0x0F1A) volatile __CLC2CONbits_t CLC2CONbits;
5361 #define _CLC2CON_LC2MODE0 0x01
5362 #define _CLC2CON_MODE0 0x01
5363 #define _CLC2CON_LC2MODE1 0x02
5364 #define _CLC2CON_MODE1 0x02
5365 #define _CLC2CON_LC2MODE2 0x04
5366 #define _CLC2CON_MODE2 0x04
5367 #define _CLC2CON_LC2INTN 0x08
5368 #define _CLC2CON_INTN 0x08
5369 #define _CLC2CON_LC2INTP 0x10
5370 #define _CLC2CON_INTP 0x10
5371 #define _CLC2CON_LC2OUT 0x20
5372 #define _CLC2CON_OUT 0x20
5373 #define _CLC2CON_LC2EN 0x80
5374 #define _CLC2CON_EN 0x80
5376 //==============================================================================
5379 //==============================================================================
5380 // CLC2POL Bits
5382 extern __at(0x0F1B) __sfr CLC2POL;
5384 typedef union
5386 struct
5388 unsigned LC2G1POL : 1;
5389 unsigned LC2G2POL : 1;
5390 unsigned LC2G3POL : 1;
5391 unsigned LC2G4POL : 1;
5392 unsigned : 1;
5393 unsigned : 1;
5394 unsigned : 1;
5395 unsigned LC2POL : 1;
5398 struct
5400 unsigned G1POL : 1;
5401 unsigned G2POL : 1;
5402 unsigned G3POL : 1;
5403 unsigned G4POL : 1;
5404 unsigned : 1;
5405 unsigned : 1;
5406 unsigned : 1;
5407 unsigned POL : 1;
5409 } __CLC2POLbits_t;
5411 extern __at(0x0F1B) volatile __CLC2POLbits_t CLC2POLbits;
5413 #define _CLC2POL_LC2G1POL 0x01
5414 #define _CLC2POL_G1POL 0x01
5415 #define _CLC2POL_LC2G2POL 0x02
5416 #define _CLC2POL_G2POL 0x02
5417 #define _CLC2POL_LC2G3POL 0x04
5418 #define _CLC2POL_G3POL 0x04
5419 #define _CLC2POL_LC2G4POL 0x08
5420 #define _CLC2POL_G4POL 0x08
5421 #define _CLC2POL_LC2POL 0x80
5422 #define _CLC2POL_POL 0x80
5424 //==============================================================================
5427 //==============================================================================
5428 // CLC2SEL0 Bits
5430 extern __at(0x0F1C) __sfr CLC2SEL0;
5432 typedef union
5434 struct
5436 unsigned LC2D1S0 : 1;
5437 unsigned LC2D1S1 : 1;
5438 unsigned LC2D1S2 : 1;
5439 unsigned LC2D1S3 : 1;
5440 unsigned LC2D1S4 : 1;
5441 unsigned : 1;
5442 unsigned : 1;
5443 unsigned : 1;
5446 struct
5448 unsigned D1S0 : 1;
5449 unsigned D1S1 : 1;
5450 unsigned D1S2 : 1;
5451 unsigned D1S3 : 1;
5452 unsigned D1S4 : 1;
5453 unsigned : 1;
5454 unsigned : 1;
5455 unsigned : 1;
5458 struct
5460 unsigned D1S : 5;
5461 unsigned : 3;
5464 struct
5466 unsigned LC2D1S : 5;
5467 unsigned : 3;
5469 } __CLC2SEL0bits_t;
5471 extern __at(0x0F1C) volatile __CLC2SEL0bits_t CLC2SEL0bits;
5473 #define _CLC2SEL0_LC2D1S0 0x01
5474 #define _CLC2SEL0_D1S0 0x01
5475 #define _CLC2SEL0_LC2D1S1 0x02
5476 #define _CLC2SEL0_D1S1 0x02
5477 #define _CLC2SEL0_LC2D1S2 0x04
5478 #define _CLC2SEL0_D1S2 0x04
5479 #define _CLC2SEL0_LC2D1S3 0x08
5480 #define _CLC2SEL0_D1S3 0x08
5481 #define _CLC2SEL0_LC2D1S4 0x10
5482 #define _CLC2SEL0_D1S4 0x10
5484 //==============================================================================
5487 //==============================================================================
5488 // CLC2SEL1 Bits
5490 extern __at(0x0F1D) __sfr CLC2SEL1;
5492 typedef union
5494 struct
5496 unsigned LC2D2S0 : 1;
5497 unsigned LC2D2S1 : 1;
5498 unsigned LC2D2S2 : 1;
5499 unsigned LC2D2S3 : 1;
5500 unsigned LC2D2S4 : 1;
5501 unsigned : 1;
5502 unsigned : 1;
5503 unsigned : 1;
5506 struct
5508 unsigned D2S0 : 1;
5509 unsigned D2S1 : 1;
5510 unsigned D2S2 : 1;
5511 unsigned D2S3 : 1;
5512 unsigned D2S4 : 1;
5513 unsigned : 1;
5514 unsigned : 1;
5515 unsigned : 1;
5518 struct
5520 unsigned LC2D2S : 5;
5521 unsigned : 3;
5524 struct
5526 unsigned D2S : 5;
5527 unsigned : 3;
5529 } __CLC2SEL1bits_t;
5531 extern __at(0x0F1D) volatile __CLC2SEL1bits_t CLC2SEL1bits;
5533 #define _CLC2SEL1_LC2D2S0 0x01
5534 #define _CLC2SEL1_D2S0 0x01
5535 #define _CLC2SEL1_LC2D2S1 0x02
5536 #define _CLC2SEL1_D2S1 0x02
5537 #define _CLC2SEL1_LC2D2S2 0x04
5538 #define _CLC2SEL1_D2S2 0x04
5539 #define _CLC2SEL1_LC2D2S3 0x08
5540 #define _CLC2SEL1_D2S3 0x08
5541 #define _CLC2SEL1_LC2D2S4 0x10
5542 #define _CLC2SEL1_D2S4 0x10
5544 //==============================================================================
5547 //==============================================================================
5548 // CLC2SEL2 Bits
5550 extern __at(0x0F1E) __sfr CLC2SEL2;
5552 typedef union
5554 struct
5556 unsigned LC2D3S0 : 1;
5557 unsigned LC2D3S1 : 1;
5558 unsigned LC2D3S2 : 1;
5559 unsigned LC2D3S3 : 1;
5560 unsigned LC2D3S4 : 1;
5561 unsigned : 1;
5562 unsigned : 1;
5563 unsigned : 1;
5566 struct
5568 unsigned D3S0 : 1;
5569 unsigned D3S1 : 1;
5570 unsigned D3S2 : 1;
5571 unsigned D3S3 : 1;
5572 unsigned D3S4 : 1;
5573 unsigned : 1;
5574 unsigned : 1;
5575 unsigned : 1;
5578 struct
5580 unsigned LC2D3S : 5;
5581 unsigned : 3;
5584 struct
5586 unsigned D3S : 5;
5587 unsigned : 3;
5589 } __CLC2SEL2bits_t;
5591 extern __at(0x0F1E) volatile __CLC2SEL2bits_t CLC2SEL2bits;
5593 #define _CLC2SEL2_LC2D3S0 0x01
5594 #define _CLC2SEL2_D3S0 0x01
5595 #define _CLC2SEL2_LC2D3S1 0x02
5596 #define _CLC2SEL2_D3S1 0x02
5597 #define _CLC2SEL2_LC2D3S2 0x04
5598 #define _CLC2SEL2_D3S2 0x04
5599 #define _CLC2SEL2_LC2D3S3 0x08
5600 #define _CLC2SEL2_D3S3 0x08
5601 #define _CLC2SEL2_LC2D3S4 0x10
5602 #define _CLC2SEL2_D3S4 0x10
5604 //==============================================================================
5607 //==============================================================================
5608 // CLC2SEL3 Bits
5610 extern __at(0x0F1F) __sfr CLC2SEL3;
5612 typedef union
5614 struct
5616 unsigned LC2D4S0 : 1;
5617 unsigned LC2D4S1 : 1;
5618 unsigned LC2D4S2 : 1;
5619 unsigned LC2D4S3 : 1;
5620 unsigned LC2D4S4 : 1;
5621 unsigned : 1;
5622 unsigned : 1;
5623 unsigned : 1;
5626 struct
5628 unsigned D4S0 : 1;
5629 unsigned D4S1 : 1;
5630 unsigned D4S2 : 1;
5631 unsigned D4S3 : 1;
5632 unsigned D4S4 : 1;
5633 unsigned : 1;
5634 unsigned : 1;
5635 unsigned : 1;
5638 struct
5640 unsigned D4S : 5;
5641 unsigned : 3;
5644 struct
5646 unsigned LC2D4S : 5;
5647 unsigned : 3;
5649 } __CLC2SEL3bits_t;
5651 extern __at(0x0F1F) volatile __CLC2SEL3bits_t CLC2SEL3bits;
5653 #define _CLC2SEL3_LC2D4S0 0x01
5654 #define _CLC2SEL3_D4S0 0x01
5655 #define _CLC2SEL3_LC2D4S1 0x02
5656 #define _CLC2SEL3_D4S1 0x02
5657 #define _CLC2SEL3_LC2D4S2 0x04
5658 #define _CLC2SEL3_D4S2 0x04
5659 #define _CLC2SEL3_LC2D4S3 0x08
5660 #define _CLC2SEL3_D4S3 0x08
5661 #define _CLC2SEL3_LC2D4S4 0x10
5662 #define _CLC2SEL3_D4S4 0x10
5664 //==============================================================================
5667 //==============================================================================
5668 // CLC2GLS0 Bits
5670 extern __at(0x0F20) __sfr CLC2GLS0;
5672 typedef union
5674 struct
5676 unsigned LC2G1D1N : 1;
5677 unsigned LC2G1D1T : 1;
5678 unsigned LC2G1D2N : 1;
5679 unsigned LC2G1D2T : 1;
5680 unsigned LC2G1D3N : 1;
5681 unsigned LC2G1D3T : 1;
5682 unsigned LC2G1D4N : 1;
5683 unsigned LC2G1D4T : 1;
5686 struct
5688 unsigned D1N : 1;
5689 unsigned D1T : 1;
5690 unsigned D2N : 1;
5691 unsigned D2T : 1;
5692 unsigned D3N : 1;
5693 unsigned D3T : 1;
5694 unsigned D4N : 1;
5695 unsigned D4T : 1;
5697 } __CLC2GLS0bits_t;
5699 extern __at(0x0F20) volatile __CLC2GLS0bits_t CLC2GLS0bits;
5701 #define _CLC2GLS0_LC2G1D1N 0x01
5702 #define _CLC2GLS0_D1N 0x01
5703 #define _CLC2GLS0_LC2G1D1T 0x02
5704 #define _CLC2GLS0_D1T 0x02
5705 #define _CLC2GLS0_LC2G1D2N 0x04
5706 #define _CLC2GLS0_D2N 0x04
5707 #define _CLC2GLS0_LC2G1D2T 0x08
5708 #define _CLC2GLS0_D2T 0x08
5709 #define _CLC2GLS0_LC2G1D3N 0x10
5710 #define _CLC2GLS0_D3N 0x10
5711 #define _CLC2GLS0_LC2G1D3T 0x20
5712 #define _CLC2GLS0_D3T 0x20
5713 #define _CLC2GLS0_LC2G1D4N 0x40
5714 #define _CLC2GLS0_D4N 0x40
5715 #define _CLC2GLS0_LC2G1D4T 0x80
5716 #define _CLC2GLS0_D4T 0x80
5718 //==============================================================================
5721 //==============================================================================
5722 // CLC2GLS1 Bits
5724 extern __at(0x0F21) __sfr CLC2GLS1;
5726 typedef union
5728 struct
5730 unsigned LC2G2D1N : 1;
5731 unsigned LC2G2D1T : 1;
5732 unsigned LC2G2D2N : 1;
5733 unsigned LC2G2D2T : 1;
5734 unsigned LC2G2D3N : 1;
5735 unsigned LC2G2D3T : 1;
5736 unsigned LC2G2D4N : 1;
5737 unsigned LC2G2D4T : 1;
5740 struct
5742 unsigned D1N : 1;
5743 unsigned D1T : 1;
5744 unsigned D2N : 1;
5745 unsigned D2T : 1;
5746 unsigned D3N : 1;
5747 unsigned D3T : 1;
5748 unsigned D4N : 1;
5749 unsigned D4T : 1;
5751 } __CLC2GLS1bits_t;
5753 extern __at(0x0F21) volatile __CLC2GLS1bits_t CLC2GLS1bits;
5755 #define _CLC2GLS1_LC2G2D1N 0x01
5756 #define _CLC2GLS1_D1N 0x01
5757 #define _CLC2GLS1_LC2G2D1T 0x02
5758 #define _CLC2GLS1_D1T 0x02
5759 #define _CLC2GLS1_LC2G2D2N 0x04
5760 #define _CLC2GLS1_D2N 0x04
5761 #define _CLC2GLS1_LC2G2D2T 0x08
5762 #define _CLC2GLS1_D2T 0x08
5763 #define _CLC2GLS1_LC2G2D3N 0x10
5764 #define _CLC2GLS1_D3N 0x10
5765 #define _CLC2GLS1_LC2G2D3T 0x20
5766 #define _CLC2GLS1_D3T 0x20
5767 #define _CLC2GLS1_LC2G2D4N 0x40
5768 #define _CLC2GLS1_D4N 0x40
5769 #define _CLC2GLS1_LC2G2D4T 0x80
5770 #define _CLC2GLS1_D4T 0x80
5772 //==============================================================================
5775 //==============================================================================
5776 // CLC2GLS2 Bits
5778 extern __at(0x0F22) __sfr CLC2GLS2;
5780 typedef union
5782 struct
5784 unsigned LC2G3D1N : 1;
5785 unsigned LC2G3D1T : 1;
5786 unsigned LC2G3D2N : 1;
5787 unsigned LC2G3D2T : 1;
5788 unsigned LC2G3D3N : 1;
5789 unsigned LC2G3D3T : 1;
5790 unsigned LC2G3D4N : 1;
5791 unsigned LC2G3D4T : 1;
5794 struct
5796 unsigned D1N : 1;
5797 unsigned D1T : 1;
5798 unsigned D2N : 1;
5799 unsigned D2T : 1;
5800 unsigned D3N : 1;
5801 unsigned D3T : 1;
5802 unsigned D4N : 1;
5803 unsigned D4T : 1;
5805 } __CLC2GLS2bits_t;
5807 extern __at(0x0F22) volatile __CLC2GLS2bits_t CLC2GLS2bits;
5809 #define _CLC2GLS2_LC2G3D1N 0x01
5810 #define _CLC2GLS2_D1N 0x01
5811 #define _CLC2GLS2_LC2G3D1T 0x02
5812 #define _CLC2GLS2_D1T 0x02
5813 #define _CLC2GLS2_LC2G3D2N 0x04
5814 #define _CLC2GLS2_D2N 0x04
5815 #define _CLC2GLS2_LC2G3D2T 0x08
5816 #define _CLC2GLS2_D2T 0x08
5817 #define _CLC2GLS2_LC2G3D3N 0x10
5818 #define _CLC2GLS2_D3N 0x10
5819 #define _CLC2GLS2_LC2G3D3T 0x20
5820 #define _CLC2GLS2_D3T 0x20
5821 #define _CLC2GLS2_LC2G3D4N 0x40
5822 #define _CLC2GLS2_D4N 0x40
5823 #define _CLC2GLS2_LC2G3D4T 0x80
5824 #define _CLC2GLS2_D4T 0x80
5826 //==============================================================================
5829 //==============================================================================
5830 // CLC2GLS3 Bits
5832 extern __at(0x0F23) __sfr CLC2GLS3;
5834 typedef union
5836 struct
5838 unsigned LC2G4D1N : 1;
5839 unsigned LC2G4D1T : 1;
5840 unsigned LC2G4D2N : 1;
5841 unsigned LC2G4D2T : 1;
5842 unsigned LC2G4D3N : 1;
5843 unsigned LC2G4D3T : 1;
5844 unsigned LC2G4D4N : 1;
5845 unsigned LC2G4D4T : 1;
5848 struct
5850 unsigned G4D1N : 1;
5851 unsigned G4D1T : 1;
5852 unsigned G4D2N : 1;
5853 unsigned G4D2T : 1;
5854 unsigned G4D3N : 1;
5855 unsigned G4D3T : 1;
5856 unsigned G4D4N : 1;
5857 unsigned G4D4T : 1;
5859 } __CLC2GLS3bits_t;
5861 extern __at(0x0F23) volatile __CLC2GLS3bits_t CLC2GLS3bits;
5863 #define _CLC2GLS3_LC2G4D1N 0x01
5864 #define _CLC2GLS3_G4D1N 0x01
5865 #define _CLC2GLS3_LC2G4D1T 0x02
5866 #define _CLC2GLS3_G4D1T 0x02
5867 #define _CLC2GLS3_LC2G4D2N 0x04
5868 #define _CLC2GLS3_G4D2N 0x04
5869 #define _CLC2GLS3_LC2G4D2T 0x08
5870 #define _CLC2GLS3_G4D2T 0x08
5871 #define _CLC2GLS3_LC2G4D3N 0x10
5872 #define _CLC2GLS3_G4D3N 0x10
5873 #define _CLC2GLS3_LC2G4D3T 0x20
5874 #define _CLC2GLS3_G4D3T 0x20
5875 #define _CLC2GLS3_LC2G4D4N 0x40
5876 #define _CLC2GLS3_G4D4N 0x40
5877 #define _CLC2GLS3_LC2G4D4T 0x80
5878 #define _CLC2GLS3_G4D4T 0x80
5880 //==============================================================================
5883 //==============================================================================
5884 // CLC3CON Bits
5886 extern __at(0x0F24) __sfr CLC3CON;
5888 typedef union
5890 struct
5892 unsigned LC3MODE0 : 1;
5893 unsigned LC3MODE1 : 1;
5894 unsigned LC3MODE2 : 1;
5895 unsigned LC3INTN : 1;
5896 unsigned LC3INTP : 1;
5897 unsigned LC3OUT : 1;
5898 unsigned : 1;
5899 unsigned LC3EN : 1;
5902 struct
5904 unsigned MODE0 : 1;
5905 unsigned MODE1 : 1;
5906 unsigned MODE2 : 1;
5907 unsigned INTN : 1;
5908 unsigned INTP : 1;
5909 unsigned OUT : 1;
5910 unsigned : 1;
5911 unsigned EN : 1;
5914 struct
5916 unsigned LC3MODE : 3;
5917 unsigned : 5;
5920 struct
5922 unsigned MODE : 3;
5923 unsigned : 5;
5925 } __CLC3CONbits_t;
5927 extern __at(0x0F24) volatile __CLC3CONbits_t CLC3CONbits;
5929 #define _CLC3CON_LC3MODE0 0x01
5930 #define _CLC3CON_MODE0 0x01
5931 #define _CLC3CON_LC3MODE1 0x02
5932 #define _CLC3CON_MODE1 0x02
5933 #define _CLC3CON_LC3MODE2 0x04
5934 #define _CLC3CON_MODE2 0x04
5935 #define _CLC3CON_LC3INTN 0x08
5936 #define _CLC3CON_INTN 0x08
5937 #define _CLC3CON_LC3INTP 0x10
5938 #define _CLC3CON_INTP 0x10
5939 #define _CLC3CON_LC3OUT 0x20
5940 #define _CLC3CON_OUT 0x20
5941 #define _CLC3CON_LC3EN 0x80
5942 #define _CLC3CON_EN 0x80
5944 //==============================================================================
5947 //==============================================================================
5948 // CLC3POL Bits
5950 extern __at(0x0F25) __sfr CLC3POL;
5952 typedef union
5954 struct
5956 unsigned LC3G1POL : 1;
5957 unsigned LC3G2POL : 1;
5958 unsigned LC3G3POL : 1;
5959 unsigned LC3G4POL : 1;
5960 unsigned : 1;
5961 unsigned : 1;
5962 unsigned : 1;
5963 unsigned LC3POL : 1;
5966 struct
5968 unsigned G1POL : 1;
5969 unsigned G2POL : 1;
5970 unsigned G3POL : 1;
5971 unsigned G4POL : 1;
5972 unsigned : 1;
5973 unsigned : 1;
5974 unsigned : 1;
5975 unsigned POL : 1;
5977 } __CLC3POLbits_t;
5979 extern __at(0x0F25) volatile __CLC3POLbits_t CLC3POLbits;
5981 #define _CLC3POL_LC3G1POL 0x01
5982 #define _CLC3POL_G1POL 0x01
5983 #define _CLC3POL_LC3G2POL 0x02
5984 #define _CLC3POL_G2POL 0x02
5985 #define _CLC3POL_LC3G3POL 0x04
5986 #define _CLC3POL_G3POL 0x04
5987 #define _CLC3POL_LC3G4POL 0x08
5988 #define _CLC3POL_G4POL 0x08
5989 #define _CLC3POL_LC3POL 0x80
5990 #define _CLC3POL_POL 0x80
5992 //==============================================================================
5995 //==============================================================================
5996 // CLC3SEL0 Bits
5998 extern __at(0x0F26) __sfr CLC3SEL0;
6000 typedef union
6002 struct
6004 unsigned LC3D1S0 : 1;
6005 unsigned LC3D1S1 : 1;
6006 unsigned LC3D1S2 : 1;
6007 unsigned LC3D1S3 : 1;
6008 unsigned LC3D1S4 : 1;
6009 unsigned : 1;
6010 unsigned : 1;
6011 unsigned : 1;
6014 struct
6016 unsigned D1S0 : 1;
6017 unsigned D1S1 : 1;
6018 unsigned D1S2 : 1;
6019 unsigned D1S3 : 1;
6020 unsigned D1S4 : 1;
6021 unsigned : 1;
6022 unsigned : 1;
6023 unsigned : 1;
6026 struct
6028 unsigned D1S : 5;
6029 unsigned : 3;
6032 struct
6034 unsigned LC3D1S : 5;
6035 unsigned : 3;
6037 } __CLC3SEL0bits_t;
6039 extern __at(0x0F26) volatile __CLC3SEL0bits_t CLC3SEL0bits;
6041 #define _CLC3SEL0_LC3D1S0 0x01
6042 #define _CLC3SEL0_D1S0 0x01
6043 #define _CLC3SEL0_LC3D1S1 0x02
6044 #define _CLC3SEL0_D1S1 0x02
6045 #define _CLC3SEL0_LC3D1S2 0x04
6046 #define _CLC3SEL0_D1S2 0x04
6047 #define _CLC3SEL0_LC3D1S3 0x08
6048 #define _CLC3SEL0_D1S3 0x08
6049 #define _CLC3SEL0_LC3D1S4 0x10
6050 #define _CLC3SEL0_D1S4 0x10
6052 //==============================================================================
6055 //==============================================================================
6056 // CLC3SEL1 Bits
6058 extern __at(0x0F27) __sfr CLC3SEL1;
6060 typedef union
6062 struct
6064 unsigned LC3D2S0 : 1;
6065 unsigned LC3D2S1 : 1;
6066 unsigned LC3D2S2 : 1;
6067 unsigned LC3D2S3 : 1;
6068 unsigned LC3D2S4 : 1;
6069 unsigned : 1;
6070 unsigned : 1;
6071 unsigned : 1;
6074 struct
6076 unsigned D2S0 : 1;
6077 unsigned D2S1 : 1;
6078 unsigned D2S2 : 1;
6079 unsigned D2S3 : 1;
6080 unsigned D2S4 : 1;
6081 unsigned : 1;
6082 unsigned : 1;
6083 unsigned : 1;
6086 struct
6088 unsigned LC3D2S : 5;
6089 unsigned : 3;
6092 struct
6094 unsigned D2S : 5;
6095 unsigned : 3;
6097 } __CLC3SEL1bits_t;
6099 extern __at(0x0F27) volatile __CLC3SEL1bits_t CLC3SEL1bits;
6101 #define _CLC3SEL1_LC3D2S0 0x01
6102 #define _CLC3SEL1_D2S0 0x01
6103 #define _CLC3SEL1_LC3D2S1 0x02
6104 #define _CLC3SEL1_D2S1 0x02
6105 #define _CLC3SEL1_LC3D2S2 0x04
6106 #define _CLC3SEL1_D2S2 0x04
6107 #define _CLC3SEL1_LC3D2S3 0x08
6108 #define _CLC3SEL1_D2S3 0x08
6109 #define _CLC3SEL1_LC3D2S4 0x10
6110 #define _CLC3SEL1_D2S4 0x10
6112 //==============================================================================
6115 //==============================================================================
6116 // CLC3SEL2 Bits
6118 extern __at(0x0F28) __sfr CLC3SEL2;
6120 typedef union
6122 struct
6124 unsigned LC3D3S0 : 1;
6125 unsigned LC3D3S1 : 1;
6126 unsigned LC3D3S2 : 1;
6127 unsigned LC3D3S3 : 1;
6128 unsigned LC3D3S4 : 1;
6129 unsigned : 1;
6130 unsigned : 1;
6131 unsigned : 1;
6134 struct
6136 unsigned D3S0 : 1;
6137 unsigned D3S1 : 1;
6138 unsigned D3S2 : 1;
6139 unsigned D3S3 : 1;
6140 unsigned D3S4 : 1;
6141 unsigned : 1;
6142 unsigned : 1;
6143 unsigned : 1;
6146 struct
6148 unsigned D3S : 5;
6149 unsigned : 3;
6152 struct
6154 unsigned LC3D3S : 5;
6155 unsigned : 3;
6157 } __CLC3SEL2bits_t;
6159 extern __at(0x0F28) volatile __CLC3SEL2bits_t CLC3SEL2bits;
6161 #define _CLC3SEL2_LC3D3S0 0x01
6162 #define _CLC3SEL2_D3S0 0x01
6163 #define _CLC3SEL2_LC3D3S1 0x02
6164 #define _CLC3SEL2_D3S1 0x02
6165 #define _CLC3SEL2_LC3D3S2 0x04
6166 #define _CLC3SEL2_D3S2 0x04
6167 #define _CLC3SEL2_LC3D3S3 0x08
6168 #define _CLC3SEL2_D3S3 0x08
6169 #define _CLC3SEL2_LC3D3S4 0x10
6170 #define _CLC3SEL2_D3S4 0x10
6172 //==============================================================================
6175 //==============================================================================
6176 // CLC3SEL3 Bits
6178 extern __at(0x0F29) __sfr CLC3SEL3;
6180 typedef union
6182 struct
6184 unsigned LC3D4S0 : 1;
6185 unsigned LC3D4S1 : 1;
6186 unsigned LC3D4S2 : 1;
6187 unsigned LC3D4S3 : 1;
6188 unsigned LC3D4S4 : 1;
6189 unsigned : 1;
6190 unsigned : 1;
6191 unsigned : 1;
6194 struct
6196 unsigned D4S0 : 1;
6197 unsigned D4S1 : 1;
6198 unsigned D4S2 : 1;
6199 unsigned D4S3 : 1;
6200 unsigned D4S4 : 1;
6201 unsigned : 1;
6202 unsigned : 1;
6203 unsigned : 1;
6206 struct
6208 unsigned LC3D4S : 5;
6209 unsigned : 3;
6212 struct
6214 unsigned D4S : 5;
6215 unsigned : 3;
6217 } __CLC3SEL3bits_t;
6219 extern __at(0x0F29) volatile __CLC3SEL3bits_t CLC3SEL3bits;
6221 #define _CLC3SEL3_LC3D4S0 0x01
6222 #define _CLC3SEL3_D4S0 0x01
6223 #define _CLC3SEL3_LC3D4S1 0x02
6224 #define _CLC3SEL3_D4S1 0x02
6225 #define _CLC3SEL3_LC3D4S2 0x04
6226 #define _CLC3SEL3_D4S2 0x04
6227 #define _CLC3SEL3_LC3D4S3 0x08
6228 #define _CLC3SEL3_D4S3 0x08
6229 #define _CLC3SEL3_LC3D4S4 0x10
6230 #define _CLC3SEL3_D4S4 0x10
6232 //==============================================================================
6235 //==============================================================================
6236 // CLC3GLS0 Bits
6238 extern __at(0x0F2A) __sfr CLC3GLS0;
6240 typedef union
6242 struct
6244 unsigned LC3G1D1N : 1;
6245 unsigned LC3G1D1T : 1;
6246 unsigned LC3G1D2N : 1;
6247 unsigned LC3G1D2T : 1;
6248 unsigned LC3G1D3N : 1;
6249 unsigned LC3G1D3T : 1;
6250 unsigned LC3G1D4N : 1;
6251 unsigned LC3G1D4T : 1;
6254 struct
6256 unsigned D1N : 1;
6257 unsigned D1T : 1;
6258 unsigned D2N : 1;
6259 unsigned D2T : 1;
6260 unsigned D3N : 1;
6261 unsigned D3T : 1;
6262 unsigned D4N : 1;
6263 unsigned D4T : 1;
6265 } __CLC3GLS0bits_t;
6267 extern __at(0x0F2A) volatile __CLC3GLS0bits_t CLC3GLS0bits;
6269 #define _CLC3GLS0_LC3G1D1N 0x01
6270 #define _CLC3GLS0_D1N 0x01
6271 #define _CLC3GLS0_LC3G1D1T 0x02
6272 #define _CLC3GLS0_D1T 0x02
6273 #define _CLC3GLS0_LC3G1D2N 0x04
6274 #define _CLC3GLS0_D2N 0x04
6275 #define _CLC3GLS0_LC3G1D2T 0x08
6276 #define _CLC3GLS0_D2T 0x08
6277 #define _CLC3GLS0_LC3G1D3N 0x10
6278 #define _CLC3GLS0_D3N 0x10
6279 #define _CLC3GLS0_LC3G1D3T 0x20
6280 #define _CLC3GLS0_D3T 0x20
6281 #define _CLC3GLS0_LC3G1D4N 0x40
6282 #define _CLC3GLS0_D4N 0x40
6283 #define _CLC3GLS0_LC3G1D4T 0x80
6284 #define _CLC3GLS0_D4T 0x80
6286 //==============================================================================
6289 //==============================================================================
6290 // CLC3GLS1 Bits
6292 extern __at(0x0F2B) __sfr CLC3GLS1;
6294 typedef union
6296 struct
6298 unsigned LC3G2D1N : 1;
6299 unsigned LC3G2D1T : 1;
6300 unsigned LC3G2D2N : 1;
6301 unsigned LC3G2D2T : 1;
6302 unsigned LC3G2D3N : 1;
6303 unsigned LC3G2D3T : 1;
6304 unsigned LC3G2D4N : 1;
6305 unsigned LC3G2D4T : 1;
6308 struct
6310 unsigned D1N : 1;
6311 unsigned D1T : 1;
6312 unsigned D2N : 1;
6313 unsigned D2T : 1;
6314 unsigned D3N : 1;
6315 unsigned D3T : 1;
6316 unsigned D4N : 1;
6317 unsigned D4T : 1;
6319 } __CLC3GLS1bits_t;
6321 extern __at(0x0F2B) volatile __CLC3GLS1bits_t CLC3GLS1bits;
6323 #define _CLC3GLS1_LC3G2D1N 0x01
6324 #define _CLC3GLS1_D1N 0x01
6325 #define _CLC3GLS1_LC3G2D1T 0x02
6326 #define _CLC3GLS1_D1T 0x02
6327 #define _CLC3GLS1_LC3G2D2N 0x04
6328 #define _CLC3GLS1_D2N 0x04
6329 #define _CLC3GLS1_LC3G2D2T 0x08
6330 #define _CLC3GLS1_D2T 0x08
6331 #define _CLC3GLS1_LC3G2D3N 0x10
6332 #define _CLC3GLS1_D3N 0x10
6333 #define _CLC3GLS1_LC3G2D3T 0x20
6334 #define _CLC3GLS1_D3T 0x20
6335 #define _CLC3GLS1_LC3G2D4N 0x40
6336 #define _CLC3GLS1_D4N 0x40
6337 #define _CLC3GLS1_LC3G2D4T 0x80
6338 #define _CLC3GLS1_D4T 0x80
6340 //==============================================================================
6343 //==============================================================================
6344 // CLC3GLS2 Bits
6346 extern __at(0x0F2C) __sfr CLC3GLS2;
6348 typedef union
6350 struct
6352 unsigned LC3G3D1N : 1;
6353 unsigned LC3G3D1T : 1;
6354 unsigned LC3G3D2N : 1;
6355 unsigned LC3G3D2T : 1;
6356 unsigned LC3G3D3N : 1;
6357 unsigned LC3G3D3T : 1;
6358 unsigned LC3G3D4N : 1;
6359 unsigned LC3G3D4T : 1;
6362 struct
6364 unsigned D1N : 1;
6365 unsigned D1T : 1;
6366 unsigned D2N : 1;
6367 unsigned D2T : 1;
6368 unsigned D3N : 1;
6369 unsigned D3T : 1;
6370 unsigned D4N : 1;
6371 unsigned D4T : 1;
6373 } __CLC3GLS2bits_t;
6375 extern __at(0x0F2C) volatile __CLC3GLS2bits_t CLC3GLS2bits;
6377 #define _CLC3GLS2_LC3G3D1N 0x01
6378 #define _CLC3GLS2_D1N 0x01
6379 #define _CLC3GLS2_LC3G3D1T 0x02
6380 #define _CLC3GLS2_D1T 0x02
6381 #define _CLC3GLS2_LC3G3D2N 0x04
6382 #define _CLC3GLS2_D2N 0x04
6383 #define _CLC3GLS2_LC3G3D2T 0x08
6384 #define _CLC3GLS2_D2T 0x08
6385 #define _CLC3GLS2_LC3G3D3N 0x10
6386 #define _CLC3GLS2_D3N 0x10
6387 #define _CLC3GLS2_LC3G3D3T 0x20
6388 #define _CLC3GLS2_D3T 0x20
6389 #define _CLC3GLS2_LC3G3D4N 0x40
6390 #define _CLC3GLS2_D4N 0x40
6391 #define _CLC3GLS2_LC3G3D4T 0x80
6392 #define _CLC3GLS2_D4T 0x80
6394 //==============================================================================
6397 //==============================================================================
6398 // CLC3GLS3 Bits
6400 extern __at(0x0F2D) __sfr CLC3GLS3;
6402 typedef union
6404 struct
6406 unsigned LC3G4D1N : 1;
6407 unsigned LC3G4D1T : 1;
6408 unsigned LC3G4D2N : 1;
6409 unsigned LC3G4D2T : 1;
6410 unsigned LC3G4D3N : 1;
6411 unsigned LC3G4D3T : 1;
6412 unsigned LC3G4D4N : 1;
6413 unsigned LC3G4D4T : 1;
6416 struct
6418 unsigned G4D1N : 1;
6419 unsigned G4D1T : 1;
6420 unsigned G4D2N : 1;
6421 unsigned G4D2T : 1;
6422 unsigned G4D3N : 1;
6423 unsigned G4D3T : 1;
6424 unsigned G4D4N : 1;
6425 unsigned G4D4T : 1;
6427 } __CLC3GLS3bits_t;
6429 extern __at(0x0F2D) volatile __CLC3GLS3bits_t CLC3GLS3bits;
6431 #define _CLC3GLS3_LC3G4D1N 0x01
6432 #define _CLC3GLS3_G4D1N 0x01
6433 #define _CLC3GLS3_LC3G4D1T 0x02
6434 #define _CLC3GLS3_G4D1T 0x02
6435 #define _CLC3GLS3_LC3G4D2N 0x04
6436 #define _CLC3GLS3_G4D2N 0x04
6437 #define _CLC3GLS3_LC3G4D2T 0x08
6438 #define _CLC3GLS3_G4D2T 0x08
6439 #define _CLC3GLS3_LC3G4D3N 0x10
6440 #define _CLC3GLS3_G4D3N 0x10
6441 #define _CLC3GLS3_LC3G4D3T 0x20
6442 #define _CLC3GLS3_G4D3T 0x20
6443 #define _CLC3GLS3_LC3G4D4N 0x40
6444 #define _CLC3GLS3_G4D4N 0x40
6445 #define _CLC3GLS3_LC3G4D4T 0x80
6446 #define _CLC3GLS3_G4D4T 0x80
6448 //==============================================================================
6451 //==============================================================================
6452 // ICDBK0H Bits
6454 extern __at(0x0F9E) __sfr ICDBK0H;
6456 typedef struct
6458 unsigned BKA8 : 1;
6459 unsigned BKA9 : 1;
6460 unsigned BKA10 : 1;
6461 unsigned BKA11 : 1;
6462 unsigned BKA12 : 1;
6463 unsigned BKA13 : 1;
6464 unsigned BKA14 : 1;
6465 unsigned : 1;
6466 } __ICDBK0Hbits_t;
6468 extern __at(0x0F9E) volatile __ICDBK0Hbits_t ICDBK0Hbits;
6470 #define _BKA8 0x01
6471 #define _BKA9 0x02
6472 #define _BKA10 0x04
6473 #define _BKA11 0x08
6474 #define _BKA12 0x10
6475 #define _BKA13 0x20
6476 #define _BKA14 0x40
6478 //==============================================================================
6481 //==============================================================================
6482 // STATUS_SHAD Bits
6484 extern __at(0x0FE4) __sfr STATUS_SHAD;
6486 typedef struct
6488 unsigned C_SHAD : 1;
6489 unsigned DC_SHAD : 1;
6490 unsigned Z_SHAD : 1;
6491 unsigned : 1;
6492 unsigned : 1;
6493 unsigned : 1;
6494 unsigned : 1;
6495 unsigned : 1;
6496 } __STATUS_SHADbits_t;
6498 extern __at(0x0FE4) volatile __STATUS_SHADbits_t STATUS_SHADbits;
6500 #define _C_SHAD 0x01
6501 #define _DC_SHAD 0x02
6502 #define _Z_SHAD 0x04
6504 //==============================================================================
6506 extern __at(0x0FE5) __sfr WREG_SHAD;
6507 extern __at(0x0FE6) __sfr BSR_SHAD;
6508 extern __at(0x0FE7) __sfr PCLATH_SHAD;
6509 extern __at(0x0FE8) __sfr FSR0L_SHAD;
6510 extern __at(0x0FE9) __sfr FSR0H_SHAD;
6511 extern __at(0x0FEA) __sfr FSR1L_SHAD;
6512 extern __at(0x0FEB) __sfr FSR1H_SHAD;
6513 extern __at(0x0FED) __sfr STKPTR;
6514 extern __at(0x0FEE) __sfr TOSL;
6515 extern __at(0x0FEF) __sfr TOSH;
6517 //==============================================================================
6519 // Configuration Bits
6521 //==============================================================================
6523 #define _CONFIG1 0x8007
6524 #define _CONFIG2 0x8008
6526 //----------------------------- CONFIG1 Options -------------------------------
6528 #define _FOSC_LP 0x3FF8 // LP Oscillator, Low-power crystal connected between OSC1 and OSC2 pins.
6529 #define _FOSC_XT 0x3FF9 // XT Oscillator, Crystal/resonator connected between OSC1 and OSC2 pins.
6530 #define _FOSC_HS 0x3FFA // HS Oscillator, High-speed crystal/resonator connected between OSC1 and OSC2 pins.
6531 #define _FOSC_EXTRC 0x3FFB // EXTRC oscillator: External RC circuit connected to CLKIN pin.
6532 #define _FOSC_INTOSC 0x3FFC // INTOSC oscillator: I/O function on CLKIN pin.
6533 #define _FOSC_ECL 0x3FFD // ECL, External Clock, Low Power Mode (0-0.5 MHz): device clock supplied to CLKIN pins.
6534 #define _FOSC_ECM 0x3FFE // ECM, External Clock, Medium Power Mode (0.5-4 MHz): device clock supplied to CLKIN pins.
6535 #define _FOSC_ECH 0x3FFF // ECH, External Clock, High Power Mode (4-20 MHz): device clock supplied to CLKIN pins.
6536 #define _WDTE_OFF 0x3FE7 // WDT disabled.
6537 #define _WDTE_SWDTEN 0x3FEF // WDT controlled by the SWDTEN bit in the WDTCON register.
6538 #define _WDTE_NSLEEP 0x3FF7 // WDT enabled while running and disabled in Sleep.
6539 #define _WDTE_ON 0x3FFF // WDT enabled.
6540 #define _PWRTE_ON 0x3FDF // PWRT enabled.
6541 #define _PWRTE_OFF 0x3FFF // PWRT disabled.
6542 #define _MCLRE_OFF 0x3FBF // MCLR/VPP pin function is digital input.
6543 #define _MCLRE_ON 0x3FFF // MCLR/VPP pin function is MCLR.
6544 #define _CP_ON 0x3F7F // Program memory code protection is enabled.
6545 #define _CP_OFF 0x3FFF // Program memory code protection is disabled.
6546 #define _BOREN_OFF 0x39FF // Brown-out Reset disabled.
6547 #define _BOREN_SBODEN 0x3BFF // Brown-out Reset controlled by the SBOREN bit in the BORCON register.
6548 #define _BOREN_NSLEEP 0x3DFF // Brown-out Reset enabled while running and disabled in Sleep.
6549 #define _BOREN_ON 0x3FFF // Brown-out Reset enabled.
6550 #define _CLKOUTEN_ON 0x37FF // CLKOUT function is enabled on the CLKOUT pin.
6551 #define _CLKOUTEN_OFF 0x3FFF // CLKOUT function is disabled. I/O or oscillator function on the CLKOUT pin.
6552 #define _IESO_OFF 0x2FFF // Internal/External Switchover Mode is disabled.
6553 #define _IESO_ON 0x3FFF // Internal/External Switchover Mode is enabled.
6554 #define _FCMEN_OFF 0x1FFF // Fail-Safe Clock Monitor is disabled.
6555 #define _FCMEN_ON 0x3FFF // Fail-Safe Clock Monitor is enabled.
6557 //----------------------------- CONFIG2 Options -------------------------------
6559 #define _WRT_ALL 0x3FFC // 000h to 1FFFh write protected, no addresses may be modified by EECON control.
6560 #define _WRT_HALF 0x3FFD // 000h to FFFh write protected, 1000h to 1FFFh may be modified by EECON control.
6561 #define _WRT_BOOT 0x3FFE // 000h to 1FFh write protected, 200h to 1FFFh may be modified by EECON control.
6562 #define _WRT_OFF 0x3FFF // Write protection off.
6563 #define _PPS1WAY_OFF 0x3FFB // The PPSLOCK bit can be set and cleared repeatedly by software.
6564 #define _PPS1WAY_ON 0x3FFF // The PPSLOCK bit cannot be cleared once it is set by software.
6565 #define _ZCDDIS_OFF 0x3F7F // Zero-cross detect circuit is enabled at POR.
6566 #define _ZCDDIS_ON 0x3FFF // Zero-cross detect circuit is disabled at POR.
6567 #define _PLLEN_OFF 0x3EFF // 4x PLL is enabled when software sets the SPLLEN bit.
6568 #define _PLLEN_ON 0x3FFF // 4x PLL is always enabled.
6569 #define _STVREN_OFF 0x3DFF // Stack Overflow or Underflow will not cause a Reset.
6570 #define _STVREN_ON 0x3FFF // Stack Overflow or Underflow will cause a Reset.
6571 #define _BORV_HI 0x3BFF // Brown-out Reset Voltage (Vbor), high trip point selected.
6572 #define _BORV_LO 0x3FFF // Brown-out Reset Voltage (Vbor), low trip point selected.
6573 #define _LPBOR_ON 0x37FF // Low-Power BOR is enabled.
6574 #define _LPBOR_OFF 0x3FFF // Low-Power BOR is disabled.
6575 #define _DEBUG_ON 0x2FFF // In-Circuit Debugger enabled, ICSPCLK and ICSPDAT are dedicated to the debugger.
6576 #define _DEBUG_OFF 0x3FFF // In-Circuit Debugger disabled, ICSPCLK and ICSPDAT are general purpose I/O pins.
6577 #define _LVP_OFF 0x1FFF // High-voltage on MCLR/VPP must be used for programming.
6578 #define _LVP_ON 0x3FFF // Low-voltage programming enabled.
6580 //==============================================================================
6582 #define _DEVID1 0x8006
6584 #define _IDLOC0 0x8000
6585 #define _IDLOC1 0x8001
6586 #define _IDLOC2 0x8002
6587 #define _IDLOC3 0x8003
6589 //==============================================================================
6591 #ifndef NO_BIT_DEFINES
6593 #define ADON ADCON0bits.ADON // bit 0
6594 #define GO_NOT_DONE ADCON0bits.GO_NOT_DONE // bit 1, shadows bit in ADCON0bits
6595 #define ADGO ADCON0bits.ADGO // bit 1, shadows bit in ADCON0bits
6596 #define GO ADCON0bits.GO // bit 1, shadows bit in ADCON0bits
6597 #define CHS0 ADCON0bits.CHS0 // bit 2
6598 #define CHS1 ADCON0bits.CHS1 // bit 3
6599 #define CHS2 ADCON0bits.CHS2 // bit 4
6600 #define CHS3 ADCON0bits.CHS3 // bit 5
6601 #define CHS4 ADCON0bits.CHS4 // bit 6
6603 #define ADPREF0 ADCON1bits.ADPREF0 // bit 0
6604 #define ADPREF1 ADCON1bits.ADPREF1 // bit 1
6605 #define ADNREF ADCON1bits.ADNREF // bit 2
6606 #define ADFM ADCON1bits.ADFM // bit 7
6608 #define TRIGSEL0 ADCON2bits.TRIGSEL0 // bit 4
6609 #define TRIGSEL1 ADCON2bits.TRIGSEL1 // bit 5
6610 #define TRIGSEL2 ADCON2bits.TRIGSEL2 // bit 6
6611 #define TRIGSEL3 ADCON2bits.TRIGSEL3 // bit 7
6613 #define ANSA0 ANSELAbits.ANSA0 // bit 0
6614 #define ANSA1 ANSELAbits.ANSA1 // bit 1
6615 #define ANSA2 ANSELAbits.ANSA2 // bit 2
6616 #define ANSA4 ANSELAbits.ANSA4 // bit 4
6617 #define ANS5 ANSELAbits.ANS5 // bit 5
6619 #define ANSC0 ANSELCbits.ANSC0 // bit 0
6620 #define ANSC1 ANSELCbits.ANSC1 // bit 1
6621 #define ANSC2 ANSELCbits.ANSC2 // bit 2
6622 #define ANSC3 ANSELCbits.ANSC3 // bit 3
6623 #define ANSC4 ANSELCbits.ANSC4 // bit 4
6624 #define ANSC5 ANSELCbits.ANSC5 // bit 5
6626 #define ABDEN BAUD1CONbits.ABDEN // bit 0
6627 #define WUE BAUD1CONbits.WUE // bit 1
6628 #define BRG16 BAUD1CONbits.BRG16 // bit 3
6629 #define SCKP BAUD1CONbits.SCKP // bit 4
6630 #define RCIDL BAUD1CONbits.RCIDL // bit 6
6631 #define ABDOVF BAUD1CONbits.ABDOVF // bit 7
6633 #define BORRDY BORCONbits.BORRDY // bit 0
6634 #define BORFS BORCONbits.BORFS // bit 6
6635 #define SBOREN BORCONbits.SBOREN // bit 7
6637 #define BSR0 BSRbits.BSR0 // bit 0
6638 #define BSR1 BSRbits.BSR1 // bit 1
6639 #define BSR2 BSRbits.BSR2 // bit 2
6640 #define BSR3 BSRbits.BSR3 // bit 3
6641 #define BSR4 BSRbits.BSR4 // bit 4
6643 #define CCP1M0 CCP1CONbits.CCP1M0 // bit 0
6644 #define CCP1M1 CCP1CONbits.CCP1M1 // bit 1
6645 #define CCP1M2 CCP1CONbits.CCP1M2 // bit 2
6646 #define CCP1M3 CCP1CONbits.CCP1M3 // bit 3
6647 #define DC1B0 CCP1CONbits.DC1B0 // bit 4, shadows bit in CCP1CONbits
6648 #define CCP1Y CCP1CONbits.CCP1Y // bit 4, shadows bit in CCP1CONbits
6649 #define DC1B1 CCP1CONbits.DC1B1 // bit 5, shadows bit in CCP1CONbits
6650 #define CCP1X CCP1CONbits.CCP1X // bit 5, shadows bit in CCP1CONbits
6652 #define CCP2M0 CCP2CONbits.CCP2M0 // bit 0
6653 #define CCP2M1 CCP2CONbits.CCP2M1 // bit 1
6654 #define CCP2M2 CCP2CONbits.CCP2M2 // bit 2
6655 #define CCP2M3 CCP2CONbits.CCP2M3 // bit 3
6656 #define DC2B0 CCP2CONbits.DC2B0 // bit 4, shadows bit in CCP2CONbits
6657 #define CCP2Y CCP2CONbits.CCP2Y // bit 4, shadows bit in CCP2CONbits
6658 #define DC2B1 CCP2CONbits.DC2B1 // bit 5, shadows bit in CCP2CONbits
6659 #define CCP2X CCP2CONbits.CCP2X // bit 5, shadows bit in CCP2CONbits
6661 #define C1TSEL0 CCPTMRSbits.C1TSEL0 // bit 0
6662 #define C1TSEL1 CCPTMRSbits.C1TSEL1 // bit 1
6663 #define C2TSEL0 CCPTMRSbits.C2TSEL0 // bit 2
6664 #define C2TSEL1 CCPTMRSbits.C2TSEL1 // bit 3
6665 #define P3TSEL0 CCPTMRSbits.P3TSEL0 // bit 4
6666 #define P3TSEL1 CCPTMRSbits.P3TSEL1 // bit 5
6667 #define P4TSEL0 CCPTMRSbits.P4TSEL0 // bit 6
6668 #define P4TSEL1 CCPTMRSbits.P4TSEL1 // bit 7
6670 #define LC1MODE0 CLC1CONbits.LC1MODE0 // bit 0, shadows bit in CLC1CONbits
6671 #define MODE0 CLC1CONbits.MODE0 // bit 0, shadows bit in CLC1CONbits
6672 #define LC1MODE1 CLC1CONbits.LC1MODE1 // bit 1, shadows bit in CLC1CONbits
6673 #define MODE1 CLC1CONbits.MODE1 // bit 1, shadows bit in CLC1CONbits
6674 #define LC1MODE2 CLC1CONbits.LC1MODE2 // bit 2, shadows bit in CLC1CONbits
6675 #define MODE2 CLC1CONbits.MODE2 // bit 2, shadows bit in CLC1CONbits
6676 #define LC1INTN CLC1CONbits.LC1INTN // bit 3, shadows bit in CLC1CONbits
6677 #define INTN CLC1CONbits.INTN // bit 3, shadows bit in CLC1CONbits
6678 #define LC1INTP CLC1CONbits.LC1INTP // bit 4, shadows bit in CLC1CONbits
6679 #define INTP CLC1CONbits.INTP // bit 4, shadows bit in CLC1CONbits
6680 #define LC1OUT CLC1CONbits.LC1OUT // bit 5, shadows bit in CLC1CONbits
6681 #define OUT CLC1CONbits.OUT // bit 5, shadows bit in CLC1CONbits
6682 #define LC1EN CLC1CONbits.LC1EN // bit 7, shadows bit in CLC1CONbits
6683 #define EN CLC1CONbits.EN // bit 7, shadows bit in CLC1CONbits
6685 #define LC1G1D1N CLC1GLS0bits.LC1G1D1N // bit 0, shadows bit in CLC1GLS0bits
6686 #define D1N CLC1GLS0bits.D1N // bit 0, shadows bit in CLC1GLS0bits
6687 #define LC1G1D1T CLC1GLS0bits.LC1G1D1T // bit 1, shadows bit in CLC1GLS0bits
6688 #define D1T CLC1GLS0bits.D1T // bit 1, shadows bit in CLC1GLS0bits
6689 #define LC1G1D2N CLC1GLS0bits.LC1G1D2N // bit 2, shadows bit in CLC1GLS0bits
6690 #define D2N CLC1GLS0bits.D2N // bit 2, shadows bit in CLC1GLS0bits
6691 #define LC1G1D2T CLC1GLS0bits.LC1G1D2T // bit 3, shadows bit in CLC1GLS0bits
6692 #define D2T CLC1GLS0bits.D2T // bit 3, shadows bit in CLC1GLS0bits
6693 #define LC1G1D3N CLC1GLS0bits.LC1G1D3N // bit 4, shadows bit in CLC1GLS0bits
6694 #define D3N CLC1GLS0bits.D3N // bit 4, shadows bit in CLC1GLS0bits
6695 #define LC1G1D3T CLC1GLS0bits.LC1G1D3T // bit 5, shadows bit in CLC1GLS0bits
6696 #define D3T CLC1GLS0bits.D3T // bit 5, shadows bit in CLC1GLS0bits
6697 #define LC1G1D4N CLC1GLS0bits.LC1G1D4N // bit 6, shadows bit in CLC1GLS0bits
6698 #define D4N CLC1GLS0bits.D4N // bit 6, shadows bit in CLC1GLS0bits
6699 #define LC1G1D4T CLC1GLS0bits.LC1G1D4T // bit 7, shadows bit in CLC1GLS0bits
6700 #define D4T CLC1GLS0bits.D4T // bit 7, shadows bit in CLC1GLS0bits
6702 #define LC1G4D1N CLC1GLS3bits.LC1G4D1N // bit 0, shadows bit in CLC1GLS3bits
6703 #define G4D1N CLC1GLS3bits.G4D1N // bit 0, shadows bit in CLC1GLS3bits
6704 #define LC1G4D1T CLC1GLS3bits.LC1G4D1T // bit 1, shadows bit in CLC1GLS3bits
6705 #define G4D1T CLC1GLS3bits.G4D1T // bit 1, shadows bit in CLC1GLS3bits
6706 #define LC1G4D2N CLC1GLS3bits.LC1G4D2N // bit 2, shadows bit in CLC1GLS3bits
6707 #define G4D2N CLC1GLS3bits.G4D2N // bit 2, shadows bit in CLC1GLS3bits
6708 #define LC1G4D2T CLC1GLS3bits.LC1G4D2T // bit 3, shadows bit in CLC1GLS3bits
6709 #define G4D2T CLC1GLS3bits.G4D2T // bit 3, shadows bit in CLC1GLS3bits
6710 #define LC1G4D3N CLC1GLS3bits.LC1G4D3N // bit 4, shadows bit in CLC1GLS3bits
6711 #define G4D3N CLC1GLS3bits.G4D3N // bit 4, shadows bit in CLC1GLS3bits
6712 #define LC1G4D3T CLC1GLS3bits.LC1G4D3T // bit 5, shadows bit in CLC1GLS3bits
6713 #define G4D3T CLC1GLS3bits.G4D3T // bit 5, shadows bit in CLC1GLS3bits
6714 #define LC1G4D4N CLC1GLS3bits.LC1G4D4N // bit 6, shadows bit in CLC1GLS3bits
6715 #define G4D4N CLC1GLS3bits.G4D4N // bit 6, shadows bit in CLC1GLS3bits
6716 #define LC1G4D4T CLC1GLS3bits.LC1G4D4T // bit 7, shadows bit in CLC1GLS3bits
6717 #define G4D4T CLC1GLS3bits.G4D4T // bit 7, shadows bit in CLC1GLS3bits
6719 #define LC1G1POL CLC1POLbits.LC1G1POL // bit 0, shadows bit in CLC1POLbits
6720 #define G1POL CLC1POLbits.G1POL // bit 0, shadows bit in CLC1POLbits
6721 #define LC1G2POL CLC1POLbits.LC1G2POL // bit 1, shadows bit in CLC1POLbits
6722 #define G2POL CLC1POLbits.G2POL // bit 1, shadows bit in CLC1POLbits
6723 #define LC1G3POL CLC1POLbits.LC1G3POL // bit 2, shadows bit in CLC1POLbits
6724 #define G3POL CLC1POLbits.G3POL // bit 2, shadows bit in CLC1POLbits
6725 #define LC1G4POL CLC1POLbits.LC1G4POL // bit 3, shadows bit in CLC1POLbits
6726 #define G4POL CLC1POLbits.G4POL // bit 3, shadows bit in CLC1POLbits
6727 #define LC1POL CLC1POLbits.LC1POL // bit 7, shadows bit in CLC1POLbits
6728 #define POL CLC1POLbits.POL // bit 7, shadows bit in CLC1POLbits
6730 #define LC1D1S0 CLC1SEL0bits.LC1D1S0 // bit 0, shadows bit in CLC1SEL0bits
6731 #define D1S0 CLC1SEL0bits.D1S0 // bit 0, shadows bit in CLC1SEL0bits
6732 #define LC1D1S1 CLC1SEL0bits.LC1D1S1 // bit 1, shadows bit in CLC1SEL0bits
6733 #define D1S1 CLC1SEL0bits.D1S1 // bit 1, shadows bit in CLC1SEL0bits
6734 #define LC1D1S2 CLC1SEL0bits.LC1D1S2 // bit 2, shadows bit in CLC1SEL0bits
6735 #define D1S2 CLC1SEL0bits.D1S2 // bit 2, shadows bit in CLC1SEL0bits
6736 #define LC1D1S3 CLC1SEL0bits.LC1D1S3 // bit 3, shadows bit in CLC1SEL0bits
6737 #define D1S3 CLC1SEL0bits.D1S3 // bit 3, shadows bit in CLC1SEL0bits
6738 #define LC1D1S4 CLC1SEL0bits.LC1D1S4 // bit 4, shadows bit in CLC1SEL0bits
6739 #define D1S4 CLC1SEL0bits.D1S4 // bit 4, shadows bit in CLC1SEL0bits
6741 #define LC1D2S0 CLC1SEL1bits.LC1D2S0 // bit 0, shadows bit in CLC1SEL1bits
6742 #define D2S0 CLC1SEL1bits.D2S0 // bit 0, shadows bit in CLC1SEL1bits
6743 #define LC1D2S1 CLC1SEL1bits.LC1D2S1 // bit 1, shadows bit in CLC1SEL1bits
6744 #define D2S1 CLC1SEL1bits.D2S1 // bit 1, shadows bit in CLC1SEL1bits
6745 #define LC1D2S2 CLC1SEL1bits.LC1D2S2 // bit 2, shadows bit in CLC1SEL1bits
6746 #define D2S2 CLC1SEL1bits.D2S2 // bit 2, shadows bit in CLC1SEL1bits
6747 #define LC1D2S3 CLC1SEL1bits.LC1D2S3 // bit 3, shadows bit in CLC1SEL1bits
6748 #define D2S3 CLC1SEL1bits.D2S3 // bit 3, shadows bit in CLC1SEL1bits
6749 #define LC1D2S4 CLC1SEL1bits.LC1D2S4 // bit 4, shadows bit in CLC1SEL1bits
6750 #define D2S4 CLC1SEL1bits.D2S4 // bit 4, shadows bit in CLC1SEL1bits
6752 #define LC1D3S0 CLC1SEL2bits.LC1D3S0 // bit 0, shadows bit in CLC1SEL2bits
6753 #define D3S0 CLC1SEL2bits.D3S0 // bit 0, shadows bit in CLC1SEL2bits
6754 #define LC1D3S1 CLC1SEL2bits.LC1D3S1 // bit 1, shadows bit in CLC1SEL2bits
6755 #define D3S1 CLC1SEL2bits.D3S1 // bit 1, shadows bit in CLC1SEL2bits
6756 #define LC1D3S2 CLC1SEL2bits.LC1D3S2 // bit 2, shadows bit in CLC1SEL2bits
6757 #define D3S2 CLC1SEL2bits.D3S2 // bit 2, shadows bit in CLC1SEL2bits
6758 #define LC1D3S3 CLC1SEL2bits.LC1D3S3 // bit 3, shadows bit in CLC1SEL2bits
6759 #define D3S3 CLC1SEL2bits.D3S3 // bit 3, shadows bit in CLC1SEL2bits
6760 #define LC1D3S4 CLC1SEL2bits.LC1D3S4 // bit 4, shadows bit in CLC1SEL2bits
6761 #define D3S4 CLC1SEL2bits.D3S4 // bit 4, shadows bit in CLC1SEL2bits
6763 #define LC1D4S0 CLC1SEL3bits.LC1D4S0 // bit 0, shadows bit in CLC1SEL3bits
6764 #define D4S0 CLC1SEL3bits.D4S0 // bit 0, shadows bit in CLC1SEL3bits
6765 #define LC1D4S1 CLC1SEL3bits.LC1D4S1 // bit 1, shadows bit in CLC1SEL3bits
6766 #define D4S1 CLC1SEL3bits.D4S1 // bit 1, shadows bit in CLC1SEL3bits
6767 #define LC1D4S2 CLC1SEL3bits.LC1D4S2 // bit 2, shadows bit in CLC1SEL3bits
6768 #define D4S2 CLC1SEL3bits.D4S2 // bit 2, shadows bit in CLC1SEL3bits
6769 #define LC1D4S3 CLC1SEL3bits.LC1D4S3 // bit 3, shadows bit in CLC1SEL3bits
6770 #define D4S3 CLC1SEL3bits.D4S3 // bit 3, shadows bit in CLC1SEL3bits
6771 #define LC1D4S4 CLC1SEL3bits.LC1D4S4 // bit 4, shadows bit in CLC1SEL3bits
6772 #define D4S4 CLC1SEL3bits.D4S4 // bit 4, shadows bit in CLC1SEL3bits
6774 #define MCLC1OUT CLCDATAbits.MCLC1OUT // bit 0
6775 #define MCLC2OUT CLCDATAbits.MCLC2OUT // bit 1
6776 #define MCLC3OUT CLCDATAbits.MCLC3OUT // bit 2
6778 #define C1SYNC CM1CON0bits.C1SYNC // bit 0
6779 #define C1HYS CM1CON0bits.C1HYS // bit 1
6780 #define C1SP CM1CON0bits.C1SP // bit 2
6781 #define C1ZLF CM1CON0bits.C1ZLF // bit 3
6782 #define C1POL CM1CON0bits.C1POL // bit 4
6783 #define C1OUT CM1CON0bits.C1OUT // bit 6
6784 #define C1ON CM1CON0bits.C1ON // bit 7
6786 #define C1NCH0 CM1CON1bits.C1NCH0 // bit 0
6787 #define C1NCH1 CM1CON1bits.C1NCH1 // bit 1
6788 #define C1NCH2 CM1CON1bits.C1NCH2 // bit 2
6789 #define C1PCH0 CM1CON1bits.C1PCH0 // bit 3
6790 #define C1PCH1 CM1CON1bits.C1PCH1 // bit 4
6791 #define C1PCH2 CM1CON1bits.C1PCH2 // bit 5
6792 #define C1INTN CM1CON1bits.C1INTN // bit 6
6793 #define C1INTP CM1CON1bits.C1INTP // bit 7
6795 #define C2SYNC CM2CON0bits.C2SYNC // bit 0
6796 #define C2HYS CM2CON0bits.C2HYS // bit 1
6797 #define C2SP CM2CON0bits.C2SP // bit 2
6798 #define C2ZLF CM2CON0bits.C2ZLF // bit 3
6799 #define C2POL CM2CON0bits.C2POL // bit 4
6800 #define C2OUT CM2CON0bits.C2OUT // bit 6
6801 #define C2ON CM2CON0bits.C2ON // bit 7
6803 #define C2NCH0 CM2CON1bits.C2NCH0 // bit 0
6804 #define C2NCH1 CM2CON1bits.C2NCH1 // bit 1
6805 #define C2NCH2 CM2CON1bits.C2NCH2 // bit 2
6806 #define C2PCH0 CM2CON1bits.C2PCH0 // bit 3
6807 #define C2PCH1 CM2CON1bits.C2PCH1 // bit 4
6808 #define C2PCH2 CM2CON1bits.C2PCH2 // bit 5
6809 #define C2INTN CM2CON1bits.C2INTN // bit 6
6810 #define C2INTP CM2CON1bits.C2INTP // bit 7
6812 #define MC1OUT CMOUTbits.MC1OUT // bit 0
6813 #define MC2OUT CMOUTbits.MC2OUT // bit 1
6815 #define G1ASDAC0 COG1ASD0bits.G1ASDAC0 // bit 2
6816 #define G1ASDAC1 COG1ASD0bits.G1ASDAC1 // bit 3
6817 #define G1ASDBD0 COG1ASD0bits.G1ASDBD0 // bit 4
6818 #define G1ASDBD1 COG1ASD0bits.G1ASDBD1 // bit 5
6819 #define G1ARSEN COG1ASD0bits.G1ARSEN // bit 6
6820 #define G1ASE COG1ASD0bits.G1ASE // bit 7
6822 #define G1AS0E COG1ASD1bits.G1AS0E // bit 0
6823 #define G1AS1E COG1ASD1bits.G1AS1E // bit 1
6824 #define G1AS2E COG1ASD1bits.G1AS2E // bit 2
6825 #define G1AS3E COG1ASD1bits.G1AS3E // bit 3
6827 #define G1BLKF0 COG1BLKFbits.G1BLKF0 // bit 0
6828 #define G1BLKF1 COG1BLKFbits.G1BLKF1 // bit 1
6829 #define G1BLKF2 COG1BLKFbits.G1BLKF2 // bit 2
6830 #define G1BLKF3 COG1BLKFbits.G1BLKF3 // bit 3
6831 #define G1BLKF4 COG1BLKFbits.G1BLKF4 // bit 4
6832 #define G1BLKF5 COG1BLKFbits.G1BLKF5 // bit 5
6834 #define G1BLKR0 COG1BLKRbits.G1BLKR0 // bit 0
6835 #define G1BLKR1 COG1BLKRbits.G1BLKR1 // bit 1
6836 #define G1BLKR2 COG1BLKRbits.G1BLKR2 // bit 2
6837 #define G1BLKR3 COG1BLKRbits.G1BLKR3 // bit 3
6838 #define G1BLKR4 COG1BLKRbits.G1BLKR4 // bit 4
6839 #define G1BLKR5 COG1BLKRbits.G1BLKR5 // bit 5
6841 #define G1MD0 COG1CON0bits.G1MD0 // bit 0
6842 #define G1MD1 COG1CON0bits.G1MD1 // bit 1
6843 #define G1MD2 COG1CON0bits.G1MD2 // bit 2
6844 #define G1CS0 COG1CON0bits.G1CS0 // bit 3
6845 #define G1CS1 COG1CON0bits.G1CS1 // bit 4
6846 #define G1LD COG1CON0bits.G1LD // bit 6
6847 #define G1EN COG1CON0bits.G1EN // bit 7
6849 #define G1POLA COG1CON1bits.G1POLA // bit 0
6850 #define G1POLB COG1CON1bits.G1POLB // bit 1
6851 #define G1POLC COG1CON1bits.G1POLC // bit 2
6852 #define G1POLD COG1CON1bits.G1POLD // bit 3
6853 #define G1FDBS COG1CON1bits.G1FDBS // bit 6
6854 #define G1RDBS COG1CON1bits.G1RDBS // bit 7
6856 #define G1DBF0 COG1DBFbits.G1DBF0 // bit 0
6857 #define G1DBF1 COG1DBFbits.G1DBF1 // bit 1
6858 #define G1DBF2 COG1DBFbits.G1DBF2 // bit 2
6859 #define G1DBF3 COG1DBFbits.G1DBF3 // bit 3
6860 #define G1DBF4 COG1DBFbits.G1DBF4 // bit 4
6861 #define G1DBF5 COG1DBFbits.G1DBF5 // bit 5
6863 #define G1DBR0 COG1DBRbits.G1DBR0 // bit 0
6864 #define G1DBR1 COG1DBRbits.G1DBR1 // bit 1
6865 #define G1DBR2 COG1DBRbits.G1DBR2 // bit 2
6866 #define G1DBR3 COG1DBRbits.G1DBR3 // bit 3
6867 #define G1DBR4 COG1DBRbits.G1DBR4 // bit 4
6868 #define G1DBR5 COG1DBRbits.G1DBR5 // bit 5
6870 #define G1FIS0 COG1FISbits.G1FIS0 // bit 0
6871 #define G1FIS1 COG1FISbits.G1FIS1 // bit 1
6872 #define G1FIS2 COG1FISbits.G1FIS2 // bit 2
6873 #define G1FIS3 COG1FISbits.G1FIS3 // bit 3
6874 #define G1FIS4 COG1FISbits.G1FIS4 // bit 4
6875 #define G1FIS5 COG1FISbits.G1FIS5 // bit 5
6876 #define G1FIS6 COG1FISbits.G1FIS6 // bit 6
6878 #define G1FSIM0 COG1FSIMbits.G1FSIM0 // bit 0
6879 #define G1FSIM1 COG1FSIMbits.G1FSIM1 // bit 1
6880 #define G1FSIM2 COG1FSIMbits.G1FSIM2 // bit 2
6881 #define G1FSIM3 COG1FSIMbits.G1FSIM3 // bit 3
6882 #define G1FSIM4 COG1FSIMbits.G1FSIM4 // bit 4
6883 #define G1FSIM5 COG1FSIMbits.G1FSIM5 // bit 5
6884 #define G1FSIM6 COG1FSIMbits.G1FSIM6 // bit 6
6886 #define G1PHF0 COG1PHFbits.G1PHF0 // bit 0
6887 #define G1PHF1 COG1PHFbits.G1PHF1 // bit 1
6888 #define G1PHF2 COG1PHFbits.G1PHF2 // bit 2
6889 #define G1PHF3 COG1PHFbits.G1PHF3 // bit 3
6890 #define G1PHF4 COG1PHFbits.G1PHF4 // bit 4
6891 #define G1PHF5 COG1PHFbits.G1PHF5 // bit 5
6893 #define G1PHR0 COG1PHRbits.G1PHR0 // bit 0
6894 #define G1PHR1 COG1PHRbits.G1PHR1 // bit 1
6895 #define G1PHR2 COG1PHRbits.G1PHR2 // bit 2
6896 #define G1PHR3 COG1PHRbits.G1PHR3 // bit 3
6897 #define G1PHR4 COG1PHRbits.G1PHR4 // bit 4
6898 #define G1PHR5 COG1PHRbits.G1PHR5 // bit 5
6900 #define G1RIS0 COG1RISbits.G1RIS0 // bit 0
6901 #define G1RIS1 COG1RISbits.G1RIS1 // bit 1
6902 #define G1RIS2 COG1RISbits.G1RIS2 // bit 2
6903 #define G1RIS3 COG1RISbits.G1RIS3 // bit 3
6904 #define G1RIS4 COG1RISbits.G1RIS4 // bit 4
6905 #define G1RIS5 COG1RISbits.G1RIS5 // bit 5
6906 #define G1RIS6 COG1RISbits.G1RIS6 // bit 6
6908 #define G1RSIM0 COG1RSIMbits.G1RSIM0 // bit 0
6909 #define G1RSIM1 COG1RSIMbits.G1RSIM1 // bit 1
6910 #define G1RSIM2 COG1RSIMbits.G1RSIM2 // bit 2
6911 #define G1RSIM3 COG1RSIMbits.G1RSIM3 // bit 3
6912 #define G1RSIM4 COG1RSIMbits.G1RSIM4 // bit 4
6913 #define G1RSIM5 COG1RSIMbits.G1RSIM5 // bit 5
6914 #define G1RSIM6 COG1RSIMbits.G1RSIM6 // bit 6
6916 #define G1STRA COG1STRbits.G1STRA // bit 0
6917 #define G1STRB COG1STRbits.G1STRB // bit 1
6918 #define G1STRC COG1STRbits.G1STRC // bit 2
6919 #define G1STRD COG1STRbits.G1STRD // bit 3
6920 #define G1SDATA COG1STRbits.G1SDATA // bit 4
6921 #define G1SDATB COG1STRbits.G1SDATB // bit 5
6922 #define G1SDATC COG1STRbits.G1SDATC // bit 6
6923 #define G1SDATD COG1STRbits.G1SDATD // bit 7
6925 #define DAC1NSS DAC1CON0bits.DAC1NSS // bit 0, shadows bit in DAC1CON0bits
6926 #define DACNSS DAC1CON0bits.DACNSS // bit 0, shadows bit in DAC1CON0bits
6927 #define DAC1PSS0 DAC1CON0bits.DAC1PSS0 // bit 2, shadows bit in DAC1CON0bits
6928 #define DACPSS0 DAC1CON0bits.DACPSS0 // bit 2, shadows bit in DAC1CON0bits
6929 #define DAC1PSS1 DAC1CON0bits.DAC1PSS1 // bit 3, shadows bit in DAC1CON0bits
6930 #define DACPSS1 DAC1CON0bits.DACPSS1 // bit 3, shadows bit in DAC1CON0bits
6931 #define DAC1OE2 DAC1CON0bits.DAC1OE2 // bit 4, shadows bit in DAC1CON0bits
6932 #define DACOE0 DAC1CON0bits.DACOE0 // bit 4, shadows bit in DAC1CON0bits
6933 #define DAC1OE1 DAC1CON0bits.DAC1OE1 // bit 5, shadows bit in DAC1CON0bits
6934 #define DACOE1 DAC1CON0bits.DACOE1 // bit 5, shadows bit in DAC1CON0bits
6935 #define DAC1EN DAC1CON0bits.DAC1EN // bit 7, shadows bit in DAC1CON0bits
6936 #define DACEN DAC1CON0bits.DACEN // bit 7, shadows bit in DAC1CON0bits
6938 #define DAC1R0 DAC1CON1bits.DAC1R0 // bit 0, shadows bit in DAC1CON1bits
6939 #define DACR0 DAC1CON1bits.DACR0 // bit 0, shadows bit in DAC1CON1bits
6940 #define DAC1R1 DAC1CON1bits.DAC1R1 // bit 1, shadows bit in DAC1CON1bits
6941 #define DACR1 DAC1CON1bits.DACR1 // bit 1, shadows bit in DAC1CON1bits
6942 #define DAC1R2 DAC1CON1bits.DAC1R2 // bit 2, shadows bit in DAC1CON1bits
6943 #define DACR2 DAC1CON1bits.DACR2 // bit 2, shadows bit in DAC1CON1bits
6944 #define DAC1R3 DAC1CON1bits.DAC1R3 // bit 3, shadows bit in DAC1CON1bits
6945 #define DACR3 DAC1CON1bits.DACR3 // bit 3, shadows bit in DAC1CON1bits
6946 #define DAC1R4 DAC1CON1bits.DAC1R4 // bit 4, shadows bit in DAC1CON1bits
6947 #define DACR4 DAC1CON1bits.DACR4 // bit 4, shadows bit in DAC1CON1bits
6948 #define DAC1R5 DAC1CON1bits.DAC1R5 // bit 5, shadows bit in DAC1CON1bits
6949 #define DACR5 DAC1CON1bits.DACR5 // bit 5, shadows bit in DAC1CON1bits
6950 #define DAC1R6 DAC1CON1bits.DAC1R6 // bit 6, shadows bit in DAC1CON1bits
6951 #define DACR6 DAC1CON1bits.DACR6 // bit 6, shadows bit in DAC1CON1bits
6952 #define DAC1R7 DAC1CON1bits.DAC1R7 // bit 7, shadows bit in DAC1CON1bits
6953 #define DACR7 DAC1CON1bits.DACR7 // bit 7, shadows bit in DAC1CON1bits
6955 #define ADFVR0 FVRCONbits.ADFVR0 // bit 0
6956 #define ADFVR1 FVRCONbits.ADFVR1 // bit 1
6957 #define CDAFVR0 FVRCONbits.CDAFVR0 // bit 2
6958 #define CDAFVR1 FVRCONbits.CDAFVR1 // bit 3
6959 #define TSRNG FVRCONbits.TSRNG // bit 4
6960 #define TSEN FVRCONbits.TSEN // bit 5
6961 #define FVRRDY FVRCONbits.FVRRDY // bit 6
6962 #define FVREN FVRCONbits.FVREN // bit 7
6964 #define BKA8 ICDBK0Hbits.BKA8 // bit 0
6965 #define BKA9 ICDBK0Hbits.BKA9 // bit 1
6966 #define BKA10 ICDBK0Hbits.BKA10 // bit 2
6967 #define BKA11 ICDBK0Hbits.BKA11 // bit 3
6968 #define BKA12 ICDBK0Hbits.BKA12 // bit 4
6969 #define BKA13 ICDBK0Hbits.BKA13 // bit 5
6970 #define BKA14 ICDBK0Hbits.BKA14 // bit 6
6972 #define INLVLA0 INLVLAbits.INLVLA0 // bit 0
6973 #define INLVLA1 INLVLAbits.INLVLA1 // bit 1
6974 #define INLVLA2 INLVLAbits.INLVLA2 // bit 2
6975 #define INLVLA3 INLVLAbits.INLVLA3 // bit 3
6976 #define INLVLA4 INLVLAbits.INLVLA4 // bit 4
6977 #define INLVLA5 INLVLAbits.INLVLA5 // bit 5
6979 #define INLVLC0 INLVLCbits.INLVLC0 // bit 0
6980 #define INLVLC1 INLVLCbits.INLVLC1 // bit 1
6981 #define INLVLC2 INLVLCbits.INLVLC2 // bit 2
6982 #define INLVLC3 INLVLCbits.INLVLC3 // bit 3
6983 #define INLVLC4 INLVLCbits.INLVLC4 // bit 4
6984 #define INLVLC5 INLVLCbits.INLVLC5 // bit 5
6986 #define IOCIF INTCONbits.IOCIF // bit 0
6987 #define INTF INTCONbits.INTF // bit 1
6988 #define TMR0IF INTCONbits.TMR0IF // bit 2, shadows bit in INTCONbits
6989 #define T0IF INTCONbits.T0IF // bit 2, shadows bit in INTCONbits
6990 #define IOCIE INTCONbits.IOCIE // bit 3
6991 #define INTE INTCONbits.INTE // bit 4
6992 #define TMR0IE INTCONbits.TMR0IE // bit 5, shadows bit in INTCONbits
6993 #define T0IE INTCONbits.T0IE // bit 5, shadows bit in INTCONbits
6994 #define PEIE INTCONbits.PEIE // bit 6
6995 #define GIE INTCONbits.GIE // bit 7
6997 #define IOCAF0 IOCAFbits.IOCAF0 // bit 0
6998 #define IOCAF1 IOCAFbits.IOCAF1 // bit 1
6999 #define IOCAF2 IOCAFbits.IOCAF2 // bit 2
7000 #define IOCAF3 IOCAFbits.IOCAF3 // bit 3
7001 #define IOCAF4 IOCAFbits.IOCAF4 // bit 4
7002 #define IOCAF5 IOCAFbits.IOCAF5 // bit 5
7004 #define IOCAN0 IOCANbits.IOCAN0 // bit 0
7005 #define IOCAN1 IOCANbits.IOCAN1 // bit 1
7006 #define IOCAN2 IOCANbits.IOCAN2 // bit 2
7007 #define IOCAN3 IOCANbits.IOCAN3 // bit 3
7008 #define IOCAN4 IOCANbits.IOCAN4 // bit 4
7009 #define IOCAN5 IOCANbits.IOCAN5 // bit 5
7011 #define IOCAP0 IOCAPbits.IOCAP0 // bit 0
7012 #define IOCAP1 IOCAPbits.IOCAP1 // bit 1
7013 #define IOCAP2 IOCAPbits.IOCAP2 // bit 2
7014 #define IOCAP3 IOCAPbits.IOCAP3 // bit 3
7015 #define IOCAP4 IOCAPbits.IOCAP4 // bit 4
7016 #define IOCAP5 IOCAPbits.IOCAP5 // bit 5
7018 #define IOCCF0 IOCCFbits.IOCCF0 // bit 0
7019 #define IOCCF1 IOCCFbits.IOCCF1 // bit 1
7020 #define IOCCF2 IOCCFbits.IOCCF2 // bit 2
7021 #define IOCCF3 IOCCFbits.IOCCF3 // bit 3
7022 #define IOCCF4 IOCCFbits.IOCCF4 // bit 4
7023 #define IOCCF5 IOCCFbits.IOCCF5 // bit 5
7025 #define IOCCN0 IOCCNbits.IOCCN0 // bit 0
7026 #define IOCCN1 IOCCNbits.IOCCN1 // bit 1
7027 #define IOCCN2 IOCCNbits.IOCCN2 // bit 2
7028 #define IOCCN3 IOCCNbits.IOCCN3 // bit 3
7029 #define IOCCN4 IOCCNbits.IOCCN4 // bit 4
7030 #define IOCCN5 IOCCNbits.IOCCN5 // bit 5
7032 #define IOCCP0 IOCCPbits.IOCCP0 // bit 0
7033 #define IOCCP1 IOCCPbits.IOCCP1 // bit 1
7034 #define IOCCP2 IOCCPbits.IOCCP2 // bit 2
7035 #define IOCCP3 IOCCPbits.IOCCP3 // bit 3
7036 #define IOCCP4 IOCCPbits.IOCCP4 // bit 4
7037 #define IOCCP5 IOCCPbits.IOCCP5 // bit 5
7039 #define LATA0 LATAbits.LATA0 // bit 0
7040 #define LATA1 LATAbits.LATA1 // bit 1
7041 #define LATA2 LATAbits.LATA2 // bit 2
7042 #define LATA4 LATAbits.LATA4 // bit 4
7043 #define LATA5 LATAbits.LATA5 // bit 5
7045 #define LATC0 LATCbits.LATC0 // bit 0
7046 #define LATC1 LATCbits.LATC1 // bit 1
7047 #define LATC2 LATCbits.LATC2 // bit 2
7048 #define LATC3 LATCbits.LATC3 // bit 3
7049 #define LATC4 LATCbits.LATC4 // bit 4
7050 #define LATC5 LATCbits.LATC5 // bit 5
7052 #define ODA0 ODCONAbits.ODA0 // bit 0
7053 #define ODA1 ODCONAbits.ODA1 // bit 1
7054 #define ODA2 ODCONAbits.ODA2 // bit 2
7055 #define ODA4 ODCONAbits.ODA4 // bit 4
7056 #define ODA5 ODCONAbits.ODA5 // bit 5
7058 #define ODC0 ODCONCbits.ODC0 // bit 0
7059 #define ODC1 ODCONCbits.ODC1 // bit 1
7060 #define ODC2 ODCONCbits.ODC2 // bit 2
7061 #define ODC3 ODCONCbits.ODC3 // bit 3
7062 #define ODC4 ODCONCbits.ODC4 // bit 4
7063 #define ODC5 ODCONCbits.ODC5 // bit 5
7065 #define OPA1PCH0 OPA1CONbits.OPA1PCH0 // bit 0
7066 #define OPA1PCH1 OPA1CONbits.OPA1PCH1 // bit 1
7067 #define OPA1UG OPA1CONbits.OPA1UG // bit 4
7068 #define OPA1SP OPA1CONbits.OPA1SP // bit 6
7069 #define OPA1EN OPA1CONbits.OPA1EN // bit 7
7071 #define OPA2PCH0 OPA2CONbits.OPA2PCH0 // bit 0
7072 #define OPA2PCH1 OPA2CONbits.OPA2PCH1 // bit 1
7073 #define OPA2UG OPA2CONbits.OPA2UG // bit 4
7074 #define OPA2SP OPA2CONbits.OPA2SP // bit 6
7075 #define OPA2EN OPA2CONbits.OPA2EN // bit 7
7077 #define PS0 OPTION_REGbits.PS0 // bit 0
7078 #define PS1 OPTION_REGbits.PS1 // bit 1
7079 #define PS2 OPTION_REGbits.PS2 // bit 2
7080 #define PSA OPTION_REGbits.PSA // bit 3
7081 #define TMR0SE OPTION_REGbits.TMR0SE // bit 4, shadows bit in OPTION_REGbits
7082 #define T0SE OPTION_REGbits.T0SE // bit 4, shadows bit in OPTION_REGbits
7083 #define TMR0CS OPTION_REGbits.TMR0CS // bit 5, shadows bit in OPTION_REGbits
7084 #define T0CS OPTION_REGbits.T0CS // bit 5, shadows bit in OPTION_REGbits
7085 #define INTEDG OPTION_REGbits.INTEDG // bit 6
7086 #define NOT_WPUEN OPTION_REGbits.NOT_WPUEN // bit 7
7088 #define SCS0 OSCCONbits.SCS0 // bit 0
7089 #define SCS1 OSCCONbits.SCS1 // bit 1
7090 #define IRCF0 OSCCONbits.IRCF0 // bit 3
7091 #define IRCF1 OSCCONbits.IRCF1 // bit 4
7092 #define IRCF2 OSCCONbits.IRCF2 // bit 5
7093 #define IRCF3 OSCCONbits.IRCF3 // bit 6
7094 #define SPLLEN OSCCONbits.SPLLEN // bit 7
7096 #define HFIOFS OSCSTATbits.HFIOFS // bit 0
7097 #define LFIOFR OSCSTATbits.LFIOFR // bit 1
7098 #define MFIOFR OSCSTATbits.MFIOFR // bit 2
7099 #define HFIOFL OSCSTATbits.HFIOFL // bit 3
7100 #define HFIOFR OSCSTATbits.HFIOFR // bit 4
7101 #define OSTS OSCSTATbits.OSTS // bit 5
7102 #define PLLR OSCSTATbits.PLLR // bit 6
7103 #define SOSCR OSCSTATbits.SOSCR // bit 7
7105 #define TUN0 OSCTUNEbits.TUN0 // bit 0
7106 #define TUN1 OSCTUNEbits.TUN1 // bit 1
7107 #define TUN2 OSCTUNEbits.TUN2 // bit 2
7108 #define TUN3 OSCTUNEbits.TUN3 // bit 3
7109 #define TUN4 OSCTUNEbits.TUN4 // bit 4
7110 #define TUN5 OSCTUNEbits.TUN5 // bit 5
7112 #define NOT_BOR PCONbits.NOT_BOR // bit 0
7113 #define NOT_POR PCONbits.NOT_POR // bit 1
7114 #define NOT_RI PCONbits.NOT_RI // bit 2
7115 #define NOT_RMCLR PCONbits.NOT_RMCLR // bit 3
7116 #define NOT_RWDT PCONbits.NOT_RWDT // bit 4
7117 #define STKUNF PCONbits.STKUNF // bit 6
7118 #define STKOVF PCONbits.STKOVF // bit 7
7120 #define TMR1IE PIE1bits.TMR1IE // bit 0
7121 #define TMR2IE PIE1bits.TMR2IE // bit 1
7122 #define CCP1IE PIE1bits.CCP1IE // bit 2, shadows bit in PIE1bits
7123 #define CCPIE PIE1bits.CCPIE // bit 2, shadows bit in PIE1bits
7124 #define SSP1IE PIE1bits.SSP1IE // bit 3
7125 #define TXIE PIE1bits.TXIE // bit 4
7126 #define RCIE PIE1bits.RCIE // bit 5
7127 #define ADIE PIE1bits.ADIE // bit 6
7128 #define TMR1GIE PIE1bits.TMR1GIE // bit 7
7130 #define CCP2IE PIE2bits.CCP2IE // bit 0
7131 #define TMR4IE PIE2bits.TMR4IE // bit 1
7132 #define TMR6IE PIE2bits.TMR6IE // bit 2
7133 #define BCL1IE PIE2bits.BCL1IE // bit 3
7134 #define C1IE PIE2bits.C1IE // bit 5
7135 #define C2IE PIE2bits.C2IE // bit 6
7136 #define OSFIE PIE2bits.OSFIE // bit 7
7138 #define CLC1IE PIE3bits.CLC1IE // bit 0
7139 #define CLC2IE PIE3bits.CLC2IE // bit 1
7140 #define CLC3IE PIE3bits.CLC3IE // bit 2
7141 #define ZCDIE PIE3bits.ZCDIE // bit 4
7142 #define COGIE PIE3bits.COGIE // bit 5
7144 #define TMR1IF PIR1bits.TMR1IF // bit 0
7145 #define TMR2IF PIR1bits.TMR2IF // bit 1
7146 #define CCP1IF PIR1bits.CCP1IF // bit 2, shadows bit in PIR1bits
7147 #define CCPIF PIR1bits.CCPIF // bit 2, shadows bit in PIR1bits
7148 #define SSP1IF PIR1bits.SSP1IF // bit 3
7149 #define TXIF PIR1bits.TXIF // bit 4
7150 #define RCIF PIR1bits.RCIF // bit 5
7151 #define ADIF PIR1bits.ADIF // bit 6
7152 #define TMR1GIF PIR1bits.TMR1GIF // bit 7
7154 #define CCP2IF PIR2bits.CCP2IF // bit 0
7155 #define TMR4IF PIR2bits.TMR4IF // bit 1
7156 #define TMR6IF PIR2bits.TMR6IF // bit 2
7157 #define BCL1IF PIR2bits.BCL1IF // bit 3
7158 #define C1IF PIR2bits.C1IF // bit 5
7159 #define C2IF PIR2bits.C2IF // bit 6
7160 #define OSFIF PIR2bits.OSFIF // bit 7
7162 #define CLC1IF PIR3bits.CLC1IF // bit 0
7163 #define CLC2IF PIR3bits.CLC2IF // bit 1
7164 #define CLC3IF PIR3bits.CLC3IF // bit 2
7165 #define ZCDIF PIR3bits.ZCDIF // bit 4
7166 #define COGIF PIR3bits.COGIF // bit 5
7168 #define RD PMCON1bits.RD // bit 0
7169 #define WR PMCON1bits.WR // bit 1
7170 #define WREN PMCON1bits.WREN // bit 2
7171 #define WRERR PMCON1bits.WRERR // bit 3
7172 #define FREE PMCON1bits.FREE // bit 4
7173 #define LWLO PMCON1bits.LWLO // bit 5
7174 #define CFGS PMCON1bits.CFGS // bit 6
7176 #define RA0 PORTAbits.RA0 // bit 0
7177 #define RA1 PORTAbits.RA1 // bit 1
7178 #define RA2 PORTAbits.RA2 // bit 2
7179 #define RA3 PORTAbits.RA3 // bit 3
7180 #define RA4 PORTAbits.RA4 // bit 4
7181 #define RA5 PORTAbits.RA5 // bit 5
7183 #define RC0 PORTCbits.RC0 // bit 0
7184 #define RC1 PORTCbits.RC1 // bit 1
7185 #define RC2 PORTCbits.RC2 // bit 2
7186 #define RC3 PORTCbits.RC3 // bit 3
7187 #define RC4 PORTCbits.RC4 // bit 4
7188 #define RC5 PORTCbits.RC5 // bit 5
7190 #define PPSLOCKED PPSLOCKbits.PPSLOCKED // bit 0
7192 #define PWM3POL PWM3CONbits.PWM3POL // bit 4
7193 #define PWM3OUT PWM3CONbits.PWM3OUT // bit 5
7194 #define PWM3EN PWM3CONbits.PWM3EN // bit 7
7196 #define PWM3DCH0 PWM3DCHbits.PWM3DCH0 // bit 0
7197 #define PWM3DCH1 PWM3DCHbits.PWM3DCH1 // bit 1
7198 #define PWM3DCH2 PWM3DCHbits.PWM3DCH2 // bit 2
7199 #define PWM3DCH3 PWM3DCHbits.PWM3DCH3 // bit 3
7200 #define PWM3DCH4 PWM3DCHbits.PWM3DCH4 // bit 4
7201 #define PWM3DCH5 PWM3DCHbits.PWM3DCH5 // bit 5
7202 #define PWM3DCH6 PWM3DCHbits.PWM3DCH6 // bit 6
7203 #define PWM3DCH7 PWM3DCHbits.PWM3DCH7 // bit 7
7205 #define PWM3DCL0 PWM3DCLbits.PWM3DCL0 // bit 6
7206 #define PWM3DCL1 PWM3DCLbits.PWM3DCL1 // bit 7
7208 #define PWM4POL PWM4CONbits.PWM4POL // bit 4
7209 #define PWM4OUT PWM4CONbits.PWM4OUT // bit 5
7210 #define PWM4EN PWM4CONbits.PWM4EN // bit 7
7212 #define PWM4DCH0 PWM4DCHbits.PWM4DCH0 // bit 0
7213 #define PWM4DCH1 PWM4DCHbits.PWM4DCH1 // bit 1
7214 #define PWM4DCH2 PWM4DCHbits.PWM4DCH2 // bit 2
7215 #define PWM4DCH3 PWM4DCHbits.PWM4DCH3 // bit 3
7216 #define PWM4DCH4 PWM4DCHbits.PWM4DCH4 // bit 4
7217 #define PWM4DCH5 PWM4DCHbits.PWM4DCH5 // bit 5
7218 #define PWM4DCH6 PWM4DCHbits.PWM4DCH6 // bit 6
7219 #define PWM4DCH7 PWM4DCHbits.PWM4DCH7 // bit 7
7221 #define PWM4DCL0 PWM4DCLbits.PWM4DCL0 // bit 6
7222 #define PWM4DCL1 PWM4DCLbits.PWM4DCL1 // bit 7
7224 #define RX9D RC1STAbits.RX9D // bit 0
7225 #define OERR RC1STAbits.OERR // bit 1
7226 #define FERR RC1STAbits.FERR // bit 2
7227 #define ADDEN RC1STAbits.ADDEN // bit 3
7228 #define CREN RC1STAbits.CREN // bit 4
7229 #define SREN RC1STAbits.SREN // bit 5
7230 #define RX9 RC1STAbits.RX9 // bit 6
7231 #define SPEN RC1STAbits.SPEN // bit 7
7233 #define SLRA0 SLRCONAbits.SLRA0 // bit 0
7234 #define SLRA1 SLRCONAbits.SLRA1 // bit 1
7235 #define SLRA2 SLRCONAbits.SLRA2 // bit 2
7236 #define SLRA4 SLRCONAbits.SLRA4 // bit 4
7237 #define SLRA5 SLRCONAbits.SLRA5 // bit 5
7239 #define SLRC0 SLRCONCbits.SLRC0 // bit 0
7240 #define SLRC1 SLRCONCbits.SLRC1 // bit 1
7241 #define SLRC2 SLRCONCbits.SLRC2 // bit 2
7242 #define SLRC3 SLRCONCbits.SLRC3 // bit 3
7243 #define SLRC4 SLRCONCbits.SLRC4 // bit 4
7244 #define SLRC5 SLRCONCbits.SLRC5 // bit 5
7246 #define SSP1ADD0 SSP1ADDbits.SSP1ADD0 // bit 0, shadows bit in SSP1ADDbits
7247 #define ADD0 SSP1ADDbits.ADD0 // bit 0, shadows bit in SSP1ADDbits
7248 #define SSP1ADD1 SSP1ADDbits.SSP1ADD1 // bit 1, shadows bit in SSP1ADDbits
7249 #define ADD1 SSP1ADDbits.ADD1 // bit 1, shadows bit in SSP1ADDbits
7250 #define SSP1ADD2 SSP1ADDbits.SSP1ADD2 // bit 2, shadows bit in SSP1ADDbits
7251 #define ADD2 SSP1ADDbits.ADD2 // bit 2, shadows bit in SSP1ADDbits
7252 #define SSP1ADD3 SSP1ADDbits.SSP1ADD3 // bit 3, shadows bit in SSP1ADDbits
7253 #define ADD3 SSP1ADDbits.ADD3 // bit 3, shadows bit in SSP1ADDbits
7254 #define SSP1ADD4 SSP1ADDbits.SSP1ADD4 // bit 4, shadows bit in SSP1ADDbits
7255 #define ADD4 SSP1ADDbits.ADD4 // bit 4, shadows bit in SSP1ADDbits
7256 #define SSP1ADD5 SSP1ADDbits.SSP1ADD5 // bit 5, shadows bit in SSP1ADDbits
7257 #define ADD5 SSP1ADDbits.ADD5 // bit 5, shadows bit in SSP1ADDbits
7258 #define SSP1ADD6 SSP1ADDbits.SSP1ADD6 // bit 6, shadows bit in SSP1ADDbits
7259 #define ADD6 SSP1ADDbits.ADD6 // bit 6, shadows bit in SSP1ADDbits
7260 #define SSP1ADD7 SSP1ADDbits.SSP1ADD7 // bit 7, shadows bit in SSP1ADDbits
7261 #define ADD7 SSP1ADDbits.ADD7 // bit 7, shadows bit in SSP1ADDbits
7263 #define SSP1BUF0 SSP1BUFbits.SSP1BUF0 // bit 0, shadows bit in SSP1BUFbits
7264 #define BUF0 SSP1BUFbits.BUF0 // bit 0, shadows bit in SSP1BUFbits
7265 #define SSP1BUF1 SSP1BUFbits.SSP1BUF1 // bit 1, shadows bit in SSP1BUFbits
7266 #define BUF1 SSP1BUFbits.BUF1 // bit 1, shadows bit in SSP1BUFbits
7267 #define SSP1BUF2 SSP1BUFbits.SSP1BUF2 // bit 2, shadows bit in SSP1BUFbits
7268 #define BUF2 SSP1BUFbits.BUF2 // bit 2, shadows bit in SSP1BUFbits
7269 #define SSP1BUF3 SSP1BUFbits.SSP1BUF3 // bit 3, shadows bit in SSP1BUFbits
7270 #define BUF3 SSP1BUFbits.BUF3 // bit 3, shadows bit in SSP1BUFbits
7271 #define SSP1BUF4 SSP1BUFbits.SSP1BUF4 // bit 4, shadows bit in SSP1BUFbits
7272 #define BUF4 SSP1BUFbits.BUF4 // bit 4, shadows bit in SSP1BUFbits
7273 #define SSP1BUF5 SSP1BUFbits.SSP1BUF5 // bit 5, shadows bit in SSP1BUFbits
7274 #define BUF5 SSP1BUFbits.BUF5 // bit 5, shadows bit in SSP1BUFbits
7275 #define SSP1BUF6 SSP1BUFbits.SSP1BUF6 // bit 6, shadows bit in SSP1BUFbits
7276 #define BUF6 SSP1BUFbits.BUF6 // bit 6, shadows bit in SSP1BUFbits
7277 #define SSP1BUF7 SSP1BUFbits.SSP1BUF7 // bit 7, shadows bit in SSP1BUFbits
7278 #define BUF7 SSP1BUFbits.BUF7 // bit 7, shadows bit in SSP1BUFbits
7280 #define SSPM0 SSP1CONbits.SSPM0 // bit 0
7281 #define SSPM1 SSP1CONbits.SSPM1 // bit 1
7282 #define SSPM2 SSP1CONbits.SSPM2 // bit 2
7283 #define SSPM3 SSP1CONbits.SSPM3 // bit 3
7284 #define CKP SSP1CONbits.CKP // bit 4
7285 #define SSPEN SSP1CONbits.SSPEN // bit 5
7286 #define SSPOV SSP1CONbits.SSPOV // bit 6
7287 #define WCOL SSP1CONbits.WCOL // bit 7
7289 #define SEN SSP1CON2bits.SEN // bit 0
7290 #define RSEN SSP1CON2bits.RSEN // bit 1
7291 #define PEN SSP1CON2bits.PEN // bit 2
7292 #define RCEN SSP1CON2bits.RCEN // bit 3
7293 #define ACKEN SSP1CON2bits.ACKEN // bit 4
7294 #define ACKDT SSP1CON2bits.ACKDT // bit 5
7295 #define ACKSTAT SSP1CON2bits.ACKSTAT // bit 6
7296 #define GCEN SSP1CON2bits.GCEN // bit 7
7298 #define DHEN SSP1CON3bits.DHEN // bit 0
7299 #define AHEN SSP1CON3bits.AHEN // bit 1
7300 #define SBCDE SSP1CON3bits.SBCDE // bit 2
7301 #define SDAHT SSP1CON3bits.SDAHT // bit 3
7302 #define BOEN SSP1CON3bits.BOEN // bit 4
7303 #define SCIE SSP1CON3bits.SCIE // bit 5
7304 #define PCIE SSP1CON3bits.PCIE // bit 6
7305 #define ACKTIM SSP1CON3bits.ACKTIM // bit 7
7307 #define SSP1MSK0 SSP1MSKbits.SSP1MSK0 // bit 0, shadows bit in SSP1MSKbits
7308 #define MSK0 SSP1MSKbits.MSK0 // bit 0, shadows bit in SSP1MSKbits
7309 #define SSP1MSK1 SSP1MSKbits.SSP1MSK1 // bit 1, shadows bit in SSP1MSKbits
7310 #define MSK1 SSP1MSKbits.MSK1 // bit 1, shadows bit in SSP1MSKbits
7311 #define SSP1MSK2 SSP1MSKbits.SSP1MSK2 // bit 2, shadows bit in SSP1MSKbits
7312 #define MSK2 SSP1MSKbits.MSK2 // bit 2, shadows bit in SSP1MSKbits
7313 #define SSP1MSK3 SSP1MSKbits.SSP1MSK3 // bit 3, shadows bit in SSP1MSKbits
7314 #define MSK3 SSP1MSKbits.MSK3 // bit 3, shadows bit in SSP1MSKbits
7315 #define SSP1MSK4 SSP1MSKbits.SSP1MSK4 // bit 4, shadows bit in SSP1MSKbits
7316 #define MSK4 SSP1MSKbits.MSK4 // bit 4, shadows bit in SSP1MSKbits
7317 #define SSP1MSK5 SSP1MSKbits.SSP1MSK5 // bit 5, shadows bit in SSP1MSKbits
7318 #define MSK5 SSP1MSKbits.MSK5 // bit 5, shadows bit in SSP1MSKbits
7319 #define SSP1MSK6 SSP1MSKbits.SSP1MSK6 // bit 6, shadows bit in SSP1MSKbits
7320 #define MSK6 SSP1MSKbits.MSK6 // bit 6, shadows bit in SSP1MSKbits
7321 #define SSP1MSK7 SSP1MSKbits.SSP1MSK7 // bit 7, shadows bit in SSP1MSKbits
7322 #define MSK7 SSP1MSKbits.MSK7 // bit 7, shadows bit in SSP1MSKbits
7324 #define BF SSP1STATbits.BF // bit 0
7325 #define UA SSP1STATbits.UA // bit 1
7326 #define R_NOT_W SSP1STATbits.R_NOT_W // bit 2
7327 #define S SSP1STATbits.S // bit 3
7328 #define P SSP1STATbits.P // bit 4
7329 #define D_NOT_A SSP1STATbits.D_NOT_A // bit 5
7330 #define CKE SSP1STATbits.CKE // bit 6
7331 #define SMP SSP1STATbits.SMP // bit 7
7333 #define C STATUSbits.C // bit 0
7334 #define DC STATUSbits.DC // bit 1
7335 #define Z STATUSbits.Z // bit 2
7336 #define NOT_PD STATUSbits.NOT_PD // bit 3
7337 #define NOT_TO STATUSbits.NOT_TO // bit 4
7339 #define C_SHAD STATUS_SHADbits.C_SHAD // bit 0
7340 #define DC_SHAD STATUS_SHADbits.DC_SHAD // bit 1
7341 #define Z_SHAD STATUS_SHADbits.Z_SHAD // bit 2
7343 #define TMR1ON T1CONbits.TMR1ON // bit 0
7344 #define NOT_T1SYNC T1CONbits.NOT_T1SYNC // bit 2
7345 #define T1OSCEN T1CONbits.T1OSCEN // bit 3
7346 #define T1CKPS0 T1CONbits.T1CKPS0 // bit 4
7347 #define T1CKPS1 T1CONbits.T1CKPS1 // bit 5
7348 #define TMR1CS0 T1CONbits.TMR1CS0 // bit 6
7349 #define TMR1CS1 T1CONbits.TMR1CS1 // bit 7
7351 #define T1GSS0 T1GCONbits.T1GSS0 // bit 0
7352 #define T1GSS1 T1GCONbits.T1GSS1 // bit 1
7353 #define T1GVAL T1GCONbits.T1GVAL // bit 2
7354 #define T1GGO_NOT_DONE T1GCONbits.T1GGO_NOT_DONE // bit 3
7355 #define T1GSPM T1GCONbits.T1GSPM // bit 4
7356 #define T1GTM T1GCONbits.T1GTM // bit 5
7357 #define T1GPOL T1GCONbits.T1GPOL // bit 6
7358 #define TMR1GE T1GCONbits.TMR1GE // bit 7
7360 #define T2CKPS0 T2CONbits.T2CKPS0 // bit 0
7361 #define T2CKPS1 T2CONbits.T2CKPS1 // bit 1
7362 #define TMR2ON T2CONbits.TMR2ON // bit 2
7363 #define T2OUTPS0 T2CONbits.T2OUTPS0 // bit 3
7364 #define T2OUTPS1 T2CONbits.T2OUTPS1 // bit 4
7365 #define T2OUTPS2 T2CONbits.T2OUTPS2 // bit 5
7366 #define T2OUTPS3 T2CONbits.T2OUTPS3 // bit 6
7368 #define T4CKPS0 T4CONbits.T4CKPS0 // bit 0
7369 #define T4CKPS1 T4CONbits.T4CKPS1 // bit 1
7370 #define TMR4ON T4CONbits.TMR4ON // bit 2
7371 #define T4OUTPS0 T4CONbits.T4OUTPS0 // bit 3
7372 #define T4OUTPS1 T4CONbits.T4OUTPS1 // bit 4
7373 #define T4OUTPS2 T4CONbits.T4OUTPS2 // bit 5
7374 #define T4OUTPS3 T4CONbits.T4OUTPS3 // bit 6
7376 #define T6CKPS0 T6CONbits.T6CKPS0 // bit 0
7377 #define T6CKPS1 T6CONbits.T6CKPS1 // bit 1
7378 #define TMR6ON T6CONbits.TMR6ON // bit 2
7379 #define T6OUTPS0 T6CONbits.T6OUTPS0 // bit 3
7380 #define T6OUTPS1 T6CONbits.T6OUTPS1 // bit 4
7381 #define T6OUTPS2 T6CONbits.T6OUTPS2 // bit 5
7382 #define T6OUTPS3 T6CONbits.T6OUTPS3 // bit 6
7384 #define TRISA0 TRISAbits.TRISA0 // bit 0
7385 #define TRISA1 TRISAbits.TRISA1 // bit 1
7386 #define TRISA2 TRISAbits.TRISA2 // bit 2
7387 #define TRISA4 TRISAbits.TRISA4 // bit 4
7388 #define TRISA5 TRISAbits.TRISA5 // bit 5
7390 #define TRISC0 TRISCbits.TRISC0 // bit 0
7391 #define TRISC1 TRISCbits.TRISC1 // bit 1
7392 #define TRISC2 TRISCbits.TRISC2 // bit 2
7393 #define TRISC3 TRISCbits.TRISC3 // bit 3
7394 #define TRISC4 TRISCbits.TRISC4 // bit 4
7395 #define TRISC5 TRISCbits.TRISC5 // bit 5
7397 #define TX9D TX1STAbits.TX9D // bit 0
7398 #define TRMT TX1STAbits.TRMT // bit 1
7399 #define BRGH TX1STAbits.BRGH // bit 2
7400 #define SENDB TX1STAbits.SENDB // bit 3
7401 #define SYNC TX1STAbits.SYNC // bit 4
7402 #define TXEN TX1STAbits.TXEN // bit 5
7403 #define TX9 TX1STAbits.TX9 // bit 6
7404 #define CSRC TX1STAbits.CSRC // bit 7
7406 #define Reserved VREGCONbits.Reserved // bit 0
7407 #define VREGPM VREGCONbits.VREGPM // bit 1
7409 #define SWDTEN WDTCONbits.SWDTEN // bit 0
7410 #define WDTPS0 WDTCONbits.WDTPS0 // bit 1
7411 #define WDTPS1 WDTCONbits.WDTPS1 // bit 2
7412 #define WDTPS2 WDTCONbits.WDTPS2 // bit 3
7413 #define WDTPS3 WDTCONbits.WDTPS3 // bit 4
7414 #define WDTPS4 WDTCONbits.WDTPS4 // bit 5
7416 #define WPUA0 WPUAbits.WPUA0 // bit 0
7417 #define WPUA1 WPUAbits.WPUA1 // bit 1
7418 #define WPUA2 WPUAbits.WPUA2 // bit 2
7419 #define WPUA3 WPUAbits.WPUA3 // bit 3
7420 #define WPUA4 WPUAbits.WPUA4 // bit 4
7421 #define WPUA5 WPUAbits.WPUA5 // bit 5
7423 #define WPUC0 WPUCbits.WPUC0 // bit 0
7424 #define WPUC1 WPUCbits.WPUC1 // bit 1
7425 #define WPUC2 WPUCbits.WPUC2 // bit 2
7426 #define WPUC3 WPUCbits.WPUC3 // bit 3
7427 #define WPUC4 WPUCbits.WPUC4 // bit 4
7428 #define WPUC5 WPUCbits.WPUC5 // bit 5
7430 #define ZCD1INTN ZCD1CONbits.ZCD1INTN // bit 0
7431 #define ZCD1INTP ZCD1CONbits.ZCD1INTP // bit 1
7432 #define ZCD1POL ZCD1CONbits.ZCD1POL // bit 4
7433 #define ZCD1OUT ZCD1CONbits.ZCD1OUT // bit 5
7434 #define ZCD1EN ZCD1CONbits.ZCD1EN // bit 7
7436 #endif // #ifndef NO_BIT_DEFINES
7438 #endif // #ifndef __PIC16F1705_H__