pokecrystal/home/copy.asm

435 lines
5.1 KiB
NASM
Raw Normal View History

; Functions to copy data from ROM.
2015-11-04 20:35:29 +00:00
Get2bpp_2:: ; dc9
ld a, [rLCDC]
bit 7, a
jp z, Copy2bpp
ld a, [hROMBank]
push af
2015-11-04 21:14:27 +00:00
ld a, BANK(_Get2bpp)
rst Bankswitch
2015-11-04 21:14:27 +00:00
call _Get2bpp
pop af
rst Bankswitch
ret
; ddc
2015-11-04 20:35:29 +00:00
Get1bpp_2:: ; ddc
ld a, [rLCDC]
bit 7, a
jp z, Copy1bpp
ld a, [hROMBank]
push af
2015-11-04 21:14:27 +00:00
ld a, BANK(_Get1bpp)
rst Bankswitch
2015-11-04 21:14:27 +00:00
call _Get1bpp
pop af
rst Bankswitch
ret
; def
2015-11-04 20:35:29 +00:00
FarCopyBytesDouble_DoubleBankSwitch:: ; def
ld [hBuffer], a
ld a, [hROMBank]
push af
ld a, [hBuffer]
rst Bankswitch
2015-11-04 20:35:29 +00:00
call FarCopyBytesDouble
2015-11-04 20:35:29 +00:00
pop af
rst Bankswitch
ret
; dfd
2015-11-04 21:14:27 +00:00
OldDMATransfer:: ; dfd
dec c
ld a, [hBGMapMode]
push af
xor a
ld [hBGMapMode], a
ld a, [hROMBank]
push af
ld a, b
rst Bankswitch
2015-07-21 05:52:46 +00:00
.loop
2015-11-04 21:14:27 +00:00
; load the source and target MSB and LSB
ld a, d
2015-11-04 21:14:27 +00:00
ld [rHDMA1], a ; source MSB
ld a, e
and $f0
2015-11-04 21:14:27 +00:00
ld [rHDMA2], a ; source LSB
ld a, h
and $1f
2015-11-04 21:14:27 +00:00
ld [rHDMA3], a ; target MSB
ld a, l
and $f0
2015-11-04 21:14:27 +00:00
ld [rHDMA4], a ; target LSB
; stop when c < 8
ld a, c
cp $8
2015-07-21 05:52:46 +00:00
jr c, .done
2015-11-04 21:14:27 +00:00
; decrease c by 8
sub $8
ld c, a
2015-11-04 21:14:27 +00:00
; DMA transfer state
ld a, $f
ld [hDMATransfer], a
call DelayFrame
2015-11-04 21:14:27 +00:00
; add $100 to hl and de
ld a, l
2015-11-04 21:14:27 +00:00
add $100 % $100
ld l, a
ld a, h
2015-11-04 21:14:27 +00:00
adc $100 / $100
ld h, a
ld a, e
2015-11-04 21:14:27 +00:00
add $100 % $100
ld e, a
ld a, d
2015-11-04 21:14:27 +00:00
adc $100 / $100
ld d, a
2015-07-21 05:52:46 +00:00
jr .loop
2015-07-21 05:52:46 +00:00
.done
ld a, c
2015-11-04 21:14:27 +00:00
and $7f ; pretty silly, considering at most bits 0-2 would be set
ld [hDMATransfer], a
call DelayFrame
pop af
rst Bankswitch
pop af
ld [hBGMapMode], a
ret
; e4a
2015-11-04 21:14:27 +00:00
ReplaceKrisSprite:: ; e4a
callba _ReplaceKrisSprite
ret
; e51
2015-11-04 21:14:27 +00:00
LoadStandardFont:: ; e51
callba _LoadStandardFont
ret
; e58
LoadFontsBattleExtra:: ; e58
callba _LoadFontsBattleExtra
ret
; e5f
2015-11-04 21:14:27 +00:00
LoadFontsExtra:: ; e5f
callba _LoadFontsExtra1
callba _LoadFontsExtra2
ret
; e6c
2015-11-04 21:14:27 +00:00
LoadFontsExtra2:: ; e6c
callba _LoadFontsExtra2
ret
; e73
2015-11-04 21:14:27 +00:00
DecompressRequest2bpp:: ; e73
push de
ld a, BANK(sScratch)
call GetSRAMBank
push bc
2015-11-04 21:14:27 +00:00
ld de, sScratch
ld a, b
call FarDecompress
2015-11-04 21:14:27 +00:00
pop bc
pop hl
2015-11-04 21:14:27 +00:00
ld de, sScratch
call Request2bpp
call CloseSRAM
ret
; e8d
FarCopyBytes:: ; e8d
; copy bc bytes from a:hl to de
ld [hBuffer], a
ld a, [hROMBank]
push af
ld a, [hBuffer]
rst Bankswitch
call CopyBytes
pop af
rst Bankswitch
ret
; 0xe9b
FarCopyBytesDouble:: ; e9b
; Copy bc bytes from a:hl to bc*2 bytes at de,
; doubling each byte in the process.
ld [hBuffer], a
ld a, [hROMBank]
push af
ld a, [hBuffer]
rst Bankswitch
; switcheroo, de <> hl
ld a, h
ld h, d
ld d, a
ld a, l
ld l, e
ld e, a
inc b
inc c
jr .dec
.loop
ld a, [de]
inc de
2015-07-21 02:18:18 +00:00
rept 2
ld [hli], a
2015-07-21 02:18:18 +00:00
endr
.dec
dec c
jr nz, .loop
dec b
jr nz, .loop
pop af
rst Bankswitch
ret
; 0xeba
Request2bpp:: ; eba
; Load 2bpp at b:de to occupy c tiles of hl.
ld a, [hBGMapMode]
push af
xor a
ld [hBGMapMode], a
ld a, [hROMBank]
push af
ld a, b
rst Bankswitch
2015-11-05 19:06:03 +00:00
ld a, [hTilesPerCycle]
push af
ld a, $8
2015-11-05 19:06:03 +00:00
ld [hTilesPerCycle], a
2015-10-24 14:34:19 +00:00
ld a, [wLinkMode]
2015-10-24 14:34:19 +00:00
cp LINK_MOBILE
jr nz, .NotMobile
ld a, [hMobile]
and a
2015-10-24 14:34:19 +00:00
jr nz, .NotMobile
ld a, $6
2015-11-05 19:06:03 +00:00
ld [hTilesPerCycle], a
2015-10-24 14:34:19 +00:00
.NotMobile
ld a, e
2013-09-01 19:24:07 +00:00
ld [Requested2bppSource], a
ld a, d
2013-09-01 19:24:07 +00:00
ld [Requested2bppSource + 1], a
ld a, l
2013-09-01 19:24:07 +00:00
ld [Requested2bppDest], a
ld a, h
2013-09-01 19:24:07 +00:00
ld [Requested2bppDest + 1], a
.loop
ld a, c
2015-11-05 19:06:03 +00:00
ld hl, hTilesPerCycle
cp [hl]
jr nc, .iterate
2013-09-01 19:24:07 +00:00
ld [Requested2bpp], a
.wait
call DelayFrame
2013-09-01 19:24:07 +00:00
ld a, [Requested2bpp]
and a
jr nz, .wait
pop af
2015-11-05 19:06:03 +00:00
ld [hTilesPerCycle], a
pop af
rst Bankswitch
pop af
ld [hBGMapMode], a
ret
.iterate
2015-11-05 19:06:03 +00:00
ld a, [hTilesPerCycle]
2013-09-01 19:24:07 +00:00
ld [Requested2bpp], a
2015-10-24 14:34:19 +00:00
.wait2
call DelayFrame
2013-09-01 19:24:07 +00:00
ld a, [Requested2bpp]
and a
jr nz, .wait2
2015-10-24 14:34:19 +00:00
ld a, c
2015-11-05 19:06:03 +00:00
ld hl, hTilesPerCycle
sub [hl]
ld c, a
jr .loop
; f1e
Request1bpp:: ; f1e
2015-11-05 19:06:03 +00:00
; Load 1bpp at b:de to occupy c tiles of hl.
ld a, [hBGMapMode]
push af
xor a
ld [hBGMapMode], a
ld a, [hROMBank]
push af
ld a, b
rst Bankswitch
2015-11-05 19:06:03 +00:00
ld a, [hTilesPerCycle]
push af
ld a, $8
2015-11-05 19:06:03 +00:00
ld [hTilesPerCycle], a
ld a, [wLinkMode]
2015-10-24 14:34:19 +00:00
cp LINK_MOBILE
jr nz, .NotMobile
2015-10-24 14:34:19 +00:00
ld a, [hMobile]
and a
jr nz, .NotMobile
ld a, $6
2015-11-05 19:06:03 +00:00
ld [hTilesPerCycle], a
.NotMobile
ld a, e
2013-09-01 19:24:07 +00:00
ld [Requested1bppSource], a
ld a, d
2013-09-01 19:24:07 +00:00
ld [Requested1bppSource + 1], a
ld a, l
2013-09-01 19:24:07 +00:00
ld [Requested1bppDest], a
ld a, h
2013-09-01 19:24:07 +00:00
ld [Requested1bppDest + 1], a
.loop
ld a, c
2015-11-05 19:06:03 +00:00
ld hl, hTilesPerCycle
cp [hl]
jr nc, .iterate
2013-09-01 19:24:07 +00:00
ld [Requested1bpp], a
.wait
call DelayFrame
2013-09-01 19:24:07 +00:00
ld a, [Requested1bpp]
and a
jr nz, .wait
pop af
2015-11-05 19:06:03 +00:00
ld [hTilesPerCycle], a
pop af
rst Bankswitch
pop af
ld [hBGMapMode], a
ret
.iterate
2015-11-05 19:06:03 +00:00
ld a, [hTilesPerCycle]
2013-09-01 19:24:07 +00:00
ld [Requested1bpp], a
.wait2
call DelayFrame
2013-09-01 19:24:07 +00:00
ld a, [Requested1bpp]
and a
jr nz, .wait2
ld a, c
2015-11-05 19:06:03 +00:00
ld hl, hTilesPerCycle
sub [hl]
ld c, a
jr .loop
; f82
Get2bpp:: ; f82
ld a, [rLCDC]
bit 7, a
jp nz, Request2bpp
Copy2bpp:: ; f89
; copy c 2bpp tiles from b:de to hl
push hl
ld h, d
ld l, e
pop de
; bank
ld a, b
; bc = c * $10
push af
swap c
ld a, $f
and c
ld b, a
ld a, $f0
and c
ld c, a
pop af
jp FarCopyBytes
; f9d
Get1bpp:: ; f9d
ld a, [rLCDC]
bit 7, a
jp nz, Request1bpp
Copy1bpp:: ; fa4
; copy c 1bpp tiles from b:de to hl
push de
ld d, h
ld e, l
; bank
ld a, b
; bc = c * $10 / 2
push af
ld h, 0
ld l, c
2015-07-21 02:18:18 +00:00
rept 3
add hl, hl
2015-07-21 02:18:18 +00:00
endr
ld b, h
ld c, l
pop af
pop hl
jp FarCopyBytesDouble
; fb6