Package org.lwjgl.vulkan
Class VkPushDescriptorSetInfo
java.lang.Object
org.lwjgl.system.Pointer.Default
org.lwjgl.system.Struct<VkPushDescriptorSetInfo>
org.lwjgl.vulkan.VkPushDescriptorSetInfo
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
- Direct Known Subclasses:
VkPushDescriptorSetInfoKHR
public class VkPushDescriptorSetInfo
extends org.lwjgl.system.Struct<VkPushDescriptorSetInfo>
implements org.lwjgl.system.NativeResource
Structure specifying a descriptor set push operation.
Description
If stageFlags specifies a subset of all stages corresponding to one or more pipeline bind points, the binding operation still affects all stages corresponding to the given pipeline bind point(s) as if the equivalent original version of this command had been called with the same parameters. For example, specifying a stageFlags value of SHADER_STAGE_VERTEX_BIT | SHADER_STAGE_FRAGMENT_BIT | SHADER_STAGE_COMPUTE_BIT is equivalent to calling the original version of this command once with PIPELINE_BIND_POINT_GRAPHICS and once with PIPELINE_BIND_POINT_COMPUTE.
Valid Usage
setmust be less thanVkPipelineLayoutCreateInfo::setLayoutCountprovided whenlayoutwas createdsetmust be the unique set number in the pipeline layout that uses a descriptor set layout that was created withDESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT- For each element
iwherepDescriptorWrites[i].descriptorTypeisDESCRIPTOR_TYPE_SAMPLER,DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,DESCRIPTOR_TYPE_SAMPLED_IMAGE,DESCRIPTOR_TYPE_STORAGE_IMAGE, orDESCRIPTOR_TYPE_INPUT_ATTACHMENT,pDescriptorWrites[i].pImageInfomust be a valid pointer to an array ofpDescriptorWrites[i].descriptorCountvalidVkDescriptorImageInfostructures
- If the
dynamicPipelineLayoutfeature is not enabled,layoutmust be a validVkPipelineLayouthandle - If
layoutisNULL_HANDLE, thepNextchain must include a validVkPipelineLayoutCreateInfostructure
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_PUSH_DESCRIPTOR_SET_INFOpNextmust beNULLor a pointer to a valid instance ofVkPipelineLayoutCreateInfo- The
sTypevalue of each struct in thepNextchain must be unique stageFlagsmust be a valid combination ofVkShaderStageFlagBitsvaluesstageFlagsmust not be 0- If
layoutis notNULL_HANDLE,layoutmust be a validVkPipelineLayouthandle pDescriptorWritesmust be a valid pointer to an array ofdescriptorWriteCountvalidVkWriteDescriptorSetstructuresdescriptorWriteCountmust be greater than 0
See Also
VkWriteDescriptorSet, CmdPushDescriptorSet2, CmdPushDescriptorSet2KHR
Layout
struct VkPushDescriptorSetInfo {
VkStructureType sType();
void const * pNext();
VkShaderStageFlags stageFlags();
VkPipelineLayout layout();
uint32_t set();
uint32_t descriptorWriteCount();
VkWriteDescriptorSet const * pDescriptorWrites();
}-
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 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
ConstructorsConstructorDescriptionVkPushDescriptorSetInfo(ByteBuffer container) Creates aVkPushDescriptorSetInfoinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptionstatic VkPushDescriptorSetInfocalloc()Returns a newVkPushDescriptorSetInfoinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkPushDescriptorSetInfo.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetInfo.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.static VkPushDescriptorSetInfocalloc(org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetInfoinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.static VkPushDescriptorSetInfocreate()Returns a newVkPushDescriptorSetInfoinstance allocated withBufferUtils.create(int capacity) Returns a newVkPushDescriptorSetInfo.Bufferinstance allocated withBufferUtils.static VkPushDescriptorSetInfocreate(long address) Returns a newVkPushDescriptorSetInfoinstance for the specified memory address.create(long address, int capacity) Create aVkPushDescriptorSetInfo.Bufferinstance at the specified memory.static @Nullable VkPushDescriptorSetInfocreateSafe(long address) static @Nullable VkPushDescriptorSetInfo.BuffercreateSafe(long address, int capacity) intthe number of elements in thepDescriptorWritesarray.longlayout()aVkPipelineLayoutobject used to program the bindings.layout(long value) Sets the specified value to thelayout()field.static VkPushDescriptorSetInfomalloc()Returns a newVkPushDescriptorSetInfoinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkPushDescriptorSetInfo.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetInfo.Bufferinstance allocated on the specifiedMemoryStack.static VkPushDescriptorSetInfomalloc(org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetInfoinstance allocated on the specifiedMemoryStack.static intndescriptorWriteCount(long struct) Unsafe version ofdescriptorWriteCount().static voidndescriptorWriteCount(long struct, int value) Sets the specified value to thedescriptorWriteCountfield of the specifiedstruct.static longnlayout(long struct) Unsafe version oflayout().static voidnlayout(long struct, long value) Unsafe version oflayout.static VkWriteDescriptorSet.BuffernpDescriptorWrites(long struct) Unsafe version ofpDescriptorWrites().static voidnpDescriptorWrites(long struct, VkWriteDescriptorSet.Buffer value) Unsafe version ofpDescriptorWrites.static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static intnset(long struct) Unsafe version ofset().static voidnset(long struct, int value) Unsafe version ofset.static intnstageFlags(long struct) Unsafe version ofstageFlags().static voidnstageFlags(long struct, int value) Unsafe version ofstageFlags.static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.a pointer to an array ofVkWriteDescriptorSetstructures describing the descriptors to be updated.Sets the address of the specifiedVkWriteDescriptorSet.Bufferto thepDescriptorWrites()field.longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.pNext(VkPipelineLayoutCreateInfo value) Prepends the specifiedVkPipelineLayoutCreateInfovalue to thepNextchain.intset()the set number of the descriptor set in the pipeline layout that will be updated.set(int value) Sets the specified value to theset()field.set(int sType, long pNext, int stageFlags, long layout, int set, VkWriteDescriptorSet.Buffer pDescriptorWrites) Initializes this struct with the specified values.Copies the specified struct data to this struct.intsizeof()inta bitmask ofVkShaderStageFlagBitsspecifying the shader stages that will use the descriptors.stageFlags(int value) Sets the specified value to thestageFlags()field.intsType()aVkStructureTypevalue identifying this structure.sType(int value) Sets the specified value to thesType()field.Sets theSTRUCTURE_TYPE_PUSH_DESCRIPTOR_SET_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. -
STAGEFLAGS
public static final int STAGEFLAGSThe struct member offsets. -
LAYOUT
public static final int LAYOUTThe struct member offsets. -
SET
public static final int SETThe struct member offsets. -
DESCRIPTORWRITECOUNT
public static final int DESCRIPTORWRITECOUNTThe struct member offsets. -
PDESCRIPTORWRITES
public static final int PDESCRIPTORWRITESThe struct member offsets.
-
-
Constructor Details
-
VkPushDescriptorSetInfo
Creates aVkPushDescriptorSetInfoinstance 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<VkPushDescriptorSetInfo>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
stageFlags
public int stageFlags()a bitmask ofVkShaderStageFlagBitsspecifying the shader stages that will use the descriptors. -
layout
public long layout()aVkPipelineLayoutobject used to program the bindings. If thedynamicPipelineLayoutfeature is enabled,layoutcan beNULL_HANDLEand the layout must be specified by chainingVkPipelineLayoutCreateInfostructure off thepNext -
set
public int set()the set number of the descriptor set in the pipeline layout that will be updated. -
descriptorWriteCount
public int descriptorWriteCount()the number of elements in thepDescriptorWritesarray. -
pDescriptorWrites
a pointer to an array ofVkWriteDescriptorSetstructures describing the descriptors to be updated. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_PUSH_DESCRIPTOR_SET_INFOvalue to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
pNext
Prepends the specifiedVkPipelineLayoutCreateInfovalue to thepNextchain. -
stageFlags
Sets the specified value to thestageFlags()field. -
layout
Sets the specified value to thelayout()field. -
set
Sets the specified value to theset()field. -
pDescriptorWrites
Sets the address of the specifiedVkWriteDescriptorSet.Bufferto thepDescriptorWrites()field. -
set
public VkPushDescriptorSetInfo set(int sType, long pNext, int stageFlags, long layout, int set, VkWriteDescriptorSet.Buffer pDescriptorWrites) 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 newVkPushDescriptorSetInfoinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkPushDescriptorSetInfoinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkPushDescriptorSetInfoinstance allocated withBufferUtils. -
create
Returns a newVkPushDescriptorSetInfoinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkPushDescriptorSetInfo.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkPushDescriptorSetInfo.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkPushDescriptorSetInfo.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkPushDescriptorSetInfo.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
-
malloc
Returns a newVkPushDescriptorSetInfoinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkPushDescriptorSetInfoinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkPushDescriptorSetInfo.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetInfo.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkPushDescriptorSetInfo.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetInfo.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(). -
nstageFlags
public static int nstageFlags(long struct) Unsafe version ofstageFlags(). -
nlayout
public static long nlayout(long struct) Unsafe version oflayout(). -
nset
public static int nset(long struct) Unsafe version ofset(). -
ndescriptorWriteCount
public static int ndescriptorWriteCount(long struct) Unsafe version ofdescriptorWriteCount(). -
npDescriptorWrites
Unsafe version ofpDescriptorWrites(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext. -
nstageFlags
public static void nstageFlags(long struct, int value) Unsafe version ofstageFlags. -
nlayout
public static void nlayout(long struct, long value) Unsafe version oflayout. -
nset
public static void nset(long struct, int value) Unsafe version ofset. -
ndescriptorWriteCount
public static void ndescriptorWriteCount(long struct, int value) Sets the specified value to thedescriptorWriteCountfield of the specifiedstruct. -
npDescriptorWrites
Unsafe version ofpDescriptorWrites. -
validate
public static void validate(long struct) Validates pointer members that should not beNULL.- Parameters:
struct- the struct to validate
-