Class VkVideoDecodeH264DpbSlotInfoKHR
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
Description
This structure is specified in the pNext chain of VkVideoDecodeInfoKHR::pSetupReferenceSlot, if not NULL, and the pNext chain of the elements of VkVideoDecodeInfoKHR::pReferenceSlots to specify the codec-specific reference picture information for an H.264 decode operation.
- Active Reference Picture Information
- If neither
pStdReferenceInfo→flags.top_field_flagnorpStdReferenceInfo→flags.bottom_field_flagis set, then the picture is added as a frame reference to the list of active reference pictures. - If
pStdReferenceInfo→flags.top_field_flagis set, then the picture is added as a top field reference to the list of active reference pictures. - If
pStdReferenceInfo→flags.bottom_field_flagis set, then the picture is added as a bottom field reference to the list of active reference pictures. - For each added reference picture, the corresponding image subregion used is determined according to the H.264 Decode Picture Data Access section.
- Each added reference picture is associated with the DPB slot index specified in the
slotIndexmember of the corresponding element ofVkVideoDecodeInfoKHR::pReferenceSlots. - Each added reference picture is associated with the H.264 reference information provided in
pStdReferenceInfo.
- If neither
Note
When both the top and bottom field of an interlaced frame currently associated with a DPB slot is intended to be used as an active reference picture and both fields are stored in the same image subregion (which is the case when using VIDEO_DECODE_H264_PICTURE_LAYOUT_INTERLACED_INTERLEAVED_LINES_BIT_KHR which stores the two fields at even and odd scanlines of the same image subregion), both references have to be provided through a single VkVideoReferenceSlotInfoKHR structure that has both flags.top_field_flag and flags.bottom_field_flag set in the StdVideoDecodeH264ReferenceInfo structure pointed to by the pStdReferenceInfo member of the VkVideoDecodeH264DpbSlotInfoKHR structure included in the corresponding VkVideoReferenceSlotInfoKHR structure’s pNext chain. However, this approach can only be used when both fields are stored in the same image subregion. If that is not the case (e.g. when using VIDEO_DECODE_H264_PICTURE_LAYOUT_INTERLACED_SEPARATE_PLANES_BIT_KHR which requires separate codedOffset values for the two fields and also allows storing the two fields of a frame in separate image layers or entirely separate images), then a separate VkVideoReferenceSlotInfoKHR structure needs to be provided for referencing the two fields, each only setting one of flags.top_field_flag or flags.bottom_field_flag, and providing the appropriate video picture resource information in VkVideoReferenceSlotInfoKHR::pPictureResource.
- Reconstructed Picture Information
- If neither
pStdReferenceInfo→flags.top_field_flagnorpStdReferenceInfo→flags.bottom_field_flagis set, then the picture represents a frame. - If
pStdReferenceInfo→flags.top_field_flagis set, then the picture represents a field, specifically, the top field of the frame. - If
pStdReferenceInfo→flags.bottom_field_flagis set, then the picture represents a field, specifically, the bottom field of the frame. - The image subregion used is determined according to the H.264 Decode Picture Data Access section.
- If reference picture setup is requested, then the reconstructed picture is used to activate the DPB slot with the index specified in
VkVideoDecodeInfoKHR::pSetupReferenceSlot→slotIndex. - The reconstructed picture is associated with the H.264 reference information provided in
pStdReferenceInfo.
- If neither
- Std Reference Information
flags.top_field_flagis used to indicate whether the reference is used as top field reference;flags.bottom_field_flagis used to indicate whether the reference is used as bottom field reference;flags.used_for_long_term_referenceis used to indicate whether the picture is marked as “used for long-term reference” as defined in section 8.2.5.1 of the ITU-T H.264 Specification;flags.is_non_existingis used to indicate whether the picture is marked as “non-existing” as defined in section 8.2.5.2 of the ITU-T H.264 Specification;- all other members are interpreted as defined in section 8.2 of the ITU-T H.264 Specification.
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_VIDEO_DECODE_H264_DPB_SLOT_INFO_KHRpStdReferenceInfomust be a valid pointer to a validStdVideoDecodeH264ReferenceInfovalue
Layout
struct VkVideoDecodeH264DpbSlotInfoKHR {
VkStructureType sType();
void const * pNext();
StdVideoDecodeH264ReferenceInfo const * pStdReferenceInfo();
}-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classAn array ofVkVideoDecodeH264DpbSlotInfoKHRstructs.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 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
ConstructorsConstructorDescriptionVkVideoDecodeH264DpbSlotInfoKHR(ByteBuffer container) Creates aVkVideoDecodeH264DpbSlotInfoKHRinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptioncalloc()Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.create()Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated withBufferUtils.create(int capacity) Returns a newVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance allocated withBufferUtils.create(long address) Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance for the specified memory address.create(long address, int capacity) Create aVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance at the specified memory.static @Nullable VkVideoDecodeH264DpbSlotInfoKHRcreateSafe(long address) static @Nullable VkVideoDecodeH264DpbSlotInfoKHR.BuffercreateSafe(long address, int capacity) malloc()Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance allocated on the specifiedMemoryStack.malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated on the specifiedMemoryStack.static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.npStdReferenceInfo(long struct) Unsafe version ofpStdReferenceInfo().static voidnpStdReferenceInfo(long struct, StdVideoDecodeH264ReferenceInfo value) Unsafe version ofpStdReferenceInfo.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.a pointer to aStdVideoDecodeH264ReferenceInfostructure specifying H.264 reference information.Sets the address of the specifiedStdVideoDecodeH264ReferenceInfoto thepStdReferenceInfo()field.set(int sType, long pNext, StdVideoDecodeH264ReferenceInfo pStdReferenceInfo) 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_VIDEO_DECODE_H264_DPB_SLOT_INFO_KHRvalue 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. -
PSTDREFERENCEINFO
public static final int PSTDREFERENCEINFOThe struct member offsets.
-
-
Constructor Details
-
VkVideoDecodeH264DpbSlotInfoKHR
Creates aVkVideoDecodeH264DpbSlotInfoKHRinstance 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<VkVideoDecodeH264DpbSlotInfoKHR>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
pStdReferenceInfo
a pointer to aStdVideoDecodeH264ReferenceInfostructure specifying H.264 reference information. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_VIDEO_DECODE_H264_DPB_SLOT_INFO_KHRvalue to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
pStdReferenceInfo
Sets the address of the specifiedStdVideoDecodeH264ReferenceInfoto thepStdReferenceInfo()field. -
set
public VkVideoDecodeH264DpbSlotInfoKHR set(int sType, long pNext, StdVideoDecodeH264ReferenceInfo pStdReferenceInfo) 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 newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated withBufferUtils. -
create
Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
public static @Nullable VkVideoDecodeH264DpbSlotInfoKHR.Buffer createSafe(long address, int capacity) -
malloc
Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkVideoDecodeH264DpbSlotInfoKHRinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkVideoDecodeH264DpbSlotInfoKHR.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoDecodeH264DpbSlotInfoKHR.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkVideoDecodeH264DpbSlotInfoKHR.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoDecodeH264DpbSlotInfoKHR.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(). -
npStdReferenceInfo
Unsafe version ofpStdReferenceInfo(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext. -
npStdReferenceInfo
Unsafe version ofpStdReferenceInfo. -
validate
public static void validate(long struct) Validates pointer members that should not beNULL.- Parameters:
struct- the struct to validate
-