The current URL is datacrystal.tcrf.net.
EarthBound/ASM/VRAM DMA Transfer Routines: Difference between revisions
(→$C085B7-$C08615: Batched memory/VRAM transfer: call out interaction with VRAM DMA memory) |
(Correct transfer style input) |
||
Line 5: | Line 5: | ||
===Inputs=== | ===Inputs=== | ||
* <tt>accumulator</tt>: Transfer style. | * <tt>accumulator</tt>: Transfer style. Byte index into [[EarthBound:VRAM_DMA_Transfer_Style_Table|VRAM DMA Transfer Style Table]] | ||
* <tt>x</tt>: Transfer size (bytes) | * <tt>x</tt>: Transfer size (bytes) | ||
* <tt>y</tt>: VRAM address (word) | * <tt>y</tt>: VRAM address (word) | ||
Line 19: | Line 19: | ||
====Inputs==== | ====Inputs==== | ||
* <tt>accumulator</tt>: Transfer style. | * <tt>accumulator</tt>: Transfer style. Byte index into [[EarthBound:VRAM_DMA_Transfer_Style_Table|VRAM DMA Transfer Style Table]] | ||
* <tt>x</tt>: Transfer size (bytes) | * <tt>x</tt>: Transfer size (bytes) | ||
* <tt>y</tt>: VRAM address (word) | * <tt>y</tt>: VRAM address (word) | ||
Line 28: | Line 28: | ||
====Inputs==== | ====Inputs==== | ||
* <tt>accumulator</tt>: Transfer style. | * <tt>accumulator</tt>: Transfer style. Byte index into [[EarthBound:VRAM_DMA_Transfer_Style_Table|VRAM DMA Transfer Style Table]] | ||
* <tt>x</tt>: Transfer size (bytes) | * <tt>x</tt>: Transfer size (bytes) | ||
* <tt>y</tt>: Memory address | * <tt>y</tt>: Memory address |
Revision as of 20:54, 14 June 2023
This is a sub-page of EarthBound/ASM.
$C085B7-$C08615: Batched memory/VRAM transfer
Batched transfers between main memory (ROM/WRAM) and VRAM. Sets up VRAM DMA memory and makes the transfers using multiple calls to $C08643 for batches of 0x1200 bytes, with a final transfer of the remainder up to 0x1201 bytes. Before each batch, spins on $7E0099, waiting for the value to become #$0000
.
Inputs
- accumulator: Transfer style. Byte index into VRAM DMA Transfer Style Table
- x: Transfer size (bytes)
- y: VRAM address (word)
- $0e..$10: Memory address long pointer
$C08616-$C0865A: Memory/VRAM transfer
Prepares memory (see VRAM DMA memory) and sets Data Bank and Data Page to zero. Then calls $C0865F to perform the DMA transfer.
Subroutine has multiple entry points.
Entry point $C08616
Setup including long pointer for memory address
Inputs
- accumulator: Transfer style. Byte index into VRAM DMA Transfer Style Table
- x: Transfer size (bytes)
- y: VRAM address (word)
- $0e..$10: Memory address long pointer
Entry point $C0862E
Setup including separated address/bank for memory address
Inputs
- accumulator: Transfer style. Byte index into VRAM DMA Transfer Style Table
- x: Transfer size (bytes)
- y: Memory address
- $0e: Memory address bank
- $10: VRAM address (word)
Entry point $C08643
Set up only Data Bank and Data Page registers. Used when VRAM DMA memory has already been prepared separately.
$C0865B-$C0865E: Perform DMA transfer (JSL)
Trivial JSL
wrapper around a call to $C0865F.
$C0865F-$C086DD: Perform DMA transfer (JSR)
Internal Data for EarthBound
| |
---|---|
This page is rather stubbly and could use some expansion. Are you a bad enough dude to rescue this article? |