X-Git-Url: http://git.joshuawise.com/fpgaboy.git/blobdiff_plain/20204e795d54fb0758a79f0abd5fb443c0178a54..fc443a4f61b38236a17ab2928bd90327edc68266:/rom.asm?ds=sidebyside diff --git a/rom.asm b/rom.asm index 02f095b..0c25fab 100644 --- a/rom.asm +++ b/rom.asm @@ -4,212 +4,70 @@ main: ld c, $51 ; Note that we are alive. ld a, $FF ld [c],a - - ld sp, $DFFF - - ld hl, signon - call puts - call memtest - - call insntest - - call waitsw - - jp main - -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 sp, $DFF0 - ld hl, $C000 ; Write loop -.wr: - ld a,h - xor l - ld [hli],a - ld a, $DF - cp h - jp nz, .wr + ld hl, $DF81 ld a, $80 - cp l - jp nz, .wr - - ld hl, $C000 ; Read loop -.rd: - ld a,h - xor l - ld b,a - ld a, [hli] - cp b - jp nz, .memfail + ld [hl], a + + ld c, $07 + ld a, $04 ;start timer, 4.096KHz + ld [c], a +;diqs: ei +; ld a, $80 +; ld c, $51 +; ld [c], a +; jr diqs + call irqhand + ei +coqs: jr coqs + + section "Diq", HOME[$38] +fuqed: + di + jr fuqed + + section "fuq",HOME[$100] +irqhand: + PUSH AF + PUSH BC + PUSH DE + PUSH HL - ld a, $DF - cp h - jp nz, .rd - ld a, $80 - cp l - jp nz, .rd + xor a + ld c, $0F ; ack the irq + ld [c], a - ld hl, testokstr ; Say we're OK - call puts - ret -.memfail: ; Say we failed (sadface) - ; decrement hl the easy way - ld a,[hld] - push hl - ld hl, failatstr - call puts - pop hl - ld a, h - call puthex - ld a, l - call puthex - ld a, $0A - call putc - ld a, $0D + ld a, $41 ; print A 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: ; Put two hex nibbles to the serial console. - push af - rra - rra - rra - rra - ld b,$0F - and b - ld b,$30 - add b - call putc - pop af - ld b,$0F - and b - ld b,$30 - add b - call putc - ret - -; Wait for switches to be flipped on and off again. -waitsw: - ld hl,waitswstr - call puts - - ld c, $51 - ld a, $00 - ld [c],a + ld hl, $DF81 + ld a, [hl] + ld b, 1 + add b ld c, $51 - ld b, $0 -.loop1: - ld a,[c] - cp b - jp z,.loop1 -.loop2: - ld a,[c] - cp b - jp nz,.loop2 - ret + ld [c], a + ld [hl], a -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 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 -.cpfail: - db "CP test failed.",$0D,$0A,0 -.cplfail: - db "CPL test failed.",$0D,$0A,0 -.ok: - db "OK!",$0D,$0A,0 + POP HL + POP DE + POP BC + POP AF + RETI + db $18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE + db $18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE + db $18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE,$18,$FE -; Serial port manipulation functions. putc: - push af ld b, 0 ld c, $50 + push af .waitport: ld a,[c] cp b - jp nz,.waitport + jr nz,.waitport pop af ld [c],a ret - -puts: - ld a, [hli] - ld b, $00 - cp b - jp z, .done - call putc - jp puts -.done: - ret -