<!-- CRC: 90CF26913586BBA787FE92D5537719339858A0D60DBEF79113C5DBCFD873BE2F2B702871DF5ADABCC487AA0E0C74ACDB9A0D46BD3B6AACB92DE4D84759EBB5079CA9DA2D2BBCDAE2A4D1C56CD1580BF50A2F262931DD02354D9AF1A81C2F805A5A133FC5CCC52404F4AAFEBE58FD5B6DBD162583B24A225984491F41E3A57E98A8A8402A5D2F6382348E75EECEB8CE0167210F0FAED4D2B7BAD9F28994B6A5842A2B72B55F431F82086944AE325796A651A5E4892BF5AFE4D87D4D02409CCB0F0EF54BC0953EE0AA -->
<!-- REVISION: 1.0 -->
<!-- GUID: 42DA2ABA-BBC6-4F8B-8EEE-D9F815B28481 -->
<!-- DATE: 08\08\2022 -->
<!-- DIR: FCD\PIC\16F688.fcdx -->
<root>

<device name='16F688' namealt="PIC16F688" product='PIC' cal='PIC' family='16F' bits='8' >
    <clock max_speed='20000000' master_divider='4' default='19660800' />
    <memory >
        <flash bytes='7168' />
        <ram bytes='256' />
    </memory>
    <configuration address='1' mult='2' >
	<format >
	  <word value='0x3FFF' />
        </format>
        <setting />
        <settings >
            <setting name='OSC' offset='0' mask='7' bits='3' hint='Oscillator' >
                <option name='External RC Clockout' value='7' />
                <option name='External RC No Clock' value='6' />
                <option name='Internal RC Clockout' value='5' />
                <option name='Internal RC No Clock' value='4' />
                <option name='EC' value='3' />
                <option name='HS' value='2' />
                <option name='XT' value='1' />
                <option name='LP' value='0' />
            </setting>
            <setting name='WDT' offset='3' mask='1' bits='1' hint='Watchdog Timer' >
                <option name='On' value='1' />
                <option name='Off' value='0' />
            </setting>
            <setting name='PUT' offset='4' mask='1' bits='1' hint='Power Up Timer' >
                <option name='Off' value='1' />
                <option name='On' value='0' />
            </setting>
            <setting name='MCLRE' offset='5' mask='1' bits='1' hint='Master Clear Enable' >
                <option name='External' value='1' />
                <option name='Internal' value='0' />
            </setting>
            <setting name='CP' offset='6' mask='1' bits='1' hint='Code Protect' >
                <option name='Off' value='1' />
                <option name='On' value='0' />
            </setting>
            <setting name='CPD' offset='7' mask='1' bits='1' hint='Data EE Read Protect' >
                <option name='Off' value='1' />
                <option name='On' value='0' />
            </setting>
            <setting name='BODEN' offset='8' mask='3' bits='2' hint='Brown Out Detect' >
                <option name='BOD and SBOREN disabled' value='0' />
                <option name='SBOREN controls BOR function' value='1' />
                <option name='BOD enabled in run, disabled in sleep, SBOREN disabled' value='2' />
                <option name='BOD Enabled, SBOREN Disabled' value='3' />
            </setting>
            <setting name='IESO' offset='10' mask='1' bits='1' hint='Internal External Switch Over Mode' >
                <option name='Enabled' value='1' />
                <option name='Disabled' value='0' />
            </setting>
            <setting name='FCMEN' offset='11' mask='1' bits='1' hint='Monitor Clock Fail-safe' >
                <option name='Enabled' value='1' />
                <option name='Disabled' value='0' />
            </setting>
        </settings>
    </configuration>
    <pins sides='2' smd='0' >
        <pin name='VDD' />
        <pin name='RA5/T1CKI/OSC1/CLKIN' port='0' bit='5' />
        <pin name='RA4/T1G/AN3/OSC2/CLKOUT' port='0' bit='4' adc='3' />
        <pin name='RA3/MCLR' port='0' bit='3' in_only="1" />
        <pin name='RC5' port='2' bit='5' />
        <pin name='RC4' port='2' bit='4' />
        <pin name='RC3/AN7' port='2' bit='3' adc='7' />
        <pin name='RC2/AN6' port='2' bit='2' adc='6' />
        <pin name='RC1/AN5' port='2' bit='1' adc='5' />
        <pin name='RC0/AN4' port='2' bit='0' adc='4' />
        <pin name='RA2/AN2/C1OUT/T0CKI/INT' port='0' bit='2' adc='2' />
        <pin name='RA1/AN1/CIN-/ICSPCLK' port='0' bit='1' adc='1' />
        <pin name='RA0/AN0/CIN+/ICSPDAT' port='0' bit='0' adc='0' />
        <pin name='VSS' />
    </pins>
    <adc type='3' 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='1' bytes='256' />
    <uart >
        <tx port='2' pin='4' />
        <rx port='2' pin='5' />
    </uart>
    <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;' /> 
    	<option name='2000000' value='OSCCON = 0x50;' /> 
    	<option name='4000000' value='OSCCON = 0x60;' default='1' /> 
    	<option name='8000000' value='OSCCON = 0x70;' /> 
    </intosc>
    <interrupts >
        <interrupt ident='TMR0' regl='TMR0' regh='' type='timer8' name='Timer 0' handler='#ifndef MX_INTHANDLER_INTCON_T0IF\n#define MX_INTHANDLER_INTCON_T0IF\nif (ts_bit(INTCON, T0IF) &amp;&amp; ts_bit(INTCON, T0IE))\n{\n\tFCM_%n();\n\tcr_bit(INTCON, T0IF);\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, T0IE);\n' disable='cr_bit(INTCON, T0IE);\n' >
            <timer overflow='256' extrange='0' />
            <options >
                <option name='Clock Source Select' >
                    <entry name='Transition on T0CKI pin' clkdiv='0' value='st_bit(OPTION_REG,T0CS);\n' />
                    <entry name='Internal clock (CLKO)' clkdiv='4' value='cr_bit(OPTION_REG,T0CS);\n' />
                </option>
                <option name='Source Edge Select' >
                    <entry name='high-to-low transition on TMR0 Clock' value='st_bit(OPTION_REG,T0SE);\n' />
                    <entry name='low-to-high transition on TMR0 Clock' value='cr_bit(OPTION_REG,T0SE);\n' />
                </option>
                <prescale name='Prescaler Rate' >
                    <entry name='1:1' value='OPTION_REG = (OPTION_REG &amp; 0xF0) | 0x08;\n' />
                    <entry name='1:2' value='OPTION_REG = (OPTION_REG &amp; 0xF0) | 0x00;\n' />
                    <entry name='1:4' value='OPTION_REG = (OPTION_REG &amp; 0xF0) | 0x01;\n' />
                    <entry name='1:8' value='OPTION_REG = (OPTION_REG &amp; 0xF0) | 0x02;\n' />
                    <entry name='1:16' value='OPTION_REG = (OPTION_REG &amp; 0xF0) | 0x03;\n' />
                    <entry name='1:32' value='OPTION_REG = (OPTION_REG &amp; 0xF0) | 0x04;\n' />
                    <entry name='1:64' value='OPTION_REG = (OPTION_REG &amp; 0xF0) | 0x05;\n' />
                    <entry name='1:128' value='OPTION_REG = (OPTION_REG &amp; 0xF0) | 0x06;\n' />
                    <entry name='1:256' value='OPTION_REG = (OPTION_REG &amp; 0xF0) | 0x07;\n' />
                </prescale>
            </options>
        </interrupt>
        <interrupt ident='INT0' type='pin' name='INT0 Pin' handler='#ifndef MX_INTHANDLER_INTCON_INTF\n#define MX_INTHANDLER_INTCON_INTF\nif (ts_bit(INTCON, INTF) &amp;&amp; ts_bit(INTCON, INTE))\n{\n\tFCM_%n();\n\tcr_bit(INTCON, INTF);\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, INTE);\n' disable='cr_bit(INTCON, INTE);\n' >
            <ioc config='3' >
                <rising port='0' mask='4' />
                <falling port='0' mask='4' />
            </ioc>
            <options >
                <edge name='Interrupt Edge Select' >
                    <entry name='Rising edge of INT' value='st_bit(OPTION_REG,INTEDG);\n' />
                    <entry name='Falling edge of INT' value='cr_bit(OPTION_REG,INTEDG);\n' />
                </edge>
            </options>
        </interrupt>
        <interrupt ident='IOC0' type='multipin' name='IOC PORTA' handler='#ifndef MX_INTHANDLER_INTCON_RAIF\n#define MX_INTHANDLER_INTCON_RAIF\nchar mxtmp;\nif (ts_bit(INTCON, RAIF) &amp;&amp; ts_bit(INTCON, RAIE))\n{\n\tFCM_%n();\n\tmxtmp=PORTA;\n\tcr_bit(INTCON, RAIF);\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='IOCA=%pA0v;\nst_bit(INTCON, RAIE);\n' disable='cr_bit(INTCON, RAIE);\n' >
            <ioc config='0x0C' >
                <rising port='0' mask='0x3F' />
                <falling port='0' mask='0x3F' />
            </ioc>
        </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(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='st_bit(INTCON,PEIE);\ncr_bit(T1CON,T1OSCEN);\nst_bit(T1CON,TMR1ON);\nst_bit(T1CON,TMR1CS);\n' />
                    <entry name='Internal clock (Fosc/4)' clkdiv='4' value='st_bit(INTCON,PEIE);\ncr_bit(T1CON,T1OSCEN);\nst_bit(T1CON,TMR1ON);\ncr_bit(T1CON,TMR1CS);\n' />
                    <entry name='32.768KHz XTAL T1CKI/T1CKO' clkdiv='0' value='st_bit(INTCON,PEIE);\nst_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; 0x0F;\n' />
                    <entry name='1:2' value='T1CON = (T1CON &amp; 0x0F) | 0x10;\n' />
                    <entry name='1:4' value='T1CON = (T1CON &amp; 0x0F) | 0x20;\n' />
                    <entry name='1:8' value='T1CON = (T1CON &amp; 0x0F) | 0x30;\n' />
                </prescale>
            </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\n' enable='st_bit(PIE1, RCIE);\nst_bit(INTCON, PEIE);\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\n' enable='st_bit(PIE1, TXIE);\nst_bit(INTCON, PEIE);\n' disable='cr_bit(PIE1, TXIE);\n' />
    </interrupts>
</device>
<inline >
    <defines code="" />
    <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='ANSEL = 0x00;\nCMCON0 = 0x07;\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='OPTION_REG = 0xC0;\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='0' pin='1' />
        <data port='0' pin='0' />
    </icd>
</test>
</root>
