pic18f4550-examples/c/adc/main.asm

961 lines
18 KiB
NASM

;--------------------------------------------------------
; File Created by SDCC : free open source ISO C Compiler
; Version 4.5.0 #15242 (Linux)
;--------------------------------------------------------
; PIC16 port for the Microchip 16-bit core micros
;--------------------------------------------------------
list p=18f4550
radix dec
CONFIG XINST=OFF
CONFIG FOSC=HS
CONFIG WDT=OFF
CONFIG LVP=OFF
CONFIG MCLRE=OFF
;--------------------------------------------------------
; public variables in this module
;--------------------------------------------------------
global _isr
global _tmr_isr
global _number_to_7seg
global _display
global _cleardisp
global _count1k
global _count1kbak
global _start_adc
global _setup
global _main
global _sram_end
global _digit
global _dsp_en
;--------------------------------------------------------
; extern variables in this module
;--------------------------------------------------------
extern _SPPCFGbits
extern _SPPEPSbits
extern _SPPCONbits
extern _UFRMLbits
extern _UFRMHbits
extern _UIRbits
extern _UIEbits
extern _UEIRbits
extern _UEIEbits
extern _USTATbits
extern _UCONbits
extern _UADDRbits
extern _UCFGbits
extern _UEP0bits
extern _UEP1bits
extern _UEP2bits
extern _UEP3bits
extern _UEP4bits
extern _UEP5bits
extern _UEP6bits
extern _UEP7bits
extern _UEP8bits
extern _UEP9bits
extern _UEP10bits
extern _UEP11bits
extern _UEP12bits
extern _UEP13bits
extern _UEP14bits
extern _UEP15bits
extern _PORTAbits
extern _PORTBbits
extern _PORTCbits
extern _PORTDbits
extern _PORTEbits
extern _LATAbits
extern _LATBbits
extern _LATCbits
extern _LATDbits
extern _LATEbits
extern _DDRAbits
extern _TRISAbits
extern _DDRBbits
extern _TRISBbits
extern _DDRCbits
extern _TRISCbits
extern _DDRDbits
extern _TRISDbits
extern _DDREbits
extern _TRISEbits
extern _OSCTUNEbits
extern _PIE1bits
extern _PIR1bits
extern _IPR1bits
extern _PIE2bits
extern _PIR2bits
extern _IPR2bits
extern _EECON1bits
extern _RCSTAbits
extern _TXSTAbits
extern _T3CONbits
extern _CMCONbits
extern _CVRCONbits
extern _CCP1ASbits
extern _ECCP1ASbits
extern _CCP1DELbits
extern _ECCP1DELbits
extern _BAUDCONbits
extern _BAUDCTLbits
extern _CCP2CONbits
extern _CCP1CONbits
extern _ECCP1CONbits
extern _ADCON2bits
extern _ADCON1bits
extern _ADCON0bits
extern _SSPCON2bits
extern _SSPCON1bits
extern _SSPSTATbits
extern _T2CONbits
extern _T1CONbits
extern _RCONbits
extern _WDTCONbits
extern _HLVDCONbits
extern _LVDCONbits
extern _OSCCONbits
extern _T0CONbits
extern _STATUSbits
extern _INTCON3bits
extern _INTCON2bits
extern _INTCONbits
extern _STKPTRbits
extern _SPPDATA
extern _SPPCFG
extern _SPPEPS
extern _SPPCON
extern _UFRM
extern _UFRML
extern _UFRMH
extern _UIR
extern _UIE
extern _UEIR
extern _UEIE
extern _USTAT
extern _UCON
extern _UADDR
extern _UCFG
extern _UEP0
extern _UEP1
extern _UEP2
extern _UEP3
extern _UEP4
extern _UEP5
extern _UEP6
extern _UEP7
extern _UEP8
extern _UEP9
extern _UEP10
extern _UEP11
extern _UEP12
extern _UEP13
extern _UEP14
extern _UEP15
extern _PORTA
extern _PORTB
extern _PORTC
extern _PORTD
extern _PORTE
extern _LATA
extern _LATB
extern _LATC
extern _LATD
extern _LATE
extern _DDRA
extern _TRISA
extern _DDRB
extern _TRISB
extern _DDRC
extern _TRISC
extern _DDRD
extern _TRISD
extern _DDRE
extern _TRISE
extern _OSCTUNE
extern _PIE1
extern _PIR1
extern _IPR1
extern _PIE2
extern _PIR2
extern _IPR2
extern _EECON1
extern _EECON2
extern _EEDATA
extern _EEADR
extern _RCSTA
extern _TXSTA
extern _TXREG
extern _RCREG
extern _SPBRG
extern _SPBRGH
extern _T3CON
extern _TMR3
extern _TMR3L
extern _TMR3H
extern _CMCON
extern _CVRCON
extern _CCP1AS
extern _ECCP1AS
extern _CCP1DEL
extern _ECCP1DEL
extern _BAUDCON
extern _BAUDCTL
extern _CCP2CON
extern _CCPR2
extern _CCPR2L
extern _CCPR2H
extern _CCP1CON
extern _ECCP1CON
extern _CCPR1
extern _CCPR1L
extern _CCPR1H
extern _ADCON2
extern _ADCON1
extern _ADCON0
extern _ADRES
extern _ADRESL
extern _ADRESH
extern _SSPCON2
extern _SSPCON1
extern _SSPSTAT
extern _SSPADD
extern _SSPBUF
extern _T2CON
extern _PR2
extern _TMR2
extern _T1CON
extern _TMR1
extern _TMR1L
extern _TMR1H
extern _RCON
extern _WDTCON
extern _HLVDCON
extern _LVDCON
extern _OSCCON
extern _T0CON
extern _TMR0
extern _TMR0L
extern _TMR0H
extern _STATUS
extern _FSR2L
extern _FSR2H
extern _PLUSW2
extern _PREINC2
extern _POSTDEC2
extern _POSTINC2
extern _INDF2
extern _BSR
extern _FSR1L
extern _FSR1H
extern _PLUSW1
extern _PREINC1
extern _POSTDEC1
extern _POSTINC1
extern _INDF1
extern _WREG
extern _FSR0L
extern _FSR0H
extern _PLUSW0
extern _PREINC0
extern _POSTDEC0
extern _POSTINC0
extern _INDF0
extern _INTCON3
extern _INTCON2
extern _INTCON
extern _PROD
extern _PRODL
extern _PRODH
extern _TABLAT
extern _TBLPTR
extern _TBLPTRL
extern _TBLPTRH
extern _TBLPTRU
extern _PC
extern _PCL
extern _PCLATH
extern _PCLATU
extern _STKPTR
extern _TOS
extern _TOSL
extern _TOSH
extern _TOSU
extern _delay1ktcy
extern _delay100ktcy
extern _adc_read
extern __moduint
extern __divuint
;--------------------------------------------------------
; Equates to used internal registers
;--------------------------------------------------------
STATUS equ 0xfd8
PCL equ 0xff9
PCLATH equ 0xffa
PCLATU equ 0xffb
WREG equ 0xfe8
BSR equ 0xfe0
FSR0L equ 0xfe9
FSR0H equ 0xfea
FSR1L equ 0xfe1
FSR2L equ 0xfd9
INDF0 equ 0xfef
POSTINC1 equ 0xfe6
POSTDEC1 equ 0xfe5
PREINC1 equ 0xfe4
PLUSW2 equ 0xfdb
PRODL equ 0xff3
PRODH equ 0xff4
idata
_digit db 0x00, 0x00, 0x00, 0x00
_dsp_en db 0x00
; Internal registers
.registers udata_ovr 0x0000
r0x00 res 1
r0x01 res 1
r0x02 res 1
r0x03 res 1
r0x04 res 1
r0x05 res 1
r0x06 res 1
r0x07 res 1
r0x08 res 1
ustat_main_00 udata 0X07FF
_sram_end res 0
;--------------------------------------------------------
; interrupt vector
;--------------------------------------------------------
;--------------------------------------------------------
; global & static initialisations
;--------------------------------------------------------
; ; Starting pCode block for absolute section
; ;-----------------------------------------
S_main_ivec_0x1_isr code 0X000008
ivec_0x1_isr:
GOTO _isr
; I code from now on!
; ; Starting pCode block
S_main__main code
_main:
; .line 176; main.c setup();
CALL _setup
; .line 177; main.c start_adc();
CALL _start_adc
; .line 178; main.c ADCON0bits.ADON = 1;
BSF _ADCON0bits, 0
_00255_DS_:
; .line 181; main.c ADCON0bits.GO = 1;
BSF _ADCON0bits, 1
; .line 182; main.c delay1ktcy(100);
MOVLW 0x64
CALL _delay1ktcy
_00251_DS_:
; .line 183; main.c while (ADCON0bits.GO);
BTFSC _ADCON0bits, 1
BRA _00251_DS_
; .line 184; main.c cuenta = adc_read();
CALL _adc_read
MOVWF r0x00
MOVFF PRODL, r0x01
; .line 185; main.c cleardisp();
CALL _cleardisp
; .line 186; main.c display(cuenta);
MOVF r0x01, W
MOVWF POSTDEC1
MOVF r0x00, W
MOVWF POSTDEC1
CALL _display
MOVF POSTINC1, F
MOVF POSTINC1, F
BRA _00255_DS_
; .line 189; main.c }
RETURN
; ; Starting pCode block
S_main__setup code
_setup:
; .line 137; main.c void setup(void){
MOVFF FSR2L, POSTDEC1
MOVFF FSR1L, FSR2L
; .line 139; main.c LATD = 0;
CLRF _LATD
; .line 140; main.c TRISD = 0;
CLRF _TRISD
; .line 142; main.c TRISB = 0xff;
MOVLW 0xff
MOVWF _TRISB
; .line 143; main.c LATB = 0x00;
CLRF _LATB
; .line 146; main.c TRISE = 0;
CLRF _TRISE
; .line 147; main.c LATE = 0;
CLRF _LATE
; .line 149; main.c TRISA = 0x1;
MOVLW 0x01
MOVWF _TRISA
; .line 150; main.c LATA = 0;
CLRF _LATA
; .line 153; main.c INTCONbits.GIE = 1;
BSF _INTCONbits, 7
; .line 154; main.c INTCONbits.PEIE = 1;
BSF _INTCONbits, 6
; .line 155; main.c INTCONbits.RBIE = 0;
BCF _INTCONbits, 3
; .line 156; main.c INTCON2bits.RBPU = 0;
BCF _INTCON2bits, 7
; .line 157; main.c INTCON2bits.RBIP = 1;
BSF _INTCON2bits, 0
; .line 158; main.c RCONbits.IPEN = 1;
BSF _RCONbits, 7
; .line 161; main.c INTCONbits.TMR0IE = 1;
BSF _INTCONbits, 5
; .line 162; main.c INTCON2bits.TMR0IP = 1;
BSF _INTCON2bits, 2
; .line 164; main.c T0CONbits.T08BIT = 1;
BSF _T0CONbits, 6
; .line 165; main.c T0CONbits.T0CS = 0; // Source internal oscilator
BCF _T0CONbits, 5
; .line 166; main.c T0CONbits.PSA = 0;
BCF _T0CONbits, 3
; .line 170; main.c T0CONbits.T0PS = 0x7;
MOVF _T0CONbits, W
ANDLW 0xf8
IORLW 0x07
MOVWF _T0CONbits
; .line 171; main.c T0CONbits.TMR0ON = 1;
BSF _T0CONbits, 7
; .line 172; main.c }
MOVFF PREINC1, FSR2L
RETURN
; ; Starting pCode block
S_main__start_adc code
_start_adc:
; .line 128; main.c void start_adc(void) {
MOVFF FSR2L, POSTDEC1
MOVFF FSR1L, FSR2L
; .line 129; main.c ADCON0bits.CHS = 0;
MOVF _ADCON0bits, W
ANDLW 0xc3
MOVWF _ADCON0bits
; .line 130; main.c ADCON1bits.PCFG = 0xE;
MOVF _ADCON1bits, W
ANDLW 0xf0
IORLW 0x0e
MOVWF _ADCON1bits
; .line 131; main.c ADCON2bits.ADFM = 1;
BSF _ADCON2bits, 7
; .line 132; main.c ADCON2bits.ACQT = 0x5;
MOVF _ADCON2bits, W
ANDLW 0xc7
IORLW 0x28
MOVWF _ADCON2bits
; .line 133; main.c ADCON2bits.ADCS = 0x1;
MOVF _ADCON2bits, W
ANDLW 0xf8
IORLW 0x01
MOVWF _ADCON2bits
; .line 134; main.c ADCON0bits.ADON = 1;
BSF _ADCON0bits, 0
; .line 135; main.c }
MOVFF PREINC1, FSR2L
RETURN
; ; Starting pCode block
S_main__count1kbak code
_count1kbak:
; .line 122; main.c void count1kbak(void) {
MOVFF FSR2L, POSTDEC1
MOVFF FSR1L, FSR2L
MOVFF r0x00, POSTDEC1
MOVFF r0x01, POSTDEC1
MOVFF r0x02, POSTDEC1
MOVFF r0x03, POSTDEC1
; .line 123; main.c for(int i = 9999; i >= 0; i--) {
MOVLW 0x0f
MOVWF r0x00
MOVLW 0x27
MOVWF r0x01
_00234_DS_:
BSF STATUS, 0
BTFSS r0x01, 7
BCF STATUS, 0
BC _00236_DS_
; .line 124; main.c display(i);
MOVF r0x00, W
MOVWF r0x02
MOVF r0x01, W
MOVWF r0x03
MOVF r0x03, W
MOVWF POSTDEC1
MOVF r0x02, W
MOVWF POSTDEC1
CALL _display
MOVF POSTINC1, F
MOVF POSTINC1, F
; .line 125; main.c delay100ktcy(5);
MOVLW 0x05
CALL _delay100ktcy
; .line 123; main.c for(int i = 9999; i >= 0; i--) {
MOVLW 0xff
ADDWF r0x00, F
ADDWFC r0x01, F
BRA _00234_DS_
_00236_DS_:
; .line 127; main.c }
MOVFF PREINC1, r0x03
MOVFF PREINC1, r0x02
MOVFF PREINC1, r0x01
MOVFF PREINC1, r0x00
MOVFF PREINC1, FSR2L
RETURN
; ; Starting pCode block
S_main__count1k code
_count1k:
; .line 116; main.c void count1k(void) {
MOVFF FSR2L, POSTDEC1
MOVFF FSR1L, FSR2L
MOVFF r0x00, POSTDEC1
MOVFF r0x01, POSTDEC1
MOVFF r0x02, POSTDEC1
MOVFF r0x03, POSTDEC1
; .line 117; main.c for(int i = 0; i < 9999; i++) {
CLRF r0x00
CLRF r0x01
_00210_DS_:
MOVF r0x01, W
ADDLW 0x80
ADDLW 0x59
BNZ _00227_DS_
MOVLW 0x0f
SUBWF r0x00, W
_00227_DS_:
BC _00212_DS_
; .line 118; main.c display(i);
MOVF r0x00, W
MOVWF r0x02
MOVF r0x01, W
MOVWF r0x03
MOVF r0x03, W
MOVWF POSTDEC1
MOVF r0x02, W
MOVWF POSTDEC1
CALL _display
MOVF POSTINC1, F
MOVF POSTINC1, F
; .line 119; main.c delay100ktcy(5);
MOVLW 0x05
CALL _delay100ktcy
; .line 117; main.c for(int i = 0; i < 9999; i++) {
INFSNZ r0x00, F
INCF r0x01, F
BRA _00210_DS_
_00212_DS_:
; .line 121; main.c }
MOVFF PREINC1, r0x03
MOVFF PREINC1, r0x02
MOVFF PREINC1, r0x01
MOVFF PREINC1, r0x00
MOVFF PREINC1, FSR2L
RETURN
; ; Starting pCode block
S_main__cleardisp code
_cleardisp:
; .line 109; main.c void cleardisp(void) {
MOVFF FSR2L, POSTDEC1
MOVFF FSR1L, FSR2L
BANKSEL _digit
; .line 110; main.c digit[0] = 0;
CLRF _digit, B
BANKSEL (_digit + 1)
; .line 111; main.c digit[1] = 0;
CLRF (_digit + 1), B
BANKSEL (_digit + 2)
; .line 112; main.c digit[2] = 0;
CLRF (_digit + 2), B
BANKSEL (_digit + 3)
; .line 113; main.c digit[3] = 0;
CLRF (_digit + 3), B
; .line 114; main.c }
MOVFF PREINC1, FSR2L
RETURN
; ; Starting pCode block
S_main__display code
_display:
; .line 100; main.c void display(uint16_t num){
MOVFF FSR2L, POSTDEC1
MOVFF FSR1L, FSR2L
MOVFF r0x00, POSTDEC1
MOVFF r0x01, POSTDEC1
MOVFF r0x02, POSTDEC1
MOVFF r0x03, POSTDEC1
MOVFF r0x04, POSTDEC1
MOVFF r0x05, POSTDEC1
MOVFF r0x06, POSTDEC1
MOVFF r0x07, POSTDEC1
MOVFF r0x08, POSTDEC1
MOVLW 0x02
MOVFF PLUSW2, r0x00
MOVLW 0x03
MOVFF PLUSW2, r0x01
; .line 102; main.c if (num > 9999) return;
MOVF r0x00, W
MOVWF r0x02
MOVF r0x01, W
MOVWF r0x03
MOVLW 0x27
SUBWF r0x03, W
BNZ _00198_DS_
MOVLW 0x10
SUBWF r0x02, W
_00198_DS_:
BC _00177_DS_
; .line 103; main.c while(num) {
CLRF r0x02
_00174_DS_:
MOVF r0x01, W
IORWF r0x00, W
BZ _00177_DS_
; .line 104; main.c digit[i] = num%10;
MOVLW LOW(_digit)
ADDWF r0x02, W
MOVWF r0x03
CLRF r0x04
MOVLW HIGH(_digit)
ADDWFC r0x04, F
MOVF r0x00, W
MOVWF r0x05
MOVF r0x01, W
MOVWF r0x06
MOVLW 0x00
MOVWF POSTDEC1
MOVLW 0x0a
MOVWF POSTDEC1
MOVF r0x06, W
MOVWF POSTDEC1
MOVF r0x05, W
MOVWF POSTDEC1
CALL __moduint
MOVWF r0x07
MOVFF PRODL, r0x08
MOVLW 0x04
ADDWF FSR1L, F
MOVFF r0x03, FSR0L
MOVFF r0x04, FSR0H
MOVFF r0x07, INDF0
; .line 105; main.c num = num/10;
MOVLW 0x00
MOVWF POSTDEC1
MOVLW 0x0a
MOVWF POSTDEC1
MOVF r0x06, W
MOVWF POSTDEC1
MOVF r0x05, W
MOVWF POSTDEC1
CALL __divuint
MOVWF r0x03
MOVFF PRODL, r0x04
MOVLW 0x04
ADDWF FSR1L, F
MOVF r0x03, W
MOVWF r0x00
MOVF r0x04, W
MOVWF r0x01
; .line 106; main.c i++;
INCF r0x02, F
BRA _00174_DS_
_00177_DS_:
; .line 108; main.c }
MOVFF PREINC1, r0x08
MOVFF PREINC1, r0x07
MOVFF PREINC1, r0x06
MOVFF PREINC1, r0x05
MOVFF PREINC1, r0x04
MOVFF PREINC1, r0x03
MOVFF PREINC1, r0x02
MOVFF PREINC1, r0x01
MOVFF PREINC1, r0x00
MOVFF PREINC1, FSR2L
RETURN
; ; Starting pCode block
S_main__number_to_7seg code
_number_to_7seg:
; .line 62; main.c uint8_t number_to_7seg(uint8_t number) {
MOVFF FSR2L, POSTDEC1
MOVFF FSR1L, FSR2L
MOVFF r0x00, POSTDEC1
MOVLW 0x02
MOVFF PLUSW2, r0x00
; .line 63; main.c switch (number) {
MOVLW 0x10
SUBWF r0x00, W
BTFSC STATUS, 0
BRA _00156_DS_
CLRF PCLATH
CLRF PCLATU
RLCF r0x00, W
RLCF PCLATH, F
RLCF WREG, W
RLCF PCLATH, F
ANDLW 0xfc
ADDLW LOW(_00167_DS_)
MOVWF POSTDEC1
MOVLW HIGH(_00167_DS_)
ADDWFC PCLATH, F
MOVLW UPPER(_00167_DS_)
ADDWFC PCLATU, F
MOVF PREINC1, W
MOVWF PCL
_00167_DS_:
GOTO _00140_DS_
GOTO _00141_DS_
GOTO _00142_DS_
GOTO _00143_DS_
GOTO _00144_DS_
GOTO _00145_DS_
GOTO _00146_DS_
GOTO _00147_DS_
GOTO _00148_DS_
GOTO _00149_DS_
GOTO _00150_DS_
GOTO _00151_DS_
GOTO _00152_DS_
GOTO _00153_DS_
GOTO _00154_DS_
GOTO _00155_DS_
_00140_DS_:
; .line 65; main.c return 0x3F;
MOVLW 0x3f
BRA _00158_DS_
_00141_DS_:
; .line 67; main.c return 0x06;
MOVLW 0x06
BRA _00158_DS_
_00142_DS_:
; .line 69; main.c return 0x5B;
MOVLW 0x5b
BRA _00158_DS_
_00143_DS_:
; .line 71; main.c return 0x4F;
MOVLW 0x4f
BRA _00158_DS_
_00144_DS_:
; .line 73; main.c return 0x66;
MOVLW 0x66
BRA _00158_DS_
_00145_DS_:
; .line 75; main.c return 0x6D;
MOVLW 0x6d
BRA _00158_DS_
_00146_DS_:
; .line 77; main.c return 0x7D;
MOVLW 0x7d
BRA _00158_DS_
_00147_DS_:
; .line 79; main.c return 0x07;
MOVLW 0x07
BRA _00158_DS_
_00148_DS_:
; .line 81; main.c return 0x7F;
MOVLW 0x7f
BRA _00158_DS_
_00149_DS_:
; .line 83; main.c return 0x6F;
MOVLW 0x6f
BRA _00158_DS_
_00150_DS_:
; .line 85; main.c return 0x77;
MOVLW 0x77
BRA _00158_DS_
_00151_DS_:
; .line 87; main.c return 0x7c;
MOVLW 0x7c
BRA _00158_DS_
_00152_DS_:
; .line 89; main.c return 0x39;
MOVLW 0x39
BRA _00158_DS_
_00153_DS_:
; .line 91; main.c return 0x5e;
MOVLW 0x5e
BRA _00158_DS_
_00154_DS_:
; .line 93; main.c return 0x79;
MOVLW 0x79
BRA _00158_DS_
_00155_DS_:
; .line 95; main.c return 0x71;
MOVLW 0x71
BRA _00158_DS_
_00156_DS_:
; .line 97; main.c return 0;
CLRF WREG
_00158_DS_:
; .line 99; main.c }
MOVFF PREINC1, r0x00
MOVFF PREINC1, FSR2L
RETURN
; ; Starting pCode block
S_main__tmr_isr code
_tmr_isr:
; .line 39; main.c void tmr_isr(void){
MOVFF FSR2L, POSTDEC1
MOVFF FSR1L, FSR2L
MOVFF r0x00, POSTDEC1
MOVFF r0x01, POSTDEC1
; .line 40; main.c LATA = LATE = 0;
CLRF _LATE
CLRF _LATA
; .line 41; main.c LATD = number_to_7seg(digit[dsp_en]);
MOVLW LOW(_digit)
BANKSEL _dsp_en
ADDWF _dsp_en, W, B
MOVWF r0x00
CLRF r0x01
MOVLW HIGH(_digit)
ADDWFC r0x01, F
MOVFF r0x00, FSR0L
MOVFF r0x01, FSR0H
MOVFF INDF0, r0x00
MOVF r0x00, W
MOVWF POSTDEC1
CALL _number_to_7seg
MOVWF _LATD
MOVF POSTINC1, F
; .line 42; main.c switch (dsp_en) {
MOVLW 0x04
BANKSEL _dsp_en
SUBWF _dsp_en, W, B
BC _00116_DS_
CLRF PCLATH
CLRF PCLATU
BANKSEL _dsp_en
RLCF _dsp_en, W, B
RLCF PCLATH, F
RLCF WREG, W
RLCF PCLATH, F
ANDLW 0xfc
ADDLW LOW(_00134_DS_)
MOVWF POSTDEC1
MOVLW HIGH(_00134_DS_)
ADDWFC PCLATH, F
MOVLW UPPER(_00134_DS_)
ADDWFC PCLATU, F
MOVF PREINC1, W
MOVWF PCL
_00134_DS_:
GOTO _00112_DS_
GOTO _00113_DS_
GOTO _00114_DS_
GOTO _00115_DS_
_00112_DS_:
; .line 44; main.c LATA = 0;
CLRF _LATA
; .line 45; main.c LATE = 0x4;
MOVLW 0x04
MOVWF _LATE
; .line 46; main.c break;
BRA _00116_DS_
_00113_DS_:
; .line 48; main.c LATE = 0x2;
MOVLW 0x02
MOVWF _LATE
; .line 49; main.c break;
BRA _00116_DS_
_00114_DS_:
; .line 51; main.c LATE = 0x1;
MOVLW 0x01
MOVWF _LATE
; .line 52; main.c break;
BRA _00116_DS_
_00115_DS_:
; .line 54; main.c LATE = 0;
CLRF _LATE
; .line 55; main.c LATA = 0x10;
MOVLW 0x10
MOVWF _LATA
_00116_DS_:
BANKSEL _dsp_en
; .line 58; main.c dsp_en++;
INCF _dsp_en, F, B
; .line 59; main.c if (dsp_en > 3) dsp_en = 0;
MOVLW 0x04
BANKSEL _dsp_en
SUBWF _dsp_en, W, B
BNC _00119_DS_
BANKSEL _dsp_en
CLRF _dsp_en, B
_00119_DS_:
; .line 60; main.c }
MOVFF PREINC1, r0x01
MOVFF PREINC1, r0x00
MOVFF PREINC1, FSR2L
RETURN
; ; Starting pCode block
S_main__isr code
_isr:
; .line 31; main.c void isr(void) __interrupt (1) {
MOVFF STATUS, POSTDEC1
MOVFF BSR, POSTDEC1
MOVWF POSTDEC1
MOVFF PRODL, POSTDEC1
MOVFF PRODH, POSTDEC1
MOVFF FSR0L, POSTDEC1
MOVFF FSR0H, POSTDEC1
MOVFF PCLATH, POSTDEC1
MOVFF PCLATU, POSTDEC1
MOVFF FSR2L, POSTDEC1
MOVFF FSR1L, FSR2L
; .line 32; main.c if (INTCONbits.TMR0IF){
BTFSS _INTCONbits, 2
BRA _00106_DS_
; .line 33; main.c tmr_isr();
CALL _tmr_isr
; .line 34; main.c TMR0 = RATE;
MOVLW 0xe6
MOVWF _TMR0
_00106_DS_:
; .line 36; main.c INTCONbits.TMR0IF = 0;
BCF _INTCONbits, 2
; .line 37; main.c }
MOVFF PREINC1, FSR2L
MOVFF PREINC1, PCLATU
MOVFF PREINC1, PCLATH
MOVFF PREINC1, FSR0H
MOVFF PREINC1, FSR0L
MOVFF PREINC1, PRODH
MOVFF PREINC1, PRODL
MOVF PREINC1, W
MOVFF PREINC1, BSR
MOVFF PREINC1, STATUS
RETFIE
; Statistics:
; code size: 1094 (0x0446) bytes ( 0.83%)
; 547 (0x0223) words
; udata size: 0 (0x0000) bytes ( 0.00%)
; access size: 9 (0x0009) bytes
end