[Device] Pins=40 Ports=5 ADCPins=8 ADCBits=10 MaxClock=20000000 PrescalerBits=3 ClockDivider=4 TimerOverflow=256 ConfigAddress=0x2007 ConfigCount=1 PWMCount=2 EepromSize=256 HasAltPWM=0 Pwm2IsD4=0 FlowcodeProduct=PIC ChipName=16F877a [Pins] Pin1 = "MCLR/VPP" Pin2 = "RA0/AN0" Pin3 = "RA1/AN1" Pin4 = "RA2/AN2/VREF-/CVREF" Pin5 = "RA3/AN3/VREF+" Pin6 = "RA4/T0CKI/C1OUT" Pin7 = "RA5/AN4/SS/C2OUT" Pin8 = "RE0/RD/AN5" Pin9 = "RE1/WR/AN6" Pin10 = "RE2/CS/AN7" Pin11 = "VDD" Pin12 = "VSS" Pin13 = "OSC1/CLKIN" Pin14 = "OSC2/CLKOUT" Pin15 = "RC0/T1OSO/T1CKI" Pin16 = "RC1/T1OSI/CCP2" Pin17 = "RC2/CCP1" Pin18 = "RC3/SCK/SCL" Pin19 = "RD0/PSP0" Pin20 = "RD1/PSP1" Pin21 = "RD2/PSP2" Pin22 = "RD3/PSP3" Pin23 = "RC4/SDI/SDA" Pin24 = "RC5/SDO" Pin25 = "RC6/TX/CK" Pin26 = "RC7/RX/DT" Pin27 = "RD4/PSP4" Pin28 = "RD5/PSP5" Pin29 = "RD6/PSP6" Pin30 = "RD7/PSP7" Pin31 = "VSS" Pin32 = "VDD" Pin33 = "RB0/INT" Pin34 = "RB1" Pin35 = "RB2" Pin36 = "RB3/PGM" Pin37 = "RB4" Pin38 = "RB5" Pin39 = "RB6/PGC" Pin40 = "RB7/PGD" [Ports] PortPin2=0x0000 PortPin3=0x0001 PortPin4=0x0002 PortPin5=0x0003 PortPin6=0x0004 PortPin7=0x0005 PortPin8=0x0400 PortPin9=0x0401 PortPin10=0x0402 PortPin15=0x0200 PortPin16=0x0201 PortPin17=0x0202 PortPin18=0x0203 PortPin19=0x0300 PortPin20=0x0301 PortPin21=0x0302 PortPin22=0x0303 PortPin23=0x0204 PortPin24=0x0205 PortPin25=0x0206 PortPin26=0x0207 PortPin27=0x0304 PortPin28=0x0305 PortPin29=0x0306 PortPin30=0x0307 PortPin33=0x0100 PortPin34=0x0101 PortPin35=0x0102 PortPin36=0x0103 PortPin37=0x0104 PortPin38=0x0105 PortPin39=0x0106 PortPin40=0x0107 [PortMasks] ;Only bits 0-5 available on port A ;Bits 0-2 available on port E PortMask0=0x3F PortMask1=0xFF PortMask2=0xFF PortMask3=0xFF PortMask4=0x07 [ADCPins] ADC0=2 ADC1=3 ADC2=4 ADC3=5 ADC4=7 ADC5=8 ADC6=9 ADC7=10 [Code] ;Substitute macros ;%c Clock Speed ;%o Operand ;%s Prescaler ;%p PortID ;%m MaskBits ;%i Inverse Mask ;%a ADC channel ;%a Config Address ;%v Config Value ;%r Interrupt Flag Register ;%b Interrupt Flag Bit ;%n Interrupt Macro Name Directives="#include \n#pragma CLOCK_FREQ %c\n" MainStart="void main()\n{\n" MainEnd="\tmainendloop: goto mainendloop;\n}\n\n" IntStart="void interrupt(void)\n{\n" IntEnd="}\n\n" Initialise="adcon1 = 0x07;\n" IntInit="option_reg = 0xC0;\n\n" InputCmdFull="tris%p = tris%p | %m;\n%o = port%p;\n" InputCmdOneBit="tris%p = tris%p | %m;\n%o = ((port%p & %m) == %m);\n" InputCmdMask="tris%p = tris%p | %m;\n%o = port%p & %m;\n" OutputCmdFull="tris%p = 0x00;\nport%p = %o;\n" OutputCmdOneBit="tris%p = tris%p & %i;\nif (%o)\n\tport%p = (port%p & %i) | %m;\nelse\n\tport%p = port%p & %i;\n" OutputCmdMask="tris%p = tris%p & %i;\nport%p = (port%p & %i) | (%o & %m);\n" DelayCmdS="delay_s(%o);\n" DelayCmdMs="delay_ms(%o);\n" ADCCapture="char ta, te, cnt;\nadcon1 = 0x01;\nta = trisa;\ntrisa = trisa | 0x2F;\nte = trise;\ntrise = trise | 0x07;\nadcon0 = 0x81 | (%a << 3);\ncnt =0;\nwhile (cnt <40) cnt++;\nadcon0 = adcon0 | 0x04;\nwhile (adcon0 & 0x04) ;\ntrisa = ta;\ntrise = te;\nadcon1 = 0x07;\nadcon0 = 0x80;\n" ADCHigh="return adresh;\n" ADCLow="char adclow;\nadclow = adresl;\nreturn adclow;\n" ADCFull="short iRetVal;\niRetVal = (adresh << 2);\niRetVal += (adresl >> 6);\nreturn (iRetVal);\n" InitialPortLetter="a" ConfigData="#pragma DATA %a, %v\n" IntHandler="if (%r & (1 << %b))\n{\n\tFCM_%n();\n\tclear_bit(%r, %b);\n}\n" [Defines] Define1=#define P16F877A Define2=#define MX_EE Define3=#define MX_EE_TYPE2 Define4=#define MX_EE_SIZE 256 Define5=#define MX_SPI Define6=#define MX_SPI_C Define7=#define MX_SPI_SDI 4 Define8=#define MX_SPI_SDO 5 Define9=#define MX_SPI_SCK 3 Define10=#define MX_UART Define11=#define MX_UART_C Define12=#define MX_UART_TX 6 Define13=#define MX_UART_RX 7 Define14=#define MX_I2C Define15=#define MX_MI2C Define16=#define MX_I2C_C Define17=#define MX_I2C_SDA 4 Define18=#define MX_I2C_SCL 3 Define19=#define MX_PWM Define20=#define MX_PWM_CNT 2 Define21=#define MX_PWM_TRIS1 trisc Define22=#define MX_PWM_1 2 Define23=#define MX_PWM_TRIS2 trisc Define24=#define MX_PWM_2 1 [Interrupts] ;first 3 should always be 1=TMR0, 2=RB0INT, 3=PORTB ;any other interrupts need to also have this set: "intcon.PEIE=1;\n" GeneralInit="intcon.GIE=1;\n" Count=4 1=TMR0 2=RB0INT 3=PORTB 4=TMR1 [TMR0] ;it is vital that this section remains exactly as-is (for all chips?) Name=(this is retrieved from the resource file) FlagReg=intcon FlagBit=T0IF EnReg=intcon EnBit=T0IE OptCnt=3 TmrOpt=3 Opt1="Clock Source Select" Opt1Cnt=2 Opt1_1="Transition on T0CKI pin" Opt1_1Val="option_reg.T0CS=1;\n" Opt1_2="Internal clock (CLKO)" Opt1_2Val="option_reg.T0CS=0;\n" Opt2="Source Edge Select" Opt2Cnt=2 Opt2_1="high-to-low transition on T0CKI" Opt2_1Val="option_reg.T0SE=1;\n" Opt2_2="low-to-high transition on T0CKI" Opt2_2Val="option_reg.T0SE=0;\n" Opt3="Prescaler Rate" Opt3Cnt=9 Opt3_1="1:1" Opt3_1Val="option_reg = (option_reg & 0xF0) | 0x08;\n" Opt3_2="1:2" Opt3_2Val="option_reg = (option_reg & 0xF0) | 0x00;\n" Opt3_3="1:4" Opt3_3Val="option_reg = (option_reg & 0xF0) | 0x01;\n" Opt3_4="1:8" Opt3_4Val="option_reg = (option_reg & 0xF0) | 0x02;\n" Opt3_5="1:16" Opt3_5Val="option_reg = (option_reg & 0xF0) | 0x03;\n" Opt3_6="1:32" Opt3_6Val="option_reg = (option_reg & 0xF0) | 0x04;\n" Opt3_7="1:64" Opt3_7Val="option_reg = (option_reg & 0xF0) | 0x05;\n" Opt3_8="1:128" Opt3_8Val="option_reg = (option_reg & 0xF0) | 0x06;\n" Opt3_9="1:256" Opt3_9Val="option_reg = (option_reg & 0xF0) | 0x07;\n" [RB0INT] Name=(this is retrieved from the resource file) FlagReg=intcon FlagBit=INTF EnReg=intcon EnBit=INTE OptCnt=1 TmrOpt=0 Opt1="Interrupt Edge Select" Opt1Cnt=2 Opt1_1="rising edge of RB0/INT" Opt1_1Val="option_reg.INTEDG=1;\n" Opt1_2="falling edge of RB0/INT" Opt1_2Val="option_reg.INTEDG=0;\n" [PORTB] Name=(this is retrieved from the resource file) FlagReg=intcon FlagBit=RBIF EnReg=intcon EnBit=RBIE OptCnt=0 TmrOpt=0 [TMR1] ;NOTE: this osc is enabled and turned on as part of the Opt1 code Name="TMR1 Overflow" FlagReg=pir1 FlagBit=TMR1IF EnReg=pie1 EnBit=TMR1IE OptCnt=2 TmrOpt=2 Opt1="Clock Source Select" Opt1Cnt=2 Opt1_1="Transition on T1CKI pin" Opt1_1Val="intcon.PEIE=1;\nt1con.T1OSCEN=1;\nt1con.TMR1ON=1;\nt1con.TMR1CS=1;\n" Opt1_2="Internal clock (Fosc/4)" Opt1_2Val="intcon.PEIE=1;\nt1con.T1OSCEN=1;\nt1con.TMR1ON=1;\nt1con.TMR1CS=0;\n" Opt2="Prescaler Rate" Opt2Cnt=4 Opt2_1="1:1" Opt2_1Val="t1con = t1con & 0x0F;\n" Opt2_2="1:2" Opt2_2Val="t1con = (t1con & 0x0F) | 0x10;\n" Opt2_3="1:4" Opt2_3Val="t1con = (t1con & 0x0F) | 0x20;\n" Opt2_4="1:8" Opt2_4Val="t1con = (t1con & 0x0F) | 0x30;\n"