Class VkHostImageCopyDevicePerformanceQuery
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
- Direct Known Subclasses:
VkHostImageCopyDevicePerformanceQueryEXT
Description
The implementation may return FALSE in optimalDeviceAccess if identicalMemoryLayout is FALSE. If identicalMemoryLayout is TRUE, optimalDeviceAccess must be TRUE.
The implementation may return TRUE in optimalDeviceAccess while identicalMemoryLayout is FALSE. In this situation, any device performance impact should not be measurable.
If VkPhysicalDeviceImageFormatInfo2::format is a block-compressed format and GetPhysicalDeviceImageFormatProperties2 returns SUCCESS, the implementation must return TRUE in optimalDeviceAccess.
Note
Applications can make use of optimalDeviceAccess to determine their resource copying strategy. If a resource is expected to be accessed more on device than on the host, and the implementation considers the resource sub-optimally accessed, it is likely better to use device copies instead.
Note
Layout not being identical yet still considered optimal for device access could happen if the implementation has different memory layout patterns, some of which are easier to access on the host.
Note
The most practical reason for optimalDeviceAccess to be FALSE is that host image access may disable framebuffer compression where it would otherwise have been enabled. This represents far more efficient host image access since no compression algorithm is required to read or write to the image, but it would impact device access performance. Some implementations may only set optimalDeviceAccess to FALSE if certain conditions are met, such as specific image usage flags or creation flags.
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_HOST_IMAGE_COPY_DEVICE_PERFORMANCE_QUERY
Layout
struct VkHostImageCopyDevicePerformanceQuery {
VkStructureType sType();
void * pNext();
VkBool32 optimalDeviceAccess();
VkBool32 identicalMemoryLayout();
}-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classAn array ofVkHostImageCopyDevicePerformanceQuerystructs.Nested classes/interfaces inherited from class org.lwjgl.system.Struct
org.lwjgl.system.Struct.StructValidationNested classes/interfaces inherited from interface org.lwjgl.system.Pointer
org.lwjgl.system.Pointer.Default -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intThe struct alignment in bytes.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct size in bytes.static final intThe struct member offsets.Fields inherited from interface org.lwjgl.system.Pointer
BITS32, BITS64, CLONG_SHIFT, CLONG_SIZE, POINTER_SHIFT, POINTER_SIZE -
Constructor Summary
ConstructorsConstructorDescriptionVkHostImageCopyDevicePerformanceQuery(ByteBuffer container) Creates aVkHostImageCopyDevicePerformanceQueryinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptioncalloc()Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.create()Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated withBufferUtils.create(int capacity) Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated withBufferUtils.create(long address) Returns a newVkHostImageCopyDevicePerformanceQueryinstance for the specified memory address.create(long address, int capacity) Create aVkHostImageCopyDevicePerformanceQuery.Bufferinstance at the specified memory.static @Nullable VkHostImageCopyDevicePerformanceQuerycreateSafe(long address) static @Nullable VkHostImageCopyDevicePerformanceQuery.BuffercreateSafe(long address, int capacity) booleanreturnsTRUEif use of host image copy has no impact on memory layout compared to an image that is created with exact same creation parameters, and bound to the sameVkDeviceMemory, except thatIMAGE_USAGE_HOST_TRANSFER_BITis replaced withIMAGE_USAGE_TRANSFER_SRC_BITandIMAGE_USAGE_TRANSFER_DST_BIT.malloc()Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated on the specifiedMemoryStack.malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated on the specifiedMemoryStack.static intnidenticalMemoryLayout(long struct) Unsafe version ofidenticalMemoryLayout().static intnoptimalDeviceAccess(long struct) Unsafe version ofoptimalDeviceAccess().static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.booleanreturnsTRUEif use of host image copy has no adverse effect on device access performance, compared to an image that is created with exact same creation parameters, and bound to the sameVkDeviceMemory, except thatIMAGE_USAGE_HOST_TRANSFER_BITis replaced withIMAGE_USAGE_TRANSFER_SRC_BITandIMAGE_USAGE_TRANSFER_DST_BIT.longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.set(int sType, long pNext) Initializes this struct with the specified values.Copies the specified struct data to this struct.intsizeof()intsType()aVkStructureTypevalue identifying this structure.sType(int value) Sets the specified value to thesType()field.Sets theSTRUCTURE_TYPE_HOST_IMAGE_COPY_DEVICE_PERFORMANCE_QUERYvalue to thesType()field.Methods inherited from class org.lwjgl.system.Struct
clear, free, isNull, validate, validateMethods inherited from class org.lwjgl.system.Pointer.Default
address, equals, hashCode, toStringMethods inherited from interface org.lwjgl.system.NativeResource
close, free
-
Field Details
-
SIZEOF
public static final int SIZEOFThe struct size in bytes. -
ALIGNOF
public static final int ALIGNOFThe struct alignment in bytes. -
STYPE
public static final int STYPEThe struct member offsets. -
PNEXT
public static final int PNEXTThe struct member offsets. -
OPTIMALDEVICEACCESS
public static final int OPTIMALDEVICEACCESSThe struct member offsets. -
IDENTICALMEMORYLAYOUT
public static final int IDENTICALMEMORYLAYOUTThe struct member offsets.
-
-
Constructor Details
-
VkHostImageCopyDevicePerformanceQuery
Creates aVkHostImageCopyDevicePerformanceQueryinstance at the current position of the specifiedByteBuffercontainer. Changes to the buffer's content will be visible to the struct instance and vice versa.The created instance holds a strong reference to the container object.
-
-
Method Details
-
sizeof
public int sizeof()- Specified by:
sizeofin classorg.lwjgl.system.Struct<VkHostImageCopyDevicePerformanceQuery>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
optimalDeviceAccess
public boolean optimalDeviceAccess()returnsTRUEif use of host image copy has no adverse effect on device access performance, compared to an image that is created with exact same creation parameters, and bound to the sameVkDeviceMemory, except thatIMAGE_USAGE_HOST_TRANSFER_BITis replaced withIMAGE_USAGE_TRANSFER_SRC_BITandIMAGE_USAGE_TRANSFER_DST_BIT. -
identicalMemoryLayout
public boolean identicalMemoryLayout()returnsTRUEif use of host image copy has no impact on memory layout compared to an image that is created with exact same creation parameters, and bound to the sameVkDeviceMemory, except thatIMAGE_USAGE_HOST_TRANSFER_BITis replaced withIMAGE_USAGE_TRANSFER_SRC_BITandIMAGE_USAGE_TRANSFER_DST_BIT. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_HOST_IMAGE_COPY_DEVICE_PERFORMANCE_QUERYvalue to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
set
Initializes this struct with the specified values. -
set
Copies the specified struct data to this struct.- Parameters:
src- the source struct- Returns:
- this struct
-
malloc
Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated withBufferUtils. -
create
Returns a newVkHostImageCopyDevicePerformanceQueryinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkHostImageCopyDevicePerformanceQuery.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
public static @Nullable VkHostImageCopyDevicePerformanceQuery.Buffer createSafe(long address, int capacity) -
malloc
Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkHostImageCopyDevicePerformanceQueryinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkHostImageCopyDevicePerformanceQuery.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkHostImageCopyDevicePerformanceQuery.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkHostImageCopyDevicePerformanceQuery.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
nsType
public static int nsType(long struct) Unsafe version ofsType(). -
npNext
public static long npNext(long struct) Unsafe version ofpNext(). -
noptimalDeviceAccess
public static int noptimalDeviceAccess(long struct) Unsafe version ofoptimalDeviceAccess(). -
nidenticalMemoryLayout
public static int nidenticalMemoryLayout(long struct) Unsafe version ofidenticalMemoryLayout(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext.
-