Class VkBindImageMemoryDeviceGroupInfo
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
- Direct Known Subclasses:
VkBindImageMemoryDeviceGroupInfoKHR
Description
If the pNext chain of VkBindImageMemoryInfo includes a VkBindImageMemoryDeviceGroupInfo structure, then that structure determines how memory is bound to images across multiple devices in a device group.
If deviceIndexCount is greater than zero, then on device index i image is attached to the instance of the memory on the physical device with device index pDeviceIndices[i].
Let N be the number of physical devices in the logical device. If splitInstanceBindRegionCount is greater than zero, then pSplitInstanceBindRegions is a pointer to an array of N2 rectangles, where the image region specified by the rectangle at element i*N+j in resource instance i is bound to the memory instance j. The blocks of the memory that are bound to each sparse image block region use an offset in memory, relative to memoryOffset, computed as if the whole image was being bound to a contiguous range of memory. In other words, horizontally adjacent image blocks use consecutive blocks of memory, vertically adjacent image blocks are separated by the number of bytes per block multiplied by the width in blocks of image, and the block at (0,0) corresponds to memory starting at memoryOffset.
If splitInstanceBindRegionCount and deviceIndexCount are zero and the memory comes from a memory heap with the MEMORY_HEAP_MULTI_INSTANCE_BIT bit set, then it is as if pDeviceIndices contains consecutive indices from zero to the number of physical devices in the logical device, minus one. In other words, by default each physical device attaches to its own instance of the memory.
If splitInstanceBindRegionCount and deviceIndexCount are zero and the memory comes from a memory heap without the MEMORY_HEAP_MULTI_INSTANCE_BIT bit set, then it is as if pDeviceIndices contains an array of zeros. In other words, by default each physical device attaches to instance zero.
Valid Usage
- At least one of
deviceIndexCountandsplitInstanceBindRegionCountmust be zero deviceIndexCountmust either be zero or equal to the number of physical devices in the logical device- All elements of
pDeviceIndicesmust be valid device indices splitInstanceBindRegionCountmust either be zero or equal to the number of physical devices in the logical device squared- Elements of
pSplitInstanceBindRegionsthat correspond to the same instance of an image must not overlap - The
offset.xmember of any element ofpSplitInstanceBindRegionsmust be a multiple of the sparse image block width (VkSparseImageFormatProperties::imageGranularity.width) of all non-metadata aspects of the image - The
offset.ymember of any element ofpSplitInstanceBindRegionsmust be a multiple of the sparse image block height (VkSparseImageFormatProperties::imageGranularity.height) of all non-metadata aspects of the image - The
extent.widthmember of any element ofpSplitInstanceBindRegionsmust either be a multiple of the sparse image block width of all non-metadata aspects of the image, or elseextent.width+offset.xmust equal the width of the image subresource - The
extent.heightmember of any element ofpSplitInstanceBindRegionsmust either be a multiple of the sparse image block height of all non-metadata aspects of the image, or elseextent.height+offset.ymust equal the height of the image subresource
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO- If
deviceIndexCountis not 0,pDeviceIndicesmust be a valid pointer to an array ofdeviceIndexCountuint32_tvalues - If
splitInstanceBindRegionCountis not 0,pSplitInstanceBindRegionsmust be a valid pointer to an array ofsplitInstanceBindRegionCountVkRect2Dstructures
See Also
Layout
struct VkBindImageMemoryDeviceGroupInfo {
VkStructureType sType();
void const * pNext();
uint32_t deviceIndexCount();
uint32_t const * pDeviceIndices();
uint32_t splitInstanceBindRegionCount();
VkRect2D const * pSplitInstanceBindRegions();
}-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classAn array ofVkBindImageMemoryDeviceGroupInfostructs.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 member offsets.static final intThe struct size in bytes.static final intThe struct member offsets.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
ConstructorsConstructorDescriptionVkBindImageMemoryDeviceGroupInfo(ByteBuffer container) Creates aVkBindImageMemoryDeviceGroupInfoinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptioncalloc()Returns a newVkBindImageMemoryDeviceGroupInfoinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkBindImageMemoryDeviceGroupInfo.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkBindImageMemoryDeviceGroupInfo.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkBindImageMemoryDeviceGroupInfoinstance 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 newVkBindImageMemoryDeviceGroupInfoinstance allocated withBufferUtils.create(int capacity) Returns a newVkBindImageMemoryDeviceGroupInfo.Bufferinstance allocated withBufferUtils.create(long address) Returns a newVkBindImageMemoryDeviceGroupInfoinstance for the specified memory address.create(long address, int capacity) Create aVkBindImageMemoryDeviceGroupInfo.Bufferinstance at the specified memory.static @Nullable VkBindImageMemoryDeviceGroupInfocreateSafe(long address) static @Nullable VkBindImageMemoryDeviceGroupInfo.BuffercreateSafe(long address, int capacity) intthe number of elements inpDeviceIndices.malloc()Returns a newVkBindImageMemoryDeviceGroupInfoinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkBindImageMemoryDeviceGroupInfo.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkBindImageMemoryDeviceGroupInfo.Bufferinstance allocated on the specifiedMemoryStack.malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkBindImageMemoryDeviceGroupInfoinstance 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 intndeviceIndexCount(long struct) Unsafe version ofdeviceIndexCount().static voidndeviceIndexCount(long struct, int value) Sets the specified value to thedeviceIndexCountfield of the specifiedstruct.static @Nullable IntBuffernpDeviceIndices(long struct) Unsafe version ofpDeviceIndices.static voidnpDeviceIndices(long struct, @Nullable IntBuffer value) Unsafe version ofpDeviceIndices.static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static @Nullable VkRect2D.BuffernpSplitInstanceBindRegions(long struct) Unsafe version ofpSplitInstanceBindRegions().static voidnpSplitInstanceBindRegions(long struct, @Nullable VkRect2D.Buffer value) Unsafe version ofpSplitInstanceBindRegions.static intnsplitInstanceBindRegionCount(long struct) Unsafe version ofsplitInstanceBindRegionCount().static voidnsplitInstanceBindRegionCount(long struct, int value) Sets the specified value to thesplitInstanceBindRegionCountfield of the specifiedstruct.static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.@Nullable IntBuffera pointer to an array of device indices.pDeviceIndices(@Nullable IntBuffer value) Sets the address of the specifiedIntBufferto thepDeviceIndices()field.longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.@Nullable VkRect2D.Buffera pointer to an array ofVkRect2Dstructures describing which regions of the image are attached to each instance of memory.pSplitInstanceBindRegions(@Nullable VkRect2D.Buffer value) Sets the address of the specifiedVkRect2D.Bufferto thepSplitInstanceBindRegions()field.set(int sType, long pNext, @Nullable IntBuffer pDeviceIndices, @Nullable VkRect2D.Buffer pSplitInstanceBindRegions) Initializes this struct with the specified values.Copies the specified struct data to this struct.intsizeof()intthe number of elements inpSplitInstanceBindRegions.intsType()aVkStructureTypevalue identifying this structure.sType(int value) Sets the specified value to thesType()field.Sets theSTRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFOvalue to thesType()field.static voidvalidate(long struct) Validates pointer members that should not beNULL.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. -
DEVICEINDEXCOUNT
public static final int DEVICEINDEXCOUNTThe struct member offsets. -
PDEVICEINDICES
public static final int PDEVICEINDICESThe struct member offsets. -
SPLITINSTANCEBINDREGIONCOUNT
public static final int SPLITINSTANCEBINDREGIONCOUNTThe struct member offsets. -
PSPLITINSTANCEBINDREGIONS
public static final int PSPLITINSTANCEBINDREGIONSThe struct member offsets.
-
-
Constructor Details
-
VkBindImageMemoryDeviceGroupInfo
Creates aVkBindImageMemoryDeviceGroupInfoinstance 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<VkBindImageMemoryDeviceGroupInfo>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
deviceIndexCount
public int deviceIndexCount()the number of elements inpDeviceIndices. -
pDeviceIndices
a pointer to an array of device indices. -
splitInstanceBindRegionCount
public int splitInstanceBindRegionCount()the number of elements inpSplitInstanceBindRegions. -
pSplitInstanceBindRegions
a pointer to an array ofVkRect2Dstructures describing which regions of the image are attached to each instance of memory. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFOvalue to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
pDeviceIndices
Sets the address of the specifiedIntBufferto thepDeviceIndices()field. -
pSplitInstanceBindRegions
Sets the address of the specifiedVkRect2D.Bufferto thepSplitInstanceBindRegions()field. -
set
public VkBindImageMemoryDeviceGroupInfo set(int sType, long pNext, @Nullable IntBuffer pDeviceIndices, @Nullable VkRect2D.Buffer pSplitInstanceBindRegions) 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 newVkBindImageMemoryDeviceGroupInfoinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkBindImageMemoryDeviceGroupInfoinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkBindImageMemoryDeviceGroupInfoinstance allocated withBufferUtils. -
create
Returns a newVkBindImageMemoryDeviceGroupInfoinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkBindImageMemoryDeviceGroupInfo.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkBindImageMemoryDeviceGroupInfo.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkBindImageMemoryDeviceGroupInfo.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkBindImageMemoryDeviceGroupInfo.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
public static @Nullable VkBindImageMemoryDeviceGroupInfo.Buffer createSafe(long address, int capacity) -
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 VkBindImageMemoryDeviceGroupInfo mallocStack(org.lwjgl.system.MemoryStack stack) Deprecated.Deprecated for removal in 3.4.0. Usemalloc(MemoryStack)instead. -
callocStack
@Deprecated public static VkBindImageMemoryDeviceGroupInfo 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 VkBindImageMemoryDeviceGroupInfo.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 VkBindImageMemoryDeviceGroupInfo.Buffer callocStack(int capacity, org.lwjgl.system.MemoryStack stack) Deprecated.Deprecated for removal in 3.4.0. Usecalloc(int, MemoryStack)instead. -
malloc
Returns a newVkBindImageMemoryDeviceGroupInfoinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkBindImageMemoryDeviceGroupInfoinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkBindImageMemoryDeviceGroupInfo.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkBindImageMemoryDeviceGroupInfo.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkBindImageMemoryDeviceGroupInfo.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkBindImageMemoryDeviceGroupInfo.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(). -
ndeviceIndexCount
public static int ndeviceIndexCount(long struct) Unsafe version ofdeviceIndexCount(). -
npDeviceIndices
Unsafe version ofpDeviceIndices. -
nsplitInstanceBindRegionCount
public static int nsplitInstanceBindRegionCount(long struct) Unsafe version ofsplitInstanceBindRegionCount(). -
npSplitInstanceBindRegions
Unsafe version ofpSplitInstanceBindRegions(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext. -
ndeviceIndexCount
public static void ndeviceIndexCount(long struct, int value) Sets the specified value to thedeviceIndexCountfield of the specifiedstruct. -
npDeviceIndices
Unsafe version ofpDeviceIndices. -
nsplitInstanceBindRegionCount
public static void nsplitInstanceBindRegionCount(long struct, int value) Sets the specified value to thesplitInstanceBindRegionCountfield of the specifiedstruct. -
npSplitInstanceBindRegions
Unsafe version ofpSplitInstanceBindRegions. -
validate
public static void validate(long struct) Validates pointer members that should not beNULL.- Parameters:
struct- the struct to validate
-