2013-08-29 23:39:21 +00:00
|
|
|
; Functions to copy data from ROM.
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
Get2bpp_2::
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [rLCDC]
|
2017-12-29 17:53:21 +00:00
|
|
|
bit rLCDC_ENABLE, a
|
2013-08-29 23:39:21 +00:00
|
|
|
jp z, Copy2bpp
|
|
|
|
|
2016-05-27 14:41:59 +00:00
|
|
|
homecall _Get2bpp
|
2013-08-29 23:39:21 +00:00
|
|
|
|
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
Get1bpp_2::
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [rLCDC]
|
2017-12-29 17:53:21 +00:00
|
|
|
bit rLCDC_ENABLE, a
|
2013-08-29 23:39:21 +00:00
|
|
|
jp z, Copy1bpp
|
|
|
|
|
2016-05-27 14:41:59 +00:00
|
|
|
homecall _Get1bpp
|
2013-08-29 23:39:21 +00:00
|
|
|
|
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
FarCopyBytesDouble_DoubleBankSwitch::
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hBuffer], a
|
|
|
|
ldh a, [hROMBank]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hBuffer]
|
2013-08-29 23:39:21 +00:00
|
|
|
rst Bankswitch
|
2015-11-04 20:35:29 +00:00
|
|
|
|
2013-08-29 23:39:21 +00:00
|
|
|
call FarCopyBytesDouble
|
2015-11-04 20:35:29 +00:00
|
|
|
|
2013-08-29 23:39:21 +00:00
|
|
|
pop af
|
|
|
|
rst Bankswitch
|
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
OldDMATransfer::
|
2013-08-29 23:39:21 +00:00
|
|
|
dec c
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hBGMapMode]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
|
|
|
xor a
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hBGMapMode], a
|
|
|
|
ldh a, [hROMBank]
|
2013-08-29 23:39:21 +00:00
|
|
|
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
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, d
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [rHDMA1], a ; source MSB
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, e
|
|
|
|
and $f0
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [rHDMA2], a ; source LSB
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, h
|
|
|
|
and $1f
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [rHDMA3], a ; target MSB
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, l
|
|
|
|
and $f0
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [rHDMA4], a ; target LSB
|
2015-11-04 21:14:27 +00:00
|
|
|
; stop when c < 8
|
2013-08-29 23:39:21 +00:00
|
|
|
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
|
2013-08-29 23:39:21 +00:00
|
|
|
sub $8
|
|
|
|
ld c, a
|
2015-11-04 21:14:27 +00:00
|
|
|
; DMA transfer state
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, $f
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hDMATransfer], a
|
2013-08-29 23:39:21 +00:00
|
|
|
call DelayFrame
|
2015-11-04 21:14:27 +00:00
|
|
|
; add $100 to hl and de
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, l
|
2017-12-25 18:40:10 +00:00
|
|
|
add LOW($100)
|
2013-08-29 23:39:21 +00:00
|
|
|
ld l, a
|
|
|
|
ld a, h
|
2017-12-25 18:40:10 +00:00
|
|
|
adc HIGH($100)
|
2013-08-29 23:39:21 +00:00
|
|
|
ld h, a
|
|
|
|
ld a, e
|
2017-12-25 18:40:10 +00:00
|
|
|
add LOW($100)
|
2013-08-29 23:39:21 +00:00
|
|
|
ld e, a
|
|
|
|
ld a, d
|
2017-12-25 18:40:10 +00:00
|
|
|
adc HIGH($100)
|
2013-08-29 23:39:21 +00:00
|
|
|
ld d, a
|
2015-07-21 05:52:46 +00:00
|
|
|
jr .loop
|
2013-08-29 23:39:21 +00:00
|
|
|
|
2015-07-21 05:52:46 +00:00
|
|
|
.done
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, c
|
2015-11-04 21:14:27 +00:00
|
|
|
and $7f ; pretty silly, considering at most bits 0-2 would be set
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hDMATransfer], a
|
2013-08-29 23:39:21 +00:00
|
|
|
call DelayFrame
|
|
|
|
pop af
|
|
|
|
rst Bankswitch
|
|
|
|
|
|
|
|
pop af
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hBGMapMode], a
|
2013-08-29 23:39:21 +00:00
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
ReplaceKrisSprite::
|
2017-12-24 17:47:30 +00:00
|
|
|
farcall _ReplaceKrisSprite
|
2013-08-29 23:39:21 +00:00
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
LoadStandardFont::
|
2017-12-24 17:47:30 +00:00
|
|
|
farcall _LoadStandardFont
|
2013-08-29 23:39:21 +00:00
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
LoadFontsBattleExtra::
|
2017-12-24 17:47:30 +00:00
|
|
|
farcall _LoadFontsBattleExtra
|
2013-08-29 23:39:21 +00:00
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
LoadFontsExtra::
|
2017-12-24 17:47:30 +00:00
|
|
|
farcall _LoadFontsExtra1
|
|
|
|
farcall _LoadFontsExtra2
|
2013-08-29 23:39:21 +00:00
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
LoadFontsExtra2::
|
2017-12-24 17:47:30 +00:00
|
|
|
farcall _LoadFontsExtra2
|
2013-08-29 23:39:21 +00:00
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
DecompressRequest2bpp::
|
2013-08-29 23:39:21 +00:00
|
|
|
push de
|
2015-08-20 04:51:04 +00:00
|
|
|
ld a, BANK(sScratch)
|
2013-08-29 23:39:21 +00:00
|
|
|
call GetSRAMBank
|
|
|
|
push bc
|
2015-11-04 21:14:27 +00:00
|
|
|
|
2015-08-20 04:51:04 +00:00
|
|
|
ld de, sScratch
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, b
|
|
|
|
call FarDecompress
|
2015-11-04 21:14:27 +00:00
|
|
|
|
2013-08-29 23:39:21 +00:00
|
|
|
pop bc
|
|
|
|
pop hl
|
2015-11-04 21:14:27 +00:00
|
|
|
|
2015-08-20 04:51:04 +00:00
|
|
|
ld de, sScratch
|
2013-08-29 23:39:21 +00:00
|
|
|
call Request2bpp
|
|
|
|
call CloseSRAM
|
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
FarCopyBytes::
|
2013-08-29 23:39:21 +00:00
|
|
|
; copy bc bytes from a:hl to de
|
|
|
|
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hBuffer], a
|
|
|
|
ldh a, [hROMBank]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hBuffer]
|
2013-08-29 23:39:21 +00:00
|
|
|
rst Bankswitch
|
|
|
|
|
|
|
|
call CopyBytes
|
|
|
|
|
|
|
|
pop af
|
|
|
|
rst Bankswitch
|
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
FarCopyBytesDouble::
|
2013-08-29 23:39:21 +00:00
|
|
|
; Copy bc bytes from a:hl to bc*2 bytes at de,
|
|
|
|
; doubling each byte in the process.
|
|
|
|
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hBuffer], a
|
|
|
|
ldh a, [hROMBank]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hBuffer]
|
2013-08-29 23:39:21 +00:00
|
|
|
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
|
|
|
|
ld [hli], a
|
2016-05-04 15:46:23 +00:00
|
|
|
ld [hli], a
|
2013-08-29 23:39:21 +00:00
|
|
|
.dec
|
|
|
|
dec c
|
|
|
|
jr nz, .loop
|
|
|
|
dec b
|
|
|
|
jr nz, .loop
|
|
|
|
|
|
|
|
pop af
|
|
|
|
rst Bankswitch
|
|
|
|
ret
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
Request2bpp::
|
2015-10-17 16:58:26 +00:00
|
|
|
; Load 2bpp at b:de to occupy c tiles of hl.
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hBGMapMode]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
|
|
|
xor a
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hBGMapMode], a
|
2013-08-29 23:39:21 +00:00
|
|
|
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hROMBank]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
|
|
|
ld a, b
|
|
|
|
rst Bankswitch
|
|
|
|
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hTilesPerCycle]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
|
|
|
ld a, $8
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hTilesPerCycle], a
|
2015-10-24 14:34:19 +00:00
|
|
|
|
2015-10-19 14:23:58 +00:00
|
|
|
ld a, [wLinkMode]
|
2015-10-24 14:34:19 +00:00
|
|
|
cp LINK_MOBILE
|
|
|
|
jr nz, .NotMobile
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hMobile]
|
2013-08-29 23:39:21 +00:00
|
|
|
and a
|
2015-10-24 14:34:19 +00:00
|
|
|
jr nz, .NotMobile
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, $6
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hTilesPerCycle], a
|
2013-08-29 23:39:21 +00:00
|
|
|
|
2016-04-10 18:42:14 +00:00
|
|
|
.NotMobile:
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, e
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested2bppSource], a
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, d
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested2bppSource + 1], a
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, l
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested2bppDest], a
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, h
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested2bppDest + 1], a
|
2015-10-17 16:58:26 +00:00
|
|
|
.loop
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, c
|
2015-11-05 19:06:03 +00:00
|
|
|
ld hl, hTilesPerCycle
|
2013-08-29 23:39:21 +00:00
|
|
|
cp [hl]
|
2015-10-17 16:58:26 +00:00
|
|
|
jr nc, .iterate
|
2013-08-29 23:39:21 +00:00
|
|
|
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested2bpp], a
|
2013-08-29 23:39:21 +00:00
|
|
|
.wait
|
|
|
|
call DelayFrame
|
2018-01-23 22:39:09 +00:00
|
|
|
ld a, [wRequested2bpp]
|
2013-08-29 23:39:21 +00:00
|
|
|
and a
|
|
|
|
jr nz, .wait
|
|
|
|
|
|
|
|
pop af
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hTilesPerCycle], a
|
2013-08-29 23:39:21 +00:00
|
|
|
|
|
|
|
pop af
|
|
|
|
rst Bankswitch
|
|
|
|
|
|
|
|
pop af
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hBGMapMode], a
|
2013-08-29 23:39:21 +00:00
|
|
|
ret
|
|
|
|
|
2015-10-17 16:58:26 +00:00
|
|
|
.iterate
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hTilesPerCycle]
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested2bpp], a
|
2015-10-24 14:34:19 +00:00
|
|
|
|
2015-10-17 16:58:26 +00:00
|
|
|
.wait2
|
2013-08-29 23:39:21 +00:00
|
|
|
call DelayFrame
|
2018-01-23 22:39:09 +00:00
|
|
|
ld a, [wRequested2bpp]
|
2013-08-29 23:39:21 +00:00
|
|
|
and a
|
2015-10-17 16:58:26 +00:00
|
|
|
jr nz, .wait2
|
2015-10-24 14:34:19 +00:00
|
|
|
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, c
|
2015-11-05 19:06:03 +00:00
|
|
|
ld hl, hTilesPerCycle
|
2013-08-29 23:39:21 +00:00
|
|
|
sub [hl]
|
|
|
|
ld c, a
|
2015-10-17 16:58:26 +00:00
|
|
|
jr .loop
|
2013-08-29 23:39:21 +00:00
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
Request1bpp::
|
2015-11-05 19:06:03 +00:00
|
|
|
; Load 1bpp at b:de to occupy c tiles of hl.
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hBGMapMode]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
|
|
|
xor a
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hBGMapMode], a
|
2013-08-29 23:39:21 +00:00
|
|
|
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hROMBank]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
|
|
|
ld a, b
|
|
|
|
rst Bankswitch
|
|
|
|
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hTilesPerCycle]
|
2013-08-29 23:39:21 +00:00
|
|
|
push af
|
|
|
|
|
|
|
|
ld a, $8
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hTilesPerCycle], a
|
2015-10-19 14:23:58 +00:00
|
|
|
ld a, [wLinkMode]
|
2015-10-24 14:34:19 +00:00
|
|
|
cp LINK_MOBILE
|
2015-10-17 16:58:26 +00:00
|
|
|
jr nz, .NotMobile
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hMobile]
|
2013-08-29 23:39:21 +00:00
|
|
|
and a
|
2015-10-17 16:58:26 +00:00
|
|
|
jr nz, .NotMobile
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, $6
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hTilesPerCycle], a
|
2013-08-29 23:39:21 +00:00
|
|
|
|
2016-04-10 18:42:14 +00:00
|
|
|
.NotMobile:
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, e
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested1bppSource], a
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, d
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested1bppSource + 1], a
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, l
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested1bppDest], a
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, h
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested1bppDest + 1], a
|
2015-10-17 16:58:26 +00:00
|
|
|
.loop
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, c
|
2015-11-05 19:06:03 +00:00
|
|
|
ld hl, hTilesPerCycle
|
2013-08-29 23:39:21 +00:00
|
|
|
cp [hl]
|
2015-10-17 16:58:26 +00:00
|
|
|
jr nc, .iterate
|
2013-08-29 23:39:21 +00:00
|
|
|
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested1bpp], a
|
2013-08-29 23:39:21 +00:00
|
|
|
.wait
|
|
|
|
call DelayFrame
|
2018-01-23 22:39:09 +00:00
|
|
|
ld a, [wRequested1bpp]
|
2013-08-29 23:39:21 +00:00
|
|
|
and a
|
|
|
|
jr nz, .wait
|
|
|
|
|
|
|
|
pop af
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hTilesPerCycle], a
|
2013-08-29 23:39:21 +00:00
|
|
|
|
|
|
|
pop af
|
|
|
|
rst Bankswitch
|
|
|
|
|
|
|
|
pop af
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh [hBGMapMode], a
|
2013-08-29 23:39:21 +00:00
|
|
|
ret
|
|
|
|
|
2015-10-17 16:58:26 +00:00
|
|
|
.iterate
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [hTilesPerCycle]
|
2018-01-23 22:39:09 +00:00
|
|
|
ld [wRequested1bpp], a
|
2015-10-17 16:58:26 +00:00
|
|
|
|
|
|
|
.wait2
|
2013-08-29 23:39:21 +00:00
|
|
|
call DelayFrame
|
2018-01-23 22:39:09 +00:00
|
|
|
ld a, [wRequested1bpp]
|
2013-08-29 23:39:21 +00:00
|
|
|
and a
|
2015-10-17 16:58:26 +00:00
|
|
|
jr nz, .wait2
|
|
|
|
|
2013-08-29 23:39:21 +00:00
|
|
|
ld a, c
|
2015-11-05 19:06:03 +00:00
|
|
|
ld hl, hTilesPerCycle
|
2013-08-29 23:39:21 +00:00
|
|
|
sub [hl]
|
|
|
|
ld c, a
|
2015-10-17 16:58:26 +00:00
|
|
|
jr .loop
|
2013-08-29 23:39:21 +00:00
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
Get2bpp::
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [rLCDC]
|
2017-12-29 17:53:21 +00:00
|
|
|
bit rLCDC_ENABLE, a
|
2013-08-29 23:39:21 +00:00
|
|
|
jp nz, Request2bpp
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
Copy2bpp::
|
2013-08-29 23:39:21 +00:00
|
|
|
; 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
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
Get1bpp::
|
2018-08-25 18:28:22 +00:00
|
|
|
ldh a, [rLCDC]
|
2017-12-29 17:53:21 +00:00
|
|
|
bit rLCDC_ENABLE, a
|
2013-08-29 23:39:21 +00:00
|
|
|
jp nz, Request1bpp
|
|
|
|
|
2018-06-24 14:09:41 +00:00
|
|
|
Copy1bpp::
|
2013-08-29 23:39:21 +00:00
|
|
|
; 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
|
|
|
|
add hl, hl
|
2016-05-10 16:31:49 +00:00
|
|
|
add hl, hl
|
|
|
|
add hl, hl
|
2013-08-29 23:39:21 +00:00
|
|
|
ld b, h
|
|
|
|
ld c, l
|
|
|
|
pop af
|
|
|
|
|
|
|
|
pop hl
|
|
|
|
jp FarCopyBytesDouble
|