Jon Leech 85184f305a Change log for August 26, 2016 Vulkan 1.0.25 spec update:
* Bump API patch number and header version number to 25 for this update.
  * Structurally change the specification so that multiple extensions are
    included in the +1.0+ git branch, and specifications will include or not
    include those extensions at build time based on options passed to the
    Makefile. See +doc/specs/vulkan/README.html+ and the ``Layers and
    Extensions'' section of the ``Vulkan Documentation and Extensions''
    document for more information on this change.
  * Register and publish new extensions in the single-branch form:
  ** +VK_NV_external_memory_capabilities+
  ** +VK_NV_external_memory+
  ** +VK_NV_external_memory_win32+
  ** +VK_NV_win32_keyed_mutex+

Github Issues:

  * Clarify description of GetInstanceProcAddr and GetDeviceProcAddr (public
    issue 212).
  * Add SPIR-V <<textures-operation-validation, instruction validation>> for
    single-sampled images (public issue 316).
  * Fix spelling of ``tesselation'' in a few places and note it as an
    exception to the American spelling rules convention (public issue
    327).
  * Fix Makefile to create output directory for ``styleguide''
    target (public issue 329).
  * Fix numerous minor issues with incorrectly tags on enumerant names and
    table titles (public issue 330).
  * Generate specversion.txt date in UTC time and RFC 2822 format
    (public issue 335).
  * Convert link to the SPIR-V Specification for
    flink:VkShaderModuleCreateInfo into an internal link to the normative
    reference (public issue 336).
  * Add ename:VK_ERROR_OUT_OF_MEMORY error code to
    flink:vkCreateDebugReportCallbackEXT (public issue 337).

Internal Issues:

  * Update style guide regarding use of code:NULL and dname:VK_NULL_HANDLE
    (internal issue 393).
  * Change the definition of latexmath:[$q$] in the
    <<textures-image-level-selection,texture image level selection>> section
    to be the index of the maximum defined level for the view, not the
    number of levels in the view (internal issue 406).
  * Allow developers to override dname:VK_DEFINE_NON_DISPATCHABLE_HANDLE
    with their own binary-compatible definition (internal issue 439).
  * Fix +vk_platform.h+ conditional logic causing compile failure with some
    Android compilers (internal issue 441).
  * Implement the single-branch model as described above (internal issue
    461).

Other Issues:
2016-08-28 03:47:19 -07:00

502 lines
22 KiB
Plaintext

[[wsi]]
= Window System Integration (WSI)
This chapter discusses the window system integration (WSI) between the
Vulkan API and the various forms of displaying the results of rendering
to a user. Since the Vulkan API can: be used without displaying results,
WSI is provided through the use of optional Vulkan extensions. This
chapter provides an overview of WSI. See the appendix for additional details
of each WSI extension, including which extensions must: be enabled in order
to use each of the functions described in this chapter.
== WSI Platform
A platform is an abstraction for a window system, OS, etc. Some examples
include MS Windows, Android, and Wayland. The Vulkan API may: be
integrated in a unique manner for each platform.
The Vulkan API does not define any type of platform object.
Platform-specific WSI extensions are defined, which contain
platform-specific functions for using WSI. Use of these extensions is
guarded by preprocessor symbols.
ifdef::VK_KHR_android_surface[]
include::../VK_KHR_android_surface/platformCpp_android.txt[]
endif::VK_KHR_android_surface[]
ifdef::VK_KHR_mir_surface[]
include::../VK_KHR_mir_surface/platformCpp_mir.txt[]
endif::VK_KHR_mir_surface[]
ifdef::VK_KHR_wayland_surface[]
include::../VK_KHR_wayland_surface/platformCpp_wayland.txt[]
endif::VK_KHR_wayland_surface[]
ifdef::VK_KHR_win32_surface[]
include::../VK_KHR_win32_surface/platformCpp_win32.txt[]
endif::VK_KHR_win32_surface[]
ifdef::VK_KHR_xcb_surface[]
include::../VK_KHR_xcb_surface/platformCpp_xcb.txt[]
endif::VK_KHR_xcb_surface[]
ifdef::VK_KHR_xlib_surface[]
include::../VK_KHR_xlib_surface/platformCpp_xlib.txt[]
endif::VK_KHR_xlib_surface[]
In order for an application to be compiled to use WSI with a given platform,
it can: #define the appropriate preprocessor symbol prior including the
"vulkan.h" header file. Each platform-specific extension is an instance
extension; and the application must: enable instance extensions with
fname:vkCreateInstance before using them.
== WSI Surface
A sname:VkSurfaceKHR object abstracts a native platform surface or window
object for use with Vulkan. The VK_KHR_surface extension declares the
sname:VkSurfaceKHR object, and provides a function for destroying
sname:VkSurfaceKHR objects. Separate platform-specific extensions each
provide a function for creating a sname:VkSurfaceKHR object for the
respective platform. From the application's perspective this is an opaque
handle, just like the handles of other Vulkan objects.
ifdef::implementation-guide[]
[NOTE]
.Note
====
On certain platforms, the Vulkan loader and ICDs
may: have conventions that treat the handle as a pointer to a struct that
contains the platform-specific information about the surface. This will
be described in the documentation for the loader-ICD interface, and in the
"vk_icd.h" header file of the LoaderAndTools source-code repository.
This does not affect the loader-layer interface; layers may: wrap
sname:VkSurfaceKHR objects.
====
ifdef::editing-notes[]
[NOTE]
.editing-note
====
TODO: Consider replacing the above note editing note with a pointer to the
loader spec when it exists. However, the information is not relevant to
users of the API nor does it affect conformance of a Vulkan implementation
to this spec.
====
endif::editing-notes[]
endif::implementation-guide[]
ifdef::VK_KHR_android_surface[]
include::../VK_KHR_android_surface/platformCreateSurface_android.txt[]
endif::VK_KHR_android_surface[]
ifdef::VK_KHR_mir_surface[]
include::../VK_KHR_mir_surface/platformCreateSurface_mir.txt[]
endif::VK_KHR_mir_surface[]
ifdef::VK_KHR_wayland_surface[]
include::../VK_KHR_wayland_surface/platformCreateSurface_wayland.txt[]
endif::VK_KHR_wayland_surface[]
ifdef::VK_KHR_win32_surface[]
include::../VK_KHR_win32_surface/platformCreateSurface_win32.txt[]
endif::VK_KHR_win32_surface[]
ifdef::VK_KHR_xcb_surface[]
include::../VK_KHR_xcb_surface/platformCreateSurface_xcb.txt[]
endif::VK_KHR_xcb_surface[]
ifdef::VK_KHR_xlib_surface[]
include::../VK_KHR_xlib_surface/platformCreateSurface_xlib.txt[]
endif::VK_KHR_xlib_surface[]
=== Platform-Independent Information
Once created, sname:VkSurfaceKHR objects can: be used in this and other
extensions, in particular the VK_KHR_swapchain extension.
Several WSI functions return ename:VK_ERROR_SURFACE_LOST_KHR if the surface
becomes no longer available. After such an error, the surface (and any child
swapchain, if one exists) should: be destroyed, as there is no way to
restore them to a not-lost state. Applications may: attempt to create a new
sname:VkSurfaceKHR using the same native platform window object, but whether
such re-creation will succeed is platform-dependent and may: depend on the
reason the surface became unavailable. A lost surface does not otherwise
cause devices to be <<devsandqueues-lost-device,lost>>.
// refBegin vkDestroySurfaceKHR - Destroy a VkSurfaceKHR object
To destroy a sname:VkSurfaceKHR object, call:
include::../../api/protos/vkDestroySurfaceKHR.txt[]
* pname:instance is the instance used to create the surface.
* pname:surface is the surface to destroy.
* pname:pAllocator is the allocator used for host memory allocated for the
surface object when there is no more specific allocator available (see
<<memory-allocation,Memory Allocation>>).
Destroying a sname:VkSurfaceKHR merely severs the connection between
Vulkan and the native surface, and doesn't imply destroying the native
surface, closing a window, or similar behavior.
include::../../validity/protos/vkDestroySurfaceKHR.txt[]
ifdef::VK_KHR_display[]
include::../VK_KHR_display/display.txt[]
endif::VK_KHR_display[]
== Querying for WSI Support
Not all physical devices will include WSI support. Within a physical device,
not all queue families will support presentation. WSI support and
compatibility can: be determined in a platform-neutral manner (which
determines support for presentation to a particular surface object) and
additionally may: be determined in platform-specific manners (which
determine support for presentation on the specified physical device but
don't guarantee support for presentation to a particular surface object).
// refBegin vkGetPhysicalDeviceSurfaceSupportKHR - Query if presentation is supported
To determine whether a queue family of a physical device supports
presentation to a given surface, call:
include::../../api/protos/vkGetPhysicalDeviceSurfaceSupportKHR.txt[]
* pname:physicalDevice is the physical device.
* pname:queueFamilyIndex is the queue family.
* pname:surface is the surface.
* pname:pSupported is a pointer to a basetype:VkBool32, which is set to
ename:VK_TRUE to indicate support, and ename:VK_FALSE otherwise.
include::../../validity/protos/vkGetPhysicalDeviceSurfaceSupportKHR.txt[]
ifdef::VK_KHR_android_surface[]
include::../VK_KHR_android_surface/platformQuerySupport_android.txt[]
endif::VK_KHR_android_surface[]
ifdef::VK_KHR_mir_surface[]
include::../VK_KHR_mir_surface/platformQuerySupport_mir.txt[]
endif::VK_KHR_mir_surface[]
ifdef::VK_KHR_wayland_surface[]
include::../VK_KHR_wayland_surface/platformQuerySupport_wayland.txt[]
endif::VK_KHR_wayland_surface[]
ifdef::VK_KHR_win32_surface[]
include::../VK_KHR_win32_surface/platformQuerySupport_win32.txt[]
endif::VK_KHR_win32_surface[]
ifdef::VK_KHR_xcb_surface[]
include::../VK_KHR_xcb_surface/platformQuerySupport_xcb.txt[]
endif::VK_KHR_xcb_surface[]
ifdef::VK_KHR_xlib_surface[]
include::../VK_KHR_xlib_surface/platformQuerySupport_xlib.txt[]
endif::VK_KHR_xlib_surface[]
== Surface Queries
// refBegin vkGetPhysicalDeviceSurfaceCapabilitiesKHR - Query surface capabilities
To query the basic capabilities of a surface, needed in order to create a
swapchain, call:
include::../../api/protos/vkGetPhysicalDeviceSurfaceCapabilitiesKHR.txt[]
* pname:physicalDevice is the physical device that will be associated with
the swapchain to be created, as described for
flink:vkCreateSwapchainKHR.
* pname:surface is the surface that will be associated with the swapchain.
* pname:pSurfaceCapabilities is a pointer to an instance of the
slink:VkSurfaceCapabilitiesKHR structure in which the capabilities are
returned.
include::../../validity/protos/vkGetPhysicalDeviceSurfaceCapabilitiesKHR.txt[]
// refBegin VkSurfaceCapabilitiesKHR - Structure describing capabilities of a surface
The sname:VkSurfaceCapabilitiesKHR structure is defined as:
include::../../api/structs/VkSurfaceCapabilitiesKHR.txt[]
* pname:minImageCount is the minimum number of images the specified device
supports for a swapchain created for the surface.
* pname:maxImageCount is the maximum number of images the specified device
supports for a swapchain created for the surface. A value of `0` means
that there is no limit on the number of images, though there may: be
limits related to the total amount of memory used by swapchain images.
* pname:currentExtent is the current width and height of the surface, or
the special value latexmath:[$(0xFFFFFFFF, 0xFFFFFFFF)$] indicating that
the surface size will be determined by the extent of a swapchain
targeting the surface.
* pname:minImageExtent contains the smallest valid swapchain extent for
the surface on the specified device.
* pname:maxImageExtent contains the largest valid swapchain extent for
the surface on the specified device.
* pname:maxImageArrayLayers is the maximum number of layers swapchain
images can: have for a swapchain created for this device and surface.
* pname:supportedTransforms is a bitfield of
elink:VkSurfaceTransformFlagBitsKHR, describing the presentation
transforms supported for the surface on the specified device.
* pname:currentTransform is a bitfield of
elink:VkSurfaceTransformFlagBitsKHR, describing the surface's current
transform relative to the presentation engine's natural orientation.
* pname:supportedCompositeAlpha is a bitfield of
elink:VkCompositeAlphaFlagBitsKHR, representing the
alpha compositing modes supported by the presentation engine for the
surface on the specified device. Opaque composition can: be achieved in
any alpha compositing mode by either using a swapchain image format that
has no alpha component, or by ensuring that all pixels in the swapchain
images have an alpha value of 1.0.
* pname:supportedUsageFlags is a bitfield of elink:VkImageUsageFlagBits
representing the ways the application can: use the presentable images of
a swapchain created for the surface on the specified device.
ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT must: be included in the set
but implementations may: support additional usages.
include::../../validity/structs/VkSurfaceCapabilitiesKHR.txt[]
// refBegin VkSurfaceTransformFlagBitsKHR - presentation transforms supported on a device
The pname:supportedTransforms and pname:currentTransform members are of type
ename:VkSurfaceTransformFlagBitsKHR, which contains the following values:
include::../../api/enums/VkSurfaceTransformFlagBitsKHR.txt[]
These values are described as follows:
* ename:VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR: The image content is
presented without being transformed.
* ename:VK_SURFACE_TRANSFORM_ROTATE_90_BIT_KHR: The image content is
rotated 90 degrees clockwise.
* ename:VK_SURFACE_TRANSFORM_ROTATE_180_BIT_KHR: The image content is
rotated 180 degrees clockwise.
* ename:VK_SURFACE_TRANSFORM_ROTATE_270_BIT_KHR: The image content is
rotated 270 degrees clockwise.
* ename:VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_BIT_KHR: The image
content is mirrored horizontally.
* ename:VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_90_BIT_KHR: The
image content is mirrored horizontally, then rotated 90 degrees
clockwise.
* ename:VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_180_BIT_KHR: The
image content is mirrored horizontally, then rotated 180 degrees
clockwise.
* ename:VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_270_BIT_KHR: The
image content is mirrored horizontally, then rotated 270 degrees
clockwise.
* ename:VK_SURFACE_TRANSFORM_INHERIT_BIT_KHR: The presentation transform
is not specified, and is instead determined by platform-specific
considerations and mechanisms outside Vulkan.
// refEnd VkSurfaceTransformFlagBitsKHR
// refBegin VkCompositeAlphaFlagBitsKHR - alpha compositing modes supported on a device
The pname:supportedCompositeAlpha member is of type
ename:VkCompositeAlphaFlagBitsKHR, which contains the following values:
include::../../api/enums/VkCompositeAlphaFlagBitsKHR.txt[]
These values are described as follows:
* ename:VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR: The alpha channel, if it
exists, of the images is ignored in the compositing process. Instead,
the image is treated as if it has a constant alpha of 1.0.
* ename:VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR: The alpha channel, if
it exists, of the images is respected in the compositing process. The
non-alpha channels of the image are expected to already be multiplied
by the alpha channel by the application.
* ename:VK_COMPOSITE_ALPHA_POST_MULTIPLIED_BIT_KHR: The alpha channel,
if it exists, of the images is respected in the compositing process.
The non-alpha channels of the image are not expected to already be
multiplied by the alpha channel by the application; instead, the
compositor will multiply the non-alpha channels of the image by the
alpha channel during compositing.
* ename:VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR: The way in which the
presentation engine treats the alpha channel in the images is unknown
to the Vulkan API. Instead, the application is responsible for setting
the composite alpha blending mode using native window system commands.
If the application does not set the blending mode using native window
system commands, then a platform-specific default will be used.
// refEnd VkCompositeAlphaFlagBitsKHR
// refBegin vkGetPhysicalDeviceSurfaceFormatsKHR - Query color formats supported by surface
To query the supported swapchain format-colorspace pairs for a surface,
call:
include::../../api/protos/vkGetPhysicalDeviceSurfaceFormatsKHR.txt[]
* pname:physicalDevice is the physical device that will be associated with
the swapchain to be created, as described for
flink:vkCreateSwapchainKHR.
* pname:surface is the surface that will be associated with the swapchain.
* pname:pSurfaceFormatCount is a pointer to an integer related to the
number of format pairs available or queried, as described below.
* pname:pSurfaceFormats is either `NULL` or a pointer to an array
of sname:VkSurfaceFormatKHR structures.
If pname:pSurfaceFormats is `NULL`, then the number of format pairs
supported for the given pname:surface is returned in
pname:pSurfaceFormatCount. Otherwise, pname:pSurfaceFormatCount must: point
to a variable set by the user to the number of elements in the
pname:pSurfaceFormats array, and on return the variable is overwritten with
the number of structures actually written to pname:pSurfaceFormats. If the
value of pname:pSurfaceFormatCount is less than the number of format pairs
supported, at most pname:pSurfaceFormatCount structures will be written.
If pname:pSurfaceFormatCount is smaller than the number of format pairs
supported for the given pname:surface, ename:VK_INCOMPLETE will be returned
instead of ename:VK_SUCCESS to indicate that not all the available values
were returned.
include::../../validity/protos/vkGetPhysicalDeviceSurfaceFormatsKHR.txt[]
// refBegin VkSurfaceFormatKHR - Structure describing a supported swapchain format-colorspace pair
The sname:VkSurfaceFormatKHR structure is defined as:
include::../../api/structs/VkSurfaceFormatKHR.txt[]
* pname:format is a ename:VkFormat that is compatible with the specified
surface.
* pname:colorSpace is a presentation ename:VkColorSpaceKHR that is
compatible with the surface.
include::../../validity/structs/VkSurfaceFormatKHR.txt[]
While the pname:format of a presentable image refers to the
encoding of each pixel, the pname:colorspace
determines how the the presentation engine interprets the pixel values. A
colorspace in this document refers to a specific combination of color model
(i.e. RGB, YUV, HSL etc.), the actual colorspace (defined by the
chromaticities of its primaries and a whitepoint in CIE Lab), and a transfer
function that is applied before storing or transmitting color data in the
given colorspace.
// refBegin VkColorSpaceKHR - supported colorspace of the presentation engine
The ename:VkColorSpaceKHR is defined as follows:
include::../../api/enums/VkColorSpaceKHR.txt[]
* ename:VK_COLOR_SPACE_SRGB_NONLINEAR_KHR: The presentation engine supports
the sRGB colorspace.
[NOTE]
.Note
====
If pname:pSurfaceFormats includes just one entry, whose value for
pname:format is ename:VK_FORMAT_UNDEFINED, pname:surface has no
preferred format. In this case, the application can use any valid
ename:VkFormat value.
====
[NOTE]
.Note
====
In the initial release of the VK_KHR_surface and VK_KHR_swapchain
extensions, the token ename:VK_COLORSPACE_SRGB_NONLINEAR_KHR was used.
Starting in the May 13, 2016 updates to the extension branches, matching
release 1.0.13 of the core API specification,
ename:VK_COLOR_SPACE_SRGB_NONLINEAR_KHR is used instead for consistency with
Vulkan naming rules. The older enum is still available for backwards
compatibility.
====
// refEnd VkColorSpaceKHR
// refBegin vkGetPhysicalDeviceSurfacePresentModesKHR - Query supported presentation modes
To query the supported presentation modes for a surface, call:
include::../../api/protos/vkGetPhysicalDeviceSurfacePresentModesKHR.txt[]
* pname:physicalDevice is the physical device that will be associated with
the swapchain to be created, as described for
flink:vkCreateSwapchainKHR.
* pname:surface is the surface that will be associated with the swapchain.
* pname:pPresentModeCount is a pointer to an integer related to the
number of presentation modes available or queried, as described below.
* pname:pPresentModes is either `NULL` or a pointer to an array
of elink:VkPresentModeKHR structures.
If pname:pPresentModes is `NULL`, then the number of presentation modes
supported for the given pname:surface is returned in
pname:pPresentModeCount. Otherwise, pname:pPresentModeCount must: point to a
variable set by the user to the number of elements in the
pname:pPresentModes array, and on return the variable is overwritten with
the number of values actually written to pname:pPresentModes. If the
value of pname:pPresentModeCount is less than the number of presentation
modes supported, at most pname:pPresentModeCount values will be written.
If pname:pPresentModeCount is smaller than the number of presentation modes
supported for the given pname:surface, ename:VK_INCOMPLETE will be returned
instead of ename:VK_SUCCESS to indicate that not all the available values
were returned.
include::../../validity/protos/vkGetPhysicalDeviceSurfacePresentModesKHR.txt[]
// refBegin VkPresentModeKHR - presentation mode supported for a surface
The definition of ename:VkPresentModeKHR is:
include::../../api/enums/VkPresentModeKHR.txt[]
* ename:VK_PRESENT_MODE_IMMEDIATE_KHR: The presentation engine does not
wait for a vertical blanking period to update the current image, meaning
this mode may: result in visible tearing. No internal queuing of
presentation requests is needed, as the requests are applied
immediately.
* ename:VK_PRESENT_MODE_MAILBOX_KHR: The presentation engine waits for the
next vertical blanking period to update the current image. Tearing
cannot: be observed. An internal single-entry queue is used to hold
pending presentation requests. If the queue is full when a new
presentation request is received, the new request replaces the existing
entry, and any images associated with the prior entry become available
for re-use by the application. One request is removed from the queue and
processed during each vertical blanking period in which the queue is
non-empty.
* ename:VK_PRESENT_MODE_FIFO_KHR: The presentation engine waits for the
next vertical blanking period to update the current image. Tearing
cannot: be observed. An internal queue is used to hold pending
presentation requests. New requests are appended to the end of the queue,
and one request is removed from the beginning of the queue and processed
during each vertical blanking period in which the queue is non-empty.
This is the only value of pname:presentMode that is required: to be
supported.
* ename:VK_PRESENT_MODE_FIFO_RELAXED_KHR: The presentation engine
generally waits
for the next vertical blanking period to update the current image. If a
vertical blanking period has already passed since the last update of the
current image then the presentation engine does not wait for another
vertical blanking period for the update, meaning this mode may: result
in visible tearing in this case. This mode is useful for reducing visual
stutter with an application that will mostly present a new image before
the next vertical blanking period, but may occassionally be late, and
present a new image just after the the next vertical blanking period.
An internal queue is used to hold pending presentation requests. New
requests are appended to the end of the queue, and one request is
removed from the beginning of the queue and processed during or after
each vertical blanking period in which the queue is non-empty.
[NOTE]
.Note
====
For reference, the mode indicated by ename:VK_PRESENT_MODE_FIFO_KHR is
equivalent to the behavior of {wgl|glX|egl}SwapBuffers with a swap interval
of 1, while the mode indicated by ename:VK_PRESENT_MODE_FIFO_RELAXED_KHR is
equivalent to the behavior of {wgl|glX}SwapBuffers with a swap interval
of -1 (from the {WGL|GLX}_EXT_swap_control_tear extensions).
====
// refEnd VkPresentModeKHR
ifdef::VK_KHR_swapchain[]
include::../VK_KHR_swapchain/wsi.txt[]
endif::VK_KHR_swapchain[]