######################################################################
#
# MPLAB IDE .dev File Generated by `pic2dev.py'
#
# Device: PIC16F1509
# Family: 16Exxx
# Datasheet: 41609
# Programming Spec: 41573
# Date: Tue Apr 30 09:40:39 2013
#
######################################################################


######################################################################
#
# Memory Regions & Other General Device Information
#
######################################################################

vpp (range=8.000-9.000 dflt=9.000)
vdd (range=2.300-5.500 dfltrange=2.300-5.500 nominal=5.000)
pgming (memtech=ee tries=1 lvpthresh=2.700 boundary=8)
    wait (pgm=2500 eedata=8000 cfg=5000 userid=2500 erase=6000 lvpgm=2500)
    latches (pgm=32 eedata=1 cfg=1 userid=1 rowerase=32)
EraseAlg=1
HWStackDepth=16
breakpoints (numhwbp=1 datacapture=false idbyte=x)
testmem (region=0x8000-0x81ff)
userid (region=0x8000-0x8003)
devid (region=0x8006-0x8006 idmask=0x3fe0 id=0x2d40)
    ver (id=0x2D40 desc="a0")
cfgmem (region=0x8007-0x8008)
bkbgvectmem (region=0x8004-0x8004)
pgmmem (region=0x0-0x1fff)
NumBanks=32
MirrorRegs (0x0-0xb 0x80-0x8b 0x100-0x10b 0x180-0x18b 0x200-0x20b 0x280-0x28b 0x300-0x30b 0x380-0x38b 0x400-0x40b 0x480-0x48b 0x500-0x50b 0x580-0x58b 0x600-0x60b 0x680-0x68b 0x700-0x70b 0x780-0x78b 0x800-0x80b 0x880-0x88b 0x900-0x90b 0x980-0x98b 0xa00-0xa0b 0xa80-0xa8b 0xb00-0xb0b 0xb80-0xb8b 0xc00-0xc0b 0xc80-0xc8b 0xd00-0xd0b 0xd80-0xd8b 0xe00-0xe0b 0xe80-0xe8b 0xf00-0xf0b 0xf80-0xf8b)
MirrorRegs (0x70-0x7f 0xf0-0xff 0x170-0x17f 0x1f0-0x1ff 0x270-0x27f 0x2f0-0x2ff 0x370-0x37f 0x3f0-0x3ff 0x470-0x47f 0x4f0-0x4ff 0x570-0x57f 0x5f0-0x5ff 0x670-0x67f 0x6f0-0x6ff 0x770-0x77f 0x7f0-0x7ff 0x870-0x87f 0x8f0-0x8ff 0x970-0x97f 0x9f0-0x9ff 0xa70-0xa7f 0xaf0-0xaff 0xb70-0xb7f 0xbf0-0xbff 0xc70-0xc7f 0xcf0-0xcff 0xd70-0xd7f 0xdf0-0xdff 0xe70-0xe7f 0xef0-0xeff 0xf70-0xf7f 0xff0-0xfff)
UnusedRegs (0x330-0x36f)
UnusedRegs (0x3a0-0x3ef)
UnusedRegs (0x420-0x46f)
UnusedRegs (0x4a0-0x4ef)
UnusedRegs (0x520-0x56f)
UnusedRegs (0x5a0-0x5ef)
UnusedRegs (0x620-0x66f)
UnusedRegs (0x6a0-0x6ef)
UnusedRegs (0x720-0x76f)
UnusedRegs (0x7a0-0x7ef)
UnusedRegs (0x820-0x86f)
UnusedRegs (0x8a0-0x8ef)
UnusedRegs (0x920-0x96f)
UnusedRegs (0x9a0-0x9ef)
UnusedRegs (0xa20-0xa6f)
UnusedRegs (0xaa0-0xaef)
UnusedRegs (0xb20-0xb6f)
UnusedRegs (0xba0-0xbef)
UnusedRegs (0xc20-0xc6f)
UnusedRegs (0xca0-0xcef)
UnusedRegs (0xd20-0xd6f)
UnusedRegs (0xda0-0xdef)
UnusedRegs (0xe20-0xe6f)
UnusedRegs (0xea0-0xeef)

######################################################################
#
# Special Function Registers
#
######################################################################

sfr (key=INDF0 addr=0x0 size=1 flags=i access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='INDF0' width='8')
sfr (key=INDF1 addr=0x1 size=1 flags=i access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='INDF1' width='8')
sfr (key=PCL addr=0x2 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='PCL' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=STATUS addr=0x3 size=1 access='u u u r r rw rw rw')
    reset (por='---11000' mclr='---qquuu')
    bit (names='- - - nTO nPD Z DC C' width='1 1 1 1 1 1 1 1')
sfr (key=FSR0 addr=0x4 size=2 flags=j)
sfr (key=FSR0L addr=0x4 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='uuuuuuuu')
    bit (names='FSR0L' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=w type=int)
sfr (key=FSR0H addr=0x5 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='FSR0H' width='8')
sfr (key=FSR1 addr=0x6 size=2 flags=j)
sfr (key=FSR1L addr=0x6 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='uuuuuuuu')
    bit (names='FSR1L' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=w type=int)
sfr (key=FSR1H addr=0x7 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='FSR1H' width='8')
sfr (key=BSR addr=0x8 size=1 access='u u u rw rw rw rw rw')
    reset (por='---00000' mclr='---00000')
    bit (names='- - - BSR' width='1 1 1 5')
sfr (key=WREG addr=0x9 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='uuuuuuuu')
    bit (names='WREG0' width='8')
    bit (tag=scl names='RE' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=rw)
sfr (key=PCLATH addr=0xa size=1 access='u rw rw rw rw rw rw rw')
    reset (por='-0000000' mclr='-0000000')
    bit (names='- PCLATH' width='1 7')
sfr (key=INTCON addr=0xb size=1 access='rw rw rw rw rw rw rw r')
    reset (por='0000000x' mclr='0000000u')
    bit (names='GIE PEIE TMR0IE INTE IOCIE TMR0IF INTF IOCIF' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=PORTA addr=0xc size=1 access='u u rw rw rw rw rw rw')
    reset (por='--xxxxxx' mclr='--xxxxxx')
    bit (names='- - RA5 RA4 RA3 RA2 RA1 RA0' width='1 1 1 1 1 1 1 1')
    bit (tag=scl names='RA' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=rw)
sfr (key=PORTB addr=0xd size=1 access='rw rw rw rw u u u u')
    reset (por='xxxx----' mclr='xxxx----')
    bit (names='RB7 RB6 RB5 RB4 - - - -' width='1 1 1 1 1 1 1 1')
    bit (tag=scl names='RB' width='8')
sfr (key=PORTC addr=0xe size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='RC7 RC6 RC5 RC4 RC3 RC2 RC1 RC0' width='1 1 1 1 1 1 1 1')
    bit (tag=scl names='RC' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=rw)
UnusedRegs (0xf-0xf)
UnusedRegs (0x10-0x10)
sfr (key=PIR1 addr=0x11 size=1 access='rw rw rw rw rw u rw rw')
    reset (por='00xx0-00' mclr='00xx0-00')
    bit (names='TMR1GIF ADIF RCIF TXIF SSP1IF - TMR2IF TMR1IF' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=PIR2 addr=0x12 size=1 access='rw rw rw u rw rw u u')
    reset (por='x00-00--' mclr='x00-00--')
    bit (names='OSFIF C2IF C1IF - BCL1IF NCO1IF - -' width='1 1 1 1 1 1 1 1')
sfr (key=PIR3 addr=0x13 size=1 access='u u u u rw rw rw rw')
    reset (por='----xx00' mclr='----xx00')
    bit (names='- - - - CLC4IF CLC3IF CLC2IF CLC1IF' width='1 1 1 1 1 1 1 1')
UnusedRegs (0x14-0x14)
sfr (key=TMR0 addr=0x15 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='TMR0' width='8')
    stimulus (scl=rwb pcfiles=w regfiles=w type=int)
sfr (key=TMR1 addr=0x16 size=2 flags=j)
    bit (names='TMR1' width='16')
    stimulus (scl=rwb regfiles=w type=int)
sfr (key=TMR1L addr=0x16 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='TMR1L' width='8')
sfr (key=TMR1H addr=0x17 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='TMR1H' width='8')
sfr (key=T1CON addr=0x18 size=1 access='rw rw rw rw rw rw u rw')
    reset (por='000000-0' mclr='uuuuuu-u')
    bit (names='TMR1CS T1CKPS T1OSCEN nT1SYNC - TMR1ON' width='2 2 1 1 1 1')
sfr (key=T1GCON addr=0x19 size=1 access='rw rw rw rw rw r rw rw')
    reset (por='00000x00' mclr='uuuuuxuu')
    bit (names='TMR1GE T1GPOL T1GTM T1GSPM T1GGO_nDONE T1GVAL T1GSS' width='1 1 1 1 1 1 2')
sfr (key=TMR2 addr=0x1a size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='TMR2' width='8')
    stimulus (scl=rwb pcfiles=w regfiles=w type=int)
sfr (key=PR2 addr=0x1b size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='11111111' mclr='11111111')
    bit (names='PR2' width='8')
sfr (key=T2CON addr=0x1c size=1 access='u rw rw rw rw rw rw rw')
    reset (por='-0000000' mclr='-0000000')
    bit (names='- T2OUTPS TMR2ON T2CKPS' width='1 4 1 2')
UnusedRegs (0x1d-0x1e)
UnusedRegs (0x1f-0x1f)
sfr (key=TRISA addr=0x8c size=1 access='u u rw rw u rw rw rw')
    reset (por='--111111' mclr='--111111')
    bit (names='- - TRISA5 TRISA4 TRISA3 TRISA2 TRISA1 TRISA0' width='1 1 1 1 1 1 1 1')
    bit (tag=scl names='TRISA' width='8')
    stimulus (scl=rwb regfiles=w)
sfr (key=TRISB addr=0x8d size=1 access='rw rw rw rw u u u u')
    reset (por='xxxx----' mclr='xxxx----')
    bit (names='TRISB7 TRISB6 TRISB5 TRISB4 - - - -' width='1 1 1 1 1 1 1 1')
    bit (tag=scl names='TRISB' width='8')
sfr (key=TRISC addr=0x8e size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xx111111' mclr='xx111111')
    bit (names='TRISC7 TRISC6 TRISC5 TRISC4 TRISC3 TRISC2 TRISC1 TRISC0' width='1 1 1 1 1 1 1 1')
    bit (tag=scl names='TRISC' width='8')
    stimulus (scl=rwb regfiles=w)
UnusedRegs (0x8f-0x8f)
UnusedRegs (0x90-0x90)
sfr (key=PIE1 addr=0x91 size=1 access='rw rw rw rw rw u rw rw')
    reset (por='00xx0-00' mclr='00xx0-00')
    bit (names='TMR1GIE ADIE RCIE TXIE SSP1IE - TMR2IE TMR1IE' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=PIE2 addr=0x92 size=1 access='rw rw rw u rw rw u u')
    reset (por='x00-00--' mclr='x00-00--')
    bit (names='OSFIE C2IE C1IE - BCL1IE NCO1IE - -' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=PIE3 addr=0x93 size=1 access='u u u u rw rw rw rw')
    reset (por='----xx00' mclr='----xx00')
    bit (names='- - - - CLC4IE CLC3IE CLC2IE CLC1IE' width='1 1 1 1 1 1 1 1')
UnusedRegs (0x94-0x94)
sfr (key=OPTION_REG addr=0x95 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='11111111' mclr='11111111')
    bit (names='nWPUEN INTEDG TMR0CS TMR0SE PSA PS' width='1 1 1 1 1 3')
    stimulus (scl=rwb regfiles=w)
sfr (key=PCON addr=0x96 size=1 access='rw rw u rw rw rw rw rw')
    reset (por='00-111qq' mclr='00-qqquu')
    bit (names='STKOVF STKUNF - nRWDT nRMCLR nRI nPOR nBOR' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb regfiles=w)
sfr (key=WDTCON addr=0x97 size=1 access='u u rw rw rw rw rw rw')
    reset (por='--010110' mclr='--010110')
    bit (names='- - WDTPS SWDTEN' width='1 1 5 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
UnusedRegs (0x98-0x98)
sfr (key=OSCCON addr=0x99 size=1 access='u rw rw rw rw u rw rw')
    reset (por='-0111-00' mclr='-0111-00')
    bit (names='- IRCF - SCS' width='1 4 1 2')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=OSCSTAT addr=0x9a size=1 access='rw u r r u u r r')
    reset (por='0-q0--00' mclr='q-qq--qq')
    bit (names='SOSCR - OSTS HFIOFR - - LFIOFR HFIOFS' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=ADRES addr=0x9b size=2 flags=j)
sfr (key=ADRESL addr=0x9b size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='ADRESL' width='8')
    stimulus (scl=rwb regfiles=r type=int)
sfr (key=ADRESH addr=0x9c size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='ADRESH' width='8')
    stimulus (scl=rwb type=int)
sfr (key=ADCON0 addr=0x9d size=1 access='u rw rw rw rw rw rw rw')
    reset (por='-0000000' mclr='-0000000')
    bit (names='- CHS GO/nDONE ADON' width='1 5 1 1')
    stimulus (scl=rwb regfiles=w)
sfr (key=ADCON1 addr=0x9e size=1 access='rw rw rw rw u u rw rw')
    reset (por='0000--00' mclr='0000--00')
    bit (names='ADFM ADCS - - ADPREF' width='1 3 1 1 2')
    stimulus (scl=rwb regfiles=w)
sfr (key=ADCON2 addr=0x9f size=1 access='rw rw rw rw u u u u')
    reset (por='0000----' mclr='0000----')
    bit (names='TRIGSEL - - - -' width='4 1 1 1 1')
sfr (key=LATA addr=0x10c size=1 access='u u rw rw u rw rw rw')
    reset (por='--xx-xxx' mclr='--uu-uuu')
    bit (names='- - LATA5 LATA4 - LATA2 LATA1 LATA0' width='1 1 1 1 1 1 1 1')
    bit (tag=scl names='LATA' width='8')
    stimulus (scl=rwb regfiles=w)
sfr (key=LATB addr=0x10d size=1 access='rw rw rw rw u u u u')
    reset (por='xxxx----' mclr='xxxx----')
    bit (names='LATB7 LATB6 LATB5 LATB4 - - - -' width='1 1 1 1 1 1 1 1')
    bit (tag=scl names='LATB' width='8')
sfr (key=LATC addr=0x10e size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxuuuuuu')
    bit (names='LATC7 LATC6 LATC5 LATC4 LATC3 LATC2 LATC1 LATC0' width='1 1 1 1 1 1 1 1')
    bit (tag=scl names='LATC' width='8')
    stimulus (scl=rwb regfiles=w)
UnusedRegs (0x10f-0x110)
sfr (key=CM1CON0 addr=0x111 size=1 access='rw r rw rw u rw rw rw')
    reset (por='0000-100' mclr='0000-100')
    bit (names='C1ON C1OUT C1OE C1POL - C1SP C1HYS C1SYNC' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb regfiles=w)
sfr (key=CM1CON1 addr=0x112 size=1 access='rw rw rw rw u rw rw rw')
    reset (por='0000-000' mclr='0000-000')
    bit (names='C1INTP C1INTN C1PCH1 C1PCH0 - C1NCH2 C1NCH1 C1NCH0' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb regfiles=w)
sfr (key=CM2CON0 addr=0x113 size=1 access='rw r rw rw u rw rw rw')
    reset (por='0000-100' mclr='0000-100')
    bit (names='C2ON C2OUT C2OE C2POL - C2SP C2HYS C2SYNC' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb regfiles=w)
sfr (key=CM2CON1 addr=0x114 size=1 access='rw rw rw rw u rw rw rw')
    reset (por='0000-000' mclr='0000-000')
    bit (names='C2INTP C2INTN C2PCH1 C2PCH0 - C2NCH2 C2NCH1 C2NCH0' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb regfiles=w)
sfr (key=CMOUT addr=0x115 size=1 access='u u u u u u r r')
    reset (por='------00' mclr='------00')
    bit (names='- - - - - - MC2OUT MC1OUT' width='1 1 1 1 1 1 1 1')
sfr (key=BORCON addr=0x116 size=1 access='rw rw u u u u u r')
    reset (por='10-----q' mclr='uu-----u')
    bit (names='SBOREN BORFS - - - - - BORRDY' width='1 1 1 1 1 1 1 1')
sfr (key=FVRCON addr=0x117 size=1 access='rw r rw rw rw rw rw rw')
    reset (por='0q00xx00' mclr='0q00xx00')
    bit (names='FVREN FVRRDY TSEN TSRNG CDAFVR ADFVR' width='1 1 1 1 2 2')
sfr (key=DACCON0 addr=0x118 size=1 access='rw u rw rw u rw u u')
    reset (por='0-xx-x--' mclr='0-xx-x--')
    bit (names='DACEN - DACOE1 DACOE2 - DACPSS - -' width='1 1 1 1 1 1 1 1')
sfr (key=DACCON1 addr=0x119 size=1 access='u u u rw rw rw rw rw')
    reset (por='---xxxxx' mclr='---xxxxx')
    bit (names='- - - DACR' width='1 1 1 5')
UnusedRegs (0x11a-0x11c)
sfr (key=APFCON addr=0x11d size=1 access='u u u rw rw u rw rw')
    reset (por='---00-00' mclr='---00-00')
    bit (names='- - - SSSEL T1GSEL - CLC1SEL NCO1SEL' width='1 1 1 1 1 1 1 1')
UnusedRegs (0x11e-0x11f)
sfr (key=ANSELA addr=0x18c size=1 access='u u u rw u rw rw rw')
    reset (por='---1-111' mclr='---1-111')
    bit (names='- - - ANSA4 - ANSA2 ANSA1 ANSA0' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb regfiles=r)
sfr (key=ANSELB addr=0x18d size=1 access='u u rw rw u u u u')
    reset (por='--xx----' mclr='--xx----')
    bit (names='- - ANSB5 ANSB4 - - - -' width='1 1 1 1 1 1 1 1')
sfr (key=ANSELC addr=0x18e size=1 access='rw rw u u rw rw rw rw')
    reset (por='xx--1111' mclr='xx--1111')
    bit (names='ANSC7 ANSC6 - - ANSC3 ANSC2 ANSC1 ANSC0' width='1 1 1 1 1 1 1 1')
UnusedRegs (0x18f-0x190)
sfr (key=PMADR addr=0x191 size=2 flags=j)
sfr (key=PMADRL addr=0x191 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='PMADRL' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=PMADRH addr=0x192 size=1 access='u rw rw rw rw rw rw rw')
    reset (por='10000000' mclr='10000000')
    bit (names='- PMADRH' width='1 7')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=PMDAT addr=0x193 size=2 flags=j)
sfr (key=PMDATL addr=0x193 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='PMDATL' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=rw)
sfr (key=PMDATH addr=0x194 size=1 access='u u rw rw rw rw rw rw')
    reset (por='--xxxxxx' mclr='--uuuuuu')
    bit (names='- - PMDATH' width='1 1 6')
    stimulus (scl=rwb pcfiles=rw regfiles=rw)
sfr (key=PMCON1 addr=0x195 size=1 access='u rw rw rw rw rw rs rs')
    reset (por='1000x000' mclr='1000q000')
    bit (names='EEPGD CFGS LWLO FREE WRERR WREN WR RD' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=PMCON2 addr=0x196 size=1 access='w w w w w w w w')
    reset (por='00000000' mclr='00000000')
    bit (names='PMCON2' width='8')
sfr (key=VREGCON addr=0x197 size=1 access='u u u u u u rw r')
    reset (por='------01' mclr='------01')
    bit (names='- - - - - - VREGPM Reserved' width='1 1 1 1 1 1 1 1')
UnusedRegs (0x198-0x198)
sfr (key=RCREG addr=0x199 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='RCREG' width='8')
sfr (key=TXREG addr=0x19a size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='TXREG' width='8')
sfr (key=SPBRGL addr=0x19b size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='SPBRGL' width='8')
sfr (key=SPBRGH addr=0x19c size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='SPBRGH' width='8')
sfr (key=RCSTA addr=0x19d size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='SPEN RX9 SREN CREN ADDEN FERR OERR RX9D' width='1 1 1 1 1 1 1 1')
sfr (key=TXSTA addr=0x19e size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D' width='1 1 1 1 1 1 1 1')
sfr (key=BAUDCON addr=0x19f size=1 access='rw rw u rw rw u rw rw')
    reset (por='xx-xx-xx' mclr='xx-xx-xx')
    bit (names='ABDOVF RCIDL - SCKP BRG16 - WUE ABDEN' width='1 1 1 1 1 1 1 1')
sfr (key=WPUA addr=0x20c size=1 access='u u rw rw rw rw rw rw')
    reset (por='--111111' mclr='--111111')
    bit (names='- - WPUA5 WPUA4 WPUA3 WPUA2 WPUA1 WPUA0' width='1 1 1 1 1 1 1 1')
sfr (key=WPUB addr=0x20d size=1 access='rw rw rw rw u u u u')
    reset (por='xxxx----' mclr='xxxx----')
    bit (names='WPUB7 WPUB6 WPUB5 WPUB4 - - - -' width='1 1 1 1 1 1 1 1')
UnusedRegs (0x20e-0x210)
sfr (key=SSP1BUF addr=0x211 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='SSPBUF' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=rw type=int)
sfr (key=SSP1ADD addr=0x212 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='ADD' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=w type=int)
sfr (key=SSP1MSK addr=0x213 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='11111111' mclr='11111111')
    bit (names='MSK' width='8')
    stimulus (scl=rwb pcfiles=rw regfiles=rw type=int)
sfr (key=SSP1STAT addr=0x214 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='SMP CKE D/nA P S R/nW UA BF' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=rw)
sfr (key=SSP1CON1 addr=0x215 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='0000xxxx' mclr='0000uuuu')
    bit (names='WCOL SSPOV SSPEN CKP SSPM3 SSPM2 SSPM1 SSPM0' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=SSP1CON2 addr=0x216 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='GCEN ACKSTAT ACKDT ACKEN RCEN PEN RSEN SEN' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
sfr (key=SSP1CON3 addr=0x217 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='ACKTIM PCIE SCIE BOEN SDAHT SBCDE AHEN DHEN' width='1 1 1 1 1 1 1 1')
    stimulus (scl=rwb pcfiles=rw regfiles=w)
UnusedRegs (0x218-0x21f)
UnusedRegs (0x28c-0x29f)
UnusedRegs (0x30c-0x31f)
UnusedRegs (0x38c-0x390)
sfr (key=IOCAP addr=0x391 size=1 access='u u rw rw rw rw rw rw')
    reset (por='--000000' mclr='--000000')
    bit (names='- - IOCAP5 IOCAP4 IOCAP3 IOCAP2 IOCAP1 IOCAP0' width='1 1 1 1 1 1 1 1')
sfr (key=IOCAN addr=0x392 size=1 access='u u rw rw rw rw rw rw')
    reset (por='--000000' mclr='--000000')
    bit (names='- - IOCAN5 IOCAN4 IOCAN3 IOCAN2 IOCAN1 IOCAN0' width='1 1 1 1 1 1 1 1')
sfr (key=IOCAF addr=0x393 size=1 access='u u rw rw rw rw rw rw')
    reset (por='--000000' mclr='--000000')
    bit (names='- - IOCAF5 IOCAF4 IOCAF3 IOCAF2 IOCAF1 IOCAF0' width='1 1 1 1 1 1 1 1')
sfr (key=IOCBP addr=0x394 size=1 access='rw rw rw rw u u u u')
    reset (por='xxxx----' mclr='xxxx----')
    bit (names='IOCBP7 IOCBP6 IOCBP5 IOCBP4 - - - -' width='1 1 1 1 1 1 1 1')
sfr (key=IOCBN addr=0x395 size=1 access='rw rw rw rw u u u u')
    reset (por='xxxx----' mclr='xxxx----')
    bit (names='IOCBN7 IOCBN6 IOCBN5 IOCBN4 - - - -' width='1 1 1 1 1 1 1 1')
sfr (key=IOCBF addr=0x396 size=1 access='rw rw rw rw u u u u')
    reset (por='xxxx----' mclr='xxxx----')
    bit (names='IOCBF7 IOCBF6 IOCBF5 IOCBF4 - - - -' width='1 1 1 1 1 1 1 1')
UnusedRegs (0x397-0x39f)
UnusedRegs (0x40c-0x41f)
UnusedRegs (0x48c-0x497)
sfr (key=NCO1ACC addr=0x498 size=3 flags=j)
sfr (key=NCO1ACCL addr=0x498 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='NCO1ACC7 NCO1ACC6 NCO1ACC5 NCO1ACC4 NCO1ACC3 NCO1ACC2 NCO1ACC1 NCO1ACC0' width='1 1 1 1 1 1 1 1')
sfr (key=NCO1ACCH addr=0x499 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='NCO1ACC15 NCO1ACC14 NCO1ACC13 NCO1ACC12 NCO1ACC11 NCO1ACC10 NCO1ACC9 NCO1ACC8' width='1 1 1 1 1 1 1 1')
sfr (key=NCO1ACCU addr=0x49a size=1 access='u u u u rw rw rw rw')
    reset (por='----0000' mclr='----0000')
    bit (names='- - - - NCO1ACC19 NCO1ACC18 NCO1ACC17 NCO1ACC16' width='1 1 1 1 1 1 1 1')
sfr (key=NCO1INC addr=0x49b size=3 flags=j)
sfr (key=NCO1INCL addr=0x49b size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000001' mclr='00000001')
    bit (names='NCO1INC7 NCO1INC6 NCO1INC5 NCO1INC4 NCO1INC3 NCO1INC2 NCO1INC1 NCO1INC0' width='1 1 1 1 1 1 1 1')
sfr (key=NCO1INCH addr=0x49c size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='00000000' mclr='00000000')
    bit (names='NCO1INC15 NCO1INC14 NCO1INC13 NCO1INC12 NCO1INC11 NCO1INC10 NCO1INC9 NCO1INC8' width='1 1 1 1 1 1 1 1')
sfr (key=NCO1INCU addr=0x49d size=1 access='u u u u u u u u')
    reset (por='--------' mclr='--------')
    bit (names='- - - - - - - -' width='1 1 1 1 1 1 1 1')
sfr (key=NCO1CON addr=0x49e size=1 access='rw rw r rw u u u rw')
    reset (por='0000---0' mclr='0000---0')
    bit (names='N1EN N1OE N1OUT N1POL - - - N1PFM' width='1 1 1 1 1 1 1 1')
sfr (key=NCO1CLK addr=0x49f size=1 access='rw rw rw u u u rw rw')
    reset (por='000---00' mclr='000---00')
    bit (names='N1PWS - N1CKS' width='3 1 4')
UnusedRegs (0x50c-0x51f)
UnusedRegs (0x58c-0x59f)
UnusedRegs (0x60c-0x610)
sfr (key=PWM1DCL addr=0x611 size=1 access='rw rw u u u u u u')
    reset (por='xx------' mclr='uu------')
    bit (names='PWM1DCL - - - - - -' width='2 1 1 1 1 1 1')
sfr (key=PWM1DCH addr=0x612 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='PWM1DCH' width='8')
sfr (key=PWM1CON addr=0x613 size=1 access='rw rw rw rw u u u u')
    reset (por='00x0----' mclr='00x0----')
    bit (names='PWM1EN PWM1OE PWM1OUT PWM1POL - - - -' width='1 1 1 1 1 1 1 1')
sfr (key=PWM2DCL addr=0x614 size=1 access='rw rw u u u u u u')
    reset (por='xx------' mclr='uu------')
    bit (names='PWM2DCL - - - - - -' width='2 1 1 1 1 1 1')
sfr (key=PWM2DCH addr=0x615 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='PWM2DCH' width='8')
sfr (key=PWM2CON addr=0x616 size=1 access='rw rw rw rw u u u u')
    reset (por='00x0----' mclr='00x0----')
    bit (names='PWM2EN PWM2OE PWM2OUT PWM2POL - - - -' width='1 1 1 1 1 1 1 1')
sfr (key=PWM3DCL addr=0x617 size=1 access='rw rw u u u u u u')
    reset (por='xx------' mclr='uu------')
    bit (names='PWM3DCL - - - - - -' width='2 1 1 1 1 1 1')
sfr (key=PWM3DCH addr=0x618 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='PWM3DCH' width='8')
sfr (key=PWM3CON addr=0x619 size=1 access='rw rw rw rw u u u u')
    reset (por='00x0----' mclr='00x0----')
    bit (names='PWM3EN PWM3OE PWM3OUT PWM3POL - - - -' width='1 1 1 1 1 1 1 1')
sfr (key=PWM4DCL addr=0x61a size=1 access='rw rw u u u u u u')
    reset (por='xx------' mclr='uu------')
    bit (names='PWM4DCL - - - - - -' width='2 1 1 1 1 1 1')
sfr (key=PWM4DCH addr=0x61b size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='PWM4DCH' width='8')
sfr (key=PWM4CON addr=0x61c size=1 access='rw rw rw rw u u u u')
    reset (por='00x0----' mclr='00x0----')
    bit (names='PWM4EN PWM4OE PWM4OUT PWM4POL - - - -' width='1 1 1 1 1 1 1 1')
UnusedRegs (0x61d-0x61f)
UnusedRegs (0x68c-0x690)
sfr (key=CWG1DBR addr=0x691 size=1 access='u u rw rw rw rw rw rw')
    reset (por='--xxxxxx' mclr='--uuuuuu')
    bit (names='- - CWG1DBR' width='1 1 6')
sfr (key=CWG1DBF addr=0x692 size=1 access='u u rw rw rw rw rw rw')
    reset (por='--xxxxxx' mclr='--uuuuuu')
    bit (names='- - CWG1DBF' width='1 1 6')
sfr (key=CWG1CON0 addr=0x693 size=1 access='rw rw rw rw rw u u rw')
    reset (por='00000--x' mclr='00000--x')
    bit (names='G1EN G1OEB G1OEA G1POLB G1POLA - - G1CS0' width='1 1 1 1 1 1 1 1')
sfr (key=CWG1CON1 addr=0x694 size=1 access='rw rw rw rw u rw rw rw')
    reset (por='xxxx-xxx' mclr='uuuu-xxx')
    bit (names='G1ASDLB G1ASDLA - G1IS2 G1IS1 G1IS0' width='2 2 1 1 1 1')
sfr (key=CWG1CON2 addr=0x695 size=1 access='rw rw u u rw rw rw rw')
    reset (por='xx--xxxx' mclr='uu--uuuu')
    bit (names='G1ASE G1ARSEN - - G1ASDSC2 G1ASDSC1 G1ASDSFLT G1ASDSCLC2' width='1 1 1 1 1 1 1 1')
UnusedRegs (0x696-0x69f)
UnusedRegs (0x70c-0x71f)
UnusedRegs (0x78c-0x79f)
UnusedRegs (0x80c-0x81f)
UnusedRegs (0x88c-0x89f)
UnusedRegs (0x90c-0x91f)
UnusedRegs (0x98c-0x99f)
UnusedRegs (0xa0c-0xa1f)
UnusedRegs (0xa8c-0xa9f)
UnusedRegs (0xb0c-0xb1f)
UnusedRegs (0xb8c-0xb9f)
UnusedRegs (0xc0c-0xc1f)
UnusedRegs (0xc8c-0xc9f)
UnusedRegs (0xd0c-0xd1f)
UnusedRegs (0xd8c-0xd9f)
UnusedRegs (0xe0c-0xe1f)
UnusedRegs (0xe8c-0xe9f)
UnusedRegs (0xf0c-0xf0e)
sfr (key=CLCDATA addr=0xf0f size=1 access='u u u u rw rw r r')
    reset (por='----xx00' mclr='----xx00')
    bit (names='- - - - MCLC4OUT MCLC3OUT MCLC2OUT MCLC1OUT' width='1 1 1 1 1 1 1 1')
sfr (key=CLC1CON addr=0xf10 size=1 access='rw rw r rw rw rw rw rw')
    reset (por='00u00000' mclr='00u00000')
    bit (names='LC1EN LC1OE LC1OUT LC1INTP LC1INTN LC1MODE2 LC1MODE1 LC1MODE0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC1POL addr=0xf11 size=1 access='rw u u u rw rw rw rw')
    reset (por='0---0000' mclr='0---0000')
    bit (names='LC1POL - - - LC1G4POL LC1G3POL LC1G2POL LC1G1POL' width='1 1 1 1 1 1 1 1')
sfr (key=CLC1SEL0 addr=0xf12 size=1 access='u rw rw rw u rw rw rw')
    reset (por='-xxx-xxx' mclr='-uuu-uuu')
    bit (names='- LC1D2S2 LC1D2S1 LC1D2S0 - LC1D1S2 LC1D1S1 LC1D1S0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC1SEL1 addr=0xf13 size=1 access='u rw rw rw u rw rw rw')
    reset (por='-xxx-xxx' mclr='-uuu-uuu')
    bit (names='- LC1D4S2 LC1D4S1 LC1D4S0 - LC1D3S2 LC1D3S1 LC1D3S0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC1GLS0 addr=0xf14 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC1G1D4T LC1G1D4N LC1G1D3T LC1G1D3N LC1G1D2T LC1G1D2N LC1G1D1T LC1G1D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC1GLS1 addr=0xf15 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC1G2D4T LC1G2D4N LC1G2D3T LC1G2D3N LC1G2D2T LC1G2D2N LC1G2D1T LC1G2D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC1GLS2 addr=0xf16 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC1G3D4T LC1G3D4N LC1G3D3T LC1G3D3N LC1G3D2T LC1G3D2N LC1G3D1T LC1G3D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC1GLS3 addr=0xf17 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='LC1G4D4T LC1G4D4N LC1G4D3T LC1G4D3N LC1G4D2T LC1G4D2N LC1G4D1T LC1G4D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC2CON addr=0xf18 size=1 access='rw rw r rw rw rw rw rw')
    reset (por='00u00000' mclr='00u00000')
    bit (names='LC2EN LC2OE LC2OUT LC2INTP LC2INTN LC2MODE2 LC2MODE1 LC2MODE0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC2POL addr=0xf19 size=1 access='rw u u u rw rw rw rw')
    reset (por='0---0000' mclr='0---0000')
    bit (names='LC2POL - - - LC2G4POL LC2G3POL LC2G2POL LC2G1POL' width='1 1 1 1 1 1 1 1')
sfr (key=CLC2SEL0 addr=0xf1a size=1 access='u rw rw rw u rw rw rw')
    reset (por='-xxx-xxx' mclr='-uuu-uuu')
    bit (names='- LC2D2S2 LC2D2S1 LC2D2S0 - LC2D1S2 LC2D1S1 LC2D1S0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC2SEL1 addr=0xf1b size=1 access='u rw rw rw u rw rw rw')
    reset (por='-xxx-xxx' mclr='-uuu-uuu')
    bit (names='- LC2D4S2 LC2D4S1 LC2D4S0 - LC2D3S2 LC2D3S1 LC2D3S0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC2GLS0 addr=0xf1c size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC2G1D4T LC2G1D4N LC2G1D3T LC2G1D3N LC2G1D2T LC2G1D2N LC2G1D1T LC2G1D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC2GLS1 addr=0xf1d size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC2G2D4T LC2G2D4N LC2G2D3T LC2G2D3N LC2G2D2T LC2G2D2N LC2G2D1T LC2G2D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC2GLS2 addr=0xf1e size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC2G3D4T LC2G3D4N LC2G3D3T LC2G3D3N LC2G3D2T LC2G3D2N LC2G3D1T LC2G3D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC2GLS3 addr=0xf1f size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='LC2G4D4T LC2G4D4N LC2G4D3T LC2G4D3N LC2G4D2T LC2G4D2N LC2G4D1T LC2G4D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC3CON addr=0xf20 size=1 access='rw rw r rw rw rw rw rw')
    reset (por='00u00000' mclr='00u00000')
    bit (names='LC3EN LC3OE LC3OUT LC3INTP LC3INTN LC3MODE2 LC3MODE1 LC3MODE0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC3POL addr=0xf21 size=1 access='rw u u u rw rw rw rw')
    reset (por='0---0000' mclr='0---0000')
    bit (names='LC3POL - - - LC3G4POL LC3G3POL LC3G2POL LC3G1POL' width='1 1 1 1 1 1 1 1')
sfr (key=CLC3SEL0 addr=0xf22 size=1 access='u rw rw rw u rw rw rw')
    reset (por='-xxx-xxx' mclr='-uuu-uuu')
    bit (names='- LC3D2S2 LC3D2S1 LC3D2S0 - LC3D1S2 LC3D1S1 LC3D1S0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC3SEL1 addr=0xf23 size=1 access='u rw rw rw u rw rw rw')
    reset (por='-xxx-xxx' mclr='-uuu-uuu')
    bit (names='- LC3D4S2 LC3D4S1 LC3D4S0 - LC3D3S2 LC3D3S1 LC3D3S0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC3GLS0 addr=0xf24 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC3G1D4T LC3G1D4N LC3G1D3T LC3G1D3N LC3G1D2T LC3G1D2N LC3G1D1T LC3G1D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC3GLS1 addr=0xf25 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC3G2D4T LC3G2D4N LC3G2D3T LC3G2D3N LC3G2D2T LC3G2D2N LC3G2D1T LC3G2D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC3GLS2 addr=0xf26 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC3G3D4T LC3G3D4N LC3G3D3T LC3G3D3N LC3G3D2T LC3G3D2N LC3G3D1T LC3G3D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC3GLS3 addr=0xf27 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='LC3G4D4T LC3G4D4N LC3G4D3T LC3G4D3N LC3G4D2T LC3G4D2N LC3G4D1T LC3G4D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC4CON addr=0xf28 size=1 access='rw rw r rw rw rw rw rw')
    reset (por='00u00000' mclr='00u00000')
    bit (names='LC4EN LC4OE LC4OUT LC4INTP LC4INTN LC4MODE2 LC4MODE1 LC4MODE0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC4POL addr=0xf29 size=1 access='rw u u u rw rw rw rw')
    reset (por='0---0000' mclr='0---0000')
    bit (names='LC4POL - - - LC4G4POL LC4G3POL LC4G2POL LC4G1POL' width='1 1 1 1 1 1 1 1')
sfr (key=CLC4SEL0 addr=0xf2a size=1 access='u rw rw rw u rw rw rw')
    reset (por='-xxx-xxx' mclr='-uuu-uuu')
    bit (names='- LC4D2S2 LC4D2S1 LC4D2S0 - LC4D1S2 LC4D1S1 LC4D1S0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC4SEL1 addr=0xf2b size=1 access='u rw rw rw u rw rw rw')
    reset (por='-xxx-xxx' mclr='-uuu-uuu')
    bit (names='- LC4D4S2 LC4D4S1 LC4D4S0 - LC4D3S2 LC4D3S1 LC4D3S0' width='1 1 1 1 1 1 1 1')
sfr (key=CLC4GLS0 addr=0xf2c size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC4G1D4T LC4G1D4N LC4G1D3T LC4G1D3N LC4G1D2T LC4G1D2N LC4G1D1T LC4G1D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC4GLS1 addr=0xf2d size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC4G2D4T LC4G2D4N LC4G2D3T LC4G2D3N LC4G2D2T LC4G2D2N LC4G2D1T LC4G2D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC4GLS2 addr=0xf2e size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='uuuuuuuu')
    bit (names='LC4G3D4T LC4G3D4N LC4G3D3T LC4G3D3N LC4G3D2T LC4G3D2N LC4G3D1T LC4G3D1N' width='1 1 1 1 1 1 1 1')
sfr (key=CLC4GLS3 addr=0xf2f size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='LC4G4D4T LC4G4D4N LC4G4D3T LC4G4D3N LC4G4D2T LC4G4D2N LC4G4D1T LC4G4D1N' width='1 1 1 1 1 1 1 1')
UnusedRegs (0xf30-0xf6f)
sfr (key=ICDIO addr=0xf8c size=1 access='rw rw rw rw rw rw u u')
    reset (por='xxxxxx--' mclr='xxxxxx--')
    bit (names='PORT_ICDDAT PORT_ICDCLK LAT_ICDDAT LAT_ICDCLK TRIS_ICDDAT TRIS_ICDCLK - -' width='1 1 1 1 1 1 1 1')
sfr (key=ICDCON0 addr=0xf8d size=1 access='rw rw rw u rw u u rw')
    reset (por='xxx-x--x' mclr='xxx-x--x')
    bit (names='INBUG FREEZ SSTEP - DBGINEX - - RSTVEC' width='1 1 1 1 1 1 1 1')
UnusedRegs (0xf8e-0xf90)
sfr (key=ICDSTAT addr=0xf91 size=1 access='rw rw u u u u rw u')
    reset (por='xx----x-' mclr='xx----x-')
    bit (names='TRP1HLTF TRP0HLTF - - - - USRHLTF -' width='1 1 1 1 1 1 1 1')
UnusedRegs (0xf92-0xf94)
sfr (key=DEVSEL addr=0xf95 size=1 access='u u u u u rw rw rw')
    reset (por='-----xxx' mclr='-----xxx')
    bit (names='- - - - - DEVSEL2 DEVSEL1 DEVSEL0' width='1 1 1 1 1 1 1 1')
sfr (key=ICDINSTL addr=0xf96 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='DBGIN7 DBGIN6 DBGIN5 DBGIN4 DBGIN3 DBGIN2 DBGIN1 DBGIN0' width='1 1 1 1 1 1 1 1')
sfr (key=ICDINSTH addr=0xf97 size=1 access='u u rw rw rw rw rw rw')
    reset (por='--xxxxxx' mclr='--xxxxxx')
    bit (names='- - DBGIN13 DBGIN12 DBGIN11 DBGIN10 DBGIN9 DBGIN8' width='1 1 1 1 1 1 1 1')
UnusedRegs (0xf98-0xf9b)
sfr (key=ICDBK0CON addr=0xf9c size=1 access='rw u u u u u u rw')
    reset (por='x------x' mclr='x------x')
    bit (names='BKEN - - - - - - BKHLT' width='1 1 1 1 1 1 1 1')
sfr (key=ICDBK0L addr=0xf9d size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='BKA7 BKA6 BKA5 BKA4 BKA3 BKA2 BKA1 BKA0' width='1 1 1 1 1 1 1 1')
sfr (key=ICDBK0H addr=0xf9e size=1 access='u rw rw rw rw rw rw rw')
    reset (por='-xxxxxxx' mclr='-xxxxxxx')
    bit (names='- BKA14 BKA13 BKA12 BKA11 BKA10 BKA9 BKA8' width='1 1 1 1 1 1 1 1')
UnusedRegs (0xf9f-0xf9f)
UnusedRegs (0xfa0-0xfbf)
UnusedRegs (0xfc0-0xfcf)
UnusedRegs (0xfd0-0xfe2)
sfr (key=BSRICDSHAD addr=0xfe3 size=1 access='u u u rw rw rw rw rw')
    reset (por='---xxxxx' mclr='---xxxxx')
    bit (names='- - - BSR_ICDSHAD' width='1 1 1 5')
sfr (key=STATUS_SHAD addr=0xfe4 size=1 access='u u u u u rw rw rw')
    reset (por='-----xxx' mclr='-----xxx')
    bit (names='- - - - - Z_SHAD DC_SHAD C_SHAD' width='1 1 1 1 1 1 1 1')
sfr (key=WREG_SHAD addr=0xfe5 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='WREG_SHAD' width='8')
sfr (key=BSR_SHAD addr=0xfe6 size=1 access='u u u rw rw rw rw rw')
    reset (por='---xxxxx' mclr='---xxxxx')
    bit (names='- - - BSR_SHAD' width='1 1 1 5')
sfr (key=PCLATH_SHAD addr=0xfe7 size=1 access='u rw rw rw rw rw rw rw')
    reset (por='-xxxxxxx' mclr='-xxxxxxx')
    bit (names='- PCLATH_SHAD' width='1 7')
sfr (key=FSR0L_SHAD addr=0xfe8 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='FSR0L_SHAD' width='8')
sfr (key=FSR0H_SHAD addr=0xfe9 size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='FSR0H_SHAD' width='8')
sfr (key=FSR1L_SHAD addr=0xfea size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='FSR1L_SHAD' width='8')
sfr (key=FSR1H_SHAD addr=0xfeb size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='FSR1H_SHAD' width='8')
UnusedRegs (0xfec-0xfec)
sfr (key=STKPTR addr=0xfed size=1 access='u u u rw rw rw rw rw')
    reset (por='---xxxxx' mclr='---xxxxx')
    bit (names='- - - STKPTR' width='1 1 1 5')
sfr (key=TOSL addr=0xfee size=1 access='rw rw rw rw rw rw rw rw')
    reset (por='xxxxxxxx' mclr='xxxxxxxx')
    bit (names='TOSL' width='8')
sfr (key=TOSH addr=0xfef size=1 access='u rw rw rw rw rw rw rw')
    reset (por='-xxxxxxx' mclr='-xxxxxxx')
    bit (names='- TOSH' width='1 7')

######################################################################
#
# Configuration Registers
#
######################################################################

cfgbits (key=CONFIG1 addr=0x8007 unused=0x0)
    field (key=FOSC mask=0x7 desc="Oscillator Selection Bits")
        setting (req=0x7 value=0x7 desc="ECH, External Clock, High Power Mode (4-20 MHz): device clock supplied to CLKIN pins")
        setting (req=0x7 value=0x6 desc="ECM, External Clock, Medium Power Mode (0.5-4 MHz): device clock supplied to CLKIN pins")
        setting (req=0x7 value=0x5 desc="ECL, External Clock, Low Power Mode (0-0.5 MHz): device clock supplied to CLKIN pins")
        setting (req=0x7 value=0x4 desc="INTOSC oscillator: I/O function on CLKIN pin")
        setting (req=0x7 value=0x3 desc="EXTRC oscillator: External RC circuit connected to CLKIN pin")
        setting (req=0x7 value=0x2 desc="HS Oscillator, High-speed crystal/resonator connected between OSC1 and OSC2 pins")
        setting (req=0x7 value=0x1 desc="XT Oscillator, Crystal/resonator connected between OSC1 and OSC2 pins")
        setting (req=0x7 value=0x0 desc="LP Oscillator, Low-power crystal connected between OSC1 and OSC2 pins")
    field (key=WDTE mask=0x18 desc="Watchdog Timer Enable" min=1)
        setting (req=0x18 value=0x18 desc="Enabled")
        setting (req=0x18 value=0x10 desc="WDT enabled while running and disabled in Sleep")
        setting (req=0x18 value=0x8 desc="WDT controlled by the SWDTEN bit in the WDTCON register")
        setting (req=0x18 value=0x0 desc="Disabled")
    field (key=PWRTE mask=0x20 desc="Power-up Timer Enable")
        setting (req=0x20 value=0x20 desc="Disabled")
        setting (req=0x20 value=0x0 desc="Enabled")
    field (key=MCLRE mask=0x40 desc="MCLR Pin Function Select")
        setting (req=0x40 value=0x40 desc="Enabled")
        setting (req=0x40 value=0x0 desc="Disabled")
    field (key=CP mask=0x80 desc="Flash Program Memory Code Protection")
        setting (req=0x80 value=0x80 desc="Disabled")
            checksum (type=0x0 protregion=0x0-0x0)
        setting (req=0x80 value=0x0 desc="Enabled")
            checksum (type=0x20 protregion=0x0-0x1fff)
    field (key=BOREN mask=0x600 desc="Brown-out Reset Enable")
        setting (req=0x600 value=0x600 desc="Enabled")
        setting (req=0x600 value=0x400 desc="Brown-out Reset enabled while running and disabled in Sleep")
        setting (req=0x600 value=0x200 desc="Brown-out Reset controlled by the SBOREN bit in the BORCON register")
        setting (req=0x600 value=0x0 desc="Disabled")
    field (key=CLKOUTEN mask=0x800 desc="Clock Out Enable")
        setting (req=0x800 value=0x800 desc="Disabled")
        setting (req=0x800 value=0x0 desc="Enabled")
    field (key=IESO mask=0x1000 desc="Internal/External Switchover Mode")
        setting (req=0x1000 value=0x1000 desc="Enabled")
        setting (req=0x1000 value=0x0 desc="Disabled")
    field (key=FCMEN mask=0x2000 desc="Fail-Safe Clock Monitor Enable")
        setting (req=0x2000 value=0x2000 desc="Enabled")
        setting (req=0x2000 value=0x0 desc="Disabled")
cfgbits (key=CONFIG2 addr=0x8008 unused=0x0)
    field (key=WRT mask=0x3 desc="Flash Memory Self-Write Protection")
        setting (req=0x3 value=0x3 desc="Disabled")
        setting (req=0x3 value=0x2 desc="000h to 1FFh write protected, 200h to 1FFFh may be modified by EECON control")
        setting (req=0x3 value=0x1 desc="000h to FFFh write protected, 1000h to 1FFFh may be modified by EECON control")
        setting (req=0x3 value=0x0 desc="000h to 1FFFh write protected, no addresses may be modified by EECON control")
    field (key=STVREN mask=0x200 desc="Stack Overflow/Underflow Reset Enable")
        setting (req=0x200 value=0x200 desc="Enabled")
        setting (req=0x200 value=0x0 desc="Disabled")
    field (key=BORV mask=0x400 desc="Brown-out Reset Voltage Selection")
        setting (req=0x400 value=0x400 desc="Brown-out Reset Voltage (Vbor), low trip point selected.")
        setting (req=0x400 value=0x0 desc="Brown-out Reset Voltage (Vbor), high trip point selected.")
    field (key=LPBOR mask=0x800 desc="Low-Power Brown Out Reset")
        setting (req=0x800 value=0x800 desc="Disabled")
        setting (req=0x800 value=0x0 desc="Enabled")
    field (key=DEBUG mask=0x1000 desc="In-Circuit Debugger Mode" flags=h)
        setting (req=0x1000 value=0x1000 desc="Disabled")
        setting (req=0x1000 value=0x0 desc="Enabled")
    field (key=LVP mask=0x2000 desc="Low-Voltage Programming Enable")
        setting (req=0x2000 value=0x2000 desc="Enabled")
        setting (req=0x2000 value=0x0 desc="Disabled")
