CloneVRAMPagesDefer

Copies one page of VRAM to a contiguous range of VRAM pages asynchronously.

Synopsis

Err CloneVRAMPagesDefer (Item ioreq,void *dest,void *src,uint32 numpages,uint32 mask)

Description

This call is a convenience call for SPORT device transfers. It copies the specified src VRAM page to a number of VRAM pages, starting at the specified dest address and specified numPages number of pages. The mask argument controls which bits of the destination are modified by bits of the source.

This call uses the SPORT device to do the transfer. It does not wait for the transfer to complete, but returns immediately. This allows the application to continue its work while the SPORT I/O request is in the queue. When using a deferred request such as this, use WaitIO() to wait until the I/O request completes.

Arguments

ioreq
Item number of the I/O request.
dest
Pointer to the first byte of the first page of the destination VRAM.
src
Pointer to the first byte of the page of source VRAM.
numpages
Number of destination pages to receive the copy of the source page.
mask
Write mask, which controls which bits of the source are copied to the destination.

Return Value

The call returns a non-negative value if successful or an error code (a negative value) if an error occurs.

Notes

The use of a mask value other than all 1s (0xFFFFFFFF) is discouraged. Future systems may not support this feature in a performance-conscious manner.

Implementation

Convenience call implemented in graphics.lib V20.

Associated Files

graphics.h, graphics.lib

See Also

CopyVRAMPages(), SetVRAMPages(), SetVRAMPagesDefer(), CopyVRAMPagesDefer(), CloneVRAMPages(), GetVRAMIOReq(), GetPageSize()