879 lines
16 KiB
NASM
Executable File
879 lines
16 KiB
NASM
Executable File
;--------------------------------------------------------
|
|
; 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 _count1k
|
|
global _count1kbak
|
|
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 _delay100ktcy
|
|
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 160; main.c setup();
|
|
CALL _setup
|
|
_00242_DS_:
|
|
; .line 162; main.c count1kbak();
|
|
CALL _count1kbak
|
|
BRA _00242_DS_
|
|
; .line 165; main.c }
|
|
RETURN
|
|
|
|
; ; Starting pCode block
|
|
S_main__setup code
|
|
_setup:
|
|
; .line 121; main.c void setup(void){
|
|
MOVFF FSR2L, POSTDEC1
|
|
MOVFF FSR1L, FSR2L
|
|
; .line 123; main.c LATD = 0;
|
|
CLRF _LATD
|
|
; .line 124; main.c TRISD = 0;
|
|
CLRF _TRISD
|
|
; .line 126; main.c TRISB = 0xff;
|
|
MOVLW 0xff
|
|
MOVWF _TRISB
|
|
; .line 127; main.c LATB = 0x00;
|
|
CLRF _LATB
|
|
; .line 128; main.c ADCON1 = 0xf;
|
|
MOVLW 0x0f
|
|
MOVWF _ADCON1
|
|
; .line 130; main.c TRISE = 0;
|
|
CLRF _TRISE
|
|
; .line 131; main.c LATE = 0;
|
|
CLRF _LATE
|
|
; .line 133; main.c TRISA = 0;
|
|
CLRF _TRISA
|
|
; .line 134; main.c LATA = 0;
|
|
CLRF _LATA
|
|
; .line 137; main.c INTCONbits.GIE = 1;
|
|
BSF _INTCONbits, 7
|
|
; .line 138; main.c INTCONbits.PEIE = 1;
|
|
BSF _INTCONbits, 6
|
|
; .line 139; main.c INTCONbits.RBIE = 0;
|
|
BCF _INTCONbits, 3
|
|
; .line 140; main.c INTCON2bits.RBPU = 0;
|
|
BCF _INTCON2bits, 7
|
|
; .line 141; main.c INTCON2bits.RBIP = 1;
|
|
BSF _INTCON2bits, 0
|
|
; .line 142; main.c RCONbits.IPEN = 1;
|
|
BSF _RCONbits, 7
|
|
; .line 145; main.c INTCONbits.TMR0IE = 1;
|
|
BSF _INTCONbits, 5
|
|
; .line 146; main.c INTCON2bits.TMR0IP = 1;
|
|
BSF _INTCON2bits, 2
|
|
; .line 148; main.c T0CONbits.T08BIT = 1;
|
|
BSF _T0CONbits, 6
|
|
; .line 149; main.c T0CONbits.T0CS = 0; // Source internal oscilator
|
|
BCF _T0CONbits, 5
|
|
; .line 150; main.c T0CONbits.PSA = 0;
|
|
BCF _T0CONbits, 3
|
|
; .line 154; main.c T0CONbits.T0PS = 0x7;
|
|
MOVF _T0CONbits, W
|
|
ANDLW 0xf8
|
|
IORLW 0x07
|
|
MOVWF _T0CONbits
|
|
; .line 155; main.c T0CONbits.TMR0ON = 1;
|
|
BSF _T0CONbits, 7
|
|
; .line 156; main.c }
|
|
MOVFF PREINC1, FSR2L
|
|
RETURN
|
|
|
|
; ; Starting pCode block
|
|
S_main__count1kbak code
|
|
_count1kbak:
|
|
; .line 114; main.c void count1kbak(void) {
|
|
MOVFF FSR2L, POSTDEC1
|
|
MOVFF FSR1L, FSR2L
|
|
MOVFF r0x00, POSTDEC1
|
|
MOVFF r0x01, POSTDEC1
|
|
MOVFF r0x02, POSTDEC1
|
|
MOVFF r0x03, POSTDEC1
|
|
; .line 115; main.c for(int i = 9999; i >= 0; i--) {
|
|
MOVLW 0x0f
|
|
MOVWF r0x00
|
|
MOVLW 0x27
|
|
MOVWF r0x01
|
|
_00229_DS_:
|
|
BSF STATUS, 0
|
|
BTFSS r0x01, 7
|
|
BCF STATUS, 0
|
|
BC _00231_DS_
|
|
; .line 116; 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 117; main.c delay100ktcy(5);
|
|
MOVLW 0x05
|
|
CALL _delay100ktcy
|
|
; .line 115; main.c for(int i = 9999; i >= 0; i--) {
|
|
MOVLW 0xff
|
|
ADDWF r0x00, F
|
|
ADDWFC r0x01, F
|
|
BRA _00229_DS_
|
|
_00231_DS_:
|
|
; .line 119; 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 108; main.c void count1k(void) {
|
|
MOVFF FSR2L, POSTDEC1
|
|
MOVFF FSR1L, FSR2L
|
|
MOVFF r0x00, POSTDEC1
|
|
MOVFF r0x01, POSTDEC1
|
|
MOVFF r0x02, POSTDEC1
|
|
MOVFF r0x03, POSTDEC1
|
|
; .line 109; main.c for(int i = 0; i < 9999; i++) {
|
|
CLRF r0x00
|
|
CLRF r0x01
|
|
_00205_DS_:
|
|
MOVF r0x01, W
|
|
ADDLW 0x80
|
|
ADDLW 0x59
|
|
BNZ _00222_DS_
|
|
MOVLW 0x0f
|
|
SUBWF r0x00, W
|
|
_00222_DS_:
|
|
BC _00207_DS_
|
|
; .line 110; 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 111; main.c delay100ktcy(5);
|
|
MOVLW 0x05
|
|
CALL _delay100ktcy
|
|
; .line 109; main.c for(int i = 0; i < 9999; i++) {
|
|
INFSNZ r0x00, F
|
|
INCF r0x01, F
|
|
BRA _00205_DS_
|
|
_00207_DS_:
|
|
; .line 113; main.c }
|
|
MOVFF PREINC1, r0x03
|
|
MOVFF PREINC1, r0x02
|
|
MOVFF PREINC1, r0x01
|
|
MOVFF PREINC1, r0x00
|
|
MOVFF PREINC1, FSR2L
|
|
RETURN
|
|
|
|
; ; Starting pCode block
|
|
S_main__display code
|
|
_display:
|
|
; .line 98; 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 100; 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 101; main.c while(num) {
|
|
CLRF r0x02
|
|
_00174_DS_:
|
|
MOVF r0x01, W
|
|
IORWF r0x00, W
|
|
BZ _00177_DS_
|
|
; .line 102; 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 103; 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 104; main.c i++;
|
|
INCF r0x02, F
|
|
BRA _00174_DS_
|
|
_00177_DS_:
|
|
; .line 106; 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 60; 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 61; 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 63; main.c return 0x3F;
|
|
MOVLW 0x3f
|
|
BRA _00158_DS_
|
|
_00141_DS_:
|
|
; .line 65; main.c return 0x06;
|
|
MOVLW 0x06
|
|
BRA _00158_DS_
|
|
_00142_DS_:
|
|
; .line 67; main.c return 0x5B;
|
|
MOVLW 0x5b
|
|
BRA _00158_DS_
|
|
_00143_DS_:
|
|
; .line 69; main.c return 0x4F;
|
|
MOVLW 0x4f
|
|
BRA _00158_DS_
|
|
_00144_DS_:
|
|
; .line 71; main.c return 0x66;
|
|
MOVLW 0x66
|
|
BRA _00158_DS_
|
|
_00145_DS_:
|
|
; .line 73; main.c return 0x6D;
|
|
MOVLW 0x6d
|
|
BRA _00158_DS_
|
|
_00146_DS_:
|
|
; .line 75; main.c return 0x7D;
|
|
MOVLW 0x7d
|
|
BRA _00158_DS_
|
|
_00147_DS_:
|
|
; .line 77; main.c return 0x07;
|
|
MOVLW 0x07
|
|
BRA _00158_DS_
|
|
_00148_DS_:
|
|
; .line 79; main.c return 0x7F;
|
|
MOVLW 0x7f
|
|
BRA _00158_DS_
|
|
_00149_DS_:
|
|
; .line 81; main.c return 0x6F;
|
|
MOVLW 0x6f
|
|
BRA _00158_DS_
|
|
_00150_DS_:
|
|
; .line 83; main.c return 0x77;
|
|
MOVLW 0x77
|
|
BRA _00158_DS_
|
|
_00151_DS_:
|
|
; .line 85; main.c return 0x7c;
|
|
MOVLW 0x7c
|
|
BRA _00158_DS_
|
|
_00152_DS_:
|
|
; .line 87; main.c return 0x39;
|
|
MOVLW 0x39
|
|
BRA _00158_DS_
|
|
_00153_DS_:
|
|
; .line 89; main.c return 0x5e;
|
|
MOVLW 0x5e
|
|
BRA _00158_DS_
|
|
_00154_DS_:
|
|
; .line 91; main.c return 0x79;
|
|
MOVLW 0x79
|
|
BRA _00158_DS_
|
|
_00155_DS_:
|
|
; .line 93; main.c return 0x71;
|
|
MOVLW 0x71
|
|
BRA _00158_DS_
|
|
_00156_DS_:
|
|
; .line 95; main.c return 0;
|
|
CLRF WREG
|
|
_00158_DS_:
|
|
; .line 97; main.c }
|
|
MOVFF PREINC1, r0x00
|
|
MOVFF PREINC1, FSR2L
|
|
RETURN
|
|
|
|
; ; Starting pCode block
|
|
S_main__tmr_isr code
|
|
_tmr_isr:
|
|
; .line 37; main.c void tmr_isr(void){
|
|
MOVFF FSR2L, POSTDEC1
|
|
MOVFF FSR1L, FSR2L
|
|
MOVFF r0x00, POSTDEC1
|
|
MOVFF r0x01, POSTDEC1
|
|
; .line 38; main.c LATA = LATE = 0;
|
|
CLRF _LATE
|
|
CLRF _LATA
|
|
; .line 39; 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 40; 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 42; main.c LATA = 0;
|
|
CLRF _LATA
|
|
; .line 43; main.c LATE = 0x4;
|
|
MOVLW 0x04
|
|
MOVWF _LATE
|
|
; .line 44; main.c break;
|
|
BRA _00116_DS_
|
|
_00113_DS_:
|
|
; .line 46; main.c LATE = 0x2;
|
|
MOVLW 0x02
|
|
MOVWF _LATE
|
|
; .line 47; main.c break;
|
|
BRA _00116_DS_
|
|
_00114_DS_:
|
|
; .line 49; main.c LATE = 0x1;
|
|
MOVLW 0x01
|
|
MOVWF _LATE
|
|
; .line 50; main.c break;
|
|
BRA _00116_DS_
|
|
_00115_DS_:
|
|
; .line 52; main.c LATE = 0;
|
|
CLRF _LATE
|
|
; .line 53; main.c LATA = 0x10;
|
|
MOVLW 0x10
|
|
MOVWF _LATA
|
|
_00116_DS_:
|
|
BANKSEL _dsp_en
|
|
; .line 56; main.c dsp_en++;
|
|
INCF _dsp_en, F, B
|
|
; .line 57; 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 58; main.c }
|
|
MOVFF PREINC1, r0x01
|
|
MOVFF PREINC1, r0x00
|
|
MOVFF PREINC1, FSR2L
|
|
RETURN
|
|
|
|
; ; Starting pCode block
|
|
S_main__isr code
|
|
_isr:
|
|
; .line 29; 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 30; main.c if (INTCONbits.TMR0IF){
|
|
BTFSS _INTCONbits, 2
|
|
BRA _00106_DS_
|
|
; .line 31; main.c tmr_isr();
|
|
CALL _tmr_isr
|
|
; .line 32; main.c TMR0 = RATE;
|
|
MOVLW 0xe6
|
|
MOVWF _TMR0
|
|
_00106_DS_:
|
|
; .line 34; main.c INTCONbits.TMR0IF = 0;
|
|
BCF _INTCONbits, 2
|
|
; .line 35; 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: 974 (0x03ce) bytes ( 0.74%)
|
|
; 487 (0x01e7) words
|
|
; udata size: 0 (0x0000) bytes ( 0.00%)
|
|
; access size: 9 (0x0009) bytes
|
|
|
|
|
|
end
|