• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1// Copyright 2014-2021 The Khronos Group, Inc.
2//
3// SPDX-License-Identifier: CC-BY-4.0
4
5include::{generated}/meta/{refprefix}VK_KHR_shared_presentable_image.txt[]
6
7=== Other Extension Metadata
8
9*Last Modified Date*::
10    2017-03-20
11*IP Status*::
12    No known IP claims.
13*Contributors*::
14  - Alon Or-bach, Samsung Electronics
15  - Ian Elliott, Google
16  - Jesse Hall, Google
17  - Pablo Ceballos, Google
18  - Chris Forbes, Google
19  - Jeff Juliano, NVIDIA
20  - James Jones, NVIDIA
21  - Daniel Rakos, AMD
22  - Tobias Hector, Imagination Technologies
23  - Graham Connor, Imagination Technologies
24  - Michael Worcester, Imagination Technologies
25  - Cass Everitt, Oculus
26  - Johannes Van Waveren, Oculus
27
28=== Description
29
30This extension extends `apiext:VK_KHR_swapchain` to enable creation of a
31shared presentable image.
32This allows the application to use the image while the presention engine is
33accessing it, in order to reduce the latency between rendering and
34presentation.
35
36include::{generated}/interfaces/VK_KHR_shared_presentable_image.txt[]
37
38=== Issues
39
401) Should we allow a Vulkan WSI swapchain to toggle between normal usage and
41shared presentation usage?
42
43*RESOLVED*: No.
44WSI swapchains are typically recreated with new properties instead of having
45their properties changed.
46This can also save resources, assuming that fewer images are needed for
47shared presentation, and assuming that most VR applications do not need to
48switch between normal and shared usage.
49
502) Should we have a query for determining how the presentation engine
51refresh is triggered?
52
53*RESOLVED*: Yes.
54This is done via which presentation modes a surface supports.
55
563) Should the object representing a shared presentable image be an extension
57of a slink:VkSwapchainKHR or a separate object?
58
59*RESOLVED*: Extension of a swapchain due to overlap in creation properties
60and to allow common functionality between shared and normal presentable
61images and swapchains.
62
634) What should we call the extension and the new structures it creates?
64
65*RESOLVED*: Shared presentable image / shared present.
66
675) Should the pname:minImageCount and pname:presentMode values of the
68slink:VkSwapchainCreateInfoKHR be ignored, or required to be compatible
69values?
70
71*RESOLVED*: pname:minImageCount must be set to 1, and pname:presentMode
72should be set to either ename:VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR or
73ename:VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR.
74
756) What should the layout of the shared presentable image be?
76
77*RESOLVED*: After acquiring the shared presentable image, the application
78must transition it to the ename:VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR layout
79prior to it being used.
80After this initial transition, any image usage that was requested during
81swapchain creation can: be performed on the image without layout transitions
82being performed.
83
847) Do we need a new API for the trigger to refresh new content?
85
86*RESOLVED*: flink:vkQueuePresentKHR to act as API to trigger a refresh, as
87will allow combination with other compatible extensions to
88flink:vkQueuePresentKHR.
89
908) How should an application detect a ename:VK_ERROR_OUT_OF_DATE_KHR error
91on a swapchain using the ename:VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR
92present mode?
93
94*RESOLVED*: Introduce flink:vkGetSwapchainStatusKHR to allow applications to
95query the status of a swapchain using a shared presentation mode.
96
979) What should subsequent calls to flink:vkQueuePresentKHR for
98ename:VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR swapchains be defined to
99do?
100
101*RESOLVED*: State that implementations may use it as a hint for updated
102content.
103
10410) Can the ownership of a shared presentable image be transferred to a
105different queue?
106
107*RESOLVED*: No.
108It is not possible to transfer ownership of a shared presentable image
109obtained from a swapchain created using ename:VK_SHARING_MODE_EXCLUSIVE
110after it has been presented.
111
11211) How should flink:vkQueueSubmit behave if a command buffer uses an image
113from a ename:VK_ERROR_OUT_OF_DATE_KHR swapchain?
114
115*RESOLVED*: flink:vkQueueSubmit is expected to return the
116ename:VK_ERROR_DEVICE_LOST error.
117
11812) Can Vulkan provide any guarantee on the order of rendering, to enable
119beam chasing?
120
121*RESOLVED*: This could be achieved via use of render passes to ensure strip
122rendering.
123
124
125=== Version History
126 * Revision 1, 2017-03-20 (Alon Or-bach)
127   - Internal revisions
128