|
|
View previous topic :: View next topic |
Author |
Message |
Torello
Joined: 29 Sep 2006 Posts: 123
|
Tiny bootloader image 18F4620 requested |
Posted: Tue Jul 24, 2007 3:08 am |
|
|
Hi,
I'm looking for an 18F4620 image that works under TinyBldWin v1.93 and uses the internal oscillator of the chip.
I've come a long way with modifying an existing image. It seems to work, but I can only write my custom app once. I do reserve the bootloader space ofcourse. Then my custom app. always runs and the bootloader never reacts anymore.
When examining this issue it seems that writing the code by the TinyBldWin does change the LSB of the startup vector. It does not point anymore to "IntrareBootloader" but now to "bnz way_to_exit". That's way my custom app start right away. But this makes no sense....
Has anybody encountered this issue?
I'm currently working with TinyBldWin v1.9.1;
Build 1.9.3 can -not- find the pic with the "check pic" button. Anybody knows why?
Kind regards,
Edwin |
|
|
Mark Weir
Joined: 11 Sep 2003 Posts: 51 Location: New Zealand
|
Bootloader |
Posted: Tue Jul 24, 2007 2:40 pm |
|
|
Hi there,
Have you updated the ini file? you need to change these
SizeofBLD=264 - Add this line
SizeOfBLD_W=132 - Change this line
Basically if you are getting 1 bootloader then no more you have probably overwritten the data at the reset vector.
Good Luck
Mark _________________ Life is too short to avoid asking questions |
|
|
Torello
Joined: 29 Sep 2006 Posts: 123
|
|
Posted: Tue Jul 24, 2007 3:04 pm |
|
|
Hi Mark,
Thank you for this very interesting tip. I would never have expected the buildsize of the bootloader in the ini-file.
Why do I need to also -add- a line SIzeofBLD ? Is the word count not enough?
Concerning the reset vector; I would expect tiny bootloader to not overwrite this area. Intercept the goto main opcode and write this at first_address.
But now the coin falls (this is a dutch saying ) The TinybldWin app is probably doing this and therefore needs to know the size of the bootloader. Yes! I tried to find the asm code for this interception but I can't find it.
Do you know also why v1.9.3 is not reacting with the previous bootimages?
Thanks for this great tip!
Regards,
Edwin |
|
|
Mark Weir
Joined: 11 Sep 2003 Posts: 51 Location: New Zealand
|
|
Posted: Tue Jul 24, 2007 3:20 pm |
|
|
Hi Edwin,
I spent several days doing exactly what you are doing now. I had to set up tinybootloader to work with 18F4620, intrc, 19200 baud on RS485 and at 32mhz.
I got some good info from a post labelled 'RS485 bootloader with sw reset'
Search for this on the forum. My application needs to upload at a prompt from software.
I am working with V1.91 also as I had problems with V1.93. I have since bought the Tiny Bootloader code from the designer as we will be building it into our application so we might find some of the problems as we work through this.
Cheers
Mark _________________ Life is too short to avoid asking questions |
|
|
Torello
Joined: 29 Sep 2006 Posts: 123
|
|
Posted: Wed Jul 25, 2007 1:48 am |
|
|
Hi Mark,
Maybe I can ask you for a little bit more help? The SizeofBLD is working perfectly; reset vectors are now pointing to the place they should.
Thank so far. But now an other surprise is in place.
After the first write of my custom app it runs perfectly. When I read the flash with the ICD; both my app and the bootloader are in place. Reset vector and main vector perfectly on the right spot; with the right value.
Then when I cLick "checkpic" again I get the message
Searching for PIC ...
pic sending unknown data: "K" <> 74h=t
Check baudrate & Start Write while PIC is not sending serial data (e.g. in reset)
ERROR!
-- Skip below >> see next message
So I ICD read the flash again, and the bootloader has only destroyed itself !! All "FF" My app is still perfectly in place, the reset vector is still pointing to the startpoint where the bootloader was.
Look like a James Bond movie; kill the message after use
Any thoughts? Did you encounter this also??
Regards,
Edwin.
Last edited by Torello on Wed Jul 25, 2007 2:05 am; edited 1 time in total |
|
|
Torello
Joined: 29 Sep 2006 Posts: 123
|
|
Posted: Wed Jul 25, 2007 2:02 am |
|
|
Hi Mark,
The last message was not fully correct. The bootloader get a bit destroyed. The Main app vector is still in place but upto FF40 all opcode is erased.
Adress space FFFF- FF40 + 8 (for the main app vector ) are again the famous 100 words. Is the TinybldWin still not fully aware of the new bootlader size??
Regards,
Edwin
Last edited by Torello on Wed Jul 25, 2007 12:30 pm; edited 1 time in total |
|
|
future
Joined: 14 May 2004 Posts: 330
|
|
Posted: Wed Jul 25, 2007 10:03 am |
|
|
Post your email and I'll forward the image to you. |
|
|
Torello
Joined: 29 Sep 2006 Posts: 123
|
|
Posted: Thu Jul 26, 2007 3:20 am |
|
|
Hi Mark,
Still stuck on the point that TinybldWin erases the flash upto 0xFF40. And then programs the user app.
It still calculates with 100 words size for the bootlader (minus 4 of the vector).
This seems not being corrected by the ini-settings:
- SizeOfBLD_W= <word count>
- SizeOfBLD= <word count>*2
Do you've got a tip for me? I'm I still missing a setting? Should SizeOfBld be SizeOfBlD_B ??
Kind regards,
Edwin. |
|
|
Torello
Joined: 29 Sep 2006 Posts: 123
|
|
Posted: Thu Jul 26, 2007 4:10 am |
|
|
Hi All,
I put my hope on TinybldWin v1.93. Maybe this version does not erase a fixed 100 words.
First there is a change in the way RTS is being activated. RTS should reset the pic, then it waits in reception for 0x1C of the computer.
In version 1.93 RTS is not pulsed low any more, but *KEPT* low. Put a capacitor (~100nF, Rpullup=47k) in series with the Mclr line and v.193 seems to operate.
But, unfortunately, also v1.93 seems to erase upto 0xFF40 when SizeOfBLD_W=110 is used...
Still investigating |
|
|
Mark Weir
Joined: 11 Sep 2003 Posts: 51 Location: New Zealand
|
Tiny B |
Posted: Thu Jul 26, 2007 5:41 am |
|
|
Hi Edwin,
I can't understand why you are still overwriting.
I have copied the ini file for you to check your settings against:
[PIC]
COMport=COM1
COMspeed=19200
[WINDOW]
Top=40
Left=430
Width=541
Height=278
[OPTIONS]
PreCodes=12h
PulseRTS=0
ActiveRTS=0
SearchDelay=5
Timeout=300
SearchForCOMs=0
SizeofBLD=264
SizeOfBLD_W=132
[TERMINAL]
TerminalBufferLength=10000
SwitchToTerminal=0
When you make the changes you must save the file before closing it.
Cheers
Mark _________________ Life is too short to avoid asking questions |
|
|
Torello
Joined: 29 Sep 2006 Posts: 123
|
|
Posted: Thu Jul 26, 2007 7:05 am |
|
|
Hi Mark,
I finally have found most of the troubles.
First off all:
You can not specify all different words lengths of builds. It probably has to do that the addresses are grouped in blocks of 64 bytes; I did not yet figured this out. But if I use SizeOfBLD_W=132 (my size was 110); it does not erase flash anymore upto 0xFF40
So now my bootimage for the 4620 internal oscillator 8Mhz/4*PLL/115200 works !!!
Other issues v191:
- The option SizeOfBLD (without _W) is not used
Bug/issues TinybldWin v1.93:
- has a **BIG** bug; after write flash it shifts the startup vector 2 bytes; so the goto bootloader is now suddenly at 0x0002. Yakkkk!
- The switching of com speeds (Write versus terminal) in TinybldWin v1.93 does not work very well. If you let it open the terminal automatically then you have to close and reopen the port to get to the right comspeed. The same more a less happens when at opened terminal you click "Check pic". The first time it does not find it and the second click is ok.
But because v193 has the write startup vector bug; I will use v191 for now.
Kind regards,
Edwin. |
|
|
Torello
Joined: 29 Sep 2006 Posts: 123
|
|
Posted: Thu Jul 26, 2007 7:54 am |
|
|
Hi Again,
Last part of the SizeOfBLD_W puzzle (I couldn't let is rest ); The sizes may increase with stepsize of 32 words. I tried 8 and 16; but these don't work.
It worked at 132, 164, 196 words.
Now let's wait for v1.93 to get debugged. Tinybootloader is still my favorite.
For those interested in the image see code below. I still want to tweak it a little bit. But it works now :-)
Code: | radix DEC
LIST P=18F4620 ; change also: Configure->SelectDevice from Mplab
xtal EQU 32000000 ; internal oscillator 8Mhz with 4* PLL
baud EQU 115200 ; baudrate
;********************************************************************
; Tiny Bootloader 18F series
; claudiu.chiculita@ugal.ro
; http://www.etc.ugal.ro/cchiculita/software/picbootloader.htm
; Modified by Edwin Baaij; tested with tinybldWin.exe v1.9.1
; IMPORTANT: (dd 26/07/2007) use TinybldWin version 1.9.1 (v1.9.3 has a write bug; does not work)
;*******************************************************************
; 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-264) ;132 words (264bytes)
; for the above: You can NOT specify all kinds of sizes; 100, 132, 164, 196... (these worked for me)
; Adapt tinybld.ini (first close TinybldWin.exe) Set SizeOfBLD_W=132 or you used size
__CONFIG _CONFIG1H, _IESO_OFF_1H & _FCMEN_OFF_1H & _OSC_INTIO67_1H
__CONFIG _CONFIG2L, _BOREN_OFF_2L & _PWRT_ON_2L
__CONFIG _CONFIG2H, _WDT_OFF_2H & _WDTPS_128_2H
__CONFIG _CONFIG3H, _MCLRE_ON_3H & _LPT1OSC_OFF_3H & _PBADEN_OFF_3H & _CCP2MX_PORTBE_3H
__CONFIG _CONFIG4L, _STVREN_ON_4L & _LVP_OFF_4L & _DEBUG_OFF_4L & _XINST_OFF_4L
__CONFIG _CONFIG5L, _CP0_OFF_5L & _CP1_OFF_5L & _CP2_OFF_5L &_CP3_OFF_5L
__CONFIG _CONFIG5H, _CPB_OFF_5H & _CPD_OFF_5H
__CONFIG _CONFIG6L, _WRT0_OFF_6L & _WRT1_OFF_6L & _WRT2_OFF_6L & _WRT3_OFF_6L
__CONFIG _CONFIG6H, _WRTB_OFF_6H & _WRTC_OFF_6H & _WRTD_OFF_6H
__CONFIG _CONFIG7L, _EBTR0_OFF_7L & _EBTR1_OFF_7L & _EBTR2_OFF_7L & _EBTR3_OFF_7L
__CONFIG _CONFIG7H, _EBTRB_OFF_7H
;----------------------------- 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+8
IntrareBootloader
movlw b'01110000' ;set intrc to 8mhz
movwf OSCCON
bsf OSCTUNE,6,0 ;enable 4x PLL
btfss OSCCON,2 ;wait 'til internal osc is stable
GOTO $-2
movlw b'00100100' ;Set serial port Tx Status reg.
; !! Warning b2: Hi-baudrate bit set; so what out for low buadrates !
movwf TXSTA
movlw spbrg_value
movwf SPBRG ;baudrate register low byte
; !! WHAT about SPBRGH ?????
movlw b'10010000'
movwf RCSTA ;Set serial port Rx Status reg. Enable serial port and receiver
rcall Receive ;go receive a byte by polling (with timeout)
sublw 0xC1 ;substract 0x1C (Host computer should have send 0x1C)
bnz way_to_exit ;if result!=0 exit bootloader
SendL IdTypePIC ;acknowledge host computer by sending PIC type (1 character) (see macro def.)
MainLoop
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 waitwre
noeeprom
btfss flag,7 ;is CFG data?
bra noconfig
tblwt* ;write TABLAT(byte before crc) to TBLPTR***
movlw b'11000100' ;Setup cfg
rcall Write
bra waitwre
noconfig
;write
eraseloop
movlw b'10010100' ;Setup erase
rcall Write
TBLRD*- ;point to adr-1
writebigloop
movlw 8 ;8groups
movwf counter_hi
lfsr FSR0,buffer
writesloop
movlw 8 ;8bytes = 4instr
movwf counter_lo
writebyte
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 writesloop
waitwre
btfsc EECON1,WR ;for eeprom writes ->
bra waitwre ;-> do wait for finish!. PC are fast these days
bcf EECON1,WREN ;disable writes
bra MainLoop
ziieroare ;CRC failed
SendL 'N'
bra mainl
;==========procedures ================
;********* Write *********************
Write
movwf EECON1 ;move w to EECON1 (control register memory acccess)
movlw 0x55
movwf EECON2 ;magic register writen with first 0x55 ->
movlw 0xAA
movwf EECON2 ; -> then 0xAA
bsf EECON1,WR ; initiate the write by setting b1
nop ; why this nop??
return
;********* Receive *********************
; Explanation:
; cnt1-cnt2-cnt3 makes up 24 bit timeout down-counter.
; The Receive function will timeout and exit the whole bootloader
; if it does not receive a byte withing this time
; cnt1 is loaded with a number made depending on the used clock frequency.
; this is done to make the delay befor the user app start more a less constant ~ 1sec.
Receive
movlw xtal/1000000 ; compute the clock depenting part
movwf cnt1 ; load cnt1 with xtal/1000000
rpt2
clrf cnt2 ; clear cnt2
rpt3
clrf cnt3 ; clear cnt3
rptc
btfss PIR1,RCIF ; test if byte received; if not ->
bra notrcv ; ->branch to notrcv
movf RCREG,w ;of byte received, store w
addwf crc,f ;and add w to current crc sum
return
notrcv
decfsz cnt3 ; cnt3--; while (cnt3!=0) ->
bra rptc ; -> poll byte received again
decfsz cnt2 ; cnt2--; while (cnt2!=0) ->
bra rpt3 ; -> cnt3=0; poll byte received again (I don't understand cnt3 is already 0, so can also do bre rptc ??)
decfsz cnt1 ; cnt1--; if zero exit bootloader=, and branch to first-address. Here is the user app main vector located
bra rpt2
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
|
|
|
|
Peter273 Guest
|
|
Posted: Mon Sep 03, 2007 12:31 pm |
|
|
Weird....
I recompiled the code using MPASM for use with 18F4620/18F4680 with minor modifications in the asm file (removed #fuses for instance, I personally like the use of the programmers features to modify fuses over "fixed" settings, and even WinPic has no probs with it for that matter).
Am using it at 19200baud on a 4680 (sometimes a 4620 since almost identical).
Tiny bootloader V1.93 worked flawless for me upto now from start.
Never had to cope with the "incrementing reset vector', but then I am not using it as a production programmer either.
Did have some things I had to take care of :
Low Voltage Programming disabled
ENHanced CPU instructions disabled
Watchdog disabled (but its value preset as I want it to be after enabling it by SWDTEN in my user-software to be loaded)
LPT1OSC hi power
Did also have to change the icdpictypes.inc though to add the 4680 (inserted a copy of the part of the 4620 for this).
Reading these posts now, I checked what MPASM made of the code (didn't really verify before, but I'm bit of unaware of 'deep' assembler since mainly using C or C++ platforms for several other purposes).
Just fiddled around some for what I thought fitted my purposes.
Saw that MPASM made 200byte code of what I did, fyi the .lst file ends with :
Code: |
MEMORY USAGE MAP ('X' = Used, '-' = Unused)
0000 : XXXX------------ ---------------- ---------------- ----------------
FF00 : ---------------- ---------------- ---------------- --------XXXXXXXX
FF40 : XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX
FF80 : XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX
FFC0 : XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXX----
All other memory blocks unused.
Program Memory Bytes Used: 200
Program Memory Bytes Free: 65336
MPASM 5.03 18F4680.ASM 6-26-2007 23:28:15 PAGE 51
Errors : 0
Warnings : 0 reported, 0 suppressed
Messages : 0 reported, 0 suppressed
|
The Tiny .ini fle has the line "SizeOfBLD_W=100" in it (I assume default ??), and no line "SizeOfBLD". Never modified it myself in that respect.
For your info I add the .asm file I compiled here:
Code: |
radix DEC
LIST P=18F4680 ; change also: Configure->SelectDevice from Mplab
xtal EQU 40000000 ; you may want to change: _XT_OSC_1H _HS_OSC_1H _HSPLL_OSC_1H
baud EQU 19200 ; the desired baud rate
delaytime EQU 1000000 ; for 40MHz: 1000000 gets about 1sec, for 20MHZ: 2000000 gets about 1sec
; The above 4 lines can be changed and buid a bootloader for the desired frequency (and PIC type)
;***********************************************************
; Tiny Bootloader 18F series Size=100words
; claudiu.chiculita@ugal.ro
; http : / / w w w . etc.ugal.ro/cchiculita/software/picbootloader.htm
;***********************************************************
#include "../inc/icdpictypes.inc" ;takes care of: #include "p18fxxx.inc", max_flash, IdTypePIC
#include "../inc/spbrgselect.inc" ; RoundResult and baud_rate
#define first_address max_flash-200 ;100 words
;can we dump these ? winpic etc have the function of configuring all
; __CONFIG _CONFIG1H, _OSC_HS_1H & _FCMEN_OFF_1H & _IESO_OFF_1H
; __CONFIG _CONFIG2L, _PWRT_OFF_2L & _BOREN_OFF_2L
; __CONFIG _CONFIG2H, _WDT_OFF_2H & _WDTPS_1_2H
; __CONFIG _CONFIG3H, _MCLRE_ON_3H & _PBADEN_OFF_3H ;& _CCP2MX_PORTBE_3H not in 4680
; __CONFIG _CONFIG4L, _DEBUG_OFF_4L & _LVP_OFF_4L & _STVREN_OFF_4L & _XINST_OFF_4L
; __CONFIG _CONFIG5L, _CP0_OFF_5L & _CP1_OFF_5L & _CP2_OFF_5L
; __CONFIG _CONFIG5H, _CPB_OFF_5H
; __CONFIG _CONFIG6L, _WRT0_OFF_6L & _WRT1_OFF_6L & _WRT2_OFF_6L
; __CONFIG _CONFIG6H, _WRTB_OFF_6H & _WRTC_OFF_6H
; __CONFIG _CONFIG7L, _EBTR0_OFF_7L & _EBTR1_OFF_7L & _EBTR2_OFF_7L
; __CONFIG _CONFIG7H, _EBTRB_OFF_7H & _DEVID1 & _IDLOC0
;----------------------------- PROGRAM ---------------------------------
cblock 0
crc
i
cnt1
cnt2
cnt3
counter_hi
counter_lo
flag
endc
cblock 10
buffer:64
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> ... 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+8
IntrareBootloader
;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 type
MainLoop
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 waitwre
noeeprom
btfss flag,7 ;is CFG data?
bra noconfig
tblwt* ;write TABLAT(byte before crc) to TBLPTR***
movlw b'11000100' ;Setup cfg
rcall Write
bra waitwre
noconfig
;write
eraseloop
movlw b'10010100' ; Setup erase
rcall Write
TBLRD*- ; point to adr-1
writebigloop
movlw 8 ; 8groups
movwf counter_hi
lfsr FSR0,buffer
writesloop
movlw 8 ; 8bytes = 4instr
movwf counter_lo
writebyte
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 writesloop
waitwre
;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
return
Receive
movlw xtal/delaytime+1 ; for 20MHz => 11 => 1second delay
movwf cnt1
rpt2
clrf cnt2
rpt3
clrf cnt3
rptc
btfss PIR1,RCIF ;test RX
bra notrcv
movf RCREG,w ;return read data in W
addwf crc,f ;compute crc
return
notrcv
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
|
Seems to get garbeled a bit while entering here, but you gurus will know what to take care of....
Never (upto now) had ANY kind of probs using this setup, usually (re)program about 16 devices in a row (updating).
And I can imagine some of you gurus to shake their heads for using 200 bytes instead of the promised 100... but I'm not really in a cramped space since I only use about 78% of program flash and an ampel 38% of RAM, so I really don't care for 100bytes more or less in my app. |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
Powered by phpBB © 2001, 2005 phpBB Group
|