avr: first step of boot loader works
- send FLASH_READY - waits for FLASH_START NOTE: Utils_WaitNanoSecs only works reliably with values way above 1000 because 1000 is already one cycle time, and since each assembler command already uses multiple clock cycles a value of 1000 never flies.
This commit is contained in:
@@ -69,27 +69,43 @@ bootLoader:
|
|||||||
ldi r16, Low(RAMEND)
|
ldi r16, Low(RAMEND)
|
||||||
out SPL, r16 ; init LSB stack pointer
|
out SPL, r16 ; init LSB stack pointer
|
||||||
|
|
||||||
sbi DDRA, PORTA3 ; out
|
; setup pins and interrupts
|
||||||
; sbi PINA, PORTA3 ; toggle
|
cbi COM_PORT_DATA, COM_PINNUM_DATA ; disable internal pullup for DATA
|
||||||
|
cbi COM_DDR_DATA, COM_PINNUM_DATA ; set DATA port as input
|
||||||
|
|
||||||
|
cbi COM_PORT_ATTN, COM_PINNUM_ATTN ; disable internal pullup for ATTN
|
||||||
|
cbi COM_DDR_ATTN, COM_PINNUM_ATTN ; set ATTN port as input
|
||||||
|
|
||||||
|
|
||||||
|
sbi DDRA, PORTA3 ; out
|
||||||
cbi PORTA, PORTA3 ; on
|
cbi PORTA, PORTA3 ; on
|
||||||
; sbi PORTA, PORTA3 ; off
|
sbi DDRA, PORTA2 ; out (debug)
|
||||||
|
sbi PORTA, PORTA2 ; off (debug)
|
||||||
|
|
||||||
rcall flashReadUid
|
rcall flashReadUid
|
||||||
sts flashUid, r18
|
sts flashUid, r18
|
||||||
sts flashUid+1, r19
|
sts flashUid+1, r19
|
||||||
sts flashUid+2, r20
|
sts flashUid+2, r20
|
||||||
sts flashUid+3, r21
|
sts flashUid+3, r21
|
||||||
|
|
||||||
|
; wait for 3 secs before sending message
|
||||||
|
ldi r16, 30
|
||||||
|
rcall flashWaitForMulti100ms
|
||||||
|
|
||||||
; send flash ready message
|
; send flash ready message
|
||||||
ldi xl, LOW(flashSendBuffer)
|
ldi xl, LOW(flashSendBuffer)
|
||||||
ldi xh, HIGH(flashSendBuffer)
|
ldi xh, HIGH(flashSendBuffer)
|
||||||
rcall flashWriteFlashReady
|
rcall flashWriteFlashReady
|
||||||
rcall flashSendPacketUntilSuccess
|
rcall flashSendPacketUntilSuccess
|
||||||
|
|
||||||
|
sbi PORTA, PORTA3 ; LED off
|
||||||
|
|
||||||
; wait up to 10s for incoming FLASH_START message
|
; wait up to 10s for incoming FLASH_START message
|
||||||
ldi r16, CPRO_CMD_FLASH_START
|
ldi r16, CPRO_CMD_FLASH_START
|
||||||
ldi r17, 100 ; 100*100ms=10s
|
ldi r17, 100 ; 100*100ms=10s
|
||||||
rcall flashWaitForSpecificMessageWithLed
|
rcall flashWaitForSpecificMessageWithLed
|
||||||
brcc bootLoader_startFirmware
|
brcc bootLoader_startFirmware
|
||||||
|
|
||||||
; either FLASH_START or FLASH_END received
|
; either FLASH_START or FLASH_END received
|
||||||
cpi r16, CPRO_CMD_FLASH_START ; not FLASH_START, no flashing requested
|
cpi r16, CPRO_CMD_FLASH_START ; not FLASH_START, no flashing requested
|
||||||
brne bootLoader_startFirmware
|
brne bootLoader_startFirmware
|
||||||
@@ -97,11 +113,18 @@ bootLoader:
|
|||||||
|
|
||||||
; try to start firmware
|
; try to start firmware
|
||||||
bootLoader_startFirmware:
|
bootLoader_startFirmware:
|
||||||
lds r20, firmwareStart
|
sbi PORTA, PORTA3 ; LED off
|
||||||
lds r21, firmwareStart+1
|
ldi r16, 20
|
||||||
|
rcall flashWaitForMulti100ms
|
||||||
|
|
||||||
|
ldi zl, LOW(firmwareStart*2)
|
||||||
|
ldi zh, HIGH(firmwareStart*2)
|
||||||
|
lpm r20, Z+
|
||||||
|
lpm r21, Z+
|
||||||
mov r16, r20
|
mov r16, r20
|
||||||
or r16, r21
|
or r16, r21
|
||||||
breq bootLoader ; restart boot loader
|
breq bootLoader ; restart boot loader
|
||||||
|
|
||||||
; jmp via stack
|
; jmp via stack
|
||||||
push r20
|
push r20
|
||||||
push r21
|
push r21
|
||||||
@@ -149,7 +172,7 @@ flashWaitForSpecificMessageWithLed_received:
|
|||||||
;
|
;
|
||||||
; IN:
|
; IN:
|
||||||
; - R16: msg command to wait for
|
; - R16: msg command to wait for
|
||||||
; - R17: time to wait for packet (in milliseconds) (low)
|
; - R17: time to wait for packet (in milliseconds)
|
||||||
; OUT:
|
; OUT:
|
||||||
; - CFLAG: set if msg received, cleared on timeout
|
; - CFLAG: set if msg received, cleared on timeout
|
||||||
; - R16 : message type received
|
; - R16 : message type received
|
||||||
@@ -159,9 +182,11 @@ flashWaitForSpecificMessage:
|
|||||||
mov r1, r16 ; expected message type
|
mov r1, r16 ; expected message type
|
||||||
|
|
||||||
; wait for ATTN to go low
|
; wait for ATTN to go low
|
||||||
|
|
||||||
|
flashWaitForSpecificMessage_loop0:
|
||||||
flashWaitForSpecificMessage_loop1:
|
flashWaitForSpecificMessage_loop1:
|
||||||
ldi r16, 0 ; wait for low
|
ldi r16, 0 ; wait for low
|
||||||
rcall flashWaitForAttnState1ms ; (R24, R25)
|
rcall flashWaitForAttnState1ms ; (R22, R24)
|
||||||
brcs flashWaitForSpecificMessage_isLow
|
brcs flashWaitForSpecificMessage_isLow
|
||||||
dec r17
|
dec r17
|
||||||
brne flashWaitForSpecificMessage_loop1
|
brne flashWaitForSpecificMessage_loop1
|
||||||
@@ -193,14 +218,14 @@ flashWaitForSpecificMessage_waitAttnHigh:
|
|||||||
; wait for ATTN to go high
|
; wait for ATTN to go high
|
||||||
flashWaitForSpecificMessage_loop2:
|
flashWaitForSpecificMessage_loop2:
|
||||||
ldi r16, 0xff ; wait for high
|
ldi r16, 0xff ; wait for high
|
||||||
rcall flashWaitForAttnState1ms ; (R24, R25)
|
rcall flashWaitForAttnState1ms ; (R22, R24)
|
||||||
brcs flashWaitForSpecificMessage_isHigh
|
brcs flashWaitForSpecificMessage_isHigh
|
||||||
dec r17
|
dec r17
|
||||||
brne flashWaitForSpecificMessage_loop2
|
brne flashWaitForSpecificMessage_loop2
|
||||||
rjmp flashWaitForSpecificMessage_timeout
|
rjmp flashWaitForSpecificMessage_timeout
|
||||||
|
|
||||||
flashWaitForSpecificMessage_isHigh:
|
flashWaitForSpecificMessage_isHigh:
|
||||||
rjmp flashWaitForSpecificMessage_loop1
|
rjmp flashWaitForSpecificMessage_loop0
|
||||||
|
|
||||||
flashWaitForSpecificMessage_received: ; R16 contains message type
|
flashWaitForSpecificMessage_received: ; R16 contains message type
|
||||||
sec
|
sec
|
||||||
@@ -218,18 +243,20 @@ flashWaitForSpecificMessage_timeout:
|
|||||||
; - R16: expected state (0xff for high, 0 for low)
|
; - R16: expected state (0xff for high, 0 for low)
|
||||||
; OUT:
|
; OUT:
|
||||||
; - CFLAG: set if state reached, cleared otherwise
|
; - CFLAG: set if state reached, cleared otherwise
|
||||||
; REGS: R24, R25
|
; REGS: R24 (R22)
|
||||||
|
|
||||||
flashWaitForAttnState1ms:
|
flashWaitForAttnState1ms:
|
||||||
ldi r24, LOW(1000)
|
ldi r24, 100
|
||||||
ldi r25, HIGH(1000)
|
|
||||||
|
|
||||||
flashWaitForAttnState1ms_loop:
|
flashWaitForAttnState1ms_loop:
|
||||||
in r17, COM_PIN_ATTN
|
push r17
|
||||||
eor r17, r16
|
in r17, COM_PIN_ATTN
|
||||||
andi r17, (1<<COM_PINNUM_ATTN)
|
eor r17, r16
|
||||||
|
andi r17, (1<<COM_PINNUM_ATTN)
|
||||||
|
pop r17
|
||||||
breq flashWaitForAttnState1ms_stateReached
|
breq flashWaitForAttnState1ms_stateReached
|
||||||
sbiw r25:r24, 1
|
|
||||||
|
Utils_WaitNanoSecs 10000, 0, r22 ; wait for 10us
|
||||||
|
dec r24
|
||||||
brne flashWaitForAttnState1ms_loop
|
brne flashWaitForAttnState1ms_loop
|
||||||
clc
|
clc
|
||||||
ret
|
ret
|
||||||
@@ -255,7 +282,6 @@ flashSendPacketUntilSuccess:
|
|||||||
pop xh
|
pop xh
|
||||||
pop xl
|
pop xl
|
||||||
brcc flashSendPacket_error
|
brcc flashSendPacket_error
|
||||||
cbi PORTA, PORTA3 ; on
|
|
||||||
ret
|
ret
|
||||||
flashSendPacket_error:
|
flashSendPacket_error:
|
||||||
rcall flashWaitForAttnHigh
|
rcall flashWaitForAttnHigh
|
||||||
@@ -298,17 +324,34 @@ flashWaitForAttnHigh_stillLow:
|
|||||||
flashWaitDependingOnUid:
|
flashWaitDependingOnUid:
|
||||||
lds r16, flashUid
|
lds r16, flashUid
|
||||||
tst r16
|
tst r16
|
||||||
brne flashWaitForAttnHigh_waitLoop
|
brne flashWaitDependingOnUid_l1
|
||||||
ldi r16, 17
|
ldi r16, 17
|
||||||
flashWaitForAttnHigh_waitLoop: ; wait for up to 25s before trying again
|
flashWaitDependingOnUid_l1:
|
||||||
rcall flashWaitFor100ms ; (R18, R22, R24, R25)
|
rjmp flashWaitForMulti100ms
|
||||||
sbi PINA, PORTA3 ; toggle LED
|
|
||||||
|
|
||||||
|
|
||||||
|
; ---------------------------------------------------------------------------
|
||||||
|
; wait for multiples of 100ms.
|
||||||
|
;
|
||||||
|
; IN:
|
||||||
|
; - R16: number of 100ms loops
|
||||||
|
; OUT:
|
||||||
|
; - nothing
|
||||||
|
; REGS: R16 (R18, R22, R24, R25)
|
||||||
|
|
||||||
|
flashWaitForMulti100ms:
|
||||||
|
flashWaitForMulti100ms_loop:
|
||||||
|
rcall flashWaitFor100ms ; (R18, R22, R24, R25)
|
||||||
dec r16
|
dec r16
|
||||||
brne flashWaitForAttnHigh_waitLoop
|
brne flashWaitForMulti100ms_loop
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
; ---------------------------------------------------------------------------
|
; ---------------------------------------------------------------------------
|
||||||
; wait for 100 milliseconds.
|
; wait for 100 milliseconds.
|
||||||
;
|
;
|
||||||
@@ -335,14 +378,13 @@ flashWaitFor100ms_loop:
|
|||||||
; - nothing
|
; - nothing
|
||||||
; OUT:
|
; OUT:
|
||||||
; - nothing
|
; - nothing
|
||||||
; REGS: R24, R25 (R22)
|
; REGS: R24 (R22)
|
||||||
|
|
||||||
flashWaitFor1ms:
|
flashWaitFor1ms:
|
||||||
ldi r24, LOW(1000)
|
ldi r24, 10
|
||||||
ldi r25, HIGH(1000)
|
|
||||||
flashWaitFor1ms_loop:
|
flashWaitFor1ms_loop:
|
||||||
rcall com2WaitFor1000ns
|
Utils_WaitNanoSecs 100000, 0, r22 ; wait for 100us
|
||||||
sbiw r25:r24, 1
|
dec r24
|
||||||
brne flashWaitFor1ms_loop
|
brne flashWaitFor1ms_loop
|
||||||
ret
|
ret
|
||||||
|
|
||||||
@@ -383,7 +425,7 @@ flashWriteFlashRsp:
|
|||||||
; - X : buffer to write to
|
; - X : buffer to write to
|
||||||
; OUT:
|
; OUT:
|
||||||
; - nothing
|
; - nothing
|
||||||
; MODIFIED REGS: R16 (R17, R18, R19, R20)
|
; MODIFIED REGS: R16, Z (R17, R18, R19, R20)
|
||||||
|
|
||||||
flashWriteFlashReady:
|
flashWriteFlashReady:
|
||||||
clr r16
|
clr r16
|
||||||
@@ -403,14 +445,16 @@ flashWriteFlashReady:
|
|||||||
st X+, r16
|
st X+, r16
|
||||||
lds r16, flashUid+3
|
lds r16, flashUid+3
|
||||||
st X+, r16
|
st X+, r16
|
||||||
lds r16, firmwareType
|
ldi zl, low(firmwareType*2)
|
||||||
st X+, r16
|
ldi zh, HIGH(firmwareType*2)
|
||||||
lds r16, firmwareType+1
|
lpm r16, Z+
|
||||||
st X+, r16
|
st X+, r16 ; firmwareType (low)
|
||||||
lds r16, firmwareVersion
|
lpm r16, Z+
|
||||||
st X+, r16
|
st X+, r16 ; firmwareType (high)
|
||||||
lds r16, firmwareVersion+1
|
lpm r16, Z+
|
||||||
st X+, r16
|
st X+, r16 ; firmwareVersion (low)
|
||||||
|
lpm r16, Z+
|
||||||
|
st X+, r16 ; firmwareVersion (high)
|
||||||
ldi r16, LOW(PAGESIZE*2)
|
ldi r16, LOW(PAGESIZE*2)
|
||||||
st X+, r16
|
st X+, r16
|
||||||
ldi r16, HIGH(PAGESIZE*2)
|
ldi r16, HIGH(PAGESIZE*2)
|
||||||
|
|||||||
Reference in New Issue
Block a user