projects
/
calu.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
bootromfun: testprogramm angepasst -> bytes empfangen im 'stream' geht nicht ordentlich
[calu.git]
/
2_isa
/
src
/
bootrom.s
diff --git
a/2_isa/src/bootrom.s
b/2_isa/src/bootrom.s
index 9dcc5411d9c80cfc055f4e5a611b9738e65820fc..87b7f83f1a508bbd913707b723f90962ada6ad48 100644
(file)
--- a/
2_isa/src/bootrom.s
+++ b/
2_isa/src/bootrom.s
@@
-25,15
+25,10
@@
main:
ldi r11, PBASE@lo
ldih r11, PBASE@hi
poll:
ldi r11, PBASE@lo
ldih r11, PBASE@hi
poll:
- ldw r3, UART_STATUS(r10)
- andx r3, UART_RECV_NEW
- brzs+ poll; branch if zero
- xor r0, r0, r0
- ldw r0, UART_RECV(r10)
+ call recv_byte
; we received the enter bootrom sign
xor r1, r1, r1
cmpi r0, 0x48 ; 'H'
; we received the enter bootrom sign
xor r1, r1, r1
cmpi r0, 0x48 ; 'H'
- br tehend
breq+ bt_H
br poll ; else
breq+ bt_H
br poll ; else
@@
-90,11
+85,8
@@
recv_word:
;-----
bootrom:
call recv_byte
;-----
bootrom:
call recv_byte
- ldi r1, 0x50 ; 'P'
- call send_byte
- br tehend
-
xor r1, r1, r1
xor r1, r1, r1
+
cmpi r0, 0x57 ; 'W'
breq- bt_W
cmpi r0, 0x57 ; 'W'
breq- bt_W
@@
-117,28
+109,26
@@
bootrom:
bt_H:
ldi r1, 0x4f ; 'O'
call send_byte
bt_H:
ldi r1, 0x4f ; 'O'
call send_byte
- xor r1, r1, r1
- ldi r1, 0x41 ; 'A'
- call send_byte
br bootrom
bt_W:
br bootrom
bt_W:
- call recv_word ; receive addr
- stw r0, PADDR(r11)
- call recv_word ; receive instr
- stw r0, PDATA(r11)
- ldi r1, 0x44 ; 'D'
- call send_byte
+
;
call recv_word ; receive addr
+
;
stw r0, PADDR(r11)
+
;
call recv_word ; receive instr
+
;
stw r0, PDATA(r11)
+
;
ldi r1, 0x44 ; 'D'
+
;
call send_byte
br bootrom
bt_R:
br bootrom
bt_R:
- call recv_word ; receive addr
- mov r2, r0
- ldi r1, 0x46 ; 'F'
- call send_byte
- ldx r1, 0(r2)
- call send_word
- br bootrom
+ ;call recv_word ; receive addr
+ ;mov r2, r0
+ ;ldi r1, 0x46 ; 'F'
+ ;call send_byte
+ ;ldx r1, 0(r2)
+ ;call send_word
+ ;br bootrom
+ br tehend
bt_Q:
call recv_word ; receive addr
bt_Q:
call recv_word ; receive addr
@@
-163,3
+153,12
@@
bt_J:
brr r0
tehend:
brr r0
tehend:
+ xor r1, r1, r1
+ ldi r1, 0x41 ; 'A'
+ call send_byte
+ xor r1, r1, r1
+ ldi r1, 0x42 ; 'B'
+ call send_byte
+ xor r1, r1, r1
+ ldi r1, 0x43 ; 'C'
+ call send_byte