]> Joshua Wise's Git repositories - fpgaboy.git/blob - rom.asm
2e98e136fb592519941823a6fa3a865d96b54f0d
[fpgaboy.git] / rom.asm
1         SECTION "a",HOME
2
3 main:
4         ld c, $51       ; Note that we are alive.
5         ld a, $FF
6         ld [c],a
7
8         ld sp, $DFFF
9
10         ld hl, signon
11         call puts
12         
13         call memtest
14
15         call insntest
16
17         call waitsw
18
19         jr main
20
21 signon:
22         db $0D,$0A,$1B,"[1mFPGABoy Diagnostic ROM",$1B,"[0m",$0D,$0A,0
23
24 ; Memory tester: writes h ^ l to all addresses from C000 to DF80.
25 memtest:
26         ld hl,memteststr
27         call puts
28         
29         ld hl, $C000            ; Write loop
30 .wr:
31         ld a,h
32         xor l
33         ld [hli],a
34         ld a, $DF
35         cp h
36         jr nz, .wr
37         ld a, $80
38         cp l
39         jr nz, .wr
40
41         ld hl, $C000            ; Read loop
42 .rd:
43         ld a,h
44         xor l
45         ld b,a
46         ld a, [hli]
47         cp b
48         jr nz, .memfail
49         
50         ld a, $DF
51         cp h
52         jr nz, .rd
53         ld a, $80
54         cp l
55         jr nz, .rd
56         
57         ld hl, testokstr        ; Say we're OK
58         call puts
59         ret
60 .memfail:                       ; Say we failed (sadface)
61         ; decrement hl the easy way
62         ld a,[hld]
63         push hl
64         ld hl, failatstr
65         call puts
66         pop hl
67         ld a, h
68         call puthex
69         ld a, l
70         call puthex
71         ld a, $0A
72         call putc
73         ld a, $0D
74         call putc
75         ret
76 memteststr:
77         db "Testing memory from $C000 to $DF80...",0
78 testokstr:
79         db " OK!",$0D,$0A,0
80 failatstr:
81         db " Test failed at $",0
82
83 puthex:                         ; Put two hex nibbles to the serial console.
84         push af
85         rra
86         rra
87         rra
88         rra
89         ld b,$0F
90         and b
91         ld b,$30
92         add b
93         call putc
94         pop af
95         ld b,$0F
96         and b
97         ld b,$30
98         add b
99         call putc
100         ret
101
102 ; Wait for switches to be flipped on and off again.
103 waitsw:
104         ld hl,waitswstr
105         call puts
106         
107         ld c, $51
108         ld a, $00
109         ld [c],a
110         
111         ld c, $51
112         ld b, $0
113 .loop1:
114         ld a,[c]
115         cp b
116         jr z,.loop1
117 .loop2:
118         ld a,[c]
119         cp b
120         jr nz,.loop2
121         ret
122
123 waitswstr:
124         db "Diagnostic ROM complete; flip switches to nonzero and then to zero to reset.",$0D,$0A,0
125
126 ; Core instruction basic acceptance tests.
127 insntest:
128         ld hl, .insnteststr
129         call puts
130         
131         ; Test PUSH and POP.
132         ld b, $12
133         ld c, $34
134         ld d, $56
135         ld e, $78
136         push bc
137         pop de
138         ld hl, .pushpopfail
139         ld a, d
140         cp b
141         jr nz,.fail
142         ld a, e
143         cp c
144         jr nz,.fail
145         
146         ; Test ALU (HL).
147         ld hl, .ff
148         ld a, $FF
149         xor [hl]
150         ld hl, .xorhlfail
151         jr nz, .fail
152         
153         ; Test JP (HL)
154         ld hl, .jphl
155         jp [hl]
156         ld hl, .jphlfail
157         jr .fail
158         rst $00
159 .jphl:
160
161         ; Test JR
162         ld a, $FF
163         ld b, $00
164         cp b
165         jr nz,.jr
166         ld hl, .jrfail
167         jr .fail
168         rst $00
169 .jr:
170
171         ; Test inc16
172         ld d, $12
173         ld e, $FF
174         ld hl, .inc16fail
175         inc de
176         ld a, $13
177         cp d
178         jr nz, .fail
179         ld a, $00
180         cp e
181         jr nz, .fail
182         
183         ; Test CP.
184         ld hl, .cpfail
185         ld a, $10
186         ld b, $20
187         cp b
188         jr nc,.fail
189         ld a, $20
190         ld b, $10
191         cp b
192         jr c,.fail
193         
194         ; Test CPL
195         ld hl, .cplfail
196         ld a, $55
197         ld b, $AA
198         cpl
199         cp b
200         jr nz,.fail
201         
202         ld hl, .ok
203         call puts
204         ret
205 .fail:
206         call puts
207         ld hl, .testfailed
208         call puts
209         ret
210 .insnteststr:
211         db "Testing instructions... ",0
212 .pushpopfail:
213         db "PUSH/POP",0
214 .ff:
215         db $FF
216 .xorhlfail:
217         db "XOR [HL]",0
218 .jphlfail:
219         db "JP [HL]",0
220 .jrfail:
221         db "JR",0
222 .cpfail:
223         db "CP",0
224 .cplfail:
225         db "CPL",0
226 .inc16fail:
227         db "INC16",0
228 .testfailed:
229         db " test failed.",$0D,$0A,0
230 .ok:
231         db "OK!",$0D,$0A,0
232
233 ; Serial port manipulation functions.
234 putc:
235         push af
236         ld b, 0
237         ld c, $50
238 .waitport:
239         ld a,[c]
240         cp b
241         jr nz,.waitport
242         pop af
243         ld [c],a
244         ret
245
246 puts:
247         ld a, [hli]
248         ld b, $00
249         cp b
250         ret z
251         call putc
252         jr puts
This page took 0.027485 seconds and 2 git commands to generate.