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:
Martin Preuss
2023-04-19 15:43:17 +02:00
parent b7a36cc732
commit a7d587a134

View File

@@ -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)