Change log for June 24, 2017 Vulkan 1.0.53 spec update:
* Bump API patch number and header version number to 53 for this update.
Github Issues:
Internal Issues:
* Clarify mappings of coordinates for mutable, compatible image views in
slink:VkImageViewCreateInfo (internal issue 815).
* Make ename:VK_BIND_SFR_BIT require a logical device with multiple
physical devices, so that standard sparse image block dimensions are
only required on systems that support multi-GPU (internal issue 835).
* Convert all files from use of // refBegin .. // refEnd comments to
delimit ref pages, to use of open blocks, and update style guide
accordingly (internal issue 839).
* Add valid usage for slink:VkWriteDescriptorSet when performing updates
to a ename:VK_STORAGE_IMAGE descriptor with layout
ename:VK_IMAGE_LAYOUT_GENERAL.
* Add a hack to the validity generator script to support an odd
interaction between flink:vkCmdFillBuffer and an extension (internal
issue 853).
* Remove redundant text describing slink:VkBufferCreateInfo::pname:usage,
which was already covered by implicit valid usage (internal issue 854).
* Update implicit validity generator script to properly handle the
pname:sType and pname:pNext members of "returnedonly" structures
(internal issue 874).
* Note that slink:VkApplicationInfo::pname:pApplicationName &
slink:VkApplicationInfo::pname:pEngineName are optional, and add missing
implicit valid usage statements for flink:vkDestroyInstance.
* Added missing valid usage for flink:vkCmdWriteTimestamp to require a
timestamp query pool.
* Simplify and/or split "`non-atomic`" valid usage statements.
New Extensions:
* `VK_AMD_gpu_shader_int16`
* `VK_EXT_blend_operation_advanced`
* `VK_EXT_sampler_filter_minmax`
* `VK_NV_framebuffer_mixed_samples`
-----------------------------------------------------
Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release
combines both change sets.
-----------------------------------------------------
Change log for June 13, 2017 Vulkan 1.0.52 spec update:
* Bump API patch number and header version number to 52 for this update.
Github Issues:
Internal Issues:
* Clarify behavior when non-coherent memory has
<<memory-device-unmap-does-not-flush, not been flushed before being
unmapped>> (internal issue 819).
* Fix description of code:WorkgroupSize builtin to note it decorates an
object, not a variable (internal issue 836).
* Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style
equations are rendered properly (internal issue 845).
* Add language to the "`Extension Handles, Objects, Enums, and Typedefs`"
section of the Procedures and Conventions document stating that any new
handle type requires a corresponding entry in the elink:VkObjectType
enumerated type (internal issue 856).
* Update style guide to use slink macro for Vulkan handle type names, and
define narrow conditions under which to use the *name and *text macros
instead of *link (internal issue 886).
* Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>>
extension on VK_KHX_device_group_creation to +vk.xml+ and the extension
appendix.
* Change the copyright on Vulkan specification asciidoc *source* files to
CC-BY 4.0, and update the proprietary Khronos copyright applied to the
generated *output* formats (internal issue 327). This enables broader
re-use and modification of the Vulkan specification sources, while not
affecting the Reciprocal IP License between Vulkan Adopters and Working
Group Members.
New Extensions:
* `VK_NV_fill_rectangle`
* `VK_NV_fragment_coverage_to_color`
2017-06-26 19:32:10 -07:00
|
|
|
// Copyright (c) 2016-2017 Google Inc. This work is licensed under a
|
|
|
|
// Creative Commons Attribution 4.0 International License; see
|
|
|
|
// http://creativecommons.org/licenses/by/4.0/
|
2017-03-10 17:39:29 -08:00
|
|
|
|
|
|
|
== Display Timing Queries
|
|
|
|
|
|
|
|
Traditional game and real-time-animation applications frequently use
|
|
|
|
ename:VK_PRESENT_MODE_FIFO_KHR so that presentable images are updated during
|
|
|
|
the vertical blanking period of a given refresh cycle (RC) of the
|
|
|
|
presentation engine's display.
|
|
|
|
This avoids the visual anomaly known as tearing.
|
|
|
|
|
|
|
|
However, synchronizing the presentation of images with the RC does not
|
|
|
|
prevent all forms of visual anomalies.
|
|
|
|
Stuttering occurs when the geometry for each presentable image isn't
|
|
|
|
accurately positioned for when that image will be displayed.
|
|
|
|
The geometry may appear to move too little some RCs, and too much for
|
|
|
|
others.
|
|
|
|
Sometimes the animation appears to freeze, when the same image is used for
|
|
|
|
more than one RC.
|
|
|
|
|
|
|
|
In order to minimize stuttering, an application needs to correctly position
|
|
|
|
their geometry for when the presentable image will be displayed to the user.
|
|
|
|
To accomplish this, applications need various timing information about the
|
|
|
|
presentation engine's display.
|
|
|
|
They need to know when presentable images were actually presented, and when
|
|
|
|
they could have been presented.
|
|
|
|
Applications also need to tell the presentation engine to display an image
|
|
|
|
no sooner than a given time.
|
|
|
|
This can allow the application's animation to look smooth to the user, with
|
|
|
|
no stuttering.
|
|
|
|
The +VK_GOOGLE_display_timing+ extension allows an application to satisfy
|
|
|
|
these needs.
|
|
|
|
|
|
|
|
The presentation engine's display typically refreshes the pixels that are
|
|
|
|
displayed to the user on a periodic basis.
|
|
|
|
The period may be fixed or variable.
|
|
|
|
In many cases, the presentation engine is associated with fixed refresh rate
|
|
|
|
(FRR) display technology, with a fixed refresh rate (RR, e.g. 60Hz).
|
|
|
|
In some cases, the presentation engine is associated with variable refresh
|
|
|
|
rate (VRR) display technology, where each refresh cycle (RC) can vary in
|
|
|
|
length.
|
|
|
|
This extension treats VRR displays as if they are FRR.
|
|
|
|
|
Change log for June 24, 2017 Vulkan 1.0.53 spec update:
* Bump API patch number and header version number to 53 for this update.
Github Issues:
Internal Issues:
* Clarify mappings of coordinates for mutable, compatible image views in
slink:VkImageViewCreateInfo (internal issue 815).
* Make ename:VK_BIND_SFR_BIT require a logical device with multiple
physical devices, so that standard sparse image block dimensions are
only required on systems that support multi-GPU (internal issue 835).
* Convert all files from use of // refBegin .. // refEnd comments to
delimit ref pages, to use of open blocks, and update style guide
accordingly (internal issue 839).
* Add valid usage for slink:VkWriteDescriptorSet when performing updates
to a ename:VK_STORAGE_IMAGE descriptor with layout
ename:VK_IMAGE_LAYOUT_GENERAL.
* Add a hack to the validity generator script to support an odd
interaction between flink:vkCmdFillBuffer and an extension (internal
issue 853).
* Remove redundant text describing slink:VkBufferCreateInfo::pname:usage,
which was already covered by implicit valid usage (internal issue 854).
* Update implicit validity generator script to properly handle the
pname:sType and pname:pNext members of "returnedonly" structures
(internal issue 874).
* Note that slink:VkApplicationInfo::pname:pApplicationName &
slink:VkApplicationInfo::pname:pEngineName are optional, and add missing
implicit valid usage statements for flink:vkDestroyInstance.
* Added missing valid usage for flink:vkCmdWriteTimestamp to require a
timestamp query pool.
* Simplify and/or split "`non-atomic`" valid usage statements.
New Extensions:
* `VK_AMD_gpu_shader_int16`
* `VK_EXT_blend_operation_advanced`
* `VK_EXT_sampler_filter_minmax`
* `VK_NV_framebuffer_mixed_samples`
-----------------------------------------------------
Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release
combines both change sets.
-----------------------------------------------------
Change log for June 13, 2017 Vulkan 1.0.52 spec update:
* Bump API patch number and header version number to 52 for this update.
Github Issues:
Internal Issues:
* Clarify behavior when non-coherent memory has
<<memory-device-unmap-does-not-flush, not been flushed before being
unmapped>> (internal issue 819).
* Fix description of code:WorkgroupSize builtin to note it decorates an
object, not a variable (internal issue 836).
* Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style
equations are rendered properly (internal issue 845).
* Add language to the "`Extension Handles, Objects, Enums, and Typedefs`"
section of the Procedures and Conventions document stating that any new
handle type requires a corresponding entry in the elink:VkObjectType
enumerated type (internal issue 856).
* Update style guide to use slink macro for Vulkan handle type names, and
define narrow conditions under which to use the *name and *text macros
instead of *link (internal issue 886).
* Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>>
extension on VK_KHX_device_group_creation to +vk.xml+ and the extension
appendix.
* Change the copyright on Vulkan specification asciidoc *source* files to
CC-BY 4.0, and update the proprietary Khronos copyright applied to the
generated *output* formats (internal issue 327). This enables broader
re-use and modification of the Vulkan specification sources, while not
affecting the Reciprocal IP License between Vulkan Adopters and Working
Group Members.
New Extensions:
* `VK_NV_fill_rectangle`
* `VK_NV_fragment_coverage_to_color`
2017-06-26 19:32:10 -07:00
|
|
|
[open,refpage='vkGetRefreshCycleDurationGOOGLE',desc='Obtain the RC duration of the PE\'s display',type='protos']
|
|
|
|
--
|
2017-03-10 17:39:29 -08:00
|
|
|
|
|
|
|
To query the duration of a refresh cycle (RC) for the presentation engine's
|
|
|
|
display, call:
|
|
|
|
|
|
|
|
include::../../api/protos/vkGetRefreshCycleDurationGOOGLE.txt[]
|
|
|
|
|
|
|
|
* pname:device is the device associated with pname:swapchain.
|
|
|
|
* pname:swapchain is the swapchain to obtain the refresh duration for.
|
|
|
|
* pname:pDisplayTimingProperties is a pointer to an instance of the
|
|
|
|
sname:VkRefreshCycleDurationGOOGLE structure.
|
|
|
|
|
|
|
|
include::../../validity/protos/vkGetRefreshCycleDurationGOOGLE.txt[]
|
Change log for June 24, 2017 Vulkan 1.0.53 spec update:
* Bump API patch number and header version number to 53 for this update.
Github Issues:
Internal Issues:
* Clarify mappings of coordinates for mutable, compatible image views in
slink:VkImageViewCreateInfo (internal issue 815).
* Make ename:VK_BIND_SFR_BIT require a logical device with multiple
physical devices, so that standard sparse image block dimensions are
only required on systems that support multi-GPU (internal issue 835).
* Convert all files from use of // refBegin .. // refEnd comments to
delimit ref pages, to use of open blocks, and update style guide
accordingly (internal issue 839).
* Add valid usage for slink:VkWriteDescriptorSet when performing updates
to a ename:VK_STORAGE_IMAGE descriptor with layout
ename:VK_IMAGE_LAYOUT_GENERAL.
* Add a hack to the validity generator script to support an odd
interaction between flink:vkCmdFillBuffer and an extension (internal
issue 853).
* Remove redundant text describing slink:VkBufferCreateInfo::pname:usage,
which was already covered by implicit valid usage (internal issue 854).
* Update implicit validity generator script to properly handle the
pname:sType and pname:pNext members of "returnedonly" structures
(internal issue 874).
* Note that slink:VkApplicationInfo::pname:pApplicationName &
slink:VkApplicationInfo::pname:pEngineName are optional, and add missing
implicit valid usage statements for flink:vkDestroyInstance.
* Added missing valid usage for flink:vkCmdWriteTimestamp to require a
timestamp query pool.
* Simplify and/or split "`non-atomic`" valid usage statements.
New Extensions:
* `VK_AMD_gpu_shader_int16`
* `VK_EXT_blend_operation_advanced`
* `VK_EXT_sampler_filter_minmax`
* `VK_NV_framebuffer_mixed_samples`
-----------------------------------------------------
Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release
combines both change sets.
-----------------------------------------------------
Change log for June 13, 2017 Vulkan 1.0.52 spec update:
* Bump API patch number and header version number to 52 for this update.
Github Issues:
Internal Issues:
* Clarify behavior when non-coherent memory has
<<memory-device-unmap-does-not-flush, not been flushed before being
unmapped>> (internal issue 819).
* Fix description of code:WorkgroupSize builtin to note it decorates an
object, not a variable (internal issue 836).
* Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style
equations are rendered properly (internal issue 845).
* Add language to the "`Extension Handles, Objects, Enums, and Typedefs`"
section of the Procedures and Conventions document stating that any new
handle type requires a corresponding entry in the elink:VkObjectType
enumerated type (internal issue 856).
* Update style guide to use slink macro for Vulkan handle type names, and
define narrow conditions under which to use the *name and *text macros
instead of *link (internal issue 886).
* Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>>
extension on VK_KHX_device_group_creation to +vk.xml+ and the extension
appendix.
* Change the copyright on Vulkan specification asciidoc *source* files to
CC-BY 4.0, and update the proprietary Khronos copyright applied to the
generated *output* formats (internal issue 327). This enables broader
re-use and modification of the Vulkan specification sources, while not
affecting the Reciprocal IP License between Vulkan Adopters and Working
Group Members.
New Extensions:
* `VK_NV_fill_rectangle`
* `VK_NV_fragment_coverage_to_color`
2017-06-26 19:32:10 -07:00
|
|
|
--
|
2017-03-10 17:39:29 -08:00
|
|
|
|
Change log for June 24, 2017 Vulkan 1.0.53 spec update:
* Bump API patch number and header version number to 53 for this update.
Github Issues:
Internal Issues:
* Clarify mappings of coordinates for mutable, compatible image views in
slink:VkImageViewCreateInfo (internal issue 815).
* Make ename:VK_BIND_SFR_BIT require a logical device with multiple
physical devices, so that standard sparse image block dimensions are
only required on systems that support multi-GPU (internal issue 835).
* Convert all files from use of // refBegin .. // refEnd comments to
delimit ref pages, to use of open blocks, and update style guide
accordingly (internal issue 839).
* Add valid usage for slink:VkWriteDescriptorSet when performing updates
to a ename:VK_STORAGE_IMAGE descriptor with layout
ename:VK_IMAGE_LAYOUT_GENERAL.
* Add a hack to the validity generator script to support an odd
interaction between flink:vkCmdFillBuffer and an extension (internal
issue 853).
* Remove redundant text describing slink:VkBufferCreateInfo::pname:usage,
which was already covered by implicit valid usage (internal issue 854).
* Update implicit validity generator script to properly handle the
pname:sType and pname:pNext members of "returnedonly" structures
(internal issue 874).
* Note that slink:VkApplicationInfo::pname:pApplicationName &
slink:VkApplicationInfo::pname:pEngineName are optional, and add missing
implicit valid usage statements for flink:vkDestroyInstance.
* Added missing valid usage for flink:vkCmdWriteTimestamp to require a
timestamp query pool.
* Simplify and/or split "`non-atomic`" valid usage statements.
New Extensions:
* `VK_AMD_gpu_shader_int16`
* `VK_EXT_blend_operation_advanced`
* `VK_EXT_sampler_filter_minmax`
* `VK_NV_framebuffer_mixed_samples`
-----------------------------------------------------
Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release
combines both change sets.
-----------------------------------------------------
Change log for June 13, 2017 Vulkan 1.0.52 spec update:
* Bump API patch number and header version number to 52 for this update.
Github Issues:
Internal Issues:
* Clarify behavior when non-coherent memory has
<<memory-device-unmap-does-not-flush, not been flushed before being
unmapped>> (internal issue 819).
* Fix description of code:WorkgroupSize builtin to note it decorates an
object, not a variable (internal issue 836).
* Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style
equations are rendered properly (internal issue 845).
* Add language to the "`Extension Handles, Objects, Enums, and Typedefs`"
section of the Procedures and Conventions document stating that any new
handle type requires a corresponding entry in the elink:VkObjectType
enumerated type (internal issue 856).
* Update style guide to use slink macro for Vulkan handle type names, and
define narrow conditions under which to use the *name and *text macros
instead of *link (internal issue 886).
* Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>>
extension on VK_KHX_device_group_creation to +vk.xml+ and the extension
appendix.
* Change the copyright on Vulkan specification asciidoc *source* files to
CC-BY 4.0, and update the proprietary Khronos copyright applied to the
generated *output* formats (internal issue 327). This enables broader
re-use and modification of the Vulkan specification sources, while not
affecting the Reciprocal IP License between Vulkan Adopters and Working
Group Members.
New Extensions:
* `VK_NV_fill_rectangle`
* `VK_NV_fragment_coverage_to_color`
2017-06-26 19:32:10 -07:00
|
|
|
[open,refpage='VkRefreshCycleDurationGOOGLE',desc='Structure containing the RC duration of a display',type='structs']
|
|
|
|
--
|
2017-03-10 17:39:29 -08:00
|
|
|
|
|
|
|
The sname:VkRefreshCycleDurationGOOGLE structure is defined as:
|
|
|
|
|
|
|
|
include::../../api/structs/VkRefreshCycleDurationGOOGLE.txt[]
|
|
|
|
|
|
|
|
* pname:refreshDuration is the number of nanoseconds from the start of one
|
|
|
|
refresh cycle to the next.
|
|
|
|
|
Change log for March 17, 2017 Vulkan 1.0.44 spec update:
* Bump API patch number and header version number to 44 for this update.
Github Issues:
* Fix description of <<features-extentperimagetype, Allowed Extent Values
Based On Image Type>> (public issue 290).
* Better specify VK_DEVICE_LOST behavior around flink:vkQueueSubmit,
flink:vkWaitForFences, and flink:vkGetFenceStatus (public issue 423).
* Clarify definition of flink:vkGetQueryPoolResults::pname:queryCount
(public issue 441).
* Simplify and clean up normative language. Remove shall and replace
recommend and variants with should wherever possible (public issue 448).
* Fix all dangling internal cross-references in the 1.0-extensions
specification, and add scripts/checkXrefs to find these in the future
(public issue 456).
* Reverse order of ChangeLog.txt entries so the most recent version is
documented first (public issue 463)
* Removes "become invalid" which clashes with invalid state for command
buffers. (public issue 467)
* Disallowed pending state in spec text for vkResetCommandBuffer, matching
valid usage (public issue 468)
* Removes sentence describing invalid state "like initial state". (public
issue 469)
* Disallows begin command buffer from resetting command buffers in the
"recording" state. (public issue 470)
* Removes mention of state from description of
VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT (public issue 471)
* Removed extra valid usage statement in VkSubmitInfo (public issue 472)
Internal Issues:
* Clarify description of the pname:imageLayout member of
sname:VkDescriptorImageInfo.
* Fix typos where etext:VK_VIEW_TYPE* was used instead of
etext:VK_IMAGE_VIEW_TYPE.
* Removed the <<VK_KHR_display>> and <<VK_KHR_display_swapchain>> example
code from the specification and noted it has been moved to the Vulkan
SDK cube demo (internal issue 179).
* Reorder VkExternalMemoryHandleTypeFlagBitsNV description (internal issue
480).
* Clarify than an implementation is
<<fundamentals-validusage-flags,permitted to return 'undefined' bit
flags>> in a bitfield (internal issue 640).
* Break Valid Usage statements describing unrelated parameters into
separate statements, and add a style guide entry to follow this approach
(internal issue 685).
* Move valid usage statement for slink:VkImageCreateInfo from spec body to
the explicit valid usage block (internal issue 693).
* Fix typos in the descriptions of slink:VkDisplaySurfaceCreateInfoKHR,
flink:vkCreateDisplayModeKHR, and
flink:vkGetDisplayPlaneSupportedDisplaysKHR in the <<display,Presenting
Directly to Display Devices>> section (internal issue 698, 704, 716).
* Clarified that mandatory depth/stencil formats are only a requirement
for 2D images (internal issue 719).
* Clarify that variables decorated with DeviceIndex/ViewIndex must be in
the Input storage class (internal issue 733).
* Work around generator script problem with removal of Unicode literals
from Python 3.0-3.2 using `future` package (internal issue 737).
* Remove nonexistent structure type enums from vk.xml (internal issue
738).
* Fix validextensionstructs attributes for structures in the pname:pNext
chain for VkPresentInfoKHR, fixing implicit valid usage statements for
those structures (internal issue 740).
New Extensions:
2017-03-17 22:53:58 -07:00
|
|
|
include::../../validity/structs/VkRefreshCycleDurationGOOGLE.txt[]
|
|
|
|
|
Change log for June 24, 2017 Vulkan 1.0.53 spec update:
* Bump API patch number and header version number to 53 for this update.
Github Issues:
Internal Issues:
* Clarify mappings of coordinates for mutable, compatible image views in
slink:VkImageViewCreateInfo (internal issue 815).
* Make ename:VK_BIND_SFR_BIT require a logical device with multiple
physical devices, so that standard sparse image block dimensions are
only required on systems that support multi-GPU (internal issue 835).
* Convert all files from use of // refBegin .. // refEnd comments to
delimit ref pages, to use of open blocks, and update style guide
accordingly (internal issue 839).
* Add valid usage for slink:VkWriteDescriptorSet when performing updates
to a ename:VK_STORAGE_IMAGE descriptor with layout
ename:VK_IMAGE_LAYOUT_GENERAL.
* Add a hack to the validity generator script to support an odd
interaction between flink:vkCmdFillBuffer and an extension (internal
issue 853).
* Remove redundant text describing slink:VkBufferCreateInfo::pname:usage,
which was already covered by implicit valid usage (internal issue 854).
* Update implicit validity generator script to properly handle the
pname:sType and pname:pNext members of "returnedonly" structures
(internal issue 874).
* Note that slink:VkApplicationInfo::pname:pApplicationName &
slink:VkApplicationInfo::pname:pEngineName are optional, and add missing
implicit valid usage statements for flink:vkDestroyInstance.
* Added missing valid usage for flink:vkCmdWriteTimestamp to require a
timestamp query pool.
* Simplify and/or split "`non-atomic`" valid usage statements.
New Extensions:
* `VK_AMD_gpu_shader_int16`
* `VK_EXT_blend_operation_advanced`
* `VK_EXT_sampler_filter_minmax`
* `VK_NV_framebuffer_mixed_samples`
-----------------------------------------------------
Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release
combines both change sets.
-----------------------------------------------------
Change log for June 13, 2017 Vulkan 1.0.52 spec update:
* Bump API patch number and header version number to 52 for this update.
Github Issues:
Internal Issues:
* Clarify behavior when non-coherent memory has
<<memory-device-unmap-does-not-flush, not been flushed before being
unmapped>> (internal issue 819).
* Fix description of code:WorkgroupSize builtin to note it decorates an
object, not a variable (internal issue 836).
* Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style
equations are rendered properly (internal issue 845).
* Add language to the "`Extension Handles, Objects, Enums, and Typedefs`"
section of the Procedures and Conventions document stating that any new
handle type requires a corresponding entry in the elink:VkObjectType
enumerated type (internal issue 856).
* Update style guide to use slink macro for Vulkan handle type names, and
define narrow conditions under which to use the *name and *text macros
instead of *link (internal issue 886).
* Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>>
extension on VK_KHX_device_group_creation to +vk.xml+ and the extension
appendix.
* Change the copyright on Vulkan specification asciidoc *source* files to
CC-BY 4.0, and update the proprietary Khronos copyright applied to the
generated *output* formats (internal issue 327). This enables broader
re-use and modification of the Vulkan specification sources, while not
affecting the Reciprocal IP License between Vulkan Adopters and Working
Group Members.
New Extensions:
* `VK_NV_fill_rectangle`
* `VK_NV_fragment_coverage_to_color`
2017-06-26 19:32:10 -07:00
|
|
|
--
|
Change log for March 17, 2017 Vulkan 1.0.44 spec update:
* Bump API patch number and header version number to 44 for this update.
Github Issues:
* Fix description of <<features-extentperimagetype, Allowed Extent Values
Based On Image Type>> (public issue 290).
* Better specify VK_DEVICE_LOST behavior around flink:vkQueueSubmit,
flink:vkWaitForFences, and flink:vkGetFenceStatus (public issue 423).
* Clarify definition of flink:vkGetQueryPoolResults::pname:queryCount
(public issue 441).
* Simplify and clean up normative language. Remove shall and replace
recommend and variants with should wherever possible (public issue 448).
* Fix all dangling internal cross-references in the 1.0-extensions
specification, and add scripts/checkXrefs to find these in the future
(public issue 456).
* Reverse order of ChangeLog.txt entries so the most recent version is
documented first (public issue 463)
* Removes "become invalid" which clashes with invalid state for command
buffers. (public issue 467)
* Disallowed pending state in spec text for vkResetCommandBuffer, matching
valid usage (public issue 468)
* Removes sentence describing invalid state "like initial state". (public
issue 469)
* Disallows begin command buffer from resetting command buffers in the
"recording" state. (public issue 470)
* Removes mention of state from description of
VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT (public issue 471)
* Removed extra valid usage statement in VkSubmitInfo (public issue 472)
Internal Issues:
* Clarify description of the pname:imageLayout member of
sname:VkDescriptorImageInfo.
* Fix typos where etext:VK_VIEW_TYPE* was used instead of
etext:VK_IMAGE_VIEW_TYPE.
* Removed the <<VK_KHR_display>> and <<VK_KHR_display_swapchain>> example
code from the specification and noted it has been moved to the Vulkan
SDK cube demo (internal issue 179).
* Reorder VkExternalMemoryHandleTypeFlagBitsNV description (internal issue
480).
* Clarify than an implementation is
<<fundamentals-validusage-flags,permitted to return 'undefined' bit
flags>> in a bitfield (internal issue 640).
* Break Valid Usage statements describing unrelated parameters into
separate statements, and add a style guide entry to follow this approach
(internal issue 685).
* Move valid usage statement for slink:VkImageCreateInfo from spec body to
the explicit valid usage block (internal issue 693).
* Fix typos in the descriptions of slink:VkDisplaySurfaceCreateInfoKHR,
flink:vkCreateDisplayModeKHR, and
flink:vkGetDisplayPlaneSupportedDisplaysKHR in the <<display,Presenting
Directly to Display Devices>> section (internal issue 698, 704, 716).
* Clarified that mandatory depth/stencil formats are only a requirement
for 2D images (internal issue 719).
* Clarify that variables decorated with DeviceIndex/ViewIndex must be in
the Input storage class (internal issue 733).
* Work around generator script problem with removal of Unicode literals
from Python 3.0-3.2 using `future` package (internal issue 737).
* Remove nonexistent structure type enums from vk.xml (internal issue
738).
* Fix validextensionstructs attributes for structures in the pname:pNext
chain for VkPresentInfoKHR, fixing implicit valid usage statements for
those structures (internal issue 740).
New Extensions:
2017-03-17 22:53:58 -07:00
|
|
|
|
2017-03-10 17:39:29 -08:00
|
|
|
The rate at which an application renders and presents new images is known as
|
|
|
|
the image present rate (IPR, a.k.a.
|
|
|
|
frame rate).
|
|
|
|
The inverse of IPR, or the duration between each image present, is the image
|
|
|
|
present duration (IPD).
|
|
|
|
In order to provide a smooth, stutter-free animation, an application will
|
|
|
|
want its IPD to be a multiple of pname:refreshDuration.
|
|
|
|
For example, if a display has a 60Hz refresh rate, pname:refreshDuration
|
|
|
|
will be a value in nanoseconds that is approximately equal to 16.67ms.
|
|
|
|
In such a case, an application will want an IPD of 16.67ms (1X multiplier of
|
|
|
|
pname:refreshDuration), or 33.33ms (2X multiplier of pname:refreshDuration),
|
|
|
|
or 50.0ms (3X multiplier of pname:refreshDuration), etc.
|
|
|
|
|
|
|
|
In order to determine a target IPD for a display (i.e. a multiple of
|
|
|
|
pname:refreshDuration), an application needs to determine when its images
|
|
|
|
are actually displayed.
|
|
|
|
Let's say that an application has an initial target IPD of 16.67ms (1X
|
|
|
|
multiplier of pname:refreshDuration).
|
|
|
|
It will therefore position the geometry of a new image 16.67ms later than
|
|
|
|
the previous image.
|
|
|
|
Let's say that this application is running on slower hardware, so that it
|
|
|
|
actually takes 20ms to render each new image.
|
|
|
|
This will create visual anomalies, because the images won't be displayed to
|
|
|
|
the user every 16.67ms, nor every 20ms.
|
|
|
|
In this case, it is better for the application to adjust its target IPD to
|
|
|
|
33.33ms (i.e. a 2X multiplier of pname:refreshDuration), and tell the
|
|
|
|
presentation engine to not present images any sooner than every 33.33ms.
|
|
|
|
This will allow the geometry to be correctly positioned for each presentable
|
|
|
|
image.
|
|
|
|
|
|
|
|
Adjustments to an application's IPD may be needed because different views of
|
|
|
|
an application's geometry can take different amounts of time to render.
|
|
|
|
For example, looking at the sky may take less time to render than looking at
|
|
|
|
multiple, complex items in a room.
|
|
|
|
In general, it is good to not frequently change IPD, as that can cause
|
|
|
|
visual anomalies.
|
|
|
|
Adjustments to a larger IPD because of late images should happen quickly,
|
|
|
|
but adjustments to a smaller IPD should only happen if the
|
|
|
|
pname:actualPresentTime and pname:earliestPresentTime members of the
|
|
|
|
slink:VkPastPresentationTimingGOOGLE structure are consistently different,
|
|
|
|
and if pname:presentMargin is consistently large, over multiple images.
|
|
|
|
|
Change log for June 24, 2017 Vulkan 1.0.53 spec update:
* Bump API patch number and header version number to 53 for this update.
Github Issues:
Internal Issues:
* Clarify mappings of coordinates for mutable, compatible image views in
slink:VkImageViewCreateInfo (internal issue 815).
* Make ename:VK_BIND_SFR_BIT require a logical device with multiple
physical devices, so that standard sparse image block dimensions are
only required on systems that support multi-GPU (internal issue 835).
* Convert all files from use of // refBegin .. // refEnd comments to
delimit ref pages, to use of open blocks, and update style guide
accordingly (internal issue 839).
* Add valid usage for slink:VkWriteDescriptorSet when performing updates
to a ename:VK_STORAGE_IMAGE descriptor with layout
ename:VK_IMAGE_LAYOUT_GENERAL.
* Add a hack to the validity generator script to support an odd
interaction between flink:vkCmdFillBuffer and an extension (internal
issue 853).
* Remove redundant text describing slink:VkBufferCreateInfo::pname:usage,
which was already covered by implicit valid usage (internal issue 854).
* Update implicit validity generator script to properly handle the
pname:sType and pname:pNext members of "returnedonly" structures
(internal issue 874).
* Note that slink:VkApplicationInfo::pname:pApplicationName &
slink:VkApplicationInfo::pname:pEngineName are optional, and add missing
implicit valid usage statements for flink:vkDestroyInstance.
* Added missing valid usage for flink:vkCmdWriteTimestamp to require a
timestamp query pool.
* Simplify and/or split "`non-atomic`" valid usage statements.
New Extensions:
* `VK_AMD_gpu_shader_int16`
* `VK_EXT_blend_operation_advanced`
* `VK_EXT_sampler_filter_minmax`
* `VK_NV_framebuffer_mixed_samples`
-----------------------------------------------------
Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release
combines both change sets.
-----------------------------------------------------
Change log for June 13, 2017 Vulkan 1.0.52 spec update:
* Bump API patch number and header version number to 52 for this update.
Github Issues:
Internal Issues:
* Clarify behavior when non-coherent memory has
<<memory-device-unmap-does-not-flush, not been flushed before being
unmapped>> (internal issue 819).
* Fix description of code:WorkgroupSize builtin to note it decorates an
object, not a variable (internal issue 836).
* Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style
equations are rendered properly (internal issue 845).
* Add language to the "`Extension Handles, Objects, Enums, and Typedefs`"
section of the Procedures and Conventions document stating that any new
handle type requires a corresponding entry in the elink:VkObjectType
enumerated type (internal issue 856).
* Update style guide to use slink macro for Vulkan handle type names, and
define narrow conditions under which to use the *name and *text macros
instead of *link (internal issue 886).
* Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>>
extension on VK_KHX_device_group_creation to +vk.xml+ and the extension
appendix.
* Change the copyright on Vulkan specification asciidoc *source* files to
CC-BY 4.0, and update the proprietary Khronos copyright applied to the
generated *output* formats (internal issue 327). This enables broader
re-use and modification of the Vulkan specification sources, while not
affecting the Reciprocal IP License between Vulkan Adopters and Working
Group Members.
New Extensions:
* `VK_NV_fill_rectangle`
* `VK_NV_fragment_coverage_to_color`
2017-06-26 19:32:10 -07:00
|
|
|
[open,refpage='vkGetPastPresentationTimingGOOGLE',desc='Obtain timing of a previously-presented image',type='protos']
|
|
|
|
--
|
2017-03-10 17:39:29 -08:00
|
|
|
|
|
|
|
The implementation will maintain a limited amount of history of timing
|
|
|
|
information about previous presents.
|
|
|
|
Because of the asynchronous nature of the presentation engine, the timing
|
|
|
|
information for a given flink:vkQueuePresentKHR command will become
|
|
|
|
available some time later.
|
|
|
|
These time values can be asynchronously queried, and will be returned if
|
|
|
|
available.
|
|
|
|
All time values are in nanoseconds, relative to a monotonically-increasing
|
|
|
|
clock (e.g. `CLOCK_MONOTONIC` (see clock_gettime(2)) on Android and Linux).
|
|
|
|
|
|
|
|
To asynchronously query the presentation engine, for newly-available timing
|
|
|
|
information about one or more previous presents to a given swapchain, call:
|
|
|
|
|
|
|
|
include::../../api/protos/vkGetPastPresentationTimingGOOGLE.txt[]
|
|
|
|
|
|
|
|
* pname:device is the device associated with pname:swapchain.
|
|
|
|
* pname:swapchain is the swapchain to obtain presentation timing
|
|
|
|
information duration for.
|
|
|
|
* pname:pPresentationTimingCount is a pointer to an integer related to the
|
|
|
|
number of sname:VkPastPresentationTimingGOOGLE structures to query, as
|
|
|
|
described below.
|
|
|
|
* pname:pPresentationTimings is either `NULL` or a pointer to an an array
|
|
|
|
of sname:VkPastPresentationTimingGOOGLE structures.
|
|
|
|
|
|
|
|
If pname:pPresentationTimings is `NULL`, then the number of newly-available
|
|
|
|
timing records for the given pname:swapchain is returned in
|
|
|
|
pname:pPresentationTimingCount.
|
|
|
|
Otherwise, pname:pPresentationTimingCount must: point to a variable set by
|
|
|
|
the user to the number of elements in the pname:pPresentationTimings array,
|
|
|
|
and on return the variable is overwritten with the number of structures
|
|
|
|
actually written to pname:pPresentationTimings.
|
|
|
|
If the value of pname:pPresentationTimingCount is less than the number of
|
|
|
|
newly-available timing records, at most pname:pPresentationTimingCount
|
|
|
|
structures will be written.
|
|
|
|
If pname:pPresentationTimingCount is smaller than the number of
|
|
|
|
newly-available timing records for the given pname:swapchain,
|
|
|
|
ename:VK_INCOMPLETE will be returned instead of ename:VK_SUCCESS to indicate
|
|
|
|
that not all the available values were returned.
|
|
|
|
|
|
|
|
include::../../validity/protos/vkGetPastPresentationTimingGOOGLE.txt[]
|
Change log for June 24, 2017 Vulkan 1.0.53 spec update:
* Bump API patch number and header version number to 53 for this update.
Github Issues:
Internal Issues:
* Clarify mappings of coordinates for mutable, compatible image views in
slink:VkImageViewCreateInfo (internal issue 815).
* Make ename:VK_BIND_SFR_BIT require a logical device with multiple
physical devices, so that standard sparse image block dimensions are
only required on systems that support multi-GPU (internal issue 835).
* Convert all files from use of // refBegin .. // refEnd comments to
delimit ref pages, to use of open blocks, and update style guide
accordingly (internal issue 839).
* Add valid usage for slink:VkWriteDescriptorSet when performing updates
to a ename:VK_STORAGE_IMAGE descriptor with layout
ename:VK_IMAGE_LAYOUT_GENERAL.
* Add a hack to the validity generator script to support an odd
interaction between flink:vkCmdFillBuffer and an extension (internal
issue 853).
* Remove redundant text describing slink:VkBufferCreateInfo::pname:usage,
which was already covered by implicit valid usage (internal issue 854).
* Update implicit validity generator script to properly handle the
pname:sType and pname:pNext members of "returnedonly" structures
(internal issue 874).
* Note that slink:VkApplicationInfo::pname:pApplicationName &
slink:VkApplicationInfo::pname:pEngineName are optional, and add missing
implicit valid usage statements for flink:vkDestroyInstance.
* Added missing valid usage for flink:vkCmdWriteTimestamp to require a
timestamp query pool.
* Simplify and/or split "`non-atomic`" valid usage statements.
New Extensions:
* `VK_AMD_gpu_shader_int16`
* `VK_EXT_blend_operation_advanced`
* `VK_EXT_sampler_filter_minmax`
* `VK_NV_framebuffer_mixed_samples`
-----------------------------------------------------
Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release
combines both change sets.
-----------------------------------------------------
Change log for June 13, 2017 Vulkan 1.0.52 spec update:
* Bump API patch number and header version number to 52 for this update.
Github Issues:
Internal Issues:
* Clarify behavior when non-coherent memory has
<<memory-device-unmap-does-not-flush, not been flushed before being
unmapped>> (internal issue 819).
* Fix description of code:WorkgroupSize builtin to note it decorates an
object, not a variable (internal issue 836).
* Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style
equations are rendered properly (internal issue 845).
* Add language to the "`Extension Handles, Objects, Enums, and Typedefs`"
section of the Procedures and Conventions document stating that any new
handle type requires a corresponding entry in the elink:VkObjectType
enumerated type (internal issue 856).
* Update style guide to use slink macro for Vulkan handle type names, and
define narrow conditions under which to use the *name and *text macros
instead of *link (internal issue 886).
* Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>>
extension on VK_KHX_device_group_creation to +vk.xml+ and the extension
appendix.
* Change the copyright on Vulkan specification asciidoc *source* files to
CC-BY 4.0, and update the proprietary Khronos copyright applied to the
generated *output* formats (internal issue 327). This enables broader
re-use and modification of the Vulkan specification sources, while not
affecting the Reciprocal IP License between Vulkan Adopters and Working
Group Members.
New Extensions:
* `VK_NV_fill_rectangle`
* `VK_NV_fragment_coverage_to_color`
2017-06-26 19:32:10 -07:00
|
|
|
--
|
2017-03-10 17:39:29 -08:00
|
|
|
|
Change log for June 24, 2017 Vulkan 1.0.53 spec update:
* Bump API patch number and header version number to 53 for this update.
Github Issues:
Internal Issues:
* Clarify mappings of coordinates for mutable, compatible image views in
slink:VkImageViewCreateInfo (internal issue 815).
* Make ename:VK_BIND_SFR_BIT require a logical device with multiple
physical devices, so that standard sparse image block dimensions are
only required on systems that support multi-GPU (internal issue 835).
* Convert all files from use of // refBegin .. // refEnd comments to
delimit ref pages, to use of open blocks, and update style guide
accordingly (internal issue 839).
* Add valid usage for slink:VkWriteDescriptorSet when performing updates
to a ename:VK_STORAGE_IMAGE descriptor with layout
ename:VK_IMAGE_LAYOUT_GENERAL.
* Add a hack to the validity generator script to support an odd
interaction between flink:vkCmdFillBuffer and an extension (internal
issue 853).
* Remove redundant text describing slink:VkBufferCreateInfo::pname:usage,
which was already covered by implicit valid usage (internal issue 854).
* Update implicit validity generator script to properly handle the
pname:sType and pname:pNext members of "returnedonly" structures
(internal issue 874).
* Note that slink:VkApplicationInfo::pname:pApplicationName &
slink:VkApplicationInfo::pname:pEngineName are optional, and add missing
implicit valid usage statements for flink:vkDestroyInstance.
* Added missing valid usage for flink:vkCmdWriteTimestamp to require a
timestamp query pool.
* Simplify and/or split "`non-atomic`" valid usage statements.
New Extensions:
* `VK_AMD_gpu_shader_int16`
* `VK_EXT_blend_operation_advanced`
* `VK_EXT_sampler_filter_minmax`
* `VK_NV_framebuffer_mixed_samples`
-----------------------------------------------------
Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release
combines both change sets.
-----------------------------------------------------
Change log for June 13, 2017 Vulkan 1.0.52 spec update:
* Bump API patch number and header version number to 52 for this update.
Github Issues:
Internal Issues:
* Clarify behavior when non-coherent memory has
<<memory-device-unmap-does-not-flush, not been flushed before being
unmapped>> (internal issue 819).
* Fix description of code:WorkgroupSize builtin to note it decorates an
object, not a variable (internal issue 836).
* Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style
equations are rendered properly (internal issue 845).
* Add language to the "`Extension Handles, Objects, Enums, and Typedefs`"
section of the Procedures and Conventions document stating that any new
handle type requires a corresponding entry in the elink:VkObjectType
enumerated type (internal issue 856).
* Update style guide to use slink macro for Vulkan handle type names, and
define narrow conditions under which to use the *name and *text macros
instead of *link (internal issue 886).
* Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>>
extension on VK_KHX_device_group_creation to +vk.xml+ and the extension
appendix.
* Change the copyright on Vulkan specification asciidoc *source* files to
CC-BY 4.0, and update the proprietary Khronos copyright applied to the
generated *output* formats (internal issue 327). This enables broader
re-use and modification of the Vulkan specification sources, while not
affecting the Reciprocal IP License between Vulkan Adopters and Working
Group Members.
New Extensions:
* `VK_NV_fill_rectangle`
* `VK_NV_fragment_coverage_to_color`
2017-06-26 19:32:10 -07:00
|
|
|
[open,refpage='VkPastPresentationTimingGOOGLE',desc='Structure containing timing information about a previously-presented image',type='structs']
|
|
|
|
--
|
2017-03-10 17:39:29 -08:00
|
|
|
|
|
|
|
The sname:VkPastPresentationTimingGOOGLE structure is defined as:
|
|
|
|
|
|
|
|
include::../../api/structs/VkPastPresentationTimingGOOGLE.txt[]
|
|
|
|
|
|
|
|
* pname:presentID is an application-provided value that was given to a
|
|
|
|
previous fname:vkQueuePresentKHR command via
|
|
|
|
sname:VkPresentTimeInfoGOOGLE::pname:presentID (see below).
|
|
|
|
It can: be used to uniquely identify a previous present with the
|
|
|
|
flink:vkQueuePresentKHR command.
|
|
|
|
* pname:desiredPresentTime is an application-provided value that was given
|
|
|
|
to a previous flink:vkQueuePresentKHR command via
|
|
|
|
sname:VkPresentTimeInfoGOOGLE::pname:desiredPresentTime.
|
|
|
|
If non-zero, it was used by the application to indicate that an image
|
|
|
|
not be presented any sooner than pname:desiredPresentTime.
|
|
|
|
* pname:actualPresentTime is the time when the image of the
|
|
|
|
pname:swapchain was actually displayed.
|
|
|
|
* pname:earliestPresentTime is the time when the image of the
|
|
|
|
pname:swapchain could have been displayed.
|
|
|
|
This may: differ from pname:actualPresentTime if the application
|
|
|
|
requested that the image be presented no sooner than
|
|
|
|
sname:VkPresentTimeInfoGOOGLE::pname:desiredPresentTime.
|
|
|
|
* pname:presentMargin is an indication of how early the
|
|
|
|
fname:vkQueuePresentKHR command was processed compared to how soon it
|
|
|
|
needed to be processed, and still be presented at
|
|
|
|
pname:earliestPresentTime.
|
|
|
|
|
|
|
|
The results for a given pname:swapchain and pname:presentID are only
|
|
|
|
returned once from fname:vkGetPastPresentationTimingGOOGLE.
|
|
|
|
|
|
|
|
The application can: use the fname:VkPastPresentationTimingGOOGLE values to
|
|
|
|
occasionally adjust its timing.
|
|
|
|
For example, if pname:actualPresentTime is later than expected (e.g. one
|
|
|
|
pname:refreshDuration late), the application may increase its target IPD to
|
|
|
|
a higher multiple of pname:refreshDuration (e.g. decrease its frame rate
|
|
|
|
from 60Hz to 30Hz).
|
|
|
|
If pname:actualPresentTime and pname:earliestPresentTime are consistently
|
|
|
|
different, and if pname:presentMargin is consistently large enough, the
|
|
|
|
application may decrease its target IPD to a smaller multiple of
|
|
|
|
pname:refreshDuration (e.g. increase its frame rate from 30Hz to 60Hz).
|
|
|
|
If pname:actualPresentTime and pname:earliestPresentTime are same, and if
|
|
|
|
pname:presentMargin is consistently high, the application may delay the
|
|
|
|
start of its input-render-present loop in order to decrease the latency
|
|
|
|
between user input and the corresponding present (always leaving some margin
|
|
|
|
in case a new image takes longer to render than the previous image).
|
|
|
|
An application that desires its target IPD to always be the same as
|
|
|
|
pname:refreshDuration, can also adjust features until
|
|
|
|
pname:actualPresentTime is never late and pname:presentMargin is
|
|
|
|
satisfactory.
|
|
|
|
|
Change log for June 24, 2017 Vulkan 1.0.53 spec update:
* Bump API patch number and header version number to 53 for this update.
Github Issues:
Internal Issues:
* Clarify mappings of coordinates for mutable, compatible image views in
slink:VkImageViewCreateInfo (internal issue 815).
* Make ename:VK_BIND_SFR_BIT require a logical device with multiple
physical devices, so that standard sparse image block dimensions are
only required on systems that support multi-GPU (internal issue 835).
* Convert all files from use of // refBegin .. // refEnd comments to
delimit ref pages, to use of open blocks, and update style guide
accordingly (internal issue 839).
* Add valid usage for slink:VkWriteDescriptorSet when performing updates
to a ename:VK_STORAGE_IMAGE descriptor with layout
ename:VK_IMAGE_LAYOUT_GENERAL.
* Add a hack to the validity generator script to support an odd
interaction between flink:vkCmdFillBuffer and an extension (internal
issue 853).
* Remove redundant text describing slink:VkBufferCreateInfo::pname:usage,
which was already covered by implicit valid usage (internal issue 854).
* Update implicit validity generator script to properly handle the
pname:sType and pname:pNext members of "returnedonly" structures
(internal issue 874).
* Note that slink:VkApplicationInfo::pname:pApplicationName &
slink:VkApplicationInfo::pname:pEngineName are optional, and add missing
implicit valid usage statements for flink:vkDestroyInstance.
* Added missing valid usage for flink:vkCmdWriteTimestamp to require a
timestamp query pool.
* Simplify and/or split "`non-atomic`" valid usage statements.
New Extensions:
* `VK_AMD_gpu_shader_int16`
* `VK_EXT_blend_operation_advanced`
* `VK_EXT_sampler_filter_minmax`
* `VK_NV_framebuffer_mixed_samples`
-----------------------------------------------------
Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release
combines both change sets.
-----------------------------------------------------
Change log for June 13, 2017 Vulkan 1.0.52 spec update:
* Bump API patch number and header version number to 52 for this update.
Github Issues:
Internal Issues:
* Clarify behavior when non-coherent memory has
<<memory-device-unmap-does-not-flush, not been flushed before being
unmapped>> (internal issue 819).
* Fix description of code:WorkgroupSize builtin to note it decorates an
object, not a variable (internal issue 836).
* Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style
equations are rendered properly (internal issue 845).
* Add language to the "`Extension Handles, Objects, Enums, and Typedefs`"
section of the Procedures and Conventions document stating that any new
handle type requires a corresponding entry in the elink:VkObjectType
enumerated type (internal issue 856).
* Update style guide to use slink macro for Vulkan handle type names, and
define narrow conditions under which to use the *name and *text macros
instead of *link (internal issue 886).
* Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>>
extension on VK_KHX_device_group_creation to +vk.xml+ and the extension
appendix.
* Change the copyright on Vulkan specification asciidoc *source* files to
CC-BY 4.0, and update the proprietary Khronos copyright applied to the
generated *output* formats (internal issue 327). This enables broader
re-use and modification of the Vulkan specification sources, while not
affecting the Reciprocal IP License between Vulkan Adopters and Working
Group Members.
New Extensions:
* `VK_NV_fill_rectangle`
* `VK_NV_fragment_coverage_to_color`
2017-06-26 19:32:10 -07:00
|
|
|
--
|
2017-03-10 17:39:29 -08:00
|
|
|
|
|
|
|
The full +VK_GOOGLE_display_timing+ extension semantics are described for
|
|
|
|
swapchains created with ename:VK_PRESENT_MODE_FIFO_KHR.
|
|
|
|
For example, non-zero values of
|
|
|
|
sname:VkPresentTimeGOOGLE::pname:desiredPresentTime must: be honored, and
|
|
|
|
fname:vkGetPastPresentationTimingGOOGLE should: return a
|
|
|
|
sname:VkPastPresentationTimingGOOGLE structure with valid values for all
|
|
|
|
images presented with fname:vkQueuePresentKHR.
|
|
|
|
The semantics for other present modes are as follows:
|
|
|
|
|
|
|
|
* ename:VK_PRESENT_MODE_IMMEDIATE_KHR.
|
|
|
|
The presentation engine may: ignore non-zero values of
|
|
|
|
sname:VkPresentTimeGOOGLE::pname:desiredPresentTime in favor of
|
|
|
|
presenting immediately.
|
|
|
|
The value of
|
|
|
|
sname:VkPastPresentationTimingGOOGLE::pname:earliestPresentTime must: be
|
|
|
|
the same as
|
|
|
|
sname:VkPastPresentationTimingGOOGLE::pname:actualPresentTime, which
|
|
|
|
should: be when the presentation engine displayed the image.
|
|
|
|
* ename:VK_PRESENT_MODE_MAILBOX_KHR.
|
|
|
|
The intention of using this present mode with this extension is to
|
|
|
|
handle cases where an image is presented late, and the next image is
|
|
|
|
presented soon enough to replace it at the next vertical blanking
|
|
|
|
period.
|
|
|
|
For images that are displayed to the user, the value of
|
|
|
|
sname:VkPastPresentationTimingGOOGLE::pname:actualPresentTime must: be
|
|
|
|
when the image was displayed.
|
|
|
|
For images that are not displayed to the user,
|
|
|
|
fname:vkGetPastPresentationTimingGOOGLE may: not return a
|
|
|
|
sname:VkPastPresentationTimingGOOGLE structure, or it may: return return
|
|
|
|
a sname:VkPastPresentationTimingGOOGLE structure with the value of zero
|
|
|
|
for both sname:VkPastPresentationTimingGOOGLE::pname:actualPresentTime
|
|
|
|
and sname:VkPastPresentationTimingGOOGLE::pname:earliestPresentTime.
|
|
|
|
It is possible that an application can: submit images with
|
|
|
|
sname:VkPresentTimeGOOGLE::pname:desiredPresentTime values such that new
|
|
|
|
images may: not be displayed.
|
|
|
|
For example, if sname:VkPresentTimeGOOGLE::pname:desiredPresentTime is
|
|
|
|
far enough in the future that an image is not presented before
|
|
|
|
fname:vkQueuePresentKHR is called to present another image, the first
|
|
|
|
image will not be displayed to the user.
|
|
|
|
If the application continues to do that, the presentation may: not
|
|
|
|
display new images.
|
|
|
|
* ename:VK_PRESENT_MODE_FIFO_RELAXED_KHR.
|
|
|
|
For images that are presented in time to be displayed at the next
|
|
|
|
vertical blanking period, the semantics are identical as for
|
|
|
|
ename:VK_PRESENT_MODE_FIFO_RELAXED_KHR.
|
|
|
|
For images that are presented late, and are displayed after the start of
|
|
|
|
the vertical blanking period (i.e. with tearing), the values of
|
|
|
|
sname:VkPastPresentationTimingGOOGLE may: be treated as if the image was
|
|
|
|
displayed at the start of the vertical blanking period, or may: be
|
|
|
|
treated the same as for ename:VK_PRESENT_MODE_IMMEDIATE_KHR.
|