4 ld c, $51 ; Note that we are alive.
15 ; ld a, $04 ;start timer, 4.096KHz
35 section "fuq",HOME[$50]
47 ld c, $0F ; ack the irq
73 db $0D,$0A,$1B,"[1mFPGABoy Diagnostic ROM",$1B,"[0m",$0D,$0A,0
75 ; Memory tester: writes h ^ l to all addresses from C000 to DF80.
80 ld hl, $C001 ; Write loop
92 ld hl, $C001 ; Read loop
108 ld hl, testokstr ; Say we're OK
111 .memfail: ; Say we failed (sadface)
112 ; decrement hl the easy way
128 db "Testing memory from $C000 to $DF80...",0
132 db " Test failed at $",0
134 puthex: ; Put two hex nibbles to the serial console.
153 ; Wait for switches to be flipped on and off again.
175 db "Diagnostic ROM complete; flip switches to nonzero and then to zero to reset. Expect A.",$0D,$0A,0
177 ; Core instruction basic acceptance tests.
262 db "Testing instructions... ",0
280 db " test failed.",$0D,$0A,0
284 ; Serial port manipulation functions.