Package org.lwjgl.vulkan
Class VkMemoryDedicatedRequirements
java.lang.Object
org.lwjgl.system.Pointer.Default
org.lwjgl.system.Struct<VkMemoryDedicatedRequirements>
org.lwjgl.vulkan.VkMemoryDedicatedRequirements
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
- Direct Known Subclasses:
VkMemoryDedicatedRequirementsKHR
public class VkMemoryDedicatedRequirements
extends org.lwjgl.system.Struct<VkMemoryDedicatedRequirements>
implements org.lwjgl.system.NativeResource
Structure describing dedicated allocation requirements of buffer and image resources.
Description
To determine the dedicated allocation requirements of a buffer or image resource, add a VkMemoryDedicatedRequirements structure to the pNext chain of the VkMemoryRequirements2 structure passed as the pMemoryRequirements parameter of GetBufferMemoryRequirements2 or GetImageMemoryRequirements2, respectively.
Constraints on the values returned for buffer resources are:
requiresDedicatedAllocationmay beTRUEif thepNextchain ofVkBufferCreateInfofor the call tovkCreateBufferused to create the buffer being queried included aVkExternalMemoryBufferCreateInfostructure, and any of the handle types specified inVkExternalMemoryBufferCreateInfo::handleTypesrequires dedicated allocation, as reported byGetPhysicalDeviceExternalBufferPropertiesinVkExternalBufferProperties::externalMemoryProperties.externalMemoryFeatures. Otherwise,requiresDedicatedAllocationwill beFALSE.- When the implementation sets
requiresDedicatedAllocationtoTRUE, it must also setprefersDedicatedAllocationtoTRUE. - If
BUFFER_CREATE_SPARSE_BINDING_BITwas set inVkBufferCreateInfo::flagswhenbufferwas created, then bothprefersDedicatedAllocationandrequiresDedicatedAllocationwill beFALSE.
Constraints on the values returned for image resources are:
requiresDedicatedAllocationmay beTRUEif thepNextchain ofVkImageCreateInfofor the call toCreateImageused to create the image being queried included aVkExternalMemoryImageCreateInfostructure, and any of the handle types specified inVkExternalMemoryImageCreateInfo::handleTypesrequires dedicated allocation, as reported byGetPhysicalDeviceImageFormatProperties2inVkExternalImageFormatProperties::externalMemoryProperties.externalMemoryFeatures.requiresDedicatedAllocationmay beTRUEif the image’s tiling isIMAGE_TILING_DRM_FORMAT_MODIFIER_EXT.requiresDedicatedAllocationwill otherwise beFALSE- If
IMAGE_CREATE_SPARSE_BINDING_BITwas set inVkImageCreateInfo::flagswhenimagewas created, then bothprefersDedicatedAllocationandrequiresDedicatedAllocationwill beFALSE.
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS
Layout
struct VkMemoryDedicatedRequirements {
VkStructureType sType();
void * pNext();
VkBool32 prefersDedicatedAllocation();
VkBool32 requiresDedicatedAllocation();
}-
Nested Class Summary
Nested ClassesNested 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
ConstructorsConstructorDescriptionVkMemoryDedicatedRequirements(ByteBuffer container) Creates aVkMemoryDedicatedRequirementsinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptioncalloc()Returns a newVkMemoryDedicatedRequirementsinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkMemoryDedicatedRequirements.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkMemoryDedicatedRequirements.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkMemoryDedicatedRequirementsinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.Deprecated.callocStack(int capacity) Deprecated.callocStack(int capacity, org.lwjgl.system.MemoryStack stack) Deprecated.callocStack(org.lwjgl.system.MemoryStack stack) Deprecated.create()Returns a newVkMemoryDedicatedRequirementsinstance allocated withBufferUtils.create(int capacity) Returns a newVkMemoryDedicatedRequirements.Bufferinstance allocated withBufferUtils.create(long address) Returns a newVkMemoryDedicatedRequirementsinstance for the specified memory address.create(long address, int capacity) Create aVkMemoryDedicatedRequirements.Bufferinstance at the specified memory.static @Nullable VkMemoryDedicatedRequirementscreateSafe(long address) static @Nullable VkMemoryDedicatedRequirements.BuffercreateSafe(long address, int capacity) malloc()Returns a newVkMemoryDedicatedRequirementsinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkMemoryDedicatedRequirements.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkMemoryDedicatedRequirements.Bufferinstance allocated on the specifiedMemoryStack.malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkMemoryDedicatedRequirementsinstance allocated on the specifiedMemoryStack.Deprecated.mallocStack(int capacity) Deprecated.mallocStack(int capacity, org.lwjgl.system.MemoryStack stack) Deprecated.mallocStack(org.lwjgl.system.MemoryStack stack) Deprecated.static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static intnprefersDedicatedAllocation(long struct) Unsafe version ofprefersDedicatedAllocation().static intnrequiresDedicatedAllocation(long struct) Unsafe version ofrequiresDedicatedAllocation().static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.booleanspecifies that the implementation would prefer a dedicated allocation for this resource.booleanspecifies that a dedicated allocation is required for this resource.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_MEMORY_DEDICATED_REQUIREMENTSvalue 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. -
PREFERSDEDICATEDALLOCATION
public static final int PREFERSDEDICATEDALLOCATIONThe struct member offsets. -
REQUIRESDEDICATEDALLOCATION
public static final int REQUIRESDEDICATEDALLOCATIONThe struct member offsets.
-
-
Constructor Details
-
VkMemoryDedicatedRequirements
Creates aVkMemoryDedicatedRequirementsinstance 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<VkMemoryDedicatedRequirements>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
prefersDedicatedAllocation
public boolean prefersDedicatedAllocation()specifies that the implementation would prefer a dedicated allocation for this resource. The application is still free to suballocate the resource but it may get better performance if a dedicated allocation is used. -
requiresDedicatedAllocation
public boolean requiresDedicatedAllocation()specifies that a dedicated allocation is required for this resource. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTSvalue 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 newVkMemoryDedicatedRequirementsinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkMemoryDedicatedRequirementsinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkMemoryDedicatedRequirementsinstance allocated withBufferUtils. -
create
Returns a newVkMemoryDedicatedRequirementsinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkMemoryDedicatedRequirements.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkMemoryDedicatedRequirements.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkMemoryDedicatedRequirements.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkMemoryDedicatedRequirements.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
-
mallocStack
Deprecated.Deprecated for removal in 3.4.0. Usemalloc(MemoryStack)instead. -
callocStack
Deprecated.Deprecated for removal in 3.4.0. Usecalloc(MemoryStack)instead. -
mallocStack
@Deprecated public static VkMemoryDedicatedRequirements mallocStack(org.lwjgl.system.MemoryStack stack) Deprecated.Deprecated for removal in 3.4.0. Usemalloc(MemoryStack)instead. -
callocStack
@Deprecated public static VkMemoryDedicatedRequirements callocStack(org.lwjgl.system.MemoryStack stack) Deprecated.Deprecated for removal in 3.4.0. Usecalloc(MemoryStack)instead. -
mallocStack
Deprecated.Deprecated for removal in 3.4.0. Usemalloc(int, MemoryStack)instead. -
callocStack
Deprecated.Deprecated for removal in 3.4.0. Usecalloc(int, MemoryStack)instead. -
mallocStack
@Deprecated public static VkMemoryDedicatedRequirements.Buffer mallocStack(int capacity, org.lwjgl.system.MemoryStack stack) Deprecated.Deprecated for removal in 3.4.0. Usemalloc(int, MemoryStack)instead. -
callocStack
@Deprecated public static VkMemoryDedicatedRequirements.Buffer callocStack(int capacity, org.lwjgl.system.MemoryStack stack) Deprecated.Deprecated for removal in 3.4.0. Usecalloc(int, MemoryStack)instead. -
malloc
Returns a newVkMemoryDedicatedRequirementsinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkMemoryDedicatedRequirementsinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkMemoryDedicatedRequirements.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkMemoryDedicatedRequirements.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkMemoryDedicatedRequirements.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkMemoryDedicatedRequirements.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(). -
nprefersDedicatedAllocation
public static int nprefersDedicatedAllocation(long struct) Unsafe version ofprefersDedicatedAllocation(). -
nrequiresDedicatedAllocation
public static int nrequiresDedicatedAllocation(long struct) Unsafe version ofrequiresDedicatedAllocation(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext.
-