SECTION "a",HOME
+
main:
- ld c, $51
+ ld c, $51 ; Note that we are alive.
ld a, $FF
ld [c],a
- ld sp,$DFFF
- ld hl,text
+ ld sp, $DFFF
+
+ ld hl, signon
call puts
call memtest
+
+ call insntest
+
call waitsw
+
jp main
-text:
- db $1B,"[1mFPGABoy Diagnostic ROM",$1B,"[0m",$0D,$0A,0
+signon:
+ db $0D,$0A,$1B,"[1mFPGABoy Diagnostic ROM",$1B,"[0m",$0D,$0A,0
+; Memory tester: writes h ^ l to all addresses from C000 to DF80.
memtest:
ld hl,memteststr
call puts
- ld hl, $C000
+ ld hl, $C000 ; Write loop
.wr:
ld a,h
xor l
cp l
jp nz, .wr
- ld hl, $C000
+ ld hl, $C000 ; Read loop
.rd:
ld a,h
xor l
cp l
jp nz, .rd
- ld hl, testokstr
+ ld hl, testokstr ; Say we're OK
call puts
ret
-.memfail:
- @ decrement hl the easy way
+.memfail: ; Say we failed (sadface)
+ ; decrement hl the easy way
ld a,[hld]
push hl
ld hl, failatstr
ld a, $0D
call putc
ret
-
memteststr:
db "Testing memory from $C000 to $DF80...",0
testokstr:
db " OK!",$0D,$0A,0
failatstr:
db " Test failed at $",0
-puthex:
+
+puthex: ; Put two hex nibbles to the serial console.
push af
rra
rra
call putc
ret
+; Wait for switches to be flipped on and off again.
waitsw:
ld hl,waitswstr
call puts
waitswstr:
db "Diagnostic ROM complete; flip switches to nonzero and then to zero to reset.",$0D,$0A,0
+; Core instruction basic acceptance tests.
+insntest:
+ ld hl, .insnteststr
+ call puts
+
+ ; Test PUSH and POP.
+ ld b, $12
+ ld c, $34
+ ld d, $56
+ ld e, $78
+ push bc
+ pop de
+ ld hl, .pushpopfail
+ ld a, d
+ cp b
+ jp nz,.fail
+ ld a, e
+ cp c
+ jp nz,.fail
+
+ ; Test ALU (HL).
+ ld hl, .ff
+ ld a, $FF
+ xor [hl]
+ ld hl, .xorhlfail
+ jp nz, .fail
+
+ ; Test JP (HL)
+ ld hl, .jphl
+ jp [hl]
+ ld hl, .jphlfail
+ jp .fail
+ rst $00
+.jphl:
+
+ ; Test JR
+ ld a, $FF
+ ld b, $00
+ cp b
+ jr nz,.jr
+ ld hl, .jrfail
+ jp .fail
+ rst $00
+.jr:
+
+ ; Test CP.
+ ld hl, .cpfail
+ ld a, $10
+ ld b, $20
+ cp b
+ jp nc,.fail
+ ld a, $20
+ ld b, $10
+ cp b
+ jp c,.fail
+
+ ; Test CPL
+ ld hl, .cplfail
+ ld a, $55
+ ld b, $AA
+ cpl
+ cp b
+ jp nz,.fail
+
+ ld hl, .ok
+ call puts
+ ret
+.fail:
+ call puts
+ ret
+.insnteststr:
+ db "Testing instructions... ",$0
+.pushpopfail:
+ db "PUSH/POP test failed.",$0D,$0A,0
+.ff:
+ db $FF
+.xorhlfail:
+ db "XOR [HL] test failed.",$0D,$0A,0
+.jphlfail:
+ db "JP [HL] test failed.",$0D,$0A,0
+.jrfail:
+ db "JR test failed.",$0D,$0A,0
+.cpfail:
+ db "CP test failed.",$0D,$0A,0
+.cplfail:
+ db "CPL test failed.",$0D,$0A,0
+.ok:
+ db "OK!",$0D,$0A,0
+
+; Serial port manipulation functions.
putc:
push af
ld b, 0