1// Copyright 2016-2023 The Khronos Group Inc. 2// 3// SPDX-License-Identifier: CC-BY-4.0 4 5include::{generated}/meta/{refprefix}VK_KHR_multiview.adoc[] 6 7=== Other Extension Metadata 8 9*Last Modified Date*:: 10 2016-10-28 11*IP Status*:: 12 No known IP claims. 13*Interactions and External Dependencies*:: 14 - Promoted to Vulkan 1.1 Core 15 - This extension requires 16 {spirv}/KHR/SPV_KHR_multiview.html[`SPV_KHR_multiview`] 17 - This extension provides API support for 18 {GLSLregistry}/ext/GL_EXT_multiview.txt[`GL_EXT_multiview`] 19*Contributors*:: 20 - Jeff Bolz, NVIDIA 21 22=== Description 23 24This extension has the same goal as the OpenGL ES `GL_OVR_multiview` 25extension. 26Multiview is a rendering technique originally designed for VR where it is 27more efficient to record a single set of commands to be executed with 28slightly different behavior for each "`view`". 29 30It includes a concise way to declare a render pass with multiple views, and 31gives implementations freedom to render the views in the most efficient way 32possible. 33This is done with a multiview configuration specified during <<renderpass, 34render pass>> creation with the slink:VkRenderPassMultiviewCreateInfo passed 35into slink:VkRenderPassCreateInfo::pname:pNext. 36 37This extension enables the use of the 38{spirv}/KHR/SPV_KHR_multiview.html[`SPV_KHR_multiview`] shader extension, 39which adds a new `ViewIndex` built-in type that allows shaders to control 40what to do for each view. 41If using GLSL there is also the 42{GLSLregistry}/ext/GL_EXT_multiview.txt[`GL_EXT_multiview`] extension that 43introduces a `highp int gl_ViewIndex;` built-in variable for vertex, 44tessellation, geometry, and fragment shaders. 45 46=== Promotion to Vulkan 1.1 47 48All functionality in this extension is included in core Vulkan 1.1, with the 49KHR suffix omitted. 50The original type, enum and command names are still available as aliases of 51the core functionality. 52 53include::{generated}/interfaces/VK_KHR_multiview.adoc[] 54 55=== New Built-In Variables 56 57 * <<interfaces-builtin-variables-viewindex,code:ViewIndex>> 58 59=== New SPIR-V Capabilities 60 61 * <<spirvenv-capabilities-table-MultiView, code:MultiView>> 62 63ifdef::isrefpage[] 64 65=== Additional Resources 66 67 * https://devblogs.nvidia.com/turing-multi-view-rendering-vrworks['NVIDIA 68 blog post'] 69 * https://community.arm.com/developer/tools-software/graphics/b/blog/posts/optimizing-virtual-reality-understanding-multiview['ARM 70 blog post'] 71 72endif::isrefpage[] 73 74=== Version History 75 76 * Revision 1, 2016-10-28 (Jeff Bolz) 77 ** Internal revisions 78 79