;---------------------------------------------------------- ; Code Produced by the Proton 3.5.0.6 ; Copyright Rosetta Technologies/Crownhill Associates Ltd ; Written by Les Johnson. June 2010 ;---------------------------------------------------------- ; #DEFINE CONFIG_REQ 1 #DEFINE DEBUG@REQ 1 LIST P = 18F2525, F = INHX32, W = 2, X = ON, R = DEC, MM = ON, N = 0, C = 255, T=ON PORTA EQU 0X0F80 PORTB EQU 0X0F81 PORTC EQU 0X0F82 PORTE EQU 0X0F84 LATA EQU 0X0F89 LATB EQU 0X0F8A LATC EQU 0X0F8B DDRA EQU 0X0F92 TRISA EQU 0X0F92 DDRB EQU 0X0F93 TRISB EQU 0X0F93 DDRC EQU 0X0F94 TRISC EQU 0X0F94 OSCTUNE EQU 0X0F9B PIE1 EQU 0X0F9D PIR1 EQU 0X0F9E IPR1 EQU 0X0F9F PIE2 EQU 0X0FA0 PIR2 EQU 0X0FA1 IPR2 EQU 0X0FA2 EECON1 EQU 0X0FA6 EECON2 EQU 0X0FA7 EEDATL EQU 0X0FA8 EEDATA EQU 0X0FA8 EEADR EQU 0X0FA9 EEADRH EQU 0X0FAA RCSTA EQU 0X0FAB TXSTA EQU 0X0FAC TXREG EQU 0X0FAD RCREG EQU 0X0FAE SPBRG EQU 0X0FAF SPBRGH EQU 0X0FB0 T3CON EQU 0X0FB1 TMR3L EQU 0X0FB2 TMR3LH EQU 0X0FB3 TMR3H EQU 0X0FB3 CMCON EQU 0X0FB4 CVRCON EQU 0X0FB5 BAUDCON EQU 0X0FB8 BAUDCTL EQU 0X0FB8 CCP2CON EQU 0X0FBA CCPR2 EQU 0X0FBB CCPR2L EQU 0X0FBB CCPR2LH EQU 0X0FBC CCPR2H EQU 0X0FBC CCP1CON EQU 0X0FBD CCPR1 EQU 0X0FBE CCPR1L EQU 0X0FBE CCPR1LH EQU 0X0FBF CCPR1H EQU 0X0FBF ADCON2 EQU 0X0FC0 ADCON1 EQU 0X0FC1 ADCON0 EQU 0X0FC2 ADRES EQU 0X0FC3 ADRESL EQU 0X0FC3 ADRESLH EQU 0X0FC4 ADRESH EQU 0X0FC4 SSPCON2 EQU 0X0FC5 SSPCON1 EQU 0X0FC6 SSPSTAT EQU 0X0FC7 SSPADD EQU 0X0FC8 SSPBUF EQU 0X0FC9 T2CON EQU 0X0FCA PR2 EQU 0X0FCB TMR2 EQU 0X0FCC T1CON EQU 0X0FCD TMR1L EQU 0X0FCE TMR1LH EQU 0X0FCF TMR1H EQU 0X0FCF RCON EQU 0X0FD0 WDTCON EQU 0X0FD1 HLVDCON EQU 0X0FD2 LVDCON EQU 0X0FD2 OSCCON EQU 0X0FD3 DEBUG EQU 0X0FD4 T0CON EQU 0X0FD5 TMR0L EQU 0X0FD6 TMR0LH EQU 0X0FD7 TMR0H EQU 0X0FD7 STATUS EQU 0X0FD8 FSR2L EQU 0X0FD9 FSR2LH EQU 0X0FDA FSR2H EQU 0X0FDA PLUSW2 EQU 0X0FDB PREINC2 EQU 0X0FDC POSTDEC2 EQU 0X0FDD POSTINC2 EQU 0X0FDE INDF2 EQU 0X0FDF BSR EQU 0X0FE0 FSR1L EQU 0X0FE1 FSR1LH EQU 0X0FE2 FSR1H EQU 0X0FE2 PLUSW1 EQU 0X0FE3 PREINC1 EQU 0X0FE4 POSTDEC1 EQU 0X0FE5 POSTINC1 EQU 0X0FE6 INDF1 EQU 0X0FE7 WREG EQU 0X0FE8 FSR0L EQU 0X0FE9 FSR0LH EQU 0X0FEA FSR0H EQU 0X0FEA PLUSW0 EQU 0X0FEB PREINC0 EQU 0X0FEC POSTDEC0 EQU 0X0FED POSTINC0 EQU 0X0FEE INDF0 EQU 0X0FEF INTCON3 EQU 0X0FF0 INTCON2 EQU 0X0FF1 INTCON EQU 0X0FF2 PRODL EQU 0X0FF3 PRODLH EQU 0X0FF4 PRODH EQU 0X0FF4 TABLAT EQU 0X0FF5 TBLPTRL EQU 0X0FF6 TBLPTRLH EQU 0X0FF7 TBLPTRH EQU 0X0FF7 TBLPTRU EQU 0X0FF8 TBLPTRLHH EQU 0X0FF8 PC EQU 0X0FF9 PCL EQU 0X0FF9 PCLATH EQU 0X0FFA PCLATU EQU 0X0FFB STKPTR EQU 0X0FFC TOS EQU 0X0FFD TOSL EQU 0X0FFD TOSLH EQU 0X0FFE TOSH EQU 0X0FFE TOSU EQU 0X0FFF _I2C_SCL_PORT = TRISC _I2C_SCL_PIN = 3 _I2C_SDA_PORT = TRISC _I2C_SDA_PIN = 4 RA0=0 RA1=1 RA2=2 RA3=3 RA4=4 RA5=5 RA6=6 RA7=7 T0CKI=4 AN4=5 SS=5 NOT_SS=5 LVDIN=5 HLVDIN=5 RB0=0 RB1=1 RB2=2 RB3=3 RB4=4 RB5=5 RB6=6 RB7=7 INT0=0 INT1=1 INT2=2 CCP2_PORTB=3 KBI0=4 KBI1=5 KBI2=6 KBI3=7 AN12=0 AN10=1 AN8=2 AN9=3 AN11=4 PGM=5 PGC=6 PGD=7 RC0=0 RC1=1 RC2=2 RC3=3 RC4=4 RC5=5 RC6=6 RC7=7 T1OSO=0 T1OSI=1 CCP1=2 SCK=3 SDI=4 SDO=5 TX=6 RX=7 T13CKI=0 CCP2_PORTC=1 SCL=3 SDA=4 CK=6 T1CKI=0 RE3=3 MCLR=3 NOT_MCLR=3 VPP=3 LATA0=0 LATA1=1 LATA2=2 LATA3=3 LATA4=4 LATA5=5 LATA6=6 LATA7=7 LATB0=0 LATB1=1 LATB2=2 LATB3=3 LATB4=4 LATB5=5 LATB6=6 LATB7=7 LATC0=0 LATC1=1 LATC2=2 LATC3=3 LATC4=4 LATC5=5 LATC6=6 LATC7=7 TRISA0=0 TRISA1=1 TRISA2=2 TRISA3=3 TRISA4=4 TRISA5=5 TRISA6=6 TRISA7=7 TRISB0=0 TRISB1=1 TRISB2=2 TRISB3=3 TRISB4=4 TRISB5=5 TRISB6=6 TRISB7=7 TRISC0=0 TRISC1=1 TRISC2=2 TRISC3=3 TRISC4=4 TRISC5=5 TRISC6=6 TRISC7=7 TUN0=0 TUN1=1 TUN2=2 TUN3=3 TUN4=4 PLLEN=6 INTSRC=7 TMR1IE=0 TMR2IE=1 CCP1IE=2 SSPIE=3 TXIE=4 RCIE=5 ADIE=6 TMR1IF=0 TMR2IF=1 CCP1IF=2 SSPIF=3 TXIF=4 PP_TXIF=4 RCIF=5 PP_RCIF=5 ADIF=6 TMR1IP=0 TMR2IP=1 CCP1IP=2 SSPIP=3 TXIP=4 RCIP=5 ADIP=6 CCP2IE=0 TMR3IE=1 LVDIE=2 BCLIE=3 EEIE=4 CMIE=6 OSCFIE=7 HLVDIE=2 CCP2IF=0 TMR3IF=1 LVDIF=2 BCLIF=3 EEIF=4 CMIF=6 OSCFIF=7 HLVDIF=2 CCP2IP=0 TMR3IP=1 LVDIP=2 BCLIP=3 EEIP=4 CMIP=6 OSCFIP=7 HLVDIP=2 RD=0 PP_RD=0 WR=1 PP_WR=1 WREN=2 PP_WREN=2 WRERR=3 FREE=4 CFGS=6 EEPGD=7 PP_EEPGD=7 RX9D=0 OERR=1 PP_OERR=1 FERR=2 ADEN=3 CREN=4 PP_CREN=4 SREN=5 RX9=6 SPEN=7 ADDEN=3 TX9D=0 TRMT=1 BRGH=2 SENDB=3 SYNC=4 TXEN=5 TX9=6 CSRC=7 TMR3ON=0 TMR3CS=1 T3SYNC=2 T3CCP1=3 T3CKPS0=4 T3CKPS1=5 T3CCP2=6 RD16=7 NOT_T3SYNC=2 CM0=0 CM1=1 CM2=2 CIS=3 C1INV=4 C2INV=5 C1OUT=6 C2OUT=7 CVR0=0 CVR1=1 CVR2=2 CVR3=3 CVRSS=4 CVRR=5 CVROE=6 CVREN=7 ABDEN=0 WUE=1 BRG16=3 SCKP=4 RCIDL=6 ABDOVF=7 TXCKP=4 RXDTP=5 RCMT=6 CCP2M0=0 CCP2M1=1 CCP2M2=2 CCP2M3=3 CCP2Y=4 CCP2X=5 DC2B0=4 DC2B1=5 CCP1M0=0 CCP1M1=1 CCP1M2=2 CCP1M3=3 CCP1Y=4 CCP1X=5 DC1B0=4 DC1B1=5 ADCS0=0 ADCS1=1 ADCS2=2 ACQT0=3 ACQT1=4 ACQT2=5 ADFM=7 PCFG0=0 PCFG1=1 PCFG2=2 PCFG3=3 VCFG0=4 VCFG1=5 ADON=0 PP_ADON=0 GO=1 CHS0=2 CHS1=3 CHS2=4 CHS3=5 DONE=1 NOT_DONE=1 GO_DONE=1 PP_GO_DONE=1 SEN=0 PP_SEN=0 RSEN=1 PP_RSEN=1 PEN=2 PP_PEN=2 RCEN=3 PP_RCEN=3 ACKEN=4 PP_ACKEN=4 ACKDT=5 PP_ACKDT=5 ACKSTAT=6 GCEN=7 SSPM0=0 SSPM1=1 SSPM2=2 SSPM3=3 CKP=4 SSPEN=5 SSPOV=6 WCOL=7 BF=0 UA=1 R=2 S=3 P=4 D=5 CKE=6 SMP=7 NOT_W=2 NOT_A=5 R_W=2 PP_R_W=2 D_A=5 NOT_WRITE=2 NOT_ADDRESS=5 T2CKPS0=0 PP_T2CKPS0=0 T2CKPS1=1 PP_T2CKPS1=1 TMR2ON=2 PP_TMR2ON=2 T2OUTPS0=3 T2OUTPS1=4 T2OUTPS2=5 T2OUTPS3=6 TOUTPS0=3 TOUTPS1=4 TOUTPS2=5 TOUTPS3=6 TMR1ON=0 TMR1CS=1 T1SYNC=2 T1OSCEN=3 T1CKPS0=4 T1CKPS1=5 T1RUN=6 NOT_T1SYNC=2 BOR=0 POR=1 PD=2 TO=3 RI=4 SBOREN=6 IPEN=7 NOT_BOR=0 NOT_POR=1 NOT_PD=2 NOT_TO=3 NOT_RI=4 SWDTEN=0 SWDTE=0 LVDL0=0 LVDL1=1 LVDL2=2 LVDL3=3 LVDEN=4 IRVST=5 LVV0=0 LVV1=1 LVV2=2 LVV3=3 BGST=5 HLVDL0=0 HLVDL1=1 HLVDL2=2 HLVDL3=3 HLVDEN=4 VDIRMAG=7 IVRST=5 SCS0=0 SCS1=1 IOFS=2 OSTS=3 IRCF0=4 IRCF1=5 IRCF2=6 IDLEN=7 FLTS=2 T0PS0=0 T0PS1=1 T0PS2=2 PSA=3 T0SE=4 T0CS=5 T016BIT=6 TMR0ON=7 T08BIT=6 C=0 DC=1 Z=2 OV=3 N=4 INT1F=0 INT2F=1 INT1E=3 INT2E=4 INT1P=6 INT2P=7 INT1IF=0 INT2IF=1 INT1IE=3 INT2IE=4 INT1IP=6 INT2IP=7 RBIP=0 TMR0IP=2 INTEDG2=4 INTEDG1=5 INTEDG0=6 RBPU=7 NOT_RBPU=7 RBIF=0 INT0F=1 TMR0IF=2 RBIE=3 INT0E=4 TMR0IE=5 PEIE=6 GIE=7 INT0IF=1 T0IF=2 INT0IE=4 T0IE=5 GIEL=6 GIEH=7 STKPTR0=0 STKPTR1=1 STKPTR2=2 STKPTR3=3 STKPTR4=4 STKUNF=6 STKOVF=7 SP0=0 SP1=1 SP2=2 SP3=3 SP4=4 STKFUL=7 __MAXRAM 0X0FFF __BADRAM 0X0F83 __BADRAM 0X0F85-0X0F88 __BADRAM 0X0F8C-0X0F91 __BADRAM 0X0F95-0X0F9A __BADRAM 0X0F9C __BADRAM 0X0FA3-0X0FA5 __BADRAM 0X0FB6-0X0FB7 __BADRAM 0X0FB9 CONFIG1H EQU 0X300001 CONFIG2L EQU 0X300002 CONFIG2H EQU 0X300003 CONFIG3H EQU 0X300005 CONFIG4L EQU 0X300006 CONFIG5L EQU 0X300008 CONFIG5H EQU 0X300009 CONFIG6L EQU 0X30000A CONFIG6H EQU 0X30000B CONFIG7L EQU 0X30000C CONFIG7H EQU 0X30000D OSC_LP_1 EQU 0XF0 OSC_XT_1 EQU 0XF1 OSC_HS_1 EQU 0XF2 OSC_RC_1 EQU 0XF3 OSC_EC_1 EQU 0XF4 OSC_ECIO6_1 EQU 0XF5 OSC_HSPLL_1 EQU 0XF6 OSC_RCIO6_1 EQU 0XF7 OSC_INTIO67_1 EQU 0XF8 OSC_INTIO7_1 EQU 0XF9 FCMEN_OFF_1 EQU 0XBF FCMEN_ON_1 EQU 0XFF IESO_OFF_1 EQU 0X7F IESO_ON_1 EQU 0XFF PWRT_ON_2 EQU 0XFE PWRT_OFF_2 EQU 0XFF BOREN_OFF_2 EQU 0XF9 BOREN_ON_2 EQU 0XFB BOREN_NOSLP_2 EQU 0XFD BOREN_SBORDIS_2 EQU 0XFF BORV_0_2 EQU 0XE7 BORV_1_2 EQU 0XEF BORV_2_2 EQU 0XF7 BORV_3_2 EQU 0XFF WDT_OFF_2 EQU 0XFE WDT_ON_2 EQU 0XFF WDTPS_1_2 EQU 0XE1 WDTPS_2_2 EQU 0XE3 WDTPS_4_2 EQU 0XE5 WDTPS_8_2 EQU 0XE7 WDTPS_16_2 EQU 0XE9 WDTPS_32_2 EQU 0XEB WDTPS_64_2 EQU 0XED WDTPS_128_2 EQU 0XEF WDTPS_256_2 EQU 0XF1 WDTPS_512_2 EQU 0XF3 WDTPS_1024_2 EQU 0XF5 WDTPS_2048_2 EQU 0XF7 WDTPS_4096_2 EQU 0XF9 WDTPS_8192_2 EQU 0XFB WDTPS_16384_2 EQU 0XFD WDTPS_32768_2 EQU 0XFF MCLRE_OFF_3 EQU 0X7F MCLRE_ON_3 EQU 0XFF LPT1OSC_OFF_3 EQU 0XFB LPT1OSC_ON_3 EQU 0XFF PBADEN_OFF_3 EQU 0XFD PBADEN_ON_3 EQU 0XFF CCP2MX_PORTBE_3 EQU 0XFE CCP2MX_PORTC_3 EQU 0XFF STVREN_OFF_4 EQU 0XFE STVREN_ON_4 EQU 0XFF LVP_OFF_4 EQU 0XFB LVP_ON_4 EQU 0XFF XINST_OFF_4 EQU 0XBF XINST_ON_4 EQU 0XFF DEBUG_ON_4 EQU 0X7F DEBUG_OFF_4 EQU 0XFF CP0_ON_5 EQU 0XFE CP0_OFF_5 EQU 0XFF CP1_ON_5 EQU 0XFD CP1_OFF_5 EQU 0XFF CP2_ON_5 EQU 0XFB CP2_OFF_5 EQU 0XFF CPB_ON_5 EQU 0XBF CPB_OFF_5 EQU 0XFF CPD_ON_5 EQU 0X7F CPD_OFF_5 EQU 0XFF WRT0_ON_6 EQU 0XFE WRT0_OFF_6 EQU 0XFF WRT1_ON_6 EQU 0XFD WRT1_OFF_6 EQU 0XFF WRT2_ON_6 EQU 0XFB WRT2_OFF_6 EQU 0XFF WRTB_ON_6 EQU 0XBF WRTB_OFF_6 EQU 0XFF WRTC_ON_6 EQU 0XDF WRTC_OFF_6 EQU 0XFF WRTD_ON_6 EQU 0X7F WRTD_OFF_6 EQU 0XFF EBTR0_ON_7 EQU 0XFE EBTR0_OFF_7 EQU 0XFF EBTR1_ON_7 EQU 0XFD EBTR1_OFF_7 EQU 0XFF EBTR2_ON_7 EQU 0XFB EBTR2_OFF_7 EQU 0XFF EBTRB_ON_7 EQU 0XBF EBTRB_OFF_7 EQU 0XFF DEVID1 EQU 0X3FFFFE DEVID2 EQU 0X3FFFFF IDLOC0 EQU 0X200000 __IDLOC0 EQU 0X200000 IDLOC1 EQU 0X200001 __IDLOC1 EQU 0X200001 IDLOC2 EQU 0X200002 __IDLOC2 EQU 0X200002 IDLOC3 EQU 0X200003 __IDLOC3 EQU 0X200003 IDLOC4 EQU 0X200004 __IDLOC4 EQU 0X200004 IDLOC5 EQU 0X200005 __IDLOC5 EQU 0X200005 IDLOC6 EQU 0X200006 __IDLOC6 EQU 0X200006 IDLOC7 EQU 0X200007 __IDLOC7 EQU 0X200007 #DEFINE __18F2525 1 #DEFINE XTAL 40 #DEFINE _CORE 16 #DEFINE _MAXRAM 3688 #DEFINE _RAM_END 3968 #DEFINE _MAXMEM 49152 #DEFINE _ADC 10 #DEFINE _ADC_RES 10 #DEFINE _EEPROM 1024 #DEFINE RAM_BANKS 15 #DEFINE _USART 1 #DEFINE _USB 0 #DEFINE _USB#RAM_START 0 #DEFINE _FLASH 1 #DEFINE _CWRITE_BLOCK 64 #DEFINE BANK0_START 128 #DEFINE BANK0_END 255 #DEFINE BANK1_START 256 #DEFINE BANK1_END 511 #DEFINE BANK2_START 512 #DEFINE BANK2_END 767 #DEFINE BANK3_START 768 #DEFINE BANK3_END 1023 #DEFINE BANK4_START 1024 #DEFINE BANK4_END 1279 #DEFINE BANK5_START 1280 #DEFINE BANK5_END 1535 #DEFINE BANK6_START 1536 #DEFINE BANK6_END 1791 #DEFINE BANK7_START 1792 #DEFINE BANK7_END 2047 #DEFINE BANK8_START 2048 #DEFINE BANK8_END 2303 #DEFINE BANK9_START 2304 #DEFINE BANK9_END 2559 #DEFINE BANK10_START 2560 #DEFINE BANK10_END 2815 #DEFINE BANK11_START 2816 #DEFINE BANK11_END 3071 #DEFINE BANK12_START 3072 #DEFINE BANK12_END 3327 #DEFINE BANK13_START 3328 #DEFINE BANK13_END 3583 #DEFINE BANK14_START 3584 #DEFINE BANK14_END 3839 #DEFINE BANKA_START 0 #DEFINE BANKA_END 127 #DEFINE _SYSTEM_VARIABLE_COUNT 56 #DEFINE LCD#TYPE 0 #DEFINE __HIGH_INTERRUPTS_ENABLED 1 #DEFINE _HIGH_INT_SUB_ADDRESS 3689 #DEFINE _HIGH_INT_SUB_AMOUNT 12 #DEFINE CLRW CLRF WREG #DEFINE NEGW NEGF WREG #DEFINE SKPC BTFSS STATUS,0 #DEFINE SKPNC BTFSC STATUS,0 #DEFINE CLRC BCF STATUS,0 #DEFINE SETC BSF STATUS,0 #DEFINE SKPZ BTFSS STATUS,2 #DEFINE SKPNZ BTFSC STATUS,2 #DEFINE CLRZ BCF STATUS,2 #DEFINE SETZ BSF STATUS,2 #DEFINE INIT_USART_INTERRUPT#REQ 1 #DEFINE CLEAR_SERIAL_BUFFER#REQ 1 #DEFINE _OPENTIMER0#REQ 1 GEN = 0 PBP#VAR0 = 1 PBP#VAR0H = 2 PBP#VAR1 = 3 PP0 = 4 PP0H = 5 PP1 = 6 PP1H = 7 PP2 = 8 PP2H = 9 PP3 = 10 PP3H = 11 PP4 = 12 PP4H = 13 PP7 = 14 PP7H = 15 CNTHW = 16 CNTHWH = 17 BYTEIN = 18 _I = 19 STATUSBYTE = 20 NOTEUIT = 21 RELEASE = 22 NOTEAAN = 23 VELO = 24 NOTEPRES = 25 PRES = 26 CTRL = 27 VALUE = 28 PROG = 29 AFT = 30 PBLSB = 31 PBMSB = 32 VELTIM = 33 VELTIMH = 34 VELTIMHH = 35 VELTIMHHH = 36 NEWTIM = 37 NEWTIMH = 38 NEWTIMHH = 39 NEWTIMHHH = 40 VELFLAGS = 41 VELFLAGSH = 42 CC66 = 43 ST = 44 B1 = 45 B2 = 46 CNT = 47 CNTH = 48 CNTHH = 49 CNTHHH = 50 LITES = 51 USART_FSR1_SAVE = 52 USART_FSR1_SAVEH = 53 INDEXIN = 54 INDEXOUT = 55 TASK_RSI = 56 TASK_RSIH = 57 VARIABLE TASK_RSI#0=56,TASK_RSI#0H=57,TASK_RSI#1=58,TASK_RSI#1H=59 VARIABLE TASK_RSI#2=60,TASK_RSI#2H=61,TASK_RSI#3=62,TASK_RSI#3H=63 VARIABLE TASK_RSI#4=64,TASK_RSI#4H=65 VELMSB = 66 VELMSBH = 67 VARIABLE VELMSB#0=66,VELMSB#0H=67,VELMSB#1=68,VELMSB#1H=69 VARIABLE VELMSB#2=70,VELMSB#2H=71,VELMSB#3=72,VELMSB#3H=73 VARIABLE VELMSB#4=74,VELMSB#4H=75 VELLSB = 76 VELLSBH = 77 VARIABLE VELLSB#0=76,VELLSB#0H=77,VELLSB#1=78,VELLSB#1H=79 VARIABLE VELLSB#2=80,VELLSB#2H=81,VELLSB#3=82,VELLSB#3H=83 VARIABLE VELLSB#4=84,VELLSB#4H=85 RINGBUFFER = 3712 VARIABLE RINGBUFFER#0=3712,RINGBUFFER#1=3713,RINGBUFFER#2=3714,RINGBUFFER#3=3715 VARIABLE RINGBUFFER#4=3716,RINGBUFFER#5=3717,RINGBUFFER#6=3718,RINGBUFFER#7=3719 VARIABLE RINGBUFFER#8=3720,RINGBUFFER#9=3721,RINGBUFFER#10=3722,RINGBUFFER#11=3723 VARIABLE RINGBUFFER#12=3724,RINGBUFFER#13=3725,RINGBUFFER#14=3726,RINGBUFFER#15=3727 VARIABLE RINGBUFFER#16=3728,RINGBUFFER#17=3729,RINGBUFFER#18=3730,RINGBUFFER#19=3731 VARIABLE RINGBUFFER#20=3732,RINGBUFFER#21=3733,RINGBUFFER#22=3734,RINGBUFFER#23=3735 VARIABLE RINGBUFFER#24=3736,RINGBUFFER#25=3737,RINGBUFFER#26=3738,RINGBUFFER#27=3739 VARIABLE RINGBUFFER#28=3740,RINGBUFFER#29=3741,RINGBUFFER#30=3742,RINGBUFFER#31=3743 VARIABLE RINGBUFFER#32=3744,RINGBUFFER#33=3745,RINGBUFFER#34=3746,RINGBUFFER#35=3747 VARIABLE RINGBUFFER#36=3748,RINGBUFFER#37=3749,RINGBUFFER#38=3750,RINGBUFFER#39=3751 VARIABLE RINGBUFFER#40=3752,RINGBUFFER#41=3753,RINGBUFFER#42=3754,RINGBUFFER#43=3755 VARIABLE RINGBUFFER#44=3756,RINGBUFFER#45=3757,RINGBUFFER#46=3758,RINGBUFFER#47=3759 VARIABLE RINGBUFFER#48=3760,RINGBUFFER#49=3761,RINGBUFFER#50=3762,RINGBUFFER#51=3763 VARIABLE RINGBUFFER#52=3764,RINGBUFFER#53=3765,RINGBUFFER#54=3766,RINGBUFFER#55=3767 VARIABLE RINGBUFFER#56=3768,RINGBUFFER#57=3769,RINGBUFFER#58=3770,RINGBUFFER#59=3771 VARIABLE RINGBUFFER#60=3772,RINGBUFFER#61=3773,RINGBUFFER#62=3774,RINGBUFFER#63=3775 VARIABLE RINGBUFFER#64=3776,RINGBUFFER#65=3777,RINGBUFFER#66=3778,RINGBUFFER#67=3779 VARIABLE RINGBUFFER#68=3780,RINGBUFFER#69=3781,RINGBUFFER#70=3782,RINGBUFFER#71=3783 VARIABLE RINGBUFFER#72=3784,RINGBUFFER#73=3785,RINGBUFFER#74=3786,RINGBUFFER#75=3787 VARIABLE RINGBUFFER#76=3788,RINGBUFFER#77=3789,RINGBUFFER#78=3790,RINGBUFFER#79=3791 VARIABLE RINGBUFFER#80=3792,RINGBUFFER#81=3793,RINGBUFFER#82=3794,RINGBUFFER#83=3795 VARIABLE RINGBUFFER#84=3796,RINGBUFFER#85=3797,RINGBUFFER#86=3798,RINGBUFFER#87=3799 VARIABLE RINGBUFFER#88=3800,RINGBUFFER#89=3801,RINGBUFFER#90=3802,RINGBUFFER#91=3803 VARIABLE RINGBUFFER#92=3804,RINGBUFFER#93=3805,RINGBUFFER#94=3806,RINGBUFFER#95=3807 VARIABLE RINGBUFFER#96=3808,RINGBUFFER#97=3809,RINGBUFFER#98=3810,RINGBUFFER#99=3811 VARIABLE RINGBUFFER#100=3812,RINGBUFFER#101=3813,RINGBUFFER#102=3814,RINGBUFFER#103=3815 VARIABLE RINGBUFFER#104=3816,RINGBUFFER#105=3817,RINGBUFFER#106=3818,RINGBUFFER#107=3819 VARIABLE RINGBUFFER#108=3820,RINGBUFFER#109=3821,RINGBUFFER#110=3822,RINGBUFFER#111=3823 VARIABLE RINGBUFFER#112=3824,RINGBUFFER#113=3825,RINGBUFFER#114=3826,RINGBUFFER#115=3827 VARIABLE RINGBUFFER#116=3828,RINGBUFFER#117=3829,RINGBUFFER#118=3830,RINGBUFFER#119=3831 VARIABLE RINGBUFFER#120=3832,RINGBUFFER#121=3833,RINGBUFFER#122=3834,RINGBUFFER#123=3835 VARIABLE RINGBUFFER#124=3836,RINGBUFFER#125=3837,RINGBUFFER#126=3838,RINGBUFFER#127=3839 VARIABLE RINGBUFFER#128=3840,RINGBUFFER#129=3841,RINGBUFFER#130=3842,RINGBUFFER#131=3843 VARIABLE RINGBUFFER#132=3844,RINGBUFFER#133=3845,RINGBUFFER#134=3846,RINGBUFFER#135=3847 VARIABLE RINGBUFFER#136=3848,RINGBUFFER#137=3849,RINGBUFFER#138=3850,RINGBUFFER#139=3851 VARIABLE RINGBUFFER#140=3852,RINGBUFFER#141=3853,RINGBUFFER#142=3854,RINGBUFFER#143=3855 VARIABLE RINGBUFFER#144=3856,RINGBUFFER#145=3857,RINGBUFFER#146=3858,RINGBUFFER#147=3859 VARIABLE RINGBUFFER#148=3860,RINGBUFFER#149=3861,RINGBUFFER#150=3862,RINGBUFFER#151=3863 VARIABLE RINGBUFFER#152=3864,RINGBUFFER#153=3865,RINGBUFFER#154=3866,RINGBUFFER#155=3867 VARIABLE RINGBUFFER#156=3868,RINGBUFFER#157=3869,RINGBUFFER#158=3870,RINGBUFFER#159=3871 VARIABLE RINGBUFFER#160=3872,RINGBUFFER#161=3873,RINGBUFFER#162=3874,RINGBUFFER#163=3875 VARIABLE RINGBUFFER#164=3876,RINGBUFFER#165=3877,RINGBUFFER#166=3878,RINGBUFFER#167=3879 VARIABLE RINGBUFFER#168=3880,RINGBUFFER#169=3881,RINGBUFFER#170=3882,RINGBUFFER#171=3883 VARIABLE RINGBUFFER#172=3884,RINGBUFFER#173=3885,RINGBUFFER#174=3886,RINGBUFFER#175=3887 VARIABLE RINGBUFFER#176=3888,RINGBUFFER#177=3889,RINGBUFFER#178=3890,RINGBUFFER#179=3891 VARIABLE RINGBUFFER#180=3892,RINGBUFFER#181=3893,RINGBUFFER#182=3894,RINGBUFFER#183=3895 VARIABLE RINGBUFFER#184=3896,RINGBUFFER#185=3897,RINGBUFFER#186=3898,RINGBUFFER#187=3899 VARIABLE RINGBUFFER#188=3900,RINGBUFFER#189=3901,RINGBUFFER#190=3902,RINGBUFFER#191=3903 VARIABLE RINGBUFFER#192=3904,RINGBUFFER#193=3905,RINGBUFFER#194=3906,RINGBUFFER#195=3907 VARIABLE RINGBUFFER#196=3908,RINGBUFFER#197=3909,RINGBUFFER#198=3910,RINGBUFFER#199=3911 VARIABLE RINGBUFFER#200=3912,RINGBUFFER#201=3913,RINGBUFFER#202=3914,RINGBUFFER#203=3915 VARIABLE RINGBUFFER#204=3916,RINGBUFFER#205=3917,RINGBUFFER#206=3918,RINGBUFFER#207=3919 VARIABLE RINGBUFFER#208=3920,RINGBUFFER#209=3921,RINGBUFFER#210=3922,RINGBUFFER#211=3923 VARIABLE RINGBUFFER#212=3924,RINGBUFFER#213=3925,RINGBUFFER#214=3926,RINGBUFFER#215=3927 VARIABLE RINGBUFFER#216=3928,RINGBUFFER#217=3929,RINGBUFFER#218=3930,RINGBUFFER#219=3931 VARIABLE RINGBUFFER#220=3932,RINGBUFFER#221=3933,RINGBUFFER#222=3934,RINGBUFFER#223=3935 VARIABLE RINGBUFFER#224=3936,RINGBUFFER#225=3937,RINGBUFFER#226=3938,RINGBUFFER#227=3939 VARIABLE RINGBUFFER#228=3940,RINGBUFFER#229=3941,RINGBUFFER#230=3942,RINGBUFFER#231=3943 VARIABLE RINGBUFFER#232=3944,RINGBUFFER#233=3945,RINGBUFFER#234=3946,RINGBUFFER#235=3947 VARIABLE RINGBUFFER#236=3948,RINGBUFFER#237=3949,RINGBUFFER#238=3950,RINGBUFFER#239=3951 VARIABLE RINGBUFFER#240=3952,RINGBUFFER#241=3953,RINGBUFFER#242=3954,RINGBUFFER#243=3955 VARIABLE RINGBUFFER#244=3956,RINGBUFFER#245=3957,RINGBUFFER#246=3958,RINGBUFFER#247=3959 VARIABLE RINGBUFFER#248=3960,RINGBUFFER#249=3961,RINGBUFFER#250=3962,RINGBUFFER#251=3963 VARIABLE RINGBUFFER#252=3964,RINGBUFFER#253=3965,RINGBUFFER#254=3966,RINGBUFFER#255=3967 #DEFINE CNTLW TMR0L #DEFINE CNTLWH TMR0LH #DEFINE STBIT BYTEIN,7 #DEFINE VELFLAGS0 VELFLAGS #DEFINE VELFLAGS1 VELFLAGSH #DEFINE FSR0SAVEINT PP0 #DEFINE FSR0SAVEINTH PP0H #DEFINE USART_FSR0_SAVE FSR0SAVEINT #DEFINE USART_FSR0_SAVEH FSR0SAVEINTH #DEFINE USART_FSR0 FSR0L #DEFINE USART_FSR0H FSR0LH #DEFINE USART_FSR1 FSR1L #DEFINE USART_FSR1H FSR1LH #DEFINE _WTIMER1M TMR1L #DEFINE _WTIMER1MH TMR1LH #DEFINE _WTIMER3M TMR3L #DEFINE _WTIMER3MH TMR3LH #DEFINE __OPTIMISER_LEVEL 3 #DEFINE __XTAL 40 #DEFINE MIDICHANNEL 1 #DEFINE NOTEOFF_STATUS 129 #DEFINE NOTEON_STATUS 145 #DEFINE KEYPRES_STATUS 161 #DEFINE CONTROL_STATUS 177 #DEFINE PROGCHANGE_STATUS 193 #DEFINE AFTERTOUCH_STATUS 209 #DEFINE PITCHBEND_STATUS 225 #DEFINE NRTASKS 5 #DEFINE __HSERIAL_BAUD 31250 #DEFINE __HSERIAL_TXSTA 36 #DEFINE __START_OF_RESERVE_RAM 3712 #DEFINE __RESERVE_RAM_SIZE 256 HSERIAL_SPBRG = 79 HSERIAL_TXSTA = 36 HSERIAL_RCSTA = 144 HSERIAL_BAUD = 31250 PROTON#CODE#START ORG 0X000000 GOTO PROTON#MAIN#START ORG 0X000008 BRA HIGH_PRIOR_INTERRUPT HRSIN#REQ = 1 HRSINX#REQ = 1 HRSIN#CLROERR = 1 H@PWM MOVWF 13 MOVLW 150 MOVWF 4 MOVLW 152 MOVWF 5 RCALL D@VD BTFSC 4056,2 BCF 4042,PP_T2CKPS0 BTFSS 4056,2 BSF 4042,PP_T2CKPS0 ADDLW 252 BTFSS 4056,0 BCF 4042,PP_T2CKPS1 BTFSC 4056,0 BSF 4042,PP_T2CKPS1 MOVLW 128 MOVWF 4 MOVLW 150 MOVWF 5 MOVLW 152 MOVWF 8 CLRF 9 BTFSC 4042,PP_T2CKPS0 RCALL HPW@2S BTFSC 4042,PP_T2CKPS1 RCALL HPW@2S RCALL D@VD2 DECF 4,W MOVWF 4043 MOVFF 4,6 MOVFF 5,7 MOVF 0,W MOVWF 10 MOVWF 11 INCFSZ 0,W CLRF 11 RCALL M@PY MOVF 9,W DECFSZ 13,F BRA HPW@SK1 MOVWF 4030 MOVLW 12 MOVWF 4029 BTFSC 8,7 BSF 4029,5 BTFSC 8,6 BSF 4029,4 BCF TRISB,2 HPWM@FIN BSF 4042,PP_TMR2ON RETURN HPW@SK1 MOVWF 4027 MOVLW 12 MOVWF 4026 BTFSC 8,7 BSF 4026,5 BTFSC 8,6 BSF 4026,4 BCF TRISC,1 BRA HPWM@FIN HPW@2S RCALL HPW@2L HPW@2L BCF 4056,0 RRCF 8,F RRCF 5,F RRCF 4,F RETURN D@VD CLRF 9 CLRF 8 D@VD2 MOVLW 16 MOVWF 4083 DV@LP RLCF 5,W RLCF 8,F RLCF 9,F MOVF 6,W SUBWF 8,W MOVF 7,W SUBWFB 9,W BNC D@K MOVF 6,W SUBWF 8,F MOVF 7,W SUBWFB 9,F BSF 4056,0 D@K RLCF 4,F RLCF 5,F DECFSZ 4083,F BRA DV@LP MOVF 4,W RETURN M@PY MOVF 6,W MULWF 10 MOVFF 4083,8 MOVFF 4084,9 MOVF 7,W MULWF 10 MOVF 4083,W ADDWF 9,F MOVF 6,W MULWF 11 MOVF 4083,W ADDWF 9,F MOVF 8,W RETURN PROTON#MAIN#START CLRF 4088 MOVLW 79 MOVWF 4015 MOVLW 36 MOVWF 4012 MOVLW 144 MOVWF 4011 MOVLB 0 F2_SOF EQU $ ; SIMBA_PIC1_V2.PRP F2_EOF EQU $ ; SIMBA_PIC1_V2.PRP F1_SOF EQU $ ; SIMBA_PIC1_V2.BAS F3_SOF EQU $ ; 18F2525.INC F3_EOF EQU $ ; 18F2525.INC F1_000055 EQU $ ; IN [SIMBA_PIC1_V2.BAS] DECLARE ALL_DIGITAL = TRUE MOVLW 7 MOVWF CMCON,0 MOVLW 15 MOVWF ADCON1,0 F4_SOF EQU $ ; MIDI_IRQ.INC F4_000045 EQU $ ; IN [MIDI_IRQ.INC] GOTO _OVER_IRQ_HANDLER BRA _OVER_IRQ_HANDLER HIGH_PRIOR_INTERRUPT F4_000056 EQU $ ; IN [MIDI_IRQ.INC] IF PIR1.5 = 1 THEN BTFSS PIR1,5 BRA BC@LL2 F4_000057 EQU $ ; IN [MIDI_IRQ.INC] MOVLW 6 MOVLW 6 F4_000058 EQU $ ; IN [MIDI_IRQ.INC] ANDWF RCSTA,W ANDWF RCSTA,W F4_000059 EQU $ ; IN [MIDI_IRQ.INC] BNZ _UART_ERROR BNZ _UART_ERROR F4_000060 EQU $ ; IN [MIDI_IRQ.INC] USART_FSR1_SAVE = USART_FSR1 MOVFF FSR1L,USART_FSR1_SAVE MOVFF FSR1LH,USART_FSR1_SAVEH F4_000061 EQU $ ; IN [MIDI_IRQ.INC] INC INDEXIN INCF INDEXIN,F,0 F4_000071 EQU $ ; IN [MIDI_IRQ.INC] USART_FSR1 = VARPTR RINGBUFFER LFSR 1,RINGBUFFER F4_000072 EQU $ ; IN [MIDI_IRQ.INC] USART_FSR1 = USART_FSR1 + INDEXIN MOVF INDEXIN,W,0 ADDWF FSR1L,F,0 MOVLW 0 ADDWFC FSR1LH,F,0 F4_000073 EQU $ ; IN [MIDI_IRQ.INC] INDF1 = RCREG MOVFF RCREG,INDF1 F4_000074 EQU $ ; IN [MIDI_IRQ.INC] USART_FSR1 = USART_FSR1_SAVE MOVFF USART_FSR1_SAVE,FSR1L MOVFF USART_FSR1_SAVEH,FSR1LH F4_000076 EQU $ ; IN [MIDI_IRQ.INC] RETFIE FAST RETFIE 1 _UART_ERROR F4_000078 EQU $ ; IN [MIDI_IRQ.INC] WREG = RCREG MOVF RCREG,W,0 F4_000079 EQU $ ; IN [MIDI_IRQ.INC] WREG = RCREG MOVF RCREG,W,0 F4_000080 EQU $ ; IN [MIDI_IRQ.INC] CLEAR RCSTA.4 BCF RCSTA,4,0 F4_000081 EQU $ ; IN [MIDI_IRQ.INC] SET RCSTA.4 BSF RCSTA,4,0 F4_000082 EQU $ ; IN [MIDI_IRQ.INC] RETFIE FAST RETFIE 1 BRA BC@LL3 BC@LL2 F4_000083 EQU $ ; IN [MIDI_IRQ.INC] ELSE _TIMER0_IRQ F4_000085 EQU $ ; IN [MIDI_IRQ.INC] IF INTCON.2 = 1 THEN BTFSS INTCON,2 BRA BC@LL5 F4_000086 EQU $ ; IN [MIDI_IRQ.INC] CLEAR INTCON.2 BCF INTCON,2,0 F4_000088 EQU $ ; IN [MIDI_IRQ.INC] INC CNTHW INFSNZ CNTHW,F,0 INCF CNTHWH,F,0 F4_000095 EQU $ ; IN [MIDI_IRQ.INC] RETFIE FAST RETFIE 1 F4_000096 EQU $ ; IN [MIDI_IRQ.INC] ENDIF BC@LL5 F4_000097 EQU $ ; IN [MIDI_IRQ.INC] ENDIF BC@LL3 F4_000098 EQU $ ; IN [MIDI_IRQ.INC] RETFIE FAST RETFIE 1 HRSIN: F4_000102 EQU $ ; IN [MIDI_IRQ.INC] IF INDEXIN <> INDEXOUT THEN MOVF INDEXIN,W,0 SUBWF INDEXOUT,W,0 BZ BC@LL7 F4_000103 EQU $ ; IN [MIDI_IRQ.INC] INC INDEXOUT INCF INDEXOUT,F,0 F4_000104 EQU $ ; IN [MIDI_IRQ.INC] USART_FSR0_SAVE = USART_FSR0 MOVFF FSR0L,FSR0SAVEINT MOVFF FSR0LH,FSR0SAVEINTH F4_000105 EQU $ ; IN [MIDI_IRQ.INC] USART_FSR0 = VARPTR RINGBUFFER LFSR 0,RINGBUFFER F4_000106 EQU $ ; IN [MIDI_IRQ.INC] USART_FSR0 = USART_FSR0 + INDEXOUT MOVF INDEXOUT,W,0 ADDWF FSR0L,F,0 MOVLW 0 ADDWFC FSR0LH,F,0 F4_000107 EQU $ ; IN [MIDI_IRQ.INC] WREG = INDF0 MOVF INDF0,W,0 F4_000108 EQU $ ; IN [MIDI_IRQ.INC] PP0 = WREG MOVWF PP0,0 F4_000109 EQU $ ; IN [MIDI_IRQ.INC] USART_FSR0 = USART_FSR0_SAVE MOVFF FSR0SAVEINT,FSR0L MOVFF FSR0SAVEINTH,FSR0LH F4_000110 EQU $ ; IN [MIDI_IRQ.INC] SET STATUS.0 BSF STATUS,0,0 F4_000111 EQU $ ; IN [MIDI_IRQ.INC] RET RETURN 0 BRA BC@LL8 BC@LL7 F4_000112 EQU $ ; IN [MIDI_IRQ.INC] ELSE F4_000113 EQU $ ; IN [MIDI_IRQ.INC] WREG = 255 SETF WREG,0 F4_000114 EQU $ ; IN [MIDI_IRQ.INC] PP0 = WREG MOVWF PP0,0 F4_000115 EQU $ ; IN [MIDI_IRQ.INC] BTFSS STATUS,C BTFSS STATUS,C F4_000116 EQU $ ; IN [MIDI_IRQ.INC] RET RETURN 0 F4_000117 EQU $ ; IN [MIDI_IRQ.INC] ENDIF BC@LL8 F4_000118 EQU $ ; IN [MIDI_IRQ.INC] RET RETURN 0 _INIT_USART F4_000164 EQU $ ; IN [MIDI_IRQ.INC] CLEAR INDEXIN CLRF INDEXIN,0 F4_000165 EQU $ ; IN [MIDI_IRQ.INC] CLEAR INDEXOUT CLRF INDEXOUT,0 F4_000166 EQU $ ; IN [MIDI_IRQ.INC] SET PIE1.5 BSF PIE1,5,0 F4_000170 EQU $ ; IN [MIDI_IRQ.INC] SET INTCON.7 BSF INTCON,7,0 F4_000171 EQU $ ; IN [MIDI_IRQ.INC] SET INTCON.6 BSF INTCON,6,0 F4_000173 EQU $ ; IN [MIDI_IRQ.INC] RETURN RETURN 0 _CLEAR_USART_BUFFER F4_000188 EQU $ ; IN [MIDI_IRQ.INC] PIE1.5 = 0 BCF PIE1,5,0 F4_000189 EQU $ ; IN [MIDI_IRQ.INC] CLEAR RINGBUFFER LFSR 0,RINGBUFFER MOVLW 0 CLRF POSTINC0,0 DECFSZ WREG,F,0 BRA $ - 4 F4_000190 EQU $ ; IN [MIDI_IRQ.INC] CLEAR INDEXIN CLRF INDEXIN,0 F4_000191 EQU $ ; IN [MIDI_IRQ.INC] CLEAR INDEXOUT CLRF INDEXOUT,0 F4_000192 EQU $ ; IN [MIDI_IRQ.INC] SET PIE1.5 BSF PIE1,5,0 F4_000193 EQU $ ; IN [MIDI_IRQ.INC] RETURN RETURN 0 HRSOUT F4_000228 EQU $ ; IN [MIDI_IRQ.INC] BTFSS PIR1.4 BTFSS PIR1,4 F4_000229 EQU $ ; IN [MIDI_IRQ.INC] BRA ($ - 2) BRA ($ - 2) F4_000230 EQU $ ; IN [MIDI_IRQ.INC] MOVWF TXREG MOVWF TXREG F4_000231 EQU $ ; IN [MIDI_IRQ.INC] RETURN RETURN 0 _OVER_IRQ_HANDLER F4_EOF EQU $ ; MIDI_IRQ.INC F5_SOF EQU $ ; TIMERS.INC F5_EOF EQU $ ; TIMERS.INC F6_SOF EQU $ ; DWORDARRAYS.INC F6_EOF EQU $ ; DWORDARRAYS.INC F1_000122 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TRISA = %01110000 MOVLW 112 MOVWF TRISA,0 F1_000123 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TRISB = %11100000 MOVLW 224 MOVWF TRISB,0 F1_000124 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TRISC = %11000000 MOVLW 192 MOVWF TRISC,0 F1_000127 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.3 BCF TRISB,3,0 BCF LATB,3,0 F1_000128 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.3 BCF TRISA,3,0 BCF LATA,3,0 F1_000129 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.2 BCF TRISA,2,0 BCF LATA,2,0 F1_000130 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.1 BCF TRISA,1,0 BCF LATA,1,0 F1_000131 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.0 BCF TRISA,0,0 BCF LATA,0,0 F1_000132 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.4 BCF TRISB,4,0 BCF LATB,4,0 F1_000133 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTC.2 BCF TRISC,2,0 BCF LATC,2,0 F1_000134 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTC.1 BCF TRISC,1,0 BCF LATC,1,0 F1_000135 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTC.3 BCF TRISC,3,0 BCF LATC,3,0 F1_000136 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES CLRF LITES,0 MAIN F1_000145 EQU $ ; IN [SIMBA_PIC1_V2.BAS] INIT_USART_INTERRUPT VARIABLE MAX_PARAMS=10,INIT_USART_INTERRUPT_RETURN=0,PRM_COUNT=0 RCALL _INIT_USART F1_000147 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR_SERIAL_BUFFER VARIABLE MAX_PARAMS=10,CLEAR_SERIAL_BUFFER_RETURN=0,PRM_COUNT=0 RCALL _CLEAR_USART_BUFFER F1_000160 EQU $ ; IN [SIMBA_PIC1_V2.BAS] _OPENTIMER0 %11111111 & %10111111 & %11011111 & %11110111 VARIABLE MAX_PARAMS=10,_OPENTIMER0_RETURN=0,PRM_COUNT=1 MOVLW 23 MOVWF T0CON CLRF TMR0H,0 CLRF TMR0L,0 BCF INTCON,2,0 BSF INTCON,5,0 BSF T0CON,7,0 F1_000163 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOSUB INIT_SIMBA CALL INIT_SIMBA F1_000165 EQU $ ; IN [SIMBA_PIC1_V2.BAS] WHILE 1=1 BC@LL9 F1_000167 EQU $ ; IN [SIMBA_PIC1_V2.BAS] BYTEIN = HRSIN RCALL HRSIN MOVWF BYTEIN,0 MIDI_PARSE F1_000170 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF BYTEIN > CONTROL_STATUS THEN MOVLW 178 SUBWF BYTEIN,W,0 BNC BC@LL12 F1_000171 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF BYTEIN > 253 THEN MOVLW 254 SUBWF BYTEIN,W,0 BNC BC@LL14 F1_000175 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOTO CHECK_TIMERS BRA CHECK_TIMERS BRA BC@LL15 BC@LL14 F1_000176 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000177 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR STATUSBYTE CLRF STATUSBYTE,0 F1_000178 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOTO CHECK_TIMERS BRA CHECK_TIMERS F1_000179 EQU $ ; IN [SIMBA_PIC1_V2.BAS] END IF BC@LL15 F1_000180 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL12 F1_000181 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF STBIT =1 THEN BTFSS BYTEIN,7 BRA BC@LL17 F1_000183 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR STATUSBYTE CLRF STATUSBYTE,0 F1_000184 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SELECT BYTEIN F1_000185 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE NOTEOFF_STATUS MOVLW 129 SUBWF BYTEIN,W,0 BNZ BC@LL19 F1_000186 EQU $ ; IN [SIMBA_PIC1_V2.BAS] STATUSBYTE = BYTEIN MOVFF BYTEIN,STATUSBYTE F1_000187 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEUIT = 255 SETF NOTEUIT,0 F1_000188 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RELEASE = 255 SETF RELEASE,0 BRA BC@LL18 BC@LL19 F1_000189 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE NOTEON_STATUS MOVLW 145 SUBWF BYTEIN,W,0 BNZ BC@LL22 F1_000190 EQU $ ; IN [SIMBA_PIC1_V2.BAS] STATUSBYTE = BYTEIN MOVFF BYTEIN,STATUSBYTE F1_000191 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEAAN = 255 SETF NOTEAAN,0 F1_000192 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELO = 255 SETF VELO,0 BRA BC@LL18 BC@LL22 F1_000193 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE KEYPRES_STATUS MOVLW 161 SUBWF BYTEIN,W,0 BNZ BC@LL24 F1_000194 EQU $ ; IN [SIMBA_PIC1_V2.BAS] STATUSBYTE = BYTEIN MOVFF BYTEIN,STATUSBYTE F1_000195 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEPRES = 255 SETF NOTEPRES,0 F1_000196 EQU $ ; IN [SIMBA_PIC1_V2.BAS] PRES = 255 SETF PRES,0 BRA BC@LL18 BC@LL24 F1_000197 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE CONTROL_STATUS MOVLW 177 SUBWF BYTEIN,W,0 BNZ BC@LL26 F1_000198 EQU $ ; IN [SIMBA_PIC1_V2.BAS] STATUSBYTE = BYTEIN MOVFF BYTEIN,STATUSBYTE F1_000199 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CTRL = 255 SETF CTRL,0 F1_000200 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VALUE = 255 SETF VALUE,0 F1_000211 EQU $ ; IN [SIMBA_PIC1_V2.BAS] END SELECT BC@LL26 BC@LL18 BRA BC@LL27 BC@LL17 F1_000212 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000213 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SELECT STATUSBYTE F1_000214 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 0 MOVF STATUSBYTE,F,0 BNZ BC@LL29 F1_000215 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOTO CHECK_TIMERS BRA CHECK_TIMERS BRA BC@LL28 BC@LL29 F1_000216 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE NOTEOFF_STATUS MOVLW 129 SUBWF STATUSBYTE,W,0 BTFSS STATUS,2 BRA BC@LL32 F1_000217 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF NOTEUIT = 255 THEN INCF NOTEUIT,W,0 BNZ BC@LL34 F1_000218 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEUIT = BYTEIN MOVFF BYTEIN,NOTEUIT BRA BC@LL35 BC@LL34 F1_000219 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000220 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RELEASE = BYTEIN MOVFF BYTEIN,RELEASE F1_000221 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SELECT NOTEUIT F1_000222 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 58 MOVLW 58 SUBWF NOTEUIT,W,0 BNZ BC@LL37 F1_000223 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HPWM 1, 0 , 3906 CLRF GEN,0 MOVLW 66 MOVWF PP1,0 MOVLW 15 MOVWF PP1H,0 MOVLW 1 RCALL H@PWM BRA BC@LL36 BC@LL37 F1_000225 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 59 MOVLW 59 SUBWF NOTEUIT,W,0 BNZ BC@LL40 F1_000226 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTC.1 BCF TRISC,1,0 BCF LATC,1,0 BRA BC@LL36 BC@LL40 F1_000227 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 110 MOVLW 110 SUBWF NOTEUIT,W,0 BNZ BC@LL42 F1_000228 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.0 BCF LITES,0,0 F1_000229 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.0 BCF VELFLAGS,0,0 F1_000230 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.3 BCF TRISA,3,0 BCF LATA,3,0 BRA BC@LL36 BC@LL42 F1_000231 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 111 MOVLW 111 SUBWF NOTEUIT,W,0 BNZ BC@LL44 F1_000232 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.1 BCF LITES,1,0 F1_000233 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.1 BCF VELFLAGS,1,0 F1_000234 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.2 BCF TRISA,2,0 BCF LATA,2,0 BRA BC@LL36 BC@LL44 F1_000235 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 112 MOVLW 112 SUBWF NOTEUIT,W,0 BNZ BC@LL46 F1_000236 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.2 BCF LITES,2,0 F1_000237 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.2 BCF VELFLAGS,2,0 F1_000238 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.1 BCF TRISA,1,0 BCF LATA,1,0 BRA BC@LL36 BC@LL46 F1_000239 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 113 MOVLW 113 SUBWF NOTEUIT,W,0 BNZ BC@LL48 F1_000240 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.3 BCF LITES,3,0 F1_000241 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.3 BCF VELFLAGS,3,0 F1_000242 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.0 BCF TRISA,0,0 BCF LATA,0,0 BRA BC@LL36 BC@LL48 F1_000243 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 114 MOVLW 114 SUBWF NOTEUIT,W,0 BNZ BC@LL50 F1_000244 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.4 BCF LITES,4,0 F1_000245 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.4 BCF VELFLAGS,4,0 F1_000246 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.4 BCF TRISB,4,0 BCF LATB,4,0 F1_000247 EQU $ ; IN [SIMBA_PIC1_V2.BAS] END SELECT BC@LL50 BC@LL36 F1_000248 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEUIT = 255 SETF NOTEUIT,0 F1_000249 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL35 F1_000250 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOTO CHECK_TIMERS BRA CHECK_TIMERS BRA BC@LL28 BC@LL32 F1_000251 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE NOTEON_STATUS MOVLW 145 SUBWF STATUSBYTE,W,0 BTFSS STATUS,2 BRA BC@LL52 F1_000252 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF NOTEAAN = 255 THEN INCF NOTEAAN,W,0 BNZ BC@LL54 F1_000253 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEAAN = BYTEIN MOVFF BYTEIN,NOTEAAN BRA BC@LL55 BC@LL54 F1_000254 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000255 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELO = BYTEIN MOVFF BYTEIN,VELO F1_000256 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF VELO = 0 THEN MOVF VELO,F,0 BNZ BC@LL57 F1_000257 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SELECT NOTEAAN F1_000258 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 58 MOVLW 58 SUBWF NOTEAAN,W,0 BNZ BC@LL59 F1_000259 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HPWM 1, 0 , 3906 CLRF GEN,0 MOVLW 66 MOVWF PP1,0 MOVLW 15 MOVWF PP1H,0 MOVLW 1 RCALL H@PWM BRA BC@LL58 BC@LL59 F1_000261 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 59 MOVLW 59 SUBWF NOTEAAN,W,0 BNZ BC@LL62 F1_000262 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTC.1 BCF TRISC,1,0 BCF LATC,1,0 BRA BC@LL58 BC@LL62 F1_000263 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 110 MOVLW 110 SUBWF NOTEAAN,W,0 BNZ BC@LL64 F1_000264 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.0 BCF LITES,0,0 F1_000265 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.0 BCF VELFLAGS,0,0 F1_000266 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.3 BCF TRISA,3,0 BCF LATA,3,0 BRA BC@LL58 BC@LL64 F1_000267 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 111 MOVLW 111 SUBWF NOTEAAN,W,0 BNZ BC@LL66 F1_000268 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.1 BCF LITES,1,0 F1_000269 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.1 BCF VELFLAGS,1,0 F1_000270 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.2 BCF TRISA,2,0 BCF LATA,2,0 BRA BC@LL58 BC@LL66 F1_000271 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 112 MOVLW 112 SUBWF NOTEAAN,W,0 BNZ BC@LL68 F1_000272 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.2 BCF LITES,2,0 F1_000273 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.2 BCF VELFLAGS,2,0 F1_000274 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.1 BCF TRISA,1,0 BCF LATA,1,0 BRA BC@LL58 BC@LL68 F1_000275 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 113 MOVLW 113 SUBWF NOTEAAN,W,0 BNZ BC@LL70 F1_000276 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.3 BCF LITES,3,0 F1_000277 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.3 BCF VELFLAGS,3,0 F1_000278 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.0 BCF TRISA,0,0 BCF LATA,0,0 BRA BC@LL58 BC@LL70 F1_000279 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 114 MOVLW 114 SUBWF NOTEAAN,W,0 BNZ BC@LL72 F1_000280 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES.4 BCF LITES,4,0 F1_000281 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.4 BCF VELFLAGS,4,0 F1_000282 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.4 BCF TRISB,4,0 BCF LATB,4,0 F1_000283 EQU $ ; IN [SIMBA_PIC1_V2.BAS] END SELECT BC@LL72 BC@LL58 F1_000284 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEAAN = 255 SETF NOTEAAN,0 F1_000285 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOTO CHECK_TIMERS BRA CHECK_TIMERS F1_000286 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL57 F1_000287 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SELECT NOTEAAN F1_000288 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 58 MOVLW 58 SUBWF NOTEAAN,W,0 BNZ BC@LL74 F1_000290 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HPWM 1, VELO + VELO, 3906 MOVF VELO,W,0 ADDWF VELO,W,0 MOVWF GEN,0 MOVLW 66 MOVWF PP1,0 MOVLW 15 MOVWF PP1H,0 MOVLW 1 RCALL H@PWM BRA BC@LL73 BC@LL74 F1_000291 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 59 MOVLW 59 SUBWF NOTEAAN,W,0 BNZ BC@LL77 F1_000292 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HIGH PORTC.1 BCF TRISC,1,0 BSF LATC,1,0 BRA BC@LL73 BC@LL77 F1_000293 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 110 MOVLW 110 SUBWF NOTEAAN,W,0 BNZ BC@LL79 F1_000294 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET LITES.0 BSF LITES,0,0 F1_000295 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HIGH PORTA.3 BCF TRISA,3,0 BSF LATA,3,0 BRA BC@LL73 BC@LL79 F1_000296 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 111 MOVLW 111 SUBWF NOTEAAN,W,0 BNZ BC@LL81 F1_000297 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET LITES.1 BSF LITES,1,0 F1_000298 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HIGH PORTA.2 BCF TRISA,2,0 BSF LATA,2,0 BRA BC@LL73 BC@LL81 F1_000299 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 112 MOVLW 112 SUBWF NOTEAAN,W,0 BNZ BC@LL83 F1_000300 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET LITES.2 BSF LITES,2,0 F1_000301 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HIGH PORTA.1 BCF TRISA,1,0 BSF LATA,1,0 BRA BC@LL73 BC@LL83 F1_000302 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 113 MOVLW 113 SUBWF NOTEAAN,W,0 BNZ BC@LL85 F1_000303 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET LITES.3 BSF LITES,3,0 F1_000304 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HIGH PORTA.0 BCF TRISA,0,0 BSF LATA,0,0 BRA BC@LL73 BC@LL85 F1_000305 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 114 MOVLW 114 SUBWF NOTEAAN,W,0 BNZ BC@LL87 F1_000306 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET LITES.4 BSF LITES,4,0 F1_000307 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HIGH PORTB.4 BCF TRISB,4,0 BSF LATB,4,0 F1_000310 EQU $ ; IN [SIMBA_PIC1_V2.BAS] END SELECT BC@LL87 BC@LL73 F1_000311 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEAAN = 255 SETF NOTEAAN,0 F1_000312 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL55 F1_000313 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOTO CHECK_TIMERS BRA CHECK_TIMERS BRA BC@LL28 BC@LL52 F1_000314 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE KEYPRES_STATUS MOVLW 161 SUBWF STATUSBYTE,W,0 BNZ BC@LL89 F1_000315 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF NOTEPRES = 255 THEN INCF NOTEPRES,W,0 BNZ BC@LL91 F1_000316 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEPRES = BYTEIN MOVFF BYTEIN,NOTEPRES BRA BC@LL92 BC@LL91 F1_000317 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000318 EQU $ ; IN [SIMBA_PIC1_V2.BAS] PRES = BYTEIN MOVFF BYTEIN,PRES F1_000319 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOSUB KEYPRES RCALL KEYPRES F1_000320 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL92 F1_000321 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOTO CHECK_TIMERS BRA CHECK_TIMERS BRA BC@LL28 BC@LL89 F1_000322 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE CONTROL_STATUS MOVLW 177 SUBWF STATUSBYTE,W,0 BNZ BC@LL94 F1_000323 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF CTRL = 255 THEN INCF CTRL,W,0 BNZ BC@LL96 F1_000324 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CTRL = BYTEIN MOVFF BYTEIN,CTRL BRA BC@LL97 BC@LL96 F1_000325 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000326 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VALUE = BYTEIN MOVFF BYTEIN,VALUE F1_000327 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOSUB CONTROLLER RCALL CONTROLLER F1_000328 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL97 F1_000329 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOTO CHECK_TIMERS BRA CHECK_TIMERS F1_000335 EQU $ ; IN [SIMBA_PIC1_V2.BAS] END SELECT BC@LL94 BC@LL28 F1_000336 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL27 CHECK_TIMERS F1_000342 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF VELFLAGS0 > 0 THEN MOVF VELFLAGS,F,0 BTFSC STATUS,2 BRA BC@LL99 F1_000343 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF VELFLAGS0.0 = 1 THEN BTFSS VELFLAGS,0 BRA BC@LL101 F1_000344 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD1 = VELMSB[0] MOVFF VELMSB#0,VELTIMHH MOVFF VELMSB#0H,VELTIMHHH F1_000345 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD0 = VELLSB[0] MOVFF VELLSB#0,VELTIM MOVFF VELLSB#0H,VELTIMH F1_000346 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000347 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000348 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF CNT >= VELTIM THEN GOSUB TASK0 MOVF VELTIM,W,0 SUBWF CNT,W,0 MOVF VELTIMH,W,0 SUBWFB CNTH,W,0 MOVF VELTIMHH,W,0 SUBWFB CNTHH,W,0 MOVF VELTIMHHH,W,0 SUBWFB CNTHHH,W,0 MOVF CNTHHH,W,0 XORWF VELTIMHHH,W,0 BTFSC STATUS,0,0 XORLW 128 BTFSC STATUS,4 RCALL TASK0 BC@LL103 F1_000349 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL101 F1_000350 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF VELFLAGS0.1 = 1 THEN BTFSS VELFLAGS,1 BRA BC@LL105 F1_000351 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD1 = VELMSB[1] MOVFF VELMSB#1,VELTIMHH MOVFF VELMSB#1H,VELTIMHHH F1_000352 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD0 = VELLSB[1] MOVFF VELLSB#1,VELTIM MOVFF VELLSB#1H,VELTIMH F1_000353 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000354 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000355 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF CNT >= VELTIM THEN GOSUB TASK1 MOVF VELTIM,W,0 SUBWF CNT,W,0 MOVF VELTIMH,W,0 SUBWFB CNTH,W,0 MOVF VELTIMHH,W,0 SUBWFB CNTHH,W,0 MOVF VELTIMHHH,W,0 SUBWFB CNTHHH,W,0 MOVF CNTHHH,W,0 XORWF VELTIMHHH,W,0 BTFSC STATUS,0,0 XORLW 128 BTFSC STATUS,4 RCALL TASK1 BC@LL107 F1_000356 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL105 F1_000357 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF VELFLAGS0.2 = 1 THEN BTFSS VELFLAGS,2 BRA BC@LL109 F1_000358 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD1 = VELMSB[2] MOVFF VELMSB#2,VELTIMHH MOVFF VELMSB#2H,VELTIMHHH F1_000359 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD0 = VELLSB[2] MOVFF VELLSB#2,VELTIM MOVFF VELLSB#2H,VELTIMH F1_000360 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000361 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000362 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF CNT >= VELTIM THEN GOSUB TASK2 MOVF VELTIM,W,0 SUBWF CNT,W,0 MOVF VELTIMH,W,0 SUBWFB CNTH,W,0 MOVF VELTIMHH,W,0 SUBWFB CNTHH,W,0 MOVF VELTIMHHH,W,0 SUBWFB CNTHHH,W,0 MOVF CNTHHH,W,0 XORWF VELTIMHHH,W,0 BTFSC STATUS,0,0 XORLW 128 BTFSC STATUS,4 RCALL TASK2 BC@LL111 F1_000363 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL109 F1_000364 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF VELFLAGS0.3 = 1 THEN BTFSS VELFLAGS,3 BRA BC@LL113 F1_000365 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD1 = VELMSB[3] MOVFF VELMSB#3,VELTIMHH MOVFF VELMSB#3H,VELTIMHHH F1_000366 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD0 = VELLSB[3] MOVFF VELLSB#3,VELTIM MOVFF VELLSB#3H,VELTIMH F1_000367 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000368 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000369 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF CNT >= VELTIM THEN GOSUB TASK3 MOVF VELTIM,W,0 SUBWF CNT,W,0 MOVF VELTIMH,W,0 SUBWFB CNTH,W,0 MOVF VELTIMHH,W,0 SUBWFB CNTHH,W,0 MOVF VELTIMHHH,W,0 SUBWFB CNTHHH,W,0 MOVF CNTHHH,W,0 XORWF VELTIMHHH,W,0 BTFSC STATUS,0,0 XORLW 128 BTFSC STATUS,4 RCALL TASK3 BC@LL115 F1_000370 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL113 F1_000371 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF VELFLAGS0.4 = 1 THEN BTFSS VELFLAGS,4 BRA BC@LL117 F1_000372 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD1 = VELMSB[4] MOVFF VELMSB#4,VELTIMHH MOVFF VELMSB#4H,VELTIMHHH F1_000373 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM.WORD0 = VELLSB[4] MOVFF VELLSB#4,VELTIM MOVFF VELLSB#4H,VELTIMH F1_000374 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000375 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000376 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF CNT >= VELTIM THEN GOSUB TASK4 MOVF VELTIM,W,0 SUBWF CNT,W,0 MOVF VELTIMH,W,0 SUBWFB CNTH,W,0 MOVF VELTIMHH,W,0 SUBWFB CNTHH,W,0 MOVF VELTIMHHH,W,0 SUBWFB CNTHHH,W,0 MOVF CNTHHH,W,0 XORWF VELTIMHHH,W,0 BTFSC STATUS,0,0 XORLW 128 BTFSC STATUS,4 RCALL TASK4 BC@LL119 F1_000377 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL117 BRA BC@LL120 BC@LL99 F1_000378 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000379 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF CNTHW > 0XFF THEN CLEAR CNTHW MOVLW 1 SUBWF CNTHWH,W,0 BNC BC@LL122 CLRF CNTHW,0 CLRF CNTHWH,0 BC@LL122 F1_000380 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL120 F1_000382 EQU $ ; IN [SIMBA_PIC1_V2.BAS] WEND BRA BC@LL9 BC@LL10 KEYPRES F1_000387 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SELECT NOTEPRES F1_000388 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 110 MOVLW 110 SUBWF NOTEPRES,W,0 BNZ BC@LL124 F1_000389 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.0 = 1 THEN BTFSS LITES,0 BRA BC@LL127 F1_000391 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.0 BSF VELFLAGS,0,0 F1_000392 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000393 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000394 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TASK_RSI[0] = (~PRES & 127) << 9 COMF PRES,W,0 MOVWF PBP#VAR1,0 MOVLW 127 ANDWF PBP#VAR1,W,0 MOVWF PP7,0 CLRF PP7H,0 MOVFF PP7,PBP#VAR0H CLRF PBP#VAR0,0 BCF STATUS,0,0 RLCF PBP#VAR0H,F,0 MOVFF PBP#VAR0,TASK_RSI#0 MOVFF PBP#VAR0H,TASK_RSI#0H F1_000396 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[0] MOVFF TASK_RSI#0,PBP#VAR0 MOVFF TASK_RSI#0H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000397 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[0] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#0 MOVFF VELTIMHHH,VELMSB#0H F1_000398 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[0] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#0 MOVFF VELTIMH,VELLSB#0H BRA BC@LL128 BC@LL127 F1_000399 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000400 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.0 BCF VELFLAGS,0,0 F1_000401 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.3 BCF TRISA,3,0 BCF LATA,3,0 F1_000402 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL128 BRA BC@LL123 BC@LL124 F1_000403 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 111 MOVLW 111 SUBWF NOTEPRES,W,0 BNZ BC@LL130 F1_000404 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.1 = 1 THEN BTFSS LITES,1 BRA BC@LL132 F1_000405 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.1 BSF VELFLAGS,1,0 F1_000406 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000407 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000408 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TASK_RSI[1] = (~PRES & 127) << 9 COMF PRES,W,0 MOVWF PBP#VAR1,0 MOVLW 127 ANDWF PBP#VAR1,W,0 MOVWF PP7,0 CLRF PP7H,0 MOVFF PP7,PBP#VAR0H CLRF PBP#VAR0,0 BCF STATUS,0,0 RLCF PBP#VAR0H,F,0 MOVFF PBP#VAR0,TASK_RSI#1 MOVFF PBP#VAR0H,TASK_RSI#1H F1_000410 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[1] MOVFF TASK_RSI#1,PBP#VAR0 MOVFF TASK_RSI#1H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000411 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[1] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#1 MOVFF VELTIMHHH,VELMSB#1H F1_000412 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[1] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#1 MOVFF VELTIMH,VELLSB#1H BRA BC@LL133 BC@LL132 F1_000413 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000414 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.1 BCF VELFLAGS,1,0 F1_000415 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.2 BCF TRISA,2,0 BCF LATA,2,0 F1_000416 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL133 BRA BC@LL123 BC@LL130 F1_000417 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 112 MOVLW 112 SUBWF NOTEPRES,W,0 BNZ BC@LL135 F1_000418 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.2 = 1 THEN BTFSS LITES,2 BRA BC@LL137 F1_000419 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.2 BSF VELFLAGS,2,0 F1_000420 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000421 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000422 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TASK_RSI[2] = (~PRES & 127) << 9 COMF PRES,W,0 MOVWF PBP#VAR1,0 MOVLW 127 ANDWF PBP#VAR1,W,0 MOVWF PP7,0 CLRF PP7H,0 MOVFF PP7,PBP#VAR0H CLRF PBP#VAR0,0 BCF STATUS,0,0 RLCF PBP#VAR0H,F,0 MOVFF PBP#VAR0,TASK_RSI#2 MOVFF PBP#VAR0H,TASK_RSI#2H F1_000424 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[2] MOVFF TASK_RSI#2,PBP#VAR0 MOVFF TASK_RSI#2H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000425 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[2] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#2 MOVFF VELTIMHHH,VELMSB#2H F1_000426 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[2] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#2 MOVFF VELTIMH,VELLSB#2H BRA BC@LL138 BC@LL137 F1_000427 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000428 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.2 BCF VELFLAGS,2,0 F1_000429 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.1 BCF TRISA,1,0 BCF LATA,1,0 F1_000430 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL138 BRA BC@LL123 BC@LL135 F1_000431 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 113 MOVLW 113 SUBWF NOTEPRES,W,0 BNZ BC@LL140 F1_000432 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.3 = 1 THEN BTFSS LITES,3 BRA BC@LL142 F1_000433 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.3 BSF VELFLAGS,3,0 F1_000434 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000435 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000436 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TASK_RSI[3] = (~PRES & 127) << 9 COMF PRES,W,0 MOVWF PBP#VAR1,0 MOVLW 127 ANDWF PBP#VAR1,W,0 MOVWF PP7,0 CLRF PP7H,0 MOVFF PP7,PBP#VAR0H CLRF PBP#VAR0,0 BCF STATUS,0,0 RLCF PBP#VAR0H,F,0 MOVFF PBP#VAR0,TASK_RSI#3 MOVFF PBP#VAR0H,TASK_RSI#3H F1_000438 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[3] MOVFF TASK_RSI#3,PBP#VAR0 MOVFF TASK_RSI#3H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000439 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[3] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#3 MOVFF VELTIMHHH,VELMSB#3H F1_000440 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[3] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#3 MOVFF VELTIMH,VELLSB#3H BRA BC@LL143 BC@LL142 F1_000441 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000442 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.3 BCF VELFLAGS,3,0 F1_000443 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.0 BCF TRISA,0,0 BCF LATA,0,0 F1_000444 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL143 BRA BC@LL123 BC@LL140 F1_000445 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 114 MOVLW 114 SUBWF NOTEPRES,W,0 BNZ BC@LL145 F1_000446 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.4 = 1 THEN BTFSS LITES,4 BRA BC@LL147 F1_000447 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.4 BSF VELFLAGS,4,0 F1_000448 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD0 = CNTLW MOVFF TMR0L,CNT MOVFF TMR0LH,CNTH F1_000449 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CNT.WORD1 = CNTHW MOVFF CNTHW,CNTHH MOVFF CNTHWH,CNTHHH F1_000450 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TASK_RSI[4] = (~PRES & 127) << 9 COMF PRES,W,0 MOVWF PBP#VAR1,0 MOVLW 127 ANDWF PBP#VAR1,W,0 MOVWF PP7,0 CLRF PP7H,0 MOVFF PP7,PBP#VAR0H CLRF PBP#VAR0,0 BCF STATUS,0,0 RLCF PBP#VAR0H,F,0 MOVFF PBP#VAR0,TASK_RSI#4 MOVFF PBP#VAR0H,TASK_RSI#4H F1_000452 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[4] MOVFF TASK_RSI#4,PBP#VAR0 MOVFF TASK_RSI#4H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000453 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[4] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#4 MOVFF VELTIMHHH,VELMSB#4H F1_000454 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[4] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#4 MOVFF VELTIMH,VELLSB#4H BRA BC@LL148 BC@LL147 F1_000455 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000456 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.4 BCF VELFLAGS,4,0 F1_000457 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.4 BCF TRISB,4,0 BCF LATB,4,0 F1_000458 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL148 F1_000459 EQU $ ; IN [SIMBA_PIC1_V2.BAS] END SELECT BC@LL145 BC@LL123 F1_000460 EQU $ ; IN [SIMBA_PIC1_V2.BAS] NOTEPRES = 255 SETF NOTEPRES,0 F1_000461 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 PROGCHANGE F1_000464 EQU $ ; IN [SIMBA_PIC1_V2.BAS] PROG = 255 SETF PROG,0 F1_000465 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 PITCHBEND F1_000469 EQU $ ; IN [SIMBA_PIC1_V2.BAS] PBLSB = 255 SETF PBLSB,0 F1_000470 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 AFTERTOUCH F1_000474 EQU $ ; IN [SIMBA_PIC1_V2.BAS] AFT = 255 SETF AFT,0 F1_000475 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 CONTROLLER F1_000478 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SELECT CTRL F1_000479 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 66 MOVLW 66 SUBWF CTRL,W,0 BNZ BC@LL150 F1_000481 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF VALUE = 0 THEN MOVF VALUE,F,0 BNZ BC@LL153 F1_000482 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOSUB ALLNOTESOFF RCALL ALLNOTESOFF F1_000483 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.3 BCF TRISB,3,0 BCF LATB,3,0 BRA BC@LL154 BC@LL153 F1_000484 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000485 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HIGH PORTB.3 BCF TRISB,3,0 BSF LATB,3,0 F1_000486 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL154 F1_000487 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CC66 = VALUE MOVFF VALUE,CC66 BRA BC@LL149 BC@LL150 F1_000488 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CASE 123 MOVLW 123 SUBWF CTRL,W,0 BTFSC STATUS,2 F1_000490 EQU $ ; IN [SIMBA_PIC1_V2.BAS] GOSUB ALLNOTESOFF RCALL ALLNOTESOFF F1_000491 EQU $ ; IN [SIMBA_PIC1_V2.BAS] END SELECT BC@LL156 BC@LL149 F1_000492 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CTRL = 255 SETF CTRL,0 F1_000493 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 ALLNOTESOFF F1_000496 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0 CLRF VELFLAGS,0 F1_000497 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.3 BCF TRISA,3,0 BCF LATA,3,0 F1_000498 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.2 BCF TRISA,2,0 BCF LATA,2,0 F1_000499 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.1 BCF TRISA,1,0 BCF LATA,1,0 F1_000500 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.0 BCF TRISA,0,0 BCF LATA,0,0 F1_000501 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.4 BCF TRISB,4,0 BCF LATB,4,0 F1_000503 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTC.1 BCF TRISC,1,0 BCF LATC,1,0 F1_000504 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTC.3 BCF TRISC,3,0 BCF LATC,3,0 F1_000505 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HPWM 1, 0 , 3906 CLRF GEN,0 MOVLW 66 MOVWF PP1,0 MOVLW 15 MOVWF PP1H,0 MOVLW 1 CALL H@PWM F1_000506 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES CLRF LITES,0 F1_000507 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 INIT_SIMBA F1_000510 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.3 BCF TRISB,3,0 BCF LATB,3,0 F1_000511 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.3 BCF TRISA,3,0 BCF LATA,3,0 F1_000512 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.2 BCF TRISA,2,0 BCF LATA,2,0 F1_000513 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.1 BCF TRISA,1,0 BCF LATA,1,0 F1_000514 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.0 BCF TRISA,0,0 BCF LATA,0,0 F1_000515 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.4 BCF TRISB,4,0 BCF LATB,4,0 F1_000517 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTC.1 BCF TRISC,1,0 BCF LATC,1,0 F1_000518 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTC.3 BCF TRISC,3,0 BCF LATC,3,0 F1_000519 EQU $ ; IN [SIMBA_PIC1_V2.BAS] HPWM 1, 0 , 3906 CLRF GEN,0 MOVLW 66 MOVWF PP1,0 MOVLW 15 MOVWF PP1H,0 MOVLW 1 CALL H@PWM F1_000520 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0 CLRF VELFLAGS,0 F1_000521 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR LITES CLRF LITES,0 F1_000522 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 TASK0 F1_000530 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.0 = 0 THEN BTFSC LITES,0 BRA BC@LL158 F1_000531 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.0 BCF VELFLAGS,0,0 F1_000532 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.3 BCF TRISA,3,0 BCF LATA,3,0 BRA BC@LL159 BC@LL158 F1_000533 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000535 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.0 BSF VELFLAGS,0,0 F1_000538 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[0] MOVFF TASK_RSI#0,PBP#VAR0 MOVFF TASK_RSI#0H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000539 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[0] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#0 MOVFF VELTIMHHH,VELMSB#0H F1_000540 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[0] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#0 MOVFF VELTIMH,VELLSB#0H F1_000541 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TOGGLE PORTA.3 BTG PORTA,3,0 BCF TRISA,3,0 F1_000542 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL159 F1_000543 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 TASK1 F1_000546 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.1 = 0 THEN BTFSC LITES,1 BRA BC@LL161 F1_000547 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.1 BCF VELFLAGS,1,0 F1_000548 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.2 BCF TRISA,2,0 BCF LATA,2,0 BRA BC@LL162 BC@LL161 F1_000549 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000551 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.1 BSF VELFLAGS,1,0 F1_000552 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[1] MOVFF TASK_RSI#1,PBP#VAR0 MOVFF TASK_RSI#1H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000553 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[1] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#1 MOVFF VELTIMHHH,VELMSB#1H F1_000554 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[1] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#1 MOVFF VELTIMH,VELLSB#1H F1_000555 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TOGGLE PORTA.2 BTG PORTA,2,0 BCF TRISA,2,0 F1_000556 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL162 F1_000557 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 TASK2 F1_000560 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.2 = 0 THEN BTFSC LITES,2 BRA BC@LL164 F1_000561 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.2 BCF VELFLAGS,2,0 F1_000562 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.1 BCF TRISA,1,0 BCF LATA,1,0 BRA BC@LL165 BC@LL164 F1_000563 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000565 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.2 BSF VELFLAGS,2,0 F1_000566 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[2] MOVFF TASK_RSI#2,PBP#VAR0 MOVFF TASK_RSI#2H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000567 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[2] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#2 MOVFF VELTIMHHH,VELMSB#2H F1_000568 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[2] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#2 MOVFF VELTIMH,VELLSB#2H F1_000569 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TOGGLE PORTA.1 BTG PORTA,1,0 BCF TRISA,1,0 F1_000570 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL165 F1_000571 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 TASK3 F1_000574 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.3 = 0 THEN BTFSC LITES,3 BRA BC@LL167 F1_000575 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.3 BCF VELFLAGS,3,0 F1_000576 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTA.0 BCF TRISA,0,0 BCF LATA,0,0 BRA BC@LL168 BC@LL167 F1_000577 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000579 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.3 BSF VELFLAGS,3,0 F1_000580 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[3] MOVFF TASK_RSI#3,PBP#VAR0 MOVFF TASK_RSI#3H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000581 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[3] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#3 MOVFF VELTIMHHH,VELMSB#3H F1_000582 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[3] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#3 MOVFF VELTIMH,VELLSB#3H F1_000583 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TOGGLE PORTA.0 BTG PORTA,0,0 BCF TRISA,0,0 F1_000584 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL168 F1_000585 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 TASK4 F1_000588 EQU $ ; IN [SIMBA_PIC1_V2.BAS] IF LITES.4 = 0 THEN BTFSC LITES,4 BRA BC@LL170 F1_000589 EQU $ ; IN [SIMBA_PIC1_V2.BAS] CLEAR VELFLAGS0.4 BCF VELFLAGS,4,0 F1_000590 EQU $ ; IN [SIMBA_PIC1_V2.BAS] LOW PORTB.4 BCF TRISB,4,0 BCF LATB,4,0 BRA BC@LL171 BC@LL170 F1_000591 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ELSE F1_000593 EQU $ ; IN [SIMBA_PIC1_V2.BAS] SET VELFLAGS0.4 BSF VELFLAGS,4,0 F1_000594 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELTIM = CNT + TASK_RSI[4] MOVFF TASK_RSI#4,PBP#VAR0 MOVFF TASK_RSI#4H,PBP#VAR0H MOVF PBP#VAR0,W,0 ADDWF CNT,W,0 MOVWF VELTIM,0 MOVF PBP#VAR0H,W,0 ADDWFC CNTH,W,0 MOVWF VELTIMH,0 MOVLW 0 ADDWFC CNTHH,W,0 MOVWF VELTIMHH,0 MOVLW 0 ADDWFC CNTHHH,W,0 MOVWF VELTIMHHH,0 F1_000595 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELMSB[4] = VELTIM.WORD1 MOVFF VELTIMHH,VELMSB#4 MOVFF VELTIMHHH,VELMSB#4H F1_000596 EQU $ ; IN [SIMBA_PIC1_V2.BAS] VELLSB[4] = VELTIM.WORD0 MOVFF VELTIM,VELLSB#4 MOVFF VELTIMH,VELLSB#4H F1_000597 EQU $ ; IN [SIMBA_PIC1_V2.BAS] TOGGLE PORTB.4 BTG PORTB,4,0 BCF TRISB,4,0 F1_000598 EQU $ ; IN [SIMBA_PIC1_V2.BAS] ENDIF BC@LL171 F1_000599 EQU $ ; IN [SIMBA_PIC1_V2.BAS] RETURN RETURN 0 F1_EOF EQU $ ; SIMBA_PIC1_V2.BAS PB@LB173 BRA PB@LB173 __EOF CONFIG DEBUG = OFF CONFIG XINST = OFF CONFIG STVREN = OFF CONFIG FCMEN = OFF CONFIG OSC = HSPLL CONFIG IESO = OFF CONFIG WDT = OFF CONFIG WDTPS = 128 CONFIG BOREN = SBORDIS CONFIG BORV = 2 CONFIG MCLRE = ON CONFIG LPT1OSC = ON CONFIG PBADEN = OFF CONFIG CCP2MX = PORTC CONFIG LVP = OFF CONFIG CP0 = OFF CONFIG CP1 = OFF CONFIG CPB = OFF CONFIG CPD = OFF CONFIG WRT0 = OFF CONFIG WRT1 = OFF CONFIG WRTB = OFF CONFIG WRTC = OFF CONFIG WRTD = OFF CONFIG EBTR0 = OFF CONFIG EBTR1 = OFF CONFIG EBTRB = OFF END