2017-03-11 01:39:29 +00:00
|
|
|
|
|
|
|
// refBegin VkPresentTimesInfoGOOGLE - The earliest time each image should be presented
|
|
|
|
|
|
|
|
When the +VK_GOOGLE_display_timing+ extension is enabled, additional fields
|
|
|
|
can: be specified that allow an application to specify the earliest time
|
|
|
|
that an image should be displayed.
|
|
|
|
This allows an application to avoid stutter that is caused by an image being
|
|
|
|
displayed earlier than planned.
|
|
|
|
Such stuttering can occur with both fixed and variable-refresh-rate
|
|
|
|
displays, because stuttering occurs when the geometry is not correctly
|
|
|
|
positioned for when the image is displayed.
|
|
|
|
An application can: instruct the presentation engine that an image should
|
|
|
|
not be displayed earlier than a specified time by including the
|
|
|
|
sname:VkPresentTimesInfoGOOGLE structure in the pname:pNext chain of the
|
|
|
|
sname:VkPresentInfoKHR structure.
|
|
|
|
|
|
|
|
The sname:VkPresentTimesInfoGOOGLE structure is defined as:
|
|
|
|
|
|
|
|
include::../../api/structs/VkPresentTimesInfoGOOGLE.txt[]
|
|
|
|
|
|
|
|
* pname:sType is the type of this structure.
|
|
|
|
* pname:pNext is `NULL` or a pointer to an extension-specific structure.
|
|
|
|
* pname:swapchainCount is the number of swapchains being presented to by
|
|
|
|
this command.
|
|
|
|
* pname:pTimes is `NULL` or a pointer to an array of
|
|
|
|
sname:VkPresentTimeGOOGLE elements with pname:swapchainCount entries.
|
|
|
|
If not `NULL`, each element of pname:pTimes contains the earliest time
|
|
|
|
to present the image corresponding to the entry in the
|
|
|
|
sname:VkPresentInfoKHR::pname:pImageIndices array.
|
|
|
|
|
|
|
|
.Valid Usage
|
|
|
|
****
|
Change log for May 12, 2017 Vulkan 1.0.49 spec update:
* Bump API patch number and header version number to 49 for this update.
Github Issues:
* Modify reference page extraction script to make internal links to spec
anchors refer to the core specification instead of being dangling links
(public issue 455).
* Fix GL_KHR_vulkan_glsl typo and add a nor-normative mapping to the newly
published StorageBuffer class (public issue 466).
* Both flink:vkEnumerateInstanceExtensionProperties and
flink:vkEnumerateDeviceExtensionProperties return
ename:VK_ERROR_LAYER_NOT_PRESENT, which covers the error case of an
application providing a layer name that wasn't returned by
ftext:vkEnumerate{Instance|Device}LayerProperties (public issue 487).
* The specification for flink:VkApplicationInfo::apiVersion says that the
driver must return ename:VK_ERROR_INCOMPATIBLE_DRIVER in the case that
pname:apiVersion specifies a non-supported version. That means that the
valid usage should not also state that, and so the VU statement is
removed. The VU had language about "`an effective substitute`" that
would have been lost, and so it was moved to the pname:apiVersion
description (public issue 488).
Internal Issues:
* Modify implicit validity generator script to assign asciidoc anchors to
all valid usage statements it generates, and reflow.py script to insert
Valid Usage ID (VUID) tags into the specification source files for
explicit valid usage statements. This has no semantic effects on the
specification, but will support the validation layer's detection of
valid usage violations and allow it to link into the corresponding part
of the specification (internal issue 583).
* Assign VUID tags to all explicit VU statements and document
the process and tag format in the style guide (internal issue 583).
* Clarify the rules of whether to structure new functionality as instance
extensions, device extensions, or both in the
<<extended-functionality-instance-extensions-and-devices, Instance
Extensions and Device Extensions>> section (internal issue 749).
* Require that SPIR-V run-time arrays are only used with the
code:BufferBlock decoration (internal issue 750).
* Fix implicit and explicit valid usage statements for
slink:VkWriteDescriptorSet::pname:dstSet (internal issue 767)
* Fix SPIR-V code sample for ename:VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER
in the <<descriptorsets-uniformtexelbuffer, Uniform Texel Buffer>>
section (internal issue 770).
* Clarify that disabling depth testing also disables depth writes in the
<<fragops-ds-state, Depth and Stencil Operations>> section (internal
issue 775).
* flink:VkDescriptorImageInfo::pname:imageLayout must match the actual
imageLayout at the time the image is accessed. This was in the spec
text, but needed an associated valid usage statement.
* Note that only 32-bit atomic operations are supported in the
<<spirvenv-module-validation, Validation Rules within a Module>>
section.
* Note that code:UniformConstant variables must not have initializers in
the <<spirvenv-module-validation, Validation Rules within a Module>>
section.
* Add a new elink:VkObjectType enumeration to the core API, promoted from
elink:VkDebugObjectTypeEXT, since it is used for much more than just the
debug_report extension.
New Extensions:
* `VK_KHR_get_surface_capabilities2`
* `VK_KHR_shared_presentable_image`
2017-05-12 08:37:16 +00:00
|
|
|
* [[VUID-VkPresentTimesInfoGOOGLE-swapchainCount-01247]] pname:swapchainCount must: be the same value as
|
2017-03-11 01:39:29 +00:00
|
|
|
sname:VkPresentInfoKHR::pname:swapchainCount, where
|
2017-03-25 08:46:58 +00:00
|
|
|
sname:VkPresentInfoKHR is in the pname:pNext chain of this
|
2017-03-11 01:39:29 +00:00
|
|
|
sname:VkPresentTimesInfoGOOGLE structure.
|
|
|
|
****
|
|
|
|
|
|
|
|
include::../../validity/structs/VkPresentTimesInfoGOOGLE.txt[]
|
|
|
|
|
|
|
|
// refBegin VkPresentTimeGOOGLE - The earliest time image should be presented
|
|
|
|
|
|
|
|
The sname:VkPresentTimeGOOGLE structure is defined as:
|
|
|
|
|
|
|
|
include::../../api/structs/VkPresentTimeGOOGLE.txt[]
|
|
|
|
|
|
|
|
* pname:presentID is an application-provided identification value, that
|
|
|
|
can: be used with the results of
|
|
|
|
flink:vkGetPastPresentationTimingGOOGLE, in order to uniquely identify
|
|
|
|
this present.
|
|
|
|
In order to be useful to the application, it should: be unique within
|
|
|
|
some period of time that is meaningful to the application.
|
|
|
|
* pname:desiredPresentTime indicates that the image given should: not be
|
|
|
|
displayed to the user any earlier than this time.
|
|
|
|
pname:desiredPresentTime is a time in nanoseconds, relative to a
|
|
|
|
monotonically-increasing clock (e.g. `CLOCK_MONOTONIC` (see
|
|
|
|
clock_gettime(2)) on Android and Linux).
|
|
|
|
A value of zero indicates that the presentation engine may: display the
|
|
|
|
image at any time.
|
|
|
|
This is useful when the application desires to provide pname:presentID,
|
|
|
|
but doesn't need a specific pname:desiredPresentTime.
|
|
|
|
|
|
|
|
// refEnd VkPresentTimeGOOGLE
|