<!-- CRC: 90CF26913586BBA787FE92D553771933DEAE6524290455D503DA1BD28A791BE7FC1CCCFA5F4233CFD1787D44233A22EA491B2EC06CD066CD1CFBCC074345889E5AA0C2FE173941AF4D00059D79589982BB766F810B5E0DBEF255B49F3A640601414019F0D9E79C9B3713382C4A918B6C29A5F186A7B2A6E53971FC0682DB10544F44035638C377CC7D4B7146A7330FBDFECF2148D845C9369DE67E9860FAED8C91189F8935F1732E086944AE325796A6C51E80FA0DBDF3C073A12AAD73F9AAF2AD83450A7937048456E599B5AD11AA62EAC3685094CA720B -->
<!-- REVISION: 3.0 -->
<!-- GUID: B6724BB8-CC04-41C8-85FE-45E732284560 -->
<!-- DATE: 10\11\2021 -->
<!-- DIR: FCD\PIC\18F2585.fcdx -->
<root>
<device name='18F2585' product='PIC' cal='PIC' family='18F' bits='8' >
    <clock max_speed='40000000' master_divider='4' default='19660800' />
    <memory >
        <flash bytes='49152' />
        <ram bytes='3328' />
    </memory>
    <configuration address='1' mult='2' >
        <format >
            <word value='0xF2FF' />
            <word value='0xFEFF' />
            <word value='0xFFFF' />
            <word value='0xFF8B' />
            <word value='0xFFFF' />
            <word value='0xFFFF' />
            <word value='0xFFFF' />
        </format>
        <setting />
        <settings >
            <setting name='OSC' offset='8' mask='15' bits='4' hint='Oscillator' >
                <option name='EXT RC-CLKOUT on RA6' value='12' />
                <option name='EXT RC-CLKOUT on RA6' value='10' />
                <option name='INT RC-CLKOUT on RA6,Port on RA7' value='9' />
                <option name='INT RC-Port on RA6,Port on RA7' value='8' />
                <option name='EXT RC-Port on RA6' value='7' />
                <option name='HS-PLL enabled freq=4xFosc1' value='6' />
                <option name='EC-Port on RA6' value='5' />
                <option name='EC-CLKOUT on RA6' value='4' />
                <option name='EXT RC-CLKOUT on RA6' value='3' />
                <option name='HS' value='2' />
                <option name='XT' value='1' />
                <option name='LP' value='0' />
            </setting>
            <setting name='FCMEN' offset='14' mask='1' bits='1' hint='Fail-Safe Clock Monitor Enable' >
                <option name='Disabled' value='0' />
                <option name='Enabled' value='1' />
            </setting>
            <setting name='IESO' offset='15' mask='1' bits='1' hint='Internal External Switch Over Mode' >
                <option name='Disabled' value='0' />
                <option name='Enabled' value='1' />
            </setting>
            <setting name='PUT' offset='16' mask='1' bits='1' hint='Power Up Timer' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='BODEN' offset='17' mask='3' bits='2' hint='Brown Out Detect' >
                <option name='Enabled in hardware, SBOREN disabled' value='3' />
                <option name='Enabled while active,disabled in SLEEP,SBOREN disabled' value='2' />
                <option name='Controlled with SBOREN bit' value='1' />
                <option name='Disabled in hardware, SBOREN disabled' value='0' />
            </setting>
            <setting name='BODENV' offset='19' mask='3' bits='2' hint='Brown Out Voltage' >
                <option name='2.0V' value='3' />
                <option name='2.7V' value='2' />
                <option name='4.2V' value='1' />
                <option name='4.5V' value='0' />
            </setting>
            <setting name='WDT' offset='24' mask='1' bits='1' hint='Watchdog Timer' >
                <option name='Enabled' value='1' />
                <option name='Disabled-Controlled by SWDTEN bit' value='0' />
            </setting>
            <setting name='WDTPS' offset='25' mask='15' bits='4' hint='Watchdog Postscaler' >
                <option name='1:32768' value='15' />
                <option name='1:16384' value='14' />
                <option name='1:8192' value='13' />
                <option name='1:4096' value='12' />
                <option name='1:2048' value='11' />
                <option name='1:1024' value='10' />
                <option name='1:512' value='9' />
                <option name='1:256' value='8' />
                <option name='1:128' value='7' />
                <option name='1:64' value='6' />
                <option name='1:32' value='5' />
                <option name='1:16' value='4' />
                <option name='1:8' value='3' />
                <option name='1:4' value='2' />
                <option name='1:2' value='1' />
                <option name='1:1' value='0' />
            </setting>
            <setting name='PBADEN' offset='41' mask='1' bits='1' hint='PortB A/D Enable' >
                <option name='PORTB configured as analog inputs on RESET' value='1' />
                <option name='PORTB configured as digital I/O on RESET' value='0' />
            </setting>
            <setting name='LPT1OSC' offset='42' mask='1' bits='1' hint='Low Power Timer1 Osc enable' >
                <option name='Enabled' value='1' />
                <option name='Disabled' value='0' />
            </setting>
            <setting name='MCLRE' offset='47' mask='1' bits='1' hint='Master Clear Enable' >
                <option name='MCLR Enabled,RE3 Disabled' value='1' />
                <option name='MCLR Disabled, RE3 Enabled' value='0' />
            </setting>
            <setting name='STVR' offset='48' mask='1' bits='1' hint='Stack Overflow Reset' >
                <option name='Enabled' value='1' />
                <option name='Disabled' value='0' />
            </setting>
            <setting name='LVP' offset='50' mask='1' bits='1' hint='Low Voltage Program' >
                <option name='Enabled' value='1' />
                <option name='Disabled' value='0' />
            </setting>
            <setting name='BBSIZ' offset='52' mask='3' bits='2' hint='Boot Block Size 0' >
            	<option name='4K Words boot block' value='2' />
                <option name='2K Words boot block' value='1' />
                <option name='1K Words boot block' value='0' />
            </setting>
            <setting name='ENHCPU' offset='54' mask='1' bits='1' hint='Extended CPU Enable' >
                <option name='Enabled' value='1' />
                <option name='Disabled' value='0' />
            </setting>
            <setting name='BACKBUG' offset='55' mask='1' bits='1' hint='Background Debug' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='CP_0' offset='64' mask='1' bits='1' hint='Code Protect 00800-03FFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='CP_1' offset='65' mask='1' bits='1' hint='Code Protect 04000-07FFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='CP_2' offset='66' mask='1' bits='1' hint='Code Protect 08000-0BFFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='CP_3' offset='67' mask='1' bits='1' hint='Code Protect 0C000-0FFFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='CPD' offset='79' mask='1' bits='1' hint='Data EE Read Protect' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='CPB' offset='78' mask='1' bits='1' hint='Code Protect Boot' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='WRT_0' offset='80' mask='1' bits='1' hint='Table Write Protect 00800-03FFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='WRT_1' offset='81' mask='1' bits='1' hint='Table Write Protect 04000-07FFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='WRT_2' offset='82' mask='1' bits='1' hint='Table Write Protect 08000-0BFFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='WRT_3' offset='83' mask='1' bits='1' hint='Table Write Protect 0C000-0FFFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='WRTD' offset='95' mask='1' bits='1' hint='Data EE Write Protect' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='WRTB' offset='94' mask='1' bits='1' hint='Table Write Protect Boot' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='WRTC' offset='93' mask='1' bits='1' hint='Config. Write Protect' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='EBTR_0' offset='96' mask='1' bits='1' hint='Table Read Protect 00800-03FFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='EBTR_1' offset='97' mask='1' bits='1' hint='Table Read Protect 04000-07FFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='EBTR_2' offset='98' mask='1' bits='1' hint='Table Read Protect 08000-0BFFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='EBTR_3' offset='99' mask='1' bits='1' hint='Table Read Protect 0C000-0FFFF' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
            <setting name='EBTRB' offset='110' mask='1' bits='1' hint='Table Read Protect Boot' >
                <option name='Disabled' value='1' />
                <option name='Enabled' value='0' />
            </setting>
        </settings>
    </configuration>
    <pins sides='2' smd='0' >
        <pin name='RE3/MCLR' port='4' bit='3' in_only="1" />
        <pin name='RA0/AN0' port='0' bit='0' adc='0' />
        <pin name='RA1/AN1' port='0' bit='1' adc='1' />
        <pin name='RA2/AN2/VREF-' port='0' bit='2' adc='2' />
        <pin name='RA3/AN3/VREF+' port='0' bit='3' adc='3' />
        <pin name='RA4/T0CKI' port='0' bit='4' />
        <pin name='RA5/AN4/SS/HLVDIN' port='0' bit='5' adc='4' />
        <pin name='VSS' />
        <pin name='OSC1/CLKI/RA7' port='0' bit='7' />
        <pin name='OSC2/CLKO/RA6' port='0' bit='6' />
        <pin name='RC0/T1OSO/T3CKI' port='2' bit='0' />
        <pin name='RC1/T1OSI' port='2' bit='1' />
        <pin name='RC2/CCP1' port='2' bit='2' />
        <pin name='RC3/SCK/SCL' port='2' bit='3' />
        <pin name='RC4/SDI/SDA' port='2' bit='4' />
        <pin name='RC5/SDO' port='2' bit='5' />
        <pin name='RC6/TX/CK' port='2' bit='6' />
        <pin name='RC7/RX/DT' port='2' bit='7' />
        <pin name='VSS' />
        <pin name='VDD' />
        <pin name='RB0/AN10/INT0' port='1' bit='0' adc='10' />
        <pin name='RB1/AN8/INT1' port='1' bit='1' adc='8' />
        <pin name='RB2/INT2/CANTX' port='1' bit='2' />
        <pin name='RB3/CANRX' port='1' bit='3' />
        <pin name='RB4/AN9/KBI0' port='1' bit='4' adc='9' />
        <pin name='RB5/KBI1/PGM' port='1' bit='5' />
        <pin name='RB6/KBI2/PGC' port='1' bit='6' />
        <pin name='RB7/KBI3/PGD' port='1' bit='7' />
    </pins>
    <adc type='13' bits='10' >
        <speed >
            <option name='Fosc / 2' value='0' />
            <option name='Fosc / 8' value='1' />
            <option name='Fosc / 32' value='2' />
            <option name='FRC' value='3' />
            <option name='Fosc / 4' value='4' />
            <option name='Fosc / 16' value='5' />
            <option name='Fosc / 64' value='6' />
        </speed>
    </adc>
    <eeprom type='3' bytes='1024' />
    <spi >
        <miso port='2' pin='4' />
        <mosi port='2' pin='5' />
        <clk port='2' pin='3' />
        <ss port='0' pin='5' />
    </spi>
    <uart >
        <tx port='2' pin='6' />
        <rx port='2' pin='7' />
    </uart>
    <i2c master='1' >
        <sda port='2' pin='4' />
        <scl port='2' pin='3' />
    </i2c>
    <pwm>
    	<timer>
    	    <option name='Timer2' value='2' />
    	</timer>
        <prescaler >
            <option name='1' value='1' />
            <option name='4' value='4' />
            <option name='16' value='16' />
        </prescaler>
        <out port='2' pin='2' />
    </pwm>
    <can >
        <tx port='1' pin='2' />
        <rx port='1' pin='3' />
    </can>
    <intosc>
        <option name='31000' value='OSCCON = 0x00;' />  
        <option name='125000' value='OSCCON = 0x10;' /> 
    	<option name='250000' value='OSCCON = 0x20;' /> 
    	<option name='500000' value='OSCCON = 0x30;' /> 
    	<option name='1000000' value='OSCCON = 0x40;' default='1' /> 
    	<option name='2000000' value='OSCCON = 0x50;' /> 
    	<option name='4000000' value='OSCCON = 0x60;' /> 
    	<option name='8000000' value='OSCCON = 0x70;' /> 
    </intosc>
    <interrupts >
        <interrupt ident='TMR0' regl='TMR0' regh='' type='timer8' name='Timer 0' handler='#ifndef MX_INTHANDLER_INTCON_TMR0IF\n#define MX_INTHANDLER_INTCON_TMR0IF\nif (ts_bit(INTCON, TMR0IF) &amp;&amp; ts_bit(INTCON, TMR0IE))\n{\n\tFCM_%n();\n\tcr_bit(INTCON, TMR0IF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif\n' enable='st_bit(INTCON, TMR0IE);\n' disable='cr_bit(INTCON, TMR0IE);\n' >
            <timer overflow='256' extrange='0' />
            <options >
                <option name='Clock Source Select' >
                    <entry name='Transition on T0CKI pin' clkdiv='0' value='st_bit(T0CON, T0CS);\n' />
                    <entry name='Internal clock (CLKO)' clkdiv='4' value='cr_bit(T0CON, T0CS);\n' />
                </option>
                <option name='Source Edge Select' >
                    <entry name='high-to-low transition on TMR0 Clock' value='st_bit(T0CON, T0SE);\n' />
                    <entry name='low-to-high transition on TMR0 Clock' value='cr_bit(T0CON, T0SE);\n' />
                </option>
                <prescale name='Prescaler Rate' >
                    <entry name='1:1' value='T0CON = (T0CON &amp; 0xF0) | 0x08;\n' />
                    <entry name='1:2' value='T0CON = (T0CON &amp; 0xF0) | 0x00;\n' />
                    <entry name='1:4' value='T0CON = (T0CON &amp; 0xF0) | 0x01;\n' />
                    <entry name='1:8' value='T0CON = (T0CON &amp; 0xF0) | 0x02;\n' />
                    <entry name='1:16' value='T0CON = (T0CON &amp; 0xF0) | 0x03;\n' />
                    <entry name='1:32' value='T0CON = (T0CON &amp; 0xF0) | 0x04;\n' />
                    <entry name='1:64' value='T0CON = (T0CON &amp; 0xF0) | 0x05;\n' />
                    <entry name='1:128' value='T0CON = (T0CON &amp; 0xF0) | 0x06;\n' />
                    <entry name='1:256' value='T0CON = (T0CON &amp; 0xF0) | 0x07;\n' />
                </prescale>
            </options>
        </interrupt>
        <interrupt ident='INT0' type='pin' name='INT0 Pin' handler='#ifndef MX_INTHANDLER_INTCON_INT0IF\n#define MX_INTHANDLER_INTCON_INT0IF\nif (ts_bit(INTCON, INT0IF) &amp;&amp; ts_bit(INTCON, INT0IE))\n{\n\tFCM_%n();\n\tcr_bit(INTCON, INT0IF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif\n' enable='st_bit(INTCON, INT0IE);\n' disable='cr_bit(INTCON, INT0IE);\n' >
            <ioc config='3' >
                <rising port='1' mask='1' />
                <falling port='1' mask='1' />
            </ioc>
            <options >
                <edge name='Interrupt Edge Select' >
                    <entry name='Rising edge of INT' value='st_bit(INTCON2, INTEDG0);\n' />
                    <entry name='Falling edge of INT' value='cr_bit(INTCON2, INTEDG0);\n' />
                </edge>
            </options>
        </interrupt>
        <interrupt ident='IOC0' type='multipin' name='IOC PORTB' handler='#ifndef MX_INTHANDLER_INTCON_RBIF\n#define MX_INTHANDLER_INTCON_RBIF\nchar mxtmp;\nif (ts_bit(INTCON, RBIF) &amp;&amp; ts_bit(INTCON, RBIE))\n{\n\tFCM_%n();\n\tmxtmp=PORTB;\n\tcr_bit(INTCON, RBIF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif\n' enable='st_bit(INTCON, RBIE);\n' disable='cr_bit(INTCON, RBIE);\n' >
            <ioc config='4' >
                <rising port='1' mask='0xF0' />
                <falling port='1' mask='0xF0' />
            </ioc>
            <options >
                <option name='Interrupt Pins' >
                    <entry name='RB4 - RB7' value='' />
                </option>
            </options>
        </interrupt>
        <interrupt ident='TMR1' regl='TMR1L' regh='TMR1H' type='timer16' name='Timer 1' handler='#ifndef MX_INTHANDLER_PIR1_TMR1IF\n#define MX_INTHANDLER_PIR1_TMR1IF\nif (ts_bit(PIR1, TMR1IF) &amp;&amp; ts_bit(PIE1, TMR1IE))\n{\n\tFCM_%n();\n\tcr_bit(PIR1, TMR1IF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif\n' enable='st_bit(INTCON, PEIE);\nst_bit(PIE1, TMR1IE);\n' disable='cr_bit(PIE1, TMR1IE);\n' >
            <timer overflow='65536' extrange='0' />
            <options >
                <option name='Clock Source Select' >
                    <entry name='Transition on T1CKI pin' clkdiv='0' value='cr_bit(T1CON, T1OSCEN);\nst_bit(T1CON, TMR1ON);\nst_bit(T1CON, TMR1CS);\n' />
                    <entry name='Internal clock (Fosc/4)' clkdiv='4' value='cr_bit(T1CON, T1OSCEN);\nst_bit(T1CON, TMR1ON);\ncr_bit(T1CON, TMR1CS);\n' />
                    <entry name='32.768KHz XTAL T1CKI/T1CKO' clkdiv='0' value='st_bit(T1CON, T1OSCEN);\nst_bit(T1CON, TMR1ON);\nst_bit(T1CON, TMR1CS);\n' />
                </option>
                <prescale name='Prescaler Rate' >
                    <entry name='1:1' value='T1CON = T1CON &amp; 0xCF;\n' />
                    <entry name='1:2' value='T1CON = (T1CON &amp; 0xCF) | 0x10;\n' />
                    <entry name='1:4' value='T1CON = (T1CON &amp; 0xCF) | 0x20;\n' />
                    <entry name='1:8' value='T1CON = (T1CON &amp; 0xCF) | 0x30;\n' />
                </prescale>
            </options>
        </interrupt>
        <interrupt ident='INT1' type='pin' name='INT1 Pin' handler='#ifndef MX_INTHANDLER_INTCON3_INT1IF\n#define MX_INTHANDLER_INTCON3_INT1IF\nif (ts_bit(INTCON3, INT1IF) &amp;&amp; ts_bit(INTCON3, INT1IE))\n{\n\tFCM_%n();\n\tcr_bit(INTCON3, INT1IF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif\n' enable='st_bit(INTCON3, INT1IE);\n' disable='cr_bit(INTCON3, INT1IE);\n' >
            <ioc config='3' >
                <rising port='1' mask='2' />
                <falling port='1' mask='2' />
            </ioc>
            <options >
                <edge name='Interrupt Edge Select' >
                    <entry name='Rising edge of INT' value='st_bit(INTCON2, INTEDG1);\n' />
                    <entry name='Falling edge of INT' value='cr_bit(INTCON2, INTEDG1);\n' />
                </edge>
            </options>
        </interrupt>
        <interrupt ident='INT2' type='pin' name='INT2 Pin' handler='#ifndef MX_INTHANDLER_INTCON3_INT2IF\n#define MX_INTHANDLER_INTCON3_INT2IF\nif (ts_bit(INTCON3, INT2IF) &amp;&amp; ts_bit(INTCON3, INT2IE))\n{\n\tFCM_%n();\n\tcr_bit(INTCON3, INT2IF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif\n' enable='st_bit(INTCON3, INT2IE);\n' disable='cr_bit(INTCON3, INT2IE);\n' >
            <ioc config='3' >
                <rising port='1' mask='4' />
                <falling port='1' mask='4' />
            </ioc>
            <options >
                <edge name='Interrupt Edge Select' >
                    <entry name='Rising edge of INT' value='st_bit(INTCON2, INTEDG2);\n' />
                    <entry name='Falling edge of INT' value='cr_bit(INTCON2, INTEDG2);\n' />
                </edge>
            </options>
        </interrupt>
        <interrupt ident='RXINT0' type='comms' name='UART RXINT0' handler='#ifndef MX_INTHANDLER_PIR1_RCIF\n#define MX_INTHANDLER_PIR1_RCIF\nif (ts_bit(PIR1, RCIF) &amp;&amp; ts_bit(PIE1, RCIE))\n{\n\tFCM_%n();\n\tcr_bit(PIR1, RCIF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif' enable='st_bit(INTCON, PEIE);\nst_bit(PIE1, RCIE);\n' disable='cr_bit(PIE1, RCIE);\n' />
        <interrupt ident='TXINT0' type='comms' name='UART TXINT0' handler='#ifndef MX_INTHANDLER_PIR1_TXIF\n#define MX_INTHANDLER_PIR1_TXIF\nif (ts_bit(PIR1, TXIF) &amp;&amp; ts_bit(PIE1, TXIE))\n{\n\tFCM_%n();\n\tcr_bit(PIR1, TXIF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif' enable='st_bit(INTCON, PEIE);\nst_bit(PIE1, TXIE);\n' disable='cr_bit(PIE1, TXIE);\n' />
        <interrupt ident='TMR2' regl='TMR2' regh='' type='timer8' name='Timer 2' handler='#ifndef MX_INTHANDLER_PIR1_TMR2IF\n#define MX_INTHANDLER_PIR1_TMR2IF\nif (ts_bit(PIR1, TMR2IF) &amp;&amp; ts_bit(PIE1, TMR2IE))\n{\n\tFCM_%n();\n\tcr_bit(PIR1, TMR2IF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif' enable='st_bit(INTCON, PEIE);\nst_bit(PIE1, TMR2IE);\n' disable='cr_bit(PIE1, TMR2IE);\n' >
            <timer overflow='256' extrange='0' />
            <options >
                <prescale name='Prescaler Rate' >
                    <entry name='1:1' value='cr_bit(T2CON, T2CKPS0);\ncr_bit(T2CON, T2CKPS1);\nst_bit(T2CON, TMR2ON);\n' />
                    <entry name='1:4' value='st_bit(T2CON, T2CKPS0);\ncr_bit(T2CON, T2CKPS1);\nst_bit(T2CON, TMR2ON);\n' />
                    <entry name='1:16' value='cr_bit(T2CON, T2CKPS0);\nst_bit(T2CON, T2CKPS1);\nst_bit(T2CON, TMR2ON);\n' />
                </prescale>
                <postscale name='Postscaler Rate' >
                    <entry name='1:1' value='T2CON = T2CON &amp; 0x07;\n' />
                    <entry name='1:2' value='T2CON = (T2CON &amp; 0x07) | 0x08;\n' />
                    <entry name='1:3' value='T2CON = (T2CON &amp; 0x07) | 0x10;\n' />
                    <entry name='1:4' value='T2CON = (T2CON &amp; 0x07) | 0x18;\n' />
                    <entry name='1:5' value='T2CON = (T2CON &amp; 0x07) | 0x20;\n' />
                    <entry name='1:6' value='T2CON = (T2CON &amp; 0x07) | 0x28;\n' />
                    <entry name='1:7' value='T2CON = (T2CON &amp; 0x07) | 0x30;\n' />
                    <entry name='1:8' value='T2CON = (T2CON &amp; 0x07) | 0x38;\n' />
                    <entry name='1:9' value='T2CON = (T2CON &amp; 0x07) | 0x40;\n' />
                    <entry name='1:10' value='T2CON = (T2CON &amp; 0x07) | 0x48;\n' />
                    <entry name='1:11' value='T2CON = (T2CON &amp; 0x07) | 0x50;\n' />
                    <entry name='1:12' value='T2CON = (T2CON &amp; 0x07) | 0x58;\n' />
                    <entry name='1:13' value='T2CON = (T2CON &amp; 0x07) | 0x60;\n' />
                    <entry name='1:14' value='T2CON = (T2CON &amp; 0x07) | 0x68;\n' />
                    <entry name='1:15' value='T2CON = (T2CON &amp; 0x07) | 0x70;\n' />
                    <entry name='1:16' value='T2CON = (T2CON &amp; 0x07) | 0x78;\n' />
                </postscale>
                <rollover name='Rollover Value' >
                    <entry name='256' min='1' max='256' value='PR2=%d-1;\n' />
                </rollover>
            </options>
        </interrupt>
        <interrupt ident='TMR3' regl='TMR3L' regh='TMR3H' type='timer16' name='Timer 3' handler='#ifndef MX_INTHANDLER_PIR2_TMR3IF\n#define MX_INTHANDLER_PIR2_TMR3IF\nif (ts_bit(PIR2, TMR3IF) &amp;&amp; ts_bit(PIE2, TMR3IE))\n{\n\tFCM_%n();\n\tcr_bit(PIR2, TMR3IF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif\n' enable='st_bit(INTCON, PEIE);\nst_bit(PIE2, TMR3IE);\n' disable='cr_bit(PIE2, TMR3IE);\n' >
            <timer overflow='65536' extrange='0' />
            <options >
                <option name='Clock Source Select' >
                    <entry name='Transition on T3CKI pin' clkdiv='0' value='st_bit(T3CON, TMR3ON);\nst_bit(T3CON, TMR3CS);\n' />
                    <entry name='Internal clock (Fosc/4)' clkdiv='4' value='st_bit(T3CON, TMR3ON);\ncr_bit(T3CON, TMR3CS);\n' />
                </option>
                <prescale name='Prescaler Rate' >
                    <entry name='1:1' value='T3CON = T3CON &amp; 0xCF;\n' />
                    <entry name='1:2' value='T3CON = (T3CON &amp; 0xCF) | 0x10;\n' />
                    <entry name='1:4' value='T3CON = (T3CON &amp; 0xCF) | 0x20;\n' />
                    <entry name='1:8' value='T3CON = (T3CON &amp; 0xCF) | 0x30;\n' />
                </prescale>
            </options>
        </interrupt>
        <interrupt ident='SSP0' type='comms' name='Synchronous Serial Port1' handler='#ifndef MX_INTHANDLER_PIR1_SSPIF\n#define MX_INTHANDLER_PIR1_SSPIF\nif (ts_bit(PIR1, SSPIF) &amp;&amp; ts_bit(PIE1, SSPIE))\n{\n\tFCM_%n();\n\tcr_bit(PIR1, SSPIF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif\n' enable='st_bit(PIE1, SSPIE);\nst_bit(INTCON, PEIE);\n' disable='cr_bit(PIE1, SSPIE);\n' />
        <interrupt ident='CANRXBUF0' type='comms' name='CAN RX BUF0' handler='#ifndef MX_INTHANDLER_PIR3_RXB0IF\n#define MX_INTHANDLER_PIR3_RXB0IF\nif (ts_bit(PIR3, RXB0IF) &amp;&amp; ts_bit(PIE3, RXB0IE))\n{\n\tFCM_%n();\n\tcr_bit(PIR3, RXB0IF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif' enable='st_bit(INTCON, PEIE);\nst_bit(PIE3, RXB0IE);\n' disable='cr_bit(PIE3, RXB0IE);\n' />
        <interrupt ident='CANRXBUF1' type='comms' name='CAN RX BUF1' handler='#ifndef MX_INTHANDLER_PIR3_RXB1IF\n#define MX_INTHANDLER_PIR3_RXB1IF\nif (ts_bit(PIR3, RXB1IF) &amp;&amp; ts_bit(PIE3, RXB1IE))\n{\n\tFCM_%n();\n\tcr_bit(PIR3, RXB1IF);\n}\n#else\n#warning &quot;This interrupt has previously been enabled, so the macro &lt;%n&gt; may never get called.&quot;\n#endif' enable='st_bit(INTCON, PEIE);\nst_bit(PIE3, RXB1IE);\n' disable='cr_bit(PIE3, RXB1IE);\n' />
    </interrupts>
</device>
<inline >
    <defines code="//Missing TRISE workaround\nunsigned char TRISE;\n\n" />
    <directives code="#include &lt;xc.h&gt;\n#include &lt;math.h&gt;\n\n" />
    <main >
        <start code='\nvoid main()\n{\n\t#ifdef INTOSCHELPER\n\t\tINTOSCHELPERCODE\n\t#endif\n\n' />
        <end code='\tmainendloop: goto mainendloop;\n}\n\n' />
        <init code='ADCON1 = 0x0F;\nCCP1CON=0x00;\n' />
    </main>
    <interrupt >
        <enable code='st_bit(INTCON, GIE);\n' />
        <start code='void MX_INTERRUPT_MACRO(void)\n{\n' />
        <end code='}\n\n' />
        <init code='\n\n' />
    </interrupt>
    <config >
	<start code='//Chip Configuration Settings\n' />
        <body code='__PROG_CONFIG($(address), 0x$(value:x));\n' /> 
    </config>
</inline>
<test >
    <icd >
        <clock port='1' pin='6' />
        <data port='1' pin='7' />
    </icd>
</test>
</root>
