?? tinyb18f32.asm
字號:
radix DEC LIST P=18F4550 ; change also: Configure->Select Device from MPLAB; For 2455, 2550, 4455, and 4550: 4 MHz quartz / 1 * 24 / 4 = 24 MHzxtal EQU 24000000 ; you may want to change: _XT_OSC_1H _HS_OSC_1H _HSPLL_OSC_1Hbaud EQU 38400 ; standard TinyBld baud rates: 115200 or 19200 ; The above 3 lines can be changed and built a bootloader for the desired frequency (and PIC type) ;******************************************************************** ; Tiny Bootloader 18F series Size=100words ; claudiu.chiculita@ugal.ro ; http://www.etc.ugal.ro/cchiculita/software/picbootloader.htm ; Modified by Nam Nguyen-Quang for testing different PIC18Fs with tinybldWin.exe v1.9 ; namqn@yahoo.com ;********************************************************************; This source file is for PIC18F2420, 2520, 4420, 4520, 2455, 2550, 4455, and 4550; Copy these include files to your project directory (i.e. they are in the same; directory with your .asm source file), if necessary #include "icdpictypes.inc" ; Takes care of: #include "p18fxxx.inc", max_flash, IdTypePIC #include "spbrgselect.inc" ; RoundResult and baud_rate #define first_address max_flash-200 ;100 words; For different PICs, uncomment the appropriate lines of CONFIG directives; as indicated, and comment out all the other lines, if necessary; For example, the following configuration is for PIC18F4550, with 4 MHz crystal; You could find the symbol names for the chip in its include file; (in the Microchip\MPASM Suite directory);----- CONFIG1L Options -----; For 18F2455, 2550, 4455, and 4550 CONFIG PLLDIV = 1, CPUDIV = OSC3_PLL4, USBDIV = 2;----- CONFIG1H Options -----; For 18F2455, 2550, 4455, and 4550 CONFIG FOSC = HSPLL_HS, FCMEM = OFF, IESO = OFF; For 18F2420, 2520, 4420, and 4520; CONFIG OSC = HS, FCMEN = OFF, IESO = OFF; CONFIG OSC = INTIO67, FCMEN = OFF, IESO = OFF ; Use internal oscilator, xtal = 8000000;----- CONFIG2L Options -----; For 18F2455, 2550, 4455, and 4550 CONFIG PWRT = ON, BOR = OFF, BORV = 21, VREGEN = OFF; For 18F2420, and 4420; CONFIG PWRT = ON, BOREN = ON, BORV = 27; For 18F2520, and 4520; CONFIG PWRT = ON, BOREN = ON, BORV = 28;----- CONFIG2H Options -----; For all of the chips associated with this source file CONFIG WDT = OFF, WDTPS = 128;----- CONFIG3H Options -----; For 18F2455, 2550, 4455, and 4550 CONFIG MCLRE = ON, LPT1OSC = OFF, PBADEN = OFF, CCP2MX = OFF; For 18F2420, and 4420; CONFIG MCLRE = ON, PBADEN = OFF, CCP2MX = PORTC; For 18F2520, and 4520; CONFIG MCLRE = ON, LPT1OSC = OFF, PBADEN = OFF, CCP2MX = PORTC;----- CONFIG4L Options -----; For 18F2455, 2550, 4455, and 4550 CONFIG STVREN = ON, LVP = OFF, ICPRT = OFF, DEBUG = OFF, XINST = OFF; For 18F2420, and 4420; CONFIG STVREN = ON, LVP = OFF, ENHCPU = OFF, DEBUG = OFF; For 18F2520, and 4520; CONFIG STVREN = ON, LVP = OFF, DEBUG = OFF, XINST = OFF;----------------------------- PROGRAM --------------------------------- cblock 0 crc i cnt1 cnt2 cnt3 counter_hi counter_lo flag endc cblock 10 buffer:64 dummy4crc endc SendL macro car movlw car movwf TXREG endm ;0000000000000000000000000 RESET 00000000000000000000000000 ORG 0x0000 GOTO IntrareBootloader;view with TabSize=4;&&&&&&&&&&&&&&&&&&&&&&& START &&&&&&&&&&&&&&&&&&&&&&;---------------------- Bootloader ----------------------;PC_flash: C1h U H L x ... <64 bytes> ... crc ;PC_eeprom: C1h 40h EEADR EEDATA 0 crc ;PC_cfg C1h U OR 80h H L 1 byte crc;PIC_response: type `K` ORG first_address ;space to deposit first 4 instr. of user prog. nop nop nop nop org first_address+8IntrareBootloader ;init IntOSC, added by Nam Nguyen-Quang movlw 0x70 movwf OSCCON ; the above 2 lines should be commented out for designs not using the internal oscilator ; or for the chips without the internal oscilator ;init serial port movlw b'00100100' movwf TXSTA movlw spbrg_value movwf SPBRG movlw b'10010000' movwf RCSTA ;wait for computer rcall Receive sublw 0xC1 ;Expect C1h bnz way_to_exit SendL IdTypePIC ;send PIC typeMainLoop SendL 'K' ; "-Everything OK, ready and waiting."mainl clrf crc rcall Receive ;Upper movwf TBLPTRU movwf flag ;(for EEPROM and CFG cases) rcall Receive ;Hi movwf TBLPTRH movwf EEADR ;(for EEPROM case) rcall Receive ;Lo movwf TBLPTRL movwf EEDATA ;(for EEPROM case) rcall Receive ;count movwf i incf i lfsr FSR0, (buffer-1)rcvoct ;read 64+1 bytes movwf TABLAT ;prepare for cfg; => store byte before crc rcall Receive movwf PREINC0 decfsz i bra rcvoct tstfsz crc ;check crc bra ziieroare btfss flag,6 ;is EEPROM data? bra noeeprom movlw b'00000100' ;Setup eeprom rcall Write bra waitwrenoeeprom btfss flag,7 ;is CFG data? bra noconfig tblwt* ;write TABLAT(byte before crc) to TBLPTR*** movlw b'11000100' ;Setup cfg rcall Write bra waitwrenoconfig ;writeeraseloop movlw b'10010100' ; Setup erase rcall Write TBLRD*- ; point to adr-1 writebigloop movlw 2 ; 2groups movwf counter_hi lfsr FSR0,bufferwritesloop movlw 32 ; 32bytes = 16instr movwf counter_lowritebyte movf POSTINC0,w ; put 1 byte movwf TABLAT tblwt+* decfsz counter_lo bra writebyte movlw b'10000100' ; Setup writes rcall Write decfsz counter_hi bra writesloopwaitwre ;btfsc EECON1,WR ;for eeprom writes (wait to finish write) ;bra waitwre ;no need: round trip time with PC bigger than 4ms bcf EECON1,WREN ;disable writes bra MainLoop ziieroare ;CRC failed SendL 'N' bra mainl ;******** procedures ******************Write movwf EECON1 movlw 0x55 movwf EECON2 movlw 0xAA movwf EECON2 bsf EECON1,WR ;WRITE nop ;nop returnReceive movlw xtal/2000000+1 ; for 20MHz => 11 => 1second delay ; for 18F2xxx chips, this should be xtal/1000000+1 movwf cnt1rpt2 clrf cnt2rpt3 clrf cnt3rptc btfss PIR1,RCIF ;test RX bra notrcv movf RCREG,w ;return read data in W addwf crc,f ;compute crc returnnotrcv decfsz cnt3 bra rptc decfsz cnt2 bra rpt3 decfsz cnt1 bra rpt2 ;timeout:way_to_exit bcf RCSTA, SPEN ; deactivate UART bra first_address;*************************************************************; After reset; Do not expect the memory to be zero,; Do not expect registers to be initialised like in catalog. END
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -