ld hl, signon
call puts
+
+ call putscreen
ei
signon:
db $0D,$0A,$1B,"[1mFPGABoy Diagnostic ROM",$1B,"[0m",$0D,$0A,0
+tiles:
+ db %11111111
+ db %11111111
+ db %11000011
+ db %11000011
+ db %11000011
+ db %11000011
+ db %11111111
+ db %11111111
+
+ db %00000000
+ db %00000000
+ db %00000000
+ db %00000000
+ db %00000000
+ db %00000000
+ db %00000000
+ db %00000000
+
+putscreen:
+ ; Wait for vblank
+ call .vblwait
+
+ ld hl, $8000 ; Copy two tiles.
+ ld de, tiles
+ ld c, $10
+.cloop: push hl
+ ld h, d
+ ld l, e
+ ld a, [hl]
+ inc de
+ pop hl
+ ld [hli], a
+ ld [hli], a
+ dec c
+ xor a
+ cp c
+ jr nz, .cloop
+
+ ld hl, $9800
+.vloop: call .vblwait
+ ld c, $40
+ ld b, 0
+.loop: inc b
+ ld a, b
+ and $01
+ ld [hli], a
+ ld a, h
+ cp $9C
+ ret z
+ dec c
+ xor a
+ cp c
+ jr nz,.loop
+ jr .vloop
+
+.vblwait:
+.stat1: ld a, [$FF41] ; STAT
+ and $03
+ cp $00
+ jp nz, .stat1
+.stat2: ld a, [$FF41]
+ and $03
+ cp $01
+ jr nz, .stat2
+ ret
+
vbl:
PUSH AF
PUSH BC
PUSH HL
xor a
- ld c, $0F
- ld [c], a
+ ld [$FF0F], a
+
+ ld a, [$FF51]
+ ld b, a
+ and $80
+ cp $80
+ jr nz, .nothing
+ ld c, $0
+
+ ld a, b
+ and $1
+ cp c
+ call nz, .scyup
- ld c, $42 ; SCY
- ld a, [c]
- inc a
- ld [c], a
+ ld a, b
+ and $2
+ cp c
+ call nz, .scydown
+
+ ld a, b
+ and $4
+ cp c
+ call nz, .scxup
+
+ ld a, b
+ and $8
+ cp c
+ call nz, .scxdown
+.nothing:
POP HL
POP DE
POP BC
RETI
+.scyup: ld hl, $FF42
+ inc [hl]
+ ret
+
+.scydown: ld hl, $FF42
+ dec [hl]
+ ret
+
+.scxup: ld hl, $FF43
+ inc [hl]
+ ret
+
+.scxdown: ld hl, $FF43
+ dec [hl]
+ ret
+
+
lcdc:
PUSH AF
PUSH BC
xor a
- ld c, $0F
- ld [c], a
+ ld [$FF0F], a
POP BC
POP AF
PUSH HL
xor a
- ld c, $0F
- ld [c], a
+ ld [$FF0F], a
ld c, $45 ; LYC
ld a, [c]
inc a
ld [c], a
- ld hl, $DF82
- ld a, [hld]
+ ld a, [$DF82]
cp 0
jr z, .noprint
ld a, $41 ; print A
call putc
.noprint:
- inc [hl]
- ld a, [hl]
- ld c, $51
- ld [c], a
+ ld a, [$DF81]
+ inc a
+ ld [$DF81], a
+ ld [$FF51], a
POP HL
POP DE
ld hl,memteststr
call puts
- ld hl, $C001 ; Write loop
+ ld hl, $C000 ; Write loop
.wr:
ld a,h
xor l
cp $80
jr nz, .wr
- ld hl, $C001 ; Read loop
+ ld hl, $C000 ; Read loop
.rd:
ld a,h
xor l
ret
.memfail: ; Say we failed (sadface)
; decrement hl the easy way
- ld a,[hld]
+ dec [hl]
push hl
ld hl, failatstr
call puts