// Copyright 2016-2024 The Khronos Group Inc.
//
// SPDX-License-Identifier: CC-BY-4.0

include::{generated}/meta/{refprefix}VK_KHR_multiview.adoc[]

=== Other Extension Metadata

*Last Modified Date*::
    2016-10-28
*IP Status*::
    No known IP claims.
*Interactions and External Dependencies*::
  - This extension provides API support for
    {GLSLregistry}/ext/GL_EXT_multiview.txt[`GL_EXT_multiview`]
*Contributors*::
  - Jeff Bolz, NVIDIA

=== Description

This extension has the same goal as the OpenGL ES `GL_OVR_multiview`
extension.
Multiview is a rendering technique originally designed for VR where it is
more efficient to record a single set of commands to be executed with
slightly different behavior for each "`view`".

It includes a concise way to declare a render pass with multiple views, and
gives implementations freedom to render the views in the most efficient way
possible.
This is done with a multiview configuration specified during <<renderpass,
render pass>> creation with the slink:VkRenderPassMultiviewCreateInfo passed
into slink:VkRenderPassCreateInfo::pname:pNext.

This extension enables the use of the
{spirv}/KHR/SPV_KHR_multiview.html[`SPV_KHR_multiview`] shader extension,
which adds a new `ViewIndex` built-in type that allows shaders to control
what to do for each view.
If using GLSL there is also the
{GLSLregistry}/ext/GL_EXT_multiview.txt[`GL_EXT_multiview`] extension that
introduces a `highp int gl_ViewIndex;` built-in variable for vertex,
tessellation, geometry, and fragment shaders.

=== Promotion to Vulkan 1.1

All functionality in this extension is included in core Vulkan 1.1, with the
KHR suffix omitted.
The original type, enum and command names are still available as aliases of
the core functionality.

include::{generated}/interfaces/VK_KHR_multiview.adoc[]

=== New Built-In Variables

  * <<interfaces-builtin-variables-viewindex,code:ViewIndex>>

=== New SPIR-V Capabilities

  * <<spirvenv-capabilities-table-MultiView, code:MultiView>>

ifdef::isrefpage[]

=== Additional Resources

  * https://devblogs.nvidia.com/turing-multi-view-rendering-vrworks['NVIDIA
    blog post']
  * https://community.arm.com/developer/tools-software/graphics/b/blog/posts/optimizing-virtual-reality-understanding-multiview['ARM
    blog post']

endif::isrefpage[]

=== Version History

  * Revision 1, 2016-10-28 (Jeff Bolz)
  ** Internal revisions