C Specification
The VkFrameBoundaryEXT structure is defined as:
// Provided by VK_EXT_frame_boundary
typedef struct VkFrameBoundaryEXT {
    VkStructureType            sType;
    const void*                pNext;
    VkFrameBoundaryFlagsEXT    flags;
    uint64_t                   frameID;
    uint32_t                   imageCount;
    const VkImage*             pImages;
    uint32_t                   bufferCount;
    const VkBuffer*            pBuffers;
    uint64_t                   tagName;
    size_t                     tagSize;
    const void*                pTag;
} VkFrameBoundaryEXT;Members
- 
sTypeis a VkStructureType value identifying this structure.
- 
pNextisNULLor a pointer to a structure extending this structure.
- 
flagsis a bitmask of VkFrameBoundaryFlagBitsEXT that can flag the last submission of a frame identifier.
- 
frameIDis the frame identifier.
- 
imageCountis the number of images that store frame results.
- 
pImagesis a pointer to an array of VkImage objects with imageCount entries.
- 
bufferCountis the number of buffers the store the frame results.
- 
pBuffersis a pointer to an array of VkBuffer objects with bufferCount entries.
- 
tagNameis a numerical identifier for tag data.
- 
tagSizeis the number of bytes of tag data.
- 
pTagis a pointer to an array oftagSizebytes containing tag data.
Description
The application can associate frame boundary information to a queue
submission call by adding a VkFrameBoundaryEXT structure to the
pNext chain of queue submission,
VkPresentInfoKHR,
or VkBindSparseInfo.
| Note | The frame identifier is used to associate one or more queue submissions to a frame. It is meant to be unique within a frame lifetime, i.e. it is possible (though not recommended) to reuse frame identifiers, as long as any two frames that may have overlapping queue submissions (as in the example above) use different frame identifiers. Since the concept of frame is application-dependent, there is no way to validate the use of frame identifier. It is good practice to use a monotonically increasing counter as the frame identifier and not reuse identifiers between frames. | 
The pImages and pBuffers arrays contain a list of images and
buffers which store the "end result" of the frame.
As the concept of frame is application-dependent, not all frames may
produce their results in images or buffers, yet this is a sufficiently
common case to be handled by VkFrameBoundaryEXT.
Note that no extra information, such as image layout is being provided,
since the images are meant to be used by tools which would already be
tracking this required information.
Having the possibility of passing a list of end-result images makes
VkFrameBoundaryEXT as expressive as vkQueuePresentKHR, which is
often the default frame boundary delimiter.
The application can also associate arbitrary extra information via tag data
using tagName, tagSize and pTag.
This extra information is typically tool-specific.
Document Notes
For more information, see the Vulkan Specification
This page is extracted from the Vulkan Specification. Fixes and changes should be made to the Specification, not directly.