Added timer interrupts and 7seg multiplexer
This commit is contained in:
parent
055c39faf9
commit
fa063aa081
1
.gitignore
vendored
1
.gitignore
vendored
|
|
@ -1,2 +1,3 @@
|
|||
*.lst
|
||||
*.cod
|
||||
*.o
|
||||
|
|
|
|||
BIN
c/interrupt/test/a.out
Executable file
BIN
c/interrupt/test/a.out
Executable file
Binary file not shown.
29
c/interrupt/test/main.c
Executable file
29
c/interrupt/test/main.c
Executable file
|
|
@ -0,0 +1,29 @@
|
|||
#include <stdio.h>
|
||||
#include <stdint.h>
|
||||
|
||||
uint8_t digit[4] = { 0 };
|
||||
|
||||
void splitdigit(uint16_t);
|
||||
void splitdigit(uint16_t num) {
|
||||
uint8_t i = 0;
|
||||
while (num) {
|
||||
digit[i] = num%10;
|
||||
num = num/10;
|
||||
i++;
|
||||
}
|
||||
}
|
||||
|
||||
int main(void) {
|
||||
uint8_t i;
|
||||
uint8_t y = 2;
|
||||
uint8_t x = 3;
|
||||
splitdigit(24);
|
||||
for (i = 0; i < 4; i++) {
|
||||
printf("%d\n", digit[i]);
|
||||
}
|
||||
y = x = 2;
|
||||
printf("x = %d\n", x);
|
||||
printf("y = %d\n", y);
|
||||
|
||||
return 0;
|
||||
}
|
||||
791
c/timer_interrupt/main.asm
Executable file
791
c/timer_interrupt/main.asm
Executable file
|
|
@ -0,0 +1,791 @@
|
|||
;--------------------------------------------------------
|
||||
; 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 _setup
|
||||
global _isr
|
||||
global _tmr_isr
|
||||
global _number_to_7seg
|
||||
global _display
|
||||
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 __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 144; main.c setup();
|
||||
CALL _setup
|
||||
CLRF r0x00
|
||||
CLRF r0x01
|
||||
_00209_DS_:
|
||||
; .line 146; main.c display(cuenta);
|
||||
MOVF r0x01, W
|
||||
MOVWF POSTDEC1
|
||||
MOVF r0x00, W
|
||||
MOVWF POSTDEC1
|
||||
CALL _display
|
||||
MOVF POSTINC1, F
|
||||
MOVF POSTINC1, F
|
||||
; .line 147; main.c delay1ktcy(500);
|
||||
MOVLW 0xf4
|
||||
CALL _delay1ktcy
|
||||
; .line 148; main.c cuenta++;
|
||||
INFSNZ r0x00, F
|
||||
INCF r0x01, F
|
||||
BRA _00209_DS_
|
||||
; .line 151; main.c }
|
||||
RETURN
|
||||
|
||||
; ; Starting pCode block
|
||||
S_main__display code
|
||||
_display:
|
||||
; .line 132; 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 134; main.c if (num > 9999) return;
|
||||
MOVF r0x00, W
|
||||
MOVWF r0x02
|
||||
MOVF r0x01, W
|
||||
MOVWF r0x03
|
||||
MOVLW 0x27
|
||||
SUBWF r0x03, W
|
||||
BNZ _00203_DS_
|
||||
MOVLW 0x10
|
||||
SUBWF r0x02, W
|
||||
_00203_DS_:
|
||||
BC _00182_DS_
|
||||
; .line 135; main.c while(num) {
|
||||
CLRF r0x02
|
||||
_00179_DS_:
|
||||
MOVF r0x01, W
|
||||
IORWF r0x00, W
|
||||
BZ _00182_DS_
|
||||
; .line 136; 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 137; 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 138; main.c i++;
|
||||
INCF r0x02, F
|
||||
BRA _00179_DS_
|
||||
_00182_DS_:
|
||||
; .line 140; 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 94; 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 95; main.c switch (number) {
|
||||
MOVLW 0x10
|
||||
SUBWF r0x00, W
|
||||
BTFSC STATUS, 0
|
||||
BRA _00161_DS_
|
||||
CLRF PCLATH
|
||||
CLRF PCLATU
|
||||
RLCF r0x00, W
|
||||
RLCF PCLATH, F
|
||||
RLCF WREG, W
|
||||
RLCF PCLATH, F
|
||||
ANDLW 0xfc
|
||||
ADDLW LOW(_00172_DS_)
|
||||
MOVWF POSTDEC1
|
||||
MOVLW HIGH(_00172_DS_)
|
||||
ADDWFC PCLATH, F
|
||||
MOVLW UPPER(_00172_DS_)
|
||||
ADDWFC PCLATU, F
|
||||
MOVF PREINC1, W
|
||||
MOVWF PCL
|
||||
_00172_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_
|
||||
GOTO _00156_DS_
|
||||
GOTO _00157_DS_
|
||||
GOTO _00158_DS_
|
||||
GOTO _00159_DS_
|
||||
GOTO _00160_DS_
|
||||
_00145_DS_:
|
||||
; .line 97; main.c return 0x3F;
|
||||
MOVLW 0x3f
|
||||
BRA _00163_DS_
|
||||
_00146_DS_:
|
||||
; .line 99; main.c return 0x06;
|
||||
MOVLW 0x06
|
||||
BRA _00163_DS_
|
||||
_00147_DS_:
|
||||
; .line 101; main.c return 0x5B;
|
||||
MOVLW 0x5b
|
||||
BRA _00163_DS_
|
||||
_00148_DS_:
|
||||
; .line 103; main.c return 0x4F;
|
||||
MOVLW 0x4f
|
||||
BRA _00163_DS_
|
||||
_00149_DS_:
|
||||
; .line 105; main.c return 0x66;
|
||||
MOVLW 0x66
|
||||
BRA _00163_DS_
|
||||
_00150_DS_:
|
||||
; .line 107; main.c return 0x6D;
|
||||
MOVLW 0x6d
|
||||
BRA _00163_DS_
|
||||
_00151_DS_:
|
||||
; .line 109; main.c return 0x7D;
|
||||
MOVLW 0x7d
|
||||
BRA _00163_DS_
|
||||
_00152_DS_:
|
||||
; .line 111; main.c return 0x07;
|
||||
MOVLW 0x07
|
||||
BRA _00163_DS_
|
||||
_00153_DS_:
|
||||
; .line 113; main.c return 0x7F;
|
||||
MOVLW 0x7f
|
||||
BRA _00163_DS_
|
||||
_00154_DS_:
|
||||
; .line 115; main.c return 0x6F;
|
||||
MOVLW 0x6f
|
||||
BRA _00163_DS_
|
||||
_00155_DS_:
|
||||
; .line 117; main.c return 0x77;
|
||||
MOVLW 0x77
|
||||
BRA _00163_DS_
|
||||
_00156_DS_:
|
||||
; .line 119; main.c return 0x7c;
|
||||
MOVLW 0x7c
|
||||
BRA _00163_DS_
|
||||
_00157_DS_:
|
||||
; .line 121; main.c return 0x39;
|
||||
MOVLW 0x39
|
||||
BRA _00163_DS_
|
||||
_00158_DS_:
|
||||
; .line 123; main.c return 0x5e;
|
||||
MOVLW 0x5e
|
||||
BRA _00163_DS_
|
||||
_00159_DS_:
|
||||
; .line 125; main.c return 0x79;
|
||||
MOVLW 0x79
|
||||
BRA _00163_DS_
|
||||
_00160_DS_:
|
||||
; .line 127; main.c return 0x71;
|
||||
MOVLW 0x71
|
||||
BRA _00163_DS_
|
||||
_00161_DS_:
|
||||
; .line 129; main.c return 0;
|
||||
CLRF WREG
|
||||
_00163_DS_:
|
||||
; .line 131; main.c }
|
||||
MOVFF PREINC1, r0x00
|
||||
MOVFF PREINC1, FSR2L
|
||||
RETURN
|
||||
|
||||
; ; Starting pCode block
|
||||
S_main__tmr_isr code
|
||||
_tmr_isr:
|
||||
; .line 71; main.c void tmr_isr(void){
|
||||
MOVFF FSR2L, POSTDEC1
|
||||
MOVFF FSR1L, FSR2L
|
||||
MOVFF r0x00, POSTDEC1
|
||||
MOVFF r0x01, POSTDEC1
|
||||
; .line 72; main.c LATA = LATE = 0;
|
||||
CLRF _LATE
|
||||
CLRF _LATA
|
||||
; .line 73; 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 74; main.c switch (dsp_en) {
|
||||
MOVLW 0x04
|
||||
BANKSEL _dsp_en
|
||||
SUBWF _dsp_en, W, B
|
||||
BC _00121_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(_00139_DS_)
|
||||
MOVWF POSTDEC1
|
||||
MOVLW HIGH(_00139_DS_)
|
||||
ADDWFC PCLATH, F
|
||||
MOVLW UPPER(_00139_DS_)
|
||||
ADDWFC PCLATU, F
|
||||
MOVF PREINC1, W
|
||||
MOVWF PCL
|
||||
_00139_DS_:
|
||||
GOTO _00117_DS_
|
||||
GOTO _00118_DS_
|
||||
GOTO _00119_DS_
|
||||
GOTO _00120_DS_
|
||||
_00117_DS_:
|
||||
; .line 76; main.c LATA = 0;
|
||||
CLRF _LATA
|
||||
; .line 77; main.c LATE = 0x4;
|
||||
MOVLW 0x04
|
||||
MOVWF _LATE
|
||||
; .line 78; main.c break;
|
||||
BRA _00121_DS_
|
||||
_00118_DS_:
|
||||
; .line 80; main.c LATE = 0x2;
|
||||
MOVLW 0x02
|
||||
MOVWF _LATE
|
||||
; .line 81; main.c break;
|
||||
BRA _00121_DS_
|
||||
_00119_DS_:
|
||||
; .line 83; main.c LATE = 0x1;
|
||||
MOVLW 0x01
|
||||
MOVWF _LATE
|
||||
; .line 84; main.c break;
|
||||
BRA _00121_DS_
|
||||
_00120_DS_:
|
||||
; .line 86; main.c LATE = 0;
|
||||
CLRF _LATE
|
||||
; .line 87; main.c LATA = 0x10;
|
||||
MOVLW 0x10
|
||||
MOVWF _LATA
|
||||
_00121_DS_:
|
||||
BANKSEL _dsp_en
|
||||
; .line 90; main.c dsp_en++;
|
||||
INCF _dsp_en, F, B
|
||||
; .line 91; main.c if (dsp_en > 3) dsp_en = 0;
|
||||
MOVLW 0x04
|
||||
BANKSEL _dsp_en
|
||||
SUBWF _dsp_en, W, B
|
||||
BNC _00124_DS_
|
||||
BANKSEL _dsp_en
|
||||
CLRF _dsp_en, B
|
||||
_00124_DS_:
|
||||
; .line 92; main.c }
|
||||
MOVFF PREINC1, r0x01
|
||||
MOVFF PREINC1, r0x00
|
||||
MOVFF PREINC1, FSR2L
|
||||
RETURN
|
||||
|
||||
; ; Starting pCode block
|
||||
S_main__isr code
|
||||
_isr:
|
||||
; .line 63; 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 64; main.c if (INTCONbits.TMR0IF){
|
||||
BTFSS _INTCONbits, 2
|
||||
BRA _00111_DS_
|
||||
; .line 65; main.c tmr_isr();
|
||||
CALL _tmr_isr
|
||||
; .line 66; main.c TMR0 = RATE;
|
||||
MOVLW 0xfa
|
||||
MOVWF _TMR0
|
||||
_00111_DS_:
|
||||
; .line 68; main.c INTCONbits.TMR0IF = 0;
|
||||
BCF _INTCONbits, 2
|
||||
; .line 69; 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
|
||||
|
||||
; ; Starting pCode block
|
||||
S_main__setup code
|
||||
_setup:
|
||||
; .line 26; main.c void setup(void){
|
||||
MOVFF FSR2L, POSTDEC1
|
||||
MOVFF FSR1L, FSR2L
|
||||
; .line 28; main.c LATD = 0;
|
||||
CLRF _LATD
|
||||
; .line 29; main.c TRISD = 0;
|
||||
CLRF _TRISD
|
||||
; .line 31; main.c TRISB = 0xff;
|
||||
MOVLW 0xff
|
||||
MOVWF _TRISB
|
||||
; .line 32; main.c LATB = 0x00;
|
||||
CLRF _LATB
|
||||
; .line 33; main.c ADCON1 = 0xf;
|
||||
MOVLW 0x0f
|
||||
MOVWF _ADCON1
|
||||
; .line 35; main.c TRISE = 0;
|
||||
CLRF _TRISE
|
||||
; .line 36; main.c LATE = 0;
|
||||
CLRF _LATE
|
||||
; .line 38; main.c TRISA = 0;
|
||||
CLRF _TRISA
|
||||
; .line 39; main.c LATA = 0;
|
||||
CLRF _LATA
|
||||
; .line 42; main.c INTCONbits.GIE = 1;
|
||||
BSF _INTCONbits, 7
|
||||
; .line 43; main.c INTCONbits.PEIE = 1;
|
||||
BSF _INTCONbits, 6
|
||||
; .line 44; main.c INTCONbits.RBIE = 0;
|
||||
BCF _INTCONbits, 3
|
||||
; .line 45; main.c INTCON2bits.RBPU = 0;
|
||||
BCF _INTCON2bits, 7
|
||||
; .line 46; main.c INTCON2bits.RBIP = 1;
|
||||
BSF _INTCON2bits, 0
|
||||
; .line 47; main.c RCONbits.IPEN = 1;
|
||||
BSF _RCONbits, 7
|
||||
; .line 50; main.c INTCONbits.TMR0IE = 1;
|
||||
BSF _INTCONbits, 5
|
||||
; .line 51; main.c INTCON2bits.TMR0IP = 1;
|
||||
BSF _INTCON2bits, 2
|
||||
; .line 53; main.c T0CONbits.T08BIT = 1;
|
||||
BSF _T0CONbits, 6
|
||||
; .line 54; main.c T0CONbits.T0CS = 0; // Source internal oscilator
|
||||
BCF _T0CONbits, 5
|
||||
; .line 55; main.c T0CONbits.PSA = 0;
|
||||
BCF _T0CONbits, 3
|
||||
; .line 59; main.c T0CONbits.T0PS = 0x7;
|
||||
MOVF _T0CONbits, W
|
||||
ANDLW 0xf8
|
||||
IORLW 0x07
|
||||
MOVWF _T0CONbits
|
||||
; .line 60; main.c T0CONbits.TMR0ON = 1;
|
||||
BSF _T0CONbits, 7
|
||||
; .line 61; main.c }
|
||||
MOVFF PREINC1, FSR2L
|
||||
RETURN
|
||||
|
||||
|
||||
|
||||
; Statistics:
|
||||
; code size: 800 (0x0320) bytes ( 0.61%)
|
||||
; 400 (0x0190) words
|
||||
; udata size: 0 (0x0000) bytes ( 0.00%)
|
||||
; access size: 9 (0x0009) bytes
|
||||
|
||||
|
||||
end
|
||||
151
c/timer_interrupt/main.c
Executable file
151
c/timer_interrupt/main.c
Executable file
|
|
@ -0,0 +1,151 @@
|
|||
#include <delay.h>
|
||||
#include <pic18fregs.h>
|
||||
#include <stdint.h>
|
||||
|
||||
// FUSES START
|
||||
#pragma config XINST = OFF
|
||||
#pragma config FOSC = HS
|
||||
#pragma config WDT = OFF
|
||||
#pragma config LVP = OFF
|
||||
#pragma config MCLRE = OFF
|
||||
|
||||
#define NDIGITS 4
|
||||
#define RATE 250
|
||||
|
||||
|
||||
uint8_t digit[NDIGITS] = { 0 };
|
||||
uint8_t dsp_en = 0;
|
||||
|
||||
void setup(void);
|
||||
void isr(void) __interrupt (1);
|
||||
void tmr_isr(void);
|
||||
uint8_t number_to_7seg(uint8_t);
|
||||
void display(uint16_t);
|
||||
int main(void);
|
||||
|
||||
void setup(void){
|
||||
/* Port setup */
|
||||
LATD = 0;
|
||||
TRISD = 0;
|
||||
|
||||
TRISB = 0xff;
|
||||
LATB = 0x00;
|
||||
ADCON1 = 0xf;
|
||||
|
||||
TRISE = 0;
|
||||
LATE = 0;
|
||||
|
||||
TRISA = 0;
|
||||
LATA = 0;
|
||||
|
||||
/* Interrupt setup */
|
||||
INTCONbits.GIE = 1;
|
||||
INTCONbits.PEIE = 1;
|
||||
INTCONbits.RBIE = 0;
|
||||
INTCON2bits.RBPU = 0;
|
||||
INTCON2bits.RBIP = 1;
|
||||
RCONbits.IPEN = 1;
|
||||
|
||||
/* timer interrupt setup */
|
||||
INTCONbits.TMR0IE = 1;
|
||||
INTCON2bits.TMR0IP = 1;
|
||||
|
||||
T0CONbits.T08BIT = 1;
|
||||
T0CONbits.T0CS = 0; // Source internal oscilator
|
||||
T0CONbits.PSA = 0;
|
||||
//T0CONbits.T0PS0 = 1;
|
||||
//T0CONbits.T0PS1 = 1;
|
||||
//T0CONbits.T0PS2 = 1;
|
||||
T0CONbits.T0PS = 0x7;
|
||||
T0CONbits.TMR0ON = 1;
|
||||
}
|
||||
|
||||
void isr(void) __interrupt (1) {
|
||||
if (INTCONbits.TMR0IF){
|
||||
tmr_isr();
|
||||
TMR0 = RATE;
|
||||
}
|
||||
INTCONbits.TMR0IF = 0;
|
||||
}
|
||||
|
||||
void tmr_isr(void){
|
||||
LATA = LATE = 0;
|
||||
LATD = number_to_7seg(digit[dsp_en]);
|
||||
switch (dsp_en) {
|
||||
case 0:
|
||||
LATA = 0;
|
||||
LATE = 0x4;
|
||||
break;
|
||||
case 1:
|
||||
LATE = 0x2;
|
||||
break;
|
||||
case 2:
|
||||
LATE = 0x1;
|
||||
break;
|
||||
case 3:
|
||||
LATE = 0;
|
||||
LATA = 0x10;
|
||||
break;
|
||||
}
|
||||
dsp_en++;
|
||||
if (dsp_en > 3) dsp_en = 0;
|
||||
}
|
||||
|
||||
uint8_t number_to_7seg(uint8_t number) {
|
||||
switch (number) {
|
||||
case 0:
|
||||
return 0x3F;
|
||||
case 1:
|
||||
return 0x06;
|
||||
case 2:
|
||||
return 0x5B;
|
||||
case 3:
|
||||
return 0x4F;
|
||||
case 4:
|
||||
return 0x66;
|
||||
case 5:
|
||||
return 0x6D;
|
||||
case 6:
|
||||
return 0x7D;
|
||||
case 7:
|
||||
return 0x07;
|
||||
case 8:
|
||||
return 0x7F;
|
||||
case 9:
|
||||
return 0x6F;
|
||||
case 0xa:
|
||||
return 0x77;
|
||||
case 0xb:
|
||||
return 0x7c;
|
||||
case 0xC:
|
||||
return 0x39;
|
||||
case 0xd:
|
||||
return 0x5e;
|
||||
case 0xe:
|
||||
return 0x79;
|
||||
case 0xf:
|
||||
return 0x71;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
void display(uint16_t num){
|
||||
uint8_t i = 0;
|
||||
if (num > 9999) return;
|
||||
while(num) {
|
||||
digit[i] = num%10;
|
||||
num = num/10;
|
||||
i++;
|
||||
}
|
||||
}
|
||||
|
||||
int main(void) {
|
||||
uint16_t cuenta = 0;
|
||||
setup();
|
||||
for (;;) {
|
||||
display(cuenta);
|
||||
delay1ktcy(500);
|
||||
cuenta++;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
96
c/timer_interrupt/main.hex
Executable file
96
c/timer_interrupt/main.hex
Executable file
|
|
@ -0,0 +1,96 @@
|
|||
:020000040000FA
|
||||
:040000008DEF01F08F
|
||||
:0800080037EF02F0D9CFE5FF4C
|
||||
:10001000E1CFD9FF00C0E5FF01C0E5FF02C0E5FF69
|
||||
:1000200003C0E5FF04C0E5FF05C0E5FF06C0E5FF2E
|
||||
:1000300007C0E5FF08C0E5FF020EDBCF00F0030EAE
|
||||
:10004000DBCF01F00050026E0150036E270E035CFF
|
||||
:1000500002E1100E025C38E2026A0150001034E046
|
||||
:10006000600E0224036E046A000E04220050056E26
|
||||
:100070000150066E000EE56E0A0EE56E0650E56E46
|
||||
:100080000550E56EDBEC00F0076EF3CF08F0040ED0
|
||||
:10009000E12603C0E9FF04C0EAFF07C0EFFF000E3E
|
||||
:1000A000E56E0A0EE56E0650E56E0550E56EE2EC73
|
||||
:1000B00001F0036EF3CF04F0040EE1260350006E4E
|
||||
:1000C0000450016E022AC9D7E4CF08F0E4CF07F04C
|
||||
:1000D000E4CF06F0E4CF05F0E4CF04F0E4CF03F082
|
||||
:1000E000E4CF02F0E4CF01F0E4CF00F0E4CFD9FF99
|
||||
:1000F0001200D9CFE5FFE1CFD9FF00C0E5FF020E26
|
||||
:10010000DBCF00F0100E005CD8B04FD0FA6AFB6A6B
|
||||
:100110000034FA36E834FA36FC0B2A0FE56E010E8D
|
||||
:10012000FA22000EFB22E450F96EB5EF00F0B7EFB3
|
||||
:1001300000F0B9EF00F0BBEF00F0BDEF00F0BFEF53
|
||||
:1001400000F0C1EF00F0C3EF00F0C5EF00F0C7EF23
|
||||
:1001500000F0C9EF00F0CBEF00F0CDEF00F0CFEFF3
|
||||
:1001600000F0D1EF00F0D3EF00F03F0E1FD0060EED
|
||||
:100170001DD05B0E1BD04F0E19D0660E17D06D0E22
|
||||
:1001800015D07D0E13D0070E11D07F0E0FD06F0E3D
|
||||
:100190000DD0770E0BD07C0E09D0390E07D05E0E35
|
||||
:1001A00005D0790E03D0710E01D0E86AE4CF00F0DB
|
||||
:1001B000E4CFD9FF1200D9CFE5FFE1CFD9FF00C0CE
|
||||
:1001C000E5FF01C0E5FF02C0E5FF03C0E5FF04C095
|
||||
:1001D000E5FF05C0E5FF06C0E5FF020EDBCF00F03E
|
||||
:1001E000030EDBCF01F0040EDBCF02F0050EDBCFF8
|
||||
:1001F00003F0046A056A0350800BE844066E06505B
|
||||
:1002000011E10250022603360350015C02E1025064
|
||||
:10021000005C04E2D8900332023204D0052A05C003
|
||||
:1002200004F0E9D70350015C02E10250005C04E3F2
|
||||
:100230000250005E0350015AD8900332023204C0CB
|
||||
:1002400005F004060550EEE101C0F3FF0050E4CFD5
|
||||
:1002500006F0E4CF05F0E4CF04F0E4CF03F0E4CF00
|
||||
:1002600002F0E4CF01F0E4CF00F0E4CFD9FF1200B8
|
||||
:10027000D9CFE5FFE1CFD9FF00C0E5FF01C0E5FF21
|
||||
:100280008D6A896A600E00016425006E016A000EA5
|
||||
:10029000012200C0E9FF01C0EAFFEFCF00F00050EB
|
||||
:1002A000E56E79EC00F08C6EE652040E0001645DA0
|
||||
:1002B00025E2FA6AFB6A00016435FA36E834FA3658
|
||||
:1002C000FC0BD20FE56E020EFA22000EFB22E45068
|
||||
:1002D000F96E71EF01F075EF01F078EF01F07BEF4F
|
||||
:1002E00001F0896A040E8D6E09D0020E8D6E06D063
|
||||
:1002F000010E8D6E03D08D6A100E896E0001642B85
|
||||
:10030000040E0001645D02E30001646BE4CF01F0C0
|
||||
:10031000E4CF00F0E4CFD9FF120011EEFFF021EEA0
|
||||
:10032000FFF0F86AA68EA69C07EEFFF00068ED6A63
|
||||
:100330000050FDE1760EF66E050EF76E000EF86EBB
|
||||
:100340000900F5CF05F00900F5CF06F034D009001B
|
||||
:10035000F5CF00F00900F5CF01F00900F5CF02F06C
|
||||
:1003600009000900F5CFE9FF0900F5CFEAFF090010
|
||||
:1003700009000900F5CF03F00900F5CF04F00900EA
|
||||
:100380000900F6CF07F0F7CF08F0F8CF09F000C06A
|
||||
:10039000F6FF01C0F7FF02C0F8FF03D00900F5CF58
|
||||
:1003A000EEFF0306FBE20406F9E207C0F6FF08C011
|
||||
:1003B000F7FF09C0F8FF0506CAE20606C8E2A8EC86
|
||||
:1003C00002F0FFD7D9CFE5FFE1CFD9FF00C0E5FFAD
|
||||
:1003D00001C0E5FF02C0E5FF03C0E5FF04C0E5FF83
|
||||
:1003E00005C0E5FF06C0E5FF07C0E5FF020EDBCF55
|
||||
:1003F00000F0030EDBCF01F0040EDBCF02F0050EA0
|
||||
:10040000DBCF03F0046A056A100E066E0150800B04
|
||||
:10041000E844076E005000260136045004260536D5
|
||||
:100420000750D8A404800350055C02E10250045C2C
|
||||
:1004300005E30250045E0350055A0080060606508C
|
||||
:10044000E5E101C0F3FF0050E4CF07F0E4CF06F090
|
||||
:10045000E4CF05F0E4CF04F0E4CF03F0E4CF02F002
|
||||
:10046000E4CF01F0E4CF00F0E4CFD9FF1200D8CF01
|
||||
:10047000E5FFE0CFE5FFE56EF3CFE5FFF4CFE5FF65
|
||||
:10048000E9CFE5FFEACFE5FFFACFE5FFFBCFE5FFD8
|
||||
:10049000D9CFE5FFE1CFD9FFF2A404D038EC01F0C9
|
||||
:1004A000FA0ED66EF294E4CFD9FFE4CFFBFFE4CF8F
|
||||
:1004B000FAFFE4CFEAFFE4CFE9FFE4CFF4FFE4CFB3
|
||||
:1004C000F3FFE450E4CFE0FFE4CFD8FF1000D9CF32
|
||||
:1004D000E5FFE1CFD9FF8C6A956AFF0E936E8A6AB9
|
||||
:1004E0000F0EC16E966A8D6A926A896AF28EF28CDC
|
||||
:1004F000F296F19EF180D08EF28AF184D58CD59A55
|
||||
:10050000D596D550F80B0709D56ED58EE4CFD9FF17
|
||||
:100510001200E806E56E630E9CEC02F0E4500BE07E
|
||||
:1005200000D0E56E630E9CEC02F000D000D000001D
|
||||
:10053000E450E82EF6D71200E8060000E85007E085
|
||||
:1005400000D000D000D000D00000E82EFAD7120072
|
||||
:1005500067EC02F0006A016A0150E56E0050E56E3A
|
||||
:1005600006EC00F0E652E652F40E89EC02F0004A86
|
||||
:10057000012AF2D71200010084050000600000008B
|
||||
:0A058000060000000000000000006B
|
||||
:020000040030CA
|
||||
:010001000CF2
|
||||
:010003001EDE
|
||||
:02000500038175
|
||||
:00000001FF
|
||||
32
c/timer_interrupt/makefile
Executable file
32
c/timer_interrupt/makefile
Executable file
|
|
@ -0,0 +1,32 @@
|
|||
# My pic workflow makefile by Fernando R Jacobo
|
||||
# Dependencies
|
||||
# SDCC Small Device C Compiler
|
||||
# pk2cmd for pickit pic programmers
|
||||
|
||||
# C compiler variables
|
||||
SRC=*.c
|
||||
CC=sdcc
|
||||
FAMILY=pic16
|
||||
PROC=18f4550
|
||||
|
||||
# ASM and program variables
|
||||
PPROC=PIC18F4550
|
||||
ASMPROC=18F4550
|
||||
|
||||
all: $(SRC:.c=.hex)
|
||||
|
||||
comp: $(SRC)
|
||||
$(CC) --use-non-free -m$(FAMILY) -p$(PROC) $^
|
||||
|
||||
clean:
|
||||
rm -f $(SRC:.c=.asm) $(SRC:.c=.cod) $(SRC:.c=.hex) $(SRC:.c=.lst) $(SRC:.c=.o)
|
||||
|
||||
program:
|
||||
pk2cmd -M -P${PPROC} -Fmain.hex
|
||||
|
||||
asm: *.asm
|
||||
gpasm -p ${ASMPROC} -o main.hex $^
|
||||
|
||||
asmp: asm program
|
||||
|
||||
.PHONY: all clean
|
||||
|
|
@ -1,200 +0,0 @@
|
|||
LIST P=18F4550
|
||||
#include <p18f4550.inc>
|
||||
|
||||
CONFIG FOSC = HS ; Use internal oscillator, RA6 as clock output
|
||||
CONFIG WDT = OFF ; Watchdog Timer off
|
||||
CONFIG LVP = OFF ; Low-Voltage Programming off
|
||||
CONFIG MCLRE = OFF ; MCLR pin disabled, RE3 input enabled
|
||||
|
||||
; Definitions
|
||||
R3 EQU 0x024
|
||||
R4 EQU 0x025
|
||||
R5 EQU 0x026
|
||||
TEMP EQU 0x038
|
||||
COL EQU 0x039
|
||||
READ EQU 0x03A
|
||||
SHIFT EQU 0x03B
|
||||
|
||||
ORG 0x00
|
||||
GOTO INIT
|
||||
|
||||
ORG 0x08
|
||||
GOTO ISR
|
||||
|
||||
INIT:
|
||||
CLRF LATB
|
||||
movlw 0xf0 ; PORTB setup
|
||||
MOVWF TRISB
|
||||
|
||||
movlw 0x0f
|
||||
movwf ADCON1
|
||||
|
||||
clrf TRISD ; Set port D as output
|
||||
clrf LATD
|
||||
CLRF TRISE
|
||||
CLRF LATE
|
||||
|
||||
BSF PORTE, 2
|
||||
CLRF TEMP
|
||||
CLRF COL
|
||||
CLRF SHIFT
|
||||
CLRF READ
|
||||
|
||||
; Configure interrupts
|
||||
BSF RCON, IPEN
|
||||
BSF INTCON, GIE ; Enable Global Interrupts
|
||||
BSF INTCON, PEIE ; Enable Peripheral Interrupts
|
||||
BSF INTCON, RBIE ; Enable RB Port Change Interrupt
|
||||
BCF INTCON2, RBPU ; Enable PORTB pull-ups
|
||||
BSF INTCON2, RBIP ; Set interrupt on high priority RBIP
|
||||
|
||||
LOOP:
|
||||
MOVLW 0x0E
|
||||
MOVWF SHIFT
|
||||
MOVWF PORTB
|
||||
|
||||
CALL disp_delay
|
||||
MOVLW 0x0D
|
||||
MOVWF SHIFT
|
||||
MOVWF PORTB
|
||||
|
||||
CALL disp_delay
|
||||
MOVLW 0x0B
|
||||
MOVWF SHIFT
|
||||
MOVWF PORTB
|
||||
|
||||
CALL disp_delay
|
||||
MOVLW 0x07
|
||||
MOVWF SHIFT
|
||||
MOVWF PORTB
|
||||
|
||||
CALL disp_delay
|
||||
GOTO LOOP
|
||||
|
||||
ISR:
|
||||
BTFSS INTCON, RBIF
|
||||
RETFIE
|
||||
|
||||
MOVF PORTB, W
|
||||
NOP
|
||||
ANDLW 0xf0
|
||||
MOVWF COL
|
||||
SWAPF COL
|
||||
CPFSEQ READ
|
||||
CALL decode
|
||||
MOVWF TEMP
|
||||
CALL sevensw
|
||||
MOVWF PORTD
|
||||
CALL SDelay
|
||||
CALL SDelay
|
||||
CALL SDelay
|
||||
CALL SDelay
|
||||
CALL SDelay
|
||||
|
||||
BCF INTCON, RBIF
|
||||
RETFIE
|
||||
|
||||
display:
|
||||
|
||||
decode:
|
||||
BTFSC SHIFT, 0 ; Check if row 1 is active
|
||||
GOTO col1
|
||||
BTFSS COL, 0 ; Check every column
|
||||
RETLW 0x01
|
||||
BTFSS COL, 1
|
||||
RETLW 0x02
|
||||
BTFSS COL, 2
|
||||
RETLW 0x03
|
||||
BTFSS COL, 3
|
||||
RETLW 0x0A
|
||||
col1:
|
||||
BTFSC SHIFT, 1
|
||||
GOTO col2
|
||||
BTFSS COL, 0 ; Check every column
|
||||
RETLW 0x04
|
||||
BTFSS COL, 1
|
||||
RETLW 0x05
|
||||
BTFSS COL, 2
|
||||
RETLW 0x06
|
||||
BTFSS COL, 3
|
||||
RETLW 0x0B
|
||||
col2:
|
||||
BTFSC SHIFT, 2
|
||||
GOTO col3
|
||||
BTFSS COL, 0 ; Check every column
|
||||
RETLW 0x07
|
||||
BTFSS COL, 1
|
||||
RETLW 0x08
|
||||
BTFSS COL, 2
|
||||
RETLW 0x09
|
||||
BTFSS COL, 3
|
||||
RETLW 0x0C
|
||||
col3
|
||||
BTFSC SHIFT, 3
|
||||
RETLW 0x00
|
||||
BTFSS COL, 0 ; Check every column
|
||||
RETLW 0x00
|
||||
BTFSS COL, 1
|
||||
RETLW 0x00
|
||||
BTFSS COL, 2
|
||||
RETLW 0x00
|
||||
BTFSS COL, 3
|
||||
RETLW 0x0D
|
||||
RETLW 0x00
|
||||
|
||||
|
||||
SDelay:
|
||||
MOVLW D'250'
|
||||
MOVWF R4
|
||||
SDelay_Outer:
|
||||
MOVLW D'250'
|
||||
MOVWF R5
|
||||
SDelay_Inner:
|
||||
NOP
|
||||
NOP
|
||||
DECFSZ R5, F ; Decrement inner loop counter
|
||||
GOTO SDelay_Inner ; Repeat inner loop
|
||||
DECFSZ R4, F ; Decrement outer loop counter
|
||||
GOTO SDelay_Outer ; Repeat outer loop
|
||||
RETURN ; Return from delay
|
||||
|
||||
disp_delay:
|
||||
movlw D'250'
|
||||
movwf R3
|
||||
disp_delay_inner:
|
||||
NOP
|
||||
NOP
|
||||
NOP
|
||||
NOP
|
||||
decfsz R3, F
|
||||
goto disp_delay_inner
|
||||
return
|
||||
|
||||
sevensw:
|
||||
movlw high(sevenjmp)
|
||||
movwf PCLATH
|
||||
movf TEMP, W
|
||||
addwf TEMP, W
|
||||
addlw low(sevenjmp)
|
||||
btfsc STATUS, 0
|
||||
incf PCLATH, 1
|
||||
movwf PCL
|
||||
sevenjmp:
|
||||
retlw 3Fh
|
||||
retlw 06h
|
||||
retlw 5Bh
|
||||
retlw 4Fh
|
||||
retlw 66h
|
||||
retlw 6Dh
|
||||
retlw 7Dh
|
||||
retlw 07h ; siete
|
||||
retlw 7Fh ; ocho
|
||||
retlw 6Fh ; nueve
|
||||
retlw 77h ; A
|
||||
retlw 7Ch ; B
|
||||
retlw 39h ; C
|
||||
retlw 5Eh ; D
|
||||
retlw 79h ; E
|
||||
retlw 71h ; F
|
||||
|
||||
END
|
||||
|
|
@ -1,28 +0,0 @@
|
|||
:020000040000FA
|
||||
:0400000006EF00F017
|
||||
:0800080030EF00F08A6AF00EEF
|
||||
:10001000936E0F0EC16E956A8C6A966A8D6A84849F
|
||||
:10002000386A396A3B6A3A6AD08EF28EF28CF2866E
|
||||
:10003000F19EF1800E0E3B6E816E83EC00F00D0E92
|
||||
:100040003B6E816E83EC00F00B0E3B6E816E83EC99
|
||||
:1000500000F0070E3B6E816E83EC00F01AEF00F0AB
|
||||
:10006000F2A0100081500000F00B396E393A3A626C
|
||||
:100070004AEC00F0386E8DEC00F0836E76EC00F008
|
||||
:1000800076EC00F076EC00F076EC00F076EC00F028
|
||||
:10009000F29010003BB055EF00F039A0010C39A2EE
|
||||
:1000A000020C39A4030C39A60A0C3BB260EF00F035
|
||||
:1000B00039A0040C39A2050C39A4060C39A60B0C86
|
||||
:1000C0003BB46BEF00F039A0070C39A2080C39A43F
|
||||
:1000D000090C39A60C0C3BB6000C39A0000C39A257
|
||||
:1000E000000C39A4000C39A60D0C000CFA0E256E7C
|
||||
:1000F000FA0E266E00000000262E7AEF00F0252E64
|
||||
:1001000078EF00F01200FA0E246E000000000000EC
|
||||
:100110000000242E85EF00F01200010EFA6E385018
|
||||
:1001200038242A0FD8B0FA2AF96E3F0C060C5B0C63
|
||||
:100130004F0C660C6D0C7D0C070C7F0C6F0C770C54
|
||||
:0A0140007C0C390C5E0C790C710C7C
|
||||
:020000040030CA
|
||||
:04000000000C1F1EB3
|
||||
:02000500038175
|
||||
:060008000FC00FE00F40E5
|
||||
:00000001FF
|
||||
|
|
@ -1,200 +0,0 @@
|
|||
LIST P=18F4550
|
||||
#include <p18f4550.inc>
|
||||
|
||||
CONFIG FOSC = HS ; Use internal oscillator, RA6 as clock output
|
||||
CONFIG WDT = OFF ; Watchdog Timer off
|
||||
CONFIG LVP = OFF ; Low-Voltage Programming off
|
||||
CONFIG MCLRE = OFF ; MCLR pin disabled, RE3 input enabled
|
||||
|
||||
; Definitions
|
||||
R3 EQU 0x024
|
||||
R4 EQU 0x025
|
||||
R5 EQU 0x026
|
||||
TEMP EQU 0x038
|
||||
COL EQU 0x039
|
||||
READ EQU 0x03A
|
||||
SHIFT EQU 0x03B
|
||||
|
||||
ORG 0x00
|
||||
GOTO INIT
|
||||
|
||||
ORG 0x08
|
||||
GOTO ISR
|
||||
|
||||
INIT:
|
||||
CLRF LATB
|
||||
movlw 0xf0 ; PORTB setup
|
||||
MOVWF TRISB
|
||||
|
||||
movlw 0x0f
|
||||
movwf ADCON1
|
||||
|
||||
clrf TRISD ; Set port D as output
|
||||
clrf LATD
|
||||
CLRF TRISE
|
||||
CLRF LATE
|
||||
|
||||
BSF PORTE, 2
|
||||
CLRF TEMP
|
||||
CLRF COL
|
||||
CLRF SHIFT
|
||||
CLRF READ
|
||||
|
||||
; Configure interrupts
|
||||
BSF RCON, IPEN
|
||||
BSF INTCON, GIE ; Enable Global Interrupts
|
||||
BSF INTCON, PEIE ; Enable Peripheral Interrupts
|
||||
BSF INTCON, RBIE ; Enable RB Port Change Interrupt
|
||||
BCF INTCON2, RBPU ; Enable PORTB pull-ups
|
||||
BSF INTCON2, RBIP ; Set interrupt on high priority RBIP
|
||||
|
||||
LOOP:
|
||||
MOVLW 0x0E
|
||||
MOVWF SHIFT
|
||||
MOVWF PORTB
|
||||
|
||||
CALL disp_delay
|
||||
MOVLW 0x0D
|
||||
MOVWF SHIFT
|
||||
MOVWF PORTB
|
||||
|
||||
CALL disp_delay
|
||||
MOVLW 0x0B
|
||||
MOVWF SHIFT
|
||||
MOVWF PORTB
|
||||
|
||||
CALL disp_delay
|
||||
MOVLW 0x07
|
||||
MOVWF SHIFT
|
||||
MOVWF PORTB
|
||||
|
||||
CALL disp_delay
|
||||
GOTO LOOP
|
||||
|
||||
ISR:
|
||||
BTFSS INTCON, RBIF
|
||||
RETFIE
|
||||
|
||||
MOVF PORTB, W
|
||||
NOP
|
||||
ANDLW 0xf0
|
||||
MOVWF COL
|
||||
SWAPF COL
|
||||
CPFSEQ READ
|
||||
CALL decode
|
||||
MOVWF TEMP
|
||||
CALL sevensw
|
||||
MOVWF PORTD
|
||||
CALL SDelay
|
||||
CALL SDelay
|
||||
CALL SDelay
|
||||
CALL SDelay
|
||||
CALL SDelay
|
||||
|
||||
BCF INTCON, RBIF
|
||||
RETFIE
|
||||
|
||||
display:
|
||||
|
||||
decode:
|
||||
BTFSC SHIFT, 0 ; Check if row 1 is active
|
||||
GOTO col1
|
||||
BTFSS COL, 0 ; Check every column
|
||||
RETLW 0x01
|
||||
BTFSS COL, 1
|
||||
RETLW 0x02
|
||||
BTFSS COL, 2
|
||||
RETLW 0x03
|
||||
BTFSS COL, 3
|
||||
RETLW 0x0A
|
||||
col1:
|
||||
BTFSC SHIFT, 1
|
||||
GOTO col2
|
||||
BTFSS COL, 0 ; Check every column
|
||||
RETLW 0x04
|
||||
BTFSS COL, 1
|
||||
RETLW 0x05
|
||||
BTFSS COL, 2
|
||||
RETLW 0x06
|
||||
BTFSS COL, 3
|
||||
RETLW 0x0B
|
||||
col2:
|
||||
BTFSC SHIFT, 2
|
||||
GOTO col3
|
||||
BTFSS COL, 0 ; Check every column
|
||||
RETLW 0x07
|
||||
BTFSS COL, 1
|
||||
RETLW 0x08
|
||||
BTFSS COL, 2
|
||||
RETLW 0x09
|
||||
BTFSS COL, 3
|
||||
RETLW 0x0C
|
||||
col3
|
||||
BTFSC SHIFT, 3
|
||||
RETLW 0x00
|
||||
BTFSS COL, 0 ; Check every column
|
||||
RETLW 0x00
|
||||
BTFSS COL, 1
|
||||
RETLW 0x00
|
||||
BTFSS COL, 2
|
||||
RETLW 0x00
|
||||
BTFSS COL, 3
|
||||
RETLW 0x0D
|
||||
RETLW 0x00
|
||||
|
||||
|
||||
SDelay:
|
||||
MOVLW D'250'
|
||||
MOVWF R4
|
||||
SDelay_Outer:
|
||||
MOVLW D'250'
|
||||
MOVWF R5
|
||||
SDelay_Inner:
|
||||
NOP
|
||||
NOP
|
||||
DECFSZ R5, F ; Decrement inner loop counter
|
||||
GOTO SDelay_Inner ; Repeat inner loop
|
||||
DECFSZ R4, F ; Decrement outer loop counter
|
||||
GOTO SDelay_Outer ; Repeat outer loop
|
||||
RETURN ; Return from delay
|
||||
|
||||
disp_delay:
|
||||
movlw D'250'
|
||||
movwf R3
|
||||
disp_delay_inner:
|
||||
NOP
|
||||
NOP
|
||||
NOP
|
||||
NOP
|
||||
decfsz R3, F
|
||||
goto disp_delay_inner
|
||||
return
|
||||
|
||||
sevensw:
|
||||
movlw high(sevenjmp)
|
||||
movwf PCLATH
|
||||
movf TEMP, W
|
||||
addwf TEMP, W
|
||||
addlw low(sevenjmp)
|
||||
btfsc STATUS, 0
|
||||
incf PCLATH, 1
|
||||
movwf PCL
|
||||
sevenjmp:
|
||||
retlw 3Fh
|
||||
retlw 06h
|
||||
retlw 5Bh
|
||||
retlw 4Fh
|
||||
retlw 66h
|
||||
retlw 6Dh
|
||||
retlw 7Dh
|
||||
retlw 07h ; siete
|
||||
retlw 7Fh ; ocho
|
||||
retlw 6Fh ; nueve
|
||||
retlw 77h ; A
|
||||
retlw 7Ch ; B
|
||||
retlw 39h ; C
|
||||
retlw 5Eh ; D
|
||||
retlw 79h ; E
|
||||
retlw 71h ; F
|
||||
|
||||
END
|
||||
|
|
@ -1,28 +0,0 @@
|
|||
:020000040000FA
|
||||
:0400000006EF00F017
|
||||
:0800080030EF00F08A6AF00EEF
|
||||
:10001000936E0F0EC16E956A8C6A966A8D6A84849F
|
||||
:10002000386A396A3B6A3A6AD08EF28EF28CF2866E
|
||||
:10003000F19EF1800E0E3B6E816E83EC00F00D0E92
|
||||
:100040003B6E816E83EC00F00B0E3B6E816E83EC99
|
||||
:1000500000F0070E3B6E816E83EC00F01AEF00F0AB
|
||||
:10006000F2A0100081500000F00B396E393A3A626C
|
||||
:100070004AEC00F0386E8DEC00F0836E76EC00F008
|
||||
:1000800076EC00F076EC00F076EC00F076EC00F028
|
||||
:10009000F29010003BB055EF00F039A0010C39A2EE
|
||||
:1000A000020C39A4030C39A60A0C3BB260EF00F035
|
||||
:1000B00039A0040C39A2050C39A4060C39A60B0C86
|
||||
:1000C0003BB46BEF00F039A0070C39A2080C39A43F
|
||||
:1000D000090C39A60C0C3BB6000C39A0000C39A257
|
||||
:1000E000000C39A4000C39A60D0C000CFA0E256E7C
|
||||
:1000F000FA0E266E00000000262E7AEF00F0252E64
|
||||
:1001000078EF00F01200FA0E246E000000000000EC
|
||||
:100110000000242E85EF00F01200010EFA6E385018
|
||||
:1001200038242A0FD8B0FA2AF96E3F0C060C5B0C63
|
||||
:100130004F0C660C6D0C7D0C070C7F0C6F0C770C54
|
||||
:0A0140007C0C390C5E0C790C710C7C
|
||||
:020000040030CA
|
||||
:04000000000C1F1EB3
|
||||
:02000500038175
|
||||
:060008000FC00FE00F40E5
|
||||
:00000001FF
|
||||
Loading…
Reference in New Issue
Block a user