Change log for April 22, 2016 Vulkan 1.0.11 spec update:

* Bump API patch number and header version number to 11 for this
    update.

Github Issues:

  * Clarify the WSI extension language by switching from the fuzzier
    "ownership" language to more-consistent "acquire" language (public
    issue 117).
  * Clarify that memory barriers apply to all commands in the dependency
    chains in the flink:vkGetRenderAreaGranularity command and the
    <<synchronization-execution-and-memory-dependencies,Execution And
    Memory Dependencies>> section (public issue 132).
  * Clarify that a queue family is a set of queues in the
    <<fundamentals-execmodel,Execution Model>> section (public issue
    166).
  * Removed requirement from valid usage language that
    VkPresentInfoKHR::waitSemaphoreCount must be greater than 0 (public
    issue 171).
  * Fix broken internal links, describe structures consistently, use
    consistent style for SPIR-V codewords, and tag normative terms that
    were missing asciidoc tags (public issue 183 and ancillary
    markup/normative language fixes).
  * Fix typos for slink:VkPhysicalDeviceLimits member names in
    slink:VkImageCreateInfo validity language (public issue 184).

Internal Issues:

  * Document that the requested patch version number specified as part
    of slink:VkApplicationInfo::pname:apiVersion is ignored when
    creating an instance (internal issue 176).
  * Clarify handling of extension structs in the
    <<fundamentals-validusageValid Usage>> section (internal issue 254).
  * Update required slink:VkImageFormatProperties::pname:maxMipLevels to
    be limited to the maximum allowed mipmap pyramid size corresponding
    to the actual maximum supported size for the format (internal issue
    256).
  * Modify the <<features-extentperimagetype,Allowed Extent Values Based
    On Image Type>> section so the allowed maximum extent is the maximum
    image dimension supported for each dimension of the type of texture
    being queried (internal issue 257).
  * Clarify in the <<spirvenv-module-validation,Validation Rules within
    a Module>> section that at least one of the code:LocalSize execution
    mode or code:WorkgroupSize decoration is required for each compute
    shader entry point in a shader module (internal issue 279).
  * Add validity rules for formats in flink:vkCmdClearColorImage and
    flink:vkCmdClearDepthStencilImage (internal issue 283).
  * Clarify that slink:VkImageFormatProperties::pname:maxResourceSize is
    an upper bound, and that it may not be possible to create an image
    anywhere near that size (internal issue 284).

Other Commits:

  * Fix various minor markup errors reported by validation scripts.
  * Change copyright from Khronos Free Use License to Apache 2.0 license
    on relevant script/XML/header files. This does not affect the
    specification source copyright.
This commit is contained in:
Jon Leech 2016-04-21 01:08:38 -07:00
parent 3b32b240f6
commit 6db51e9241
71 changed files with 941 additions and 893 deletions

View File

@ -11,6 +11,7 @@ February 16, 2016 - Vulkan 1.0 initial public release
----------------------------------------------------- -----------------------------------------------------
Change log for February 25, 2015 Vulkan 1.0.4 spec update: Change log for February 25, 2015 Vulkan 1.0.4 spec update:
* Bump API patch number from 3 to 4 for the first public update to the * Bump API patch number from 3 to 4 for the first public update to the
spec. Add patch number to the spec title (this will be done spec. Add patch number to the spec title (this will be done
automatically from XML, later). automatically from XML, later).
@ -67,9 +68,11 @@ Change log for February 25, 2015 Vulkan 1.0.4 spec update:
----------------------------------------------------- -----------------------------------------------------
Change log for March 4, 2016 Vulkan 1.0.5 spec update: Change log for March 4, 2016 Vulkan 1.0.5 spec update:
* Bump API patch number to 5 for this update. * Bump API patch number to 5 for this update.
Github Issues: Github Issues:
* Correctly describe slink:VkPhysicalDeviceProperties pname:deviceName * Correctly describe slink:VkPhysicalDeviceProperties pname:deviceName
member as a string, not a pointer to a string. Also one typo fix for member as a string, not a pointer to a string. Also one typo fix for
"hetereogeneous" (public issue 4). "hetereogeneous" (public issue 4).
@ -130,6 +133,7 @@ Github Issues:
sname:VkVertexInputAttributeDescription numbers (public issue 72). sname:VkVertexInputAttributeDescription numbers (public issue 72).
Internal Issues: Internal Issues:
* Clarify the meaning of * Clarify the meaning of
ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT in ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT in
elink:VkFormatFeatureFlagBits with respect to depth compare elink:VkFormatFeatureFlagBits with respect to depth compare
@ -144,6 +148,7 @@ Internal Issues:
flink:vkEnumeratePhysicalDevices query (internal issue 163). flink:vkEnumeratePhysicalDevices query (internal issue 163).
Other Commits: Other Commits:
* Add the VK_NV_glsl_shader extension definitions to the API. * Add the VK_NV_glsl_shader extension definitions to the API.
* Update GL_KHR_vulkan_glsl with 1) origin_upper_left as default 2) * Update GL_KHR_vulkan_glsl with 1) origin_upper_left as default 2)
specialization array constant semantics. specialization array constant semantics.
@ -161,64 +166,49 @@ Github Issues:
* Define 'invocation group' for compute and graphics shaders. Cleanup * Define 'invocation group' for compute and graphics shaders. Cleanup
definition and use of 'workgroup', and add glossary entries (public definition and use of 'workgroup', and add glossary entries (public
issue 1). issue 1).
* Various minor editorial fixes (public issue 33). * Various minor editorial fixes (public issue 33).
* Clarify locations for block members in the * Clarify locations for block members in the
<<interfaces-iointerfaces-locations,Location Assignment>> <<interfaces-iointerfaces-locations,Location Assignment>>
section (public issue 45). section (public issue 45).
* Editorial fixes for <<commandbuffer-allocation,Command Buffer * Editorial fixes for <<commandbuffer-allocation,Command Buffer
Allocation>> section (public issues 54, 59). Allocation>> section (public issues 54, 59).
* Clarify behavior of depth test in the <<fragops-depth,Depth Test>>
* Clarify behavior of depth test in the <<fragops-depth,Depth section (public issues 80, 81).
Test&gt;&gt; section (public issues 80, 81).
* Remove discussion of return codes from * Remove discussion of return codes from
flink:vkGetPhysicalDeviceSparseImageFormatProperties and flink:vkGetPhysicalDeviceSparseImageFormatProperties and
flink:vkGetImageSparseMemoryRequirements, which don't return values flink:vkGetImageSparseMemoryRequirements, which don't return values
(public issue 82). (public issue 82).
* Allow flink:vkCmdDrawIndirect and flink:vkCmdDrawIndexedIndirect * Allow flink:vkCmdDrawIndirect and flink:vkCmdDrawIndexedIndirect
pname:drawCount of 0, as well as 1, when the multiDrawIndirect pname:drawCount of 0, as well as 1, when the multiDrawIndirect
feature is not supported (public issue 88). feature is not supported (public issue 88).
* Remove confusing wording in the <<features-limits,Limits>> * Remove confusing wording in the <<features-limits,Limits>>
section describing the slink:VkPhysicalDeviceLimits section describing the slink:VkPhysicalDeviceLimits
pname:minTexelBufferOffsetAlignment, pname:minTexelBufferOffsetAlignment,
pname:minUniformBufferOffsetAlignment, and pname:minUniformBufferOffsetAlignment, and
pname:minStorageBufferOffsetAlignment members as both minimums and pname:minStorageBufferOffsetAlignment members as both minimums and
maximums (public issue 91). maximums (public issue 91).
* Clarified that only the RGB components should be affected in places * Clarified that only the RGB components should be affected in places
where sRGB is referred to in the spec, such as ASTC formats. Minor where sRGB is referred to in the spec, such as ASTC formats. Minor
re-wording to avoid "color space" when actively incorrect, now that re-wording to avoid "color space" when actively incorrect, now that
we refer to the Data Format Spec which actually makes a distinction we refer to the Data Format Spec which actually makes a distinction
between color space and transfer function (public issue 94). between color space and transfer function (public issue 94).
* Treat pname:pPropertyCount == 0 consistently in * Treat pname:pPropertyCount == 0 consistently in
flink:vkEnumerateInstanceLayerProperties and flink:vkEnumerateInstanceLayerProperties and
flink:vkEnumerateDeviceLayerProperties (public issue 99) flink:vkEnumerateDeviceLayerProperties (public issue 99)
* Cleanup minor editorial issues in chapters 14-17 (public issue 100). * Cleanup minor editorial issues in chapters 14-17 (public issue 100).
* Clarify definition of flink:vkEnumerateInstanceExtensionProperties * Clarify definition of flink:vkEnumerateInstanceExtensionProperties
and flink:vkEnumerateDeviceExtensionProperties (public issue 101). and flink:vkEnumerateDeviceExtensionProperties (public issue 101).
* Define the flink:vkEnumerateInstanceExtensionProperties and * Define the flink:vkEnumerateInstanceExtensionProperties and
flink:vkEnumerateDeviceExtensionProperties pname:pLayerName flink:vkEnumerateDeviceExtensionProperties pname:pLayerName
parameter to be a pointer to a null-terminated UTF-8 string (public parameter to be a pointer to a null-terminated UTF-8 string (public
issue 101). issue 101).
* Rearrange "Missing information" references in mandatory format * Rearrange "Missing information" references in mandatory format
tables (public issue 101). tables (public issue 101).
* Clarify that the enumerated extensions returned by * Clarify that the enumerated extensions returned by
flink:vkEnumerateInstanceExtensionProperties and flink:vkEnumerateInstanceExtensionProperties and
flink:vkEnumerateDeviceExtensionProperties will only include flink:vkEnumerateDeviceExtensionProperties will only include
extensions provided by the platform or extensions implemented in extensions provided by the platform or extensions implemented in
implicitly enabled layers (public issue 101). implicitly enabled layers (public issue 101).
* Miscellaneous editorial fixes. Include the Vulkan spec patch number * Miscellaneous editorial fixes. Include the Vulkan spec patch number
in the PDF title. Fix label on <<fig-non-strict-lines,Non in the PDF title. Fix label on <<fig-non-strict-lines,Non
strict lines>> diagram. Use more easily distinguished symbols in strict lines>> diagram. Use more easily distinguished symbols in
@ -231,7 +221,6 @@ Github Issues:
Internal Issues: Internal Issues:
* Fixed excessive spacing in tables in XHTML (internal issue 18). * Fixed excessive spacing in tables in XHTML (internal issue 18).
* Clarify that ename:VK_COMMAND_BUFFER_USAGE_ONE_TIME_SUBMIT_BIT * Clarify that ename:VK_COMMAND_BUFFER_USAGE_ONE_TIME_SUBMIT_BIT
applies to secondary command buffers. Previously spec only referred applies to secondary command buffers. Previously spec only referred
to the members of pname:pCommandBuffers being affected by this bit. to the members of pname:pCommandBuffers being affected by this bit.
@ -240,37 +229,30 @@ Internal Issues:
also applies to any secondary command buffers that are recorded into also applies to any secondary command buffers that are recorded into
the primary command buffers in pname:pCommandBuffers (internal issue the primary command buffers in pname:pCommandBuffers (internal issue
106). 106).
* Clarify that slink:VkDeviceCreateInfo::pname:pEnabledFeatures can be * Clarify that slink:VkDeviceCreateInfo::pname:pEnabledFeatures can be
NULL (internal issue 117). NULL (internal issue 117).
* Remove "the value of" where it is redundant (e.g. speaking of an API * Remove "the value of" where it is redundant (e.g. speaking of an API
parameter, struct member, or SPIR-V variable, but not when speaking parameter, struct member, or SPIR-V variable, but not when speaking
of color components) (internal issue 175). of color components) (internal issue 175).
* Forced patch version to always be 0 in the header. Add a * Forced patch version to always be 0 in the header. Add a
"VK_API_VERSION_<major>_<minor>" macro for people to use to do the "VK_API_VERSION_<major>_<minor>" macro for people to use to do the
right thing. Add a VK_HEADER_VERSION which captures the header right thing. Add a VK_HEADER_VERSION which captures the header
release number independent of the spec patch number (internal issue release number independent of the spec patch number (internal issue
176). 176).
* Correct description of * Correct description of
slink:VkPipelineShaderStageCreateInfo::pname:pName to "a pointer to slink:VkPipelineShaderStageCreateInfo::pname:pName to "a pointer to
a null-terminated UTF-8 string" (internal issue #197). a null-terminated UTF-8 string" (internal issue 197).
Other Commits: Other Commits:
* Updated DataFormat spec reference to the new date for revision 5 of * Updated DataFormat spec reference to the new date for revision 5 of
that spec. that spec.
* Fixed KEEP option (to retain LaTeX intermediate files) in the * Fixed KEEP option (to retain LaTeX intermediate files) in the
Makefile to be included when edited there, as well as set on the Makefile to be included when edited there, as well as set on the
command line. command line.
* Reserve and add "VK_IMG_filter_cubic" to the registry, and implement * Reserve and add "VK_IMG_filter_cubic" to the registry, and implement
script functionality to add and remove validity from existing script functionality to add and remove validity from existing
functions. Includes schema and readme changes. functions. Includes schema and readme changes.
* Update GL_KHR_vulkan_glsl so push_constants do not have descriptor * Update GL_KHR_vulkan_glsl so push_constants do not have descriptor
sets. sets.
@ -285,60 +267,46 @@ Github Issues:
* Fix slink:VkSpecializationMapEntry example to avoid C/C++ strict * Fix slink:VkSpecializationMapEntry example to avoid C/C++ strict
aliasing issues (public issue 14). aliasing issues (public issue 14).
* Clarify the meaning of "matching" in flink:vkCmdBindDescriptorSets * Clarify the meaning of "matching" in flink:vkCmdBindDescriptorSets
validity language (public issue 33). validity language (public issue 33).
* Add stub reference pages so xrefs to not-yet-written pages don't * Add stub reference pages so xrefs to not-yet-written pages don't
generate 404 errors. However, the actual content of these pages generate 404 errors. However, the actual content of these pages
still needs to be filled in as time allows (public issue 44, but still needs to be filled in as time allows (public issue 44, but
does not close that issue out). does not close that issue out).
* Remove incorrect validity statement for * Remove incorrect validity statement for
flink:vkGetImageSparseMemoryRequirements (public issue 85). flink:vkGetImageSparseMemoryRequirements (public issue 85).
* Reword the * Reword the
<<features-limits-bufferImageGranularity,bufferImageGranularity>> <<features-limits-bufferImageGranularity,bufferImageGranularity>>
feature in terms of "aliasing", and clarify that it applies to feature in terms of "aliasing", and clarify that it applies to
bindings in the same memory object (public issue 90). bindings in the same memory object (public issue 90).
* Clarify the relationship of the slink:VkPhysicalDeviceLimits * Clarify the relationship of the slink:VkPhysicalDeviceLimits
pname:maxViewportDimensions and pname:viewportBoundsRange limits pname:maxViewportDimensions and pname:viewportBoundsRange limits
(public issue 92). (public issue 92).
* Specify sparse unbound texture replacement in the * Specify sparse unbound texture replacement in the
<<textures-texel-replacement,Texel Replacement>> section <<textures-texel-replacement,Texel Replacement>> section
independently of robust buffer access language (public issue 100). independently of robust buffer access language (public issue 100).
* Add the <<fundamentals-architecture-model,Architecture Model>> * Add the <<fundamentals-architecture-model,Architecture Model>>
section to explain architecture constraints Vulkan has chosen to section to explain architecture constraints Vulkan has chosen to
accept in order to enable portable and performant code (public issue accept in order to enable portable and performant code (public issue
122). 122).
* State that an object must not be destroyed until *all* (not *any*) * State that an object must not be destroyed until *all* (not *any*)
uses of that object have completed (public issue 123). uses of that object have completed (public issue 123).
* Minor editorial cleanup (public issues 129, 134, 146, 148). * Minor editorial cleanup (public issues 129, 134, 146, 148).
* Add validity language for layer and extension names to * Add validity language for layer and extension names to
slink:VkDeviceCreateInfo matching that used for slink:VkDeviceCreateInfo matching that used for
slink:VkInstanceCreateInfo (public issue 130). slink:VkInstanceCreateInfo (public issue 130).
* Clean up terminology for the case when the bits set in one bitmask * Clean up terminology for the case when the bits set in one bitmask
are a subset of the bits set in another bitmask (public issue 138). are a subset of the bits set in another bitmask (public issue 138).
* Document that input attachments are UniformConstant not Input, in * Document that input attachments are UniformConstant not Input, in
the <<interfaces-inputattachment,Fragment Input Attachment the <<interfaces-inputattachment,Fragment Input Attachment
Interface>> section (public glslang bug 169). Interface>> section (public glslang bug 169).
Internal Issues: Internal Issues:
* Add max enum values to "flag bits" enums (internal issue #136). * Add max enum values to "flag bits" enums (internal issue 136).
* Clarify language around the various uses of the term "block" in the * Clarify language around the various uses of the term "block" in the
<<appendix-compressedtex-bc,Block Compressed Image Formats>> section <<appendix-compressedtex-bc,Block Compressed Image Formats>> section
(internal issue #202). (internal issue 202).
* Removed "expand" dependency from <enums> groups in vk.xml and added * Removed "expand" dependency from <enums> groups in vk.xml and added
auto-generation code in the scripts to infer it instead, to ensure auto-generation code in the scripts to infer it instead, to ensure
consistency. This caused renaming of sname:VkColorSpaceKHR and consistency. This caused renaming of sname:VkColorSpaceKHR and
@ -347,7 +315,6 @@ Internal Issues:
with this change. This change adds ranges to two additional enums with this change. This change adds ranges to two additional enums
that were missing them due to not defining the "expand" attribute that were missing them due to not defining the "expand" attribute
(internal issue 217). (internal issue 217).
* Tweak makefile to generate ref page nroff (.3) files in the right * Tweak makefile to generate ref page nroff (.3) files in the right
output directory, working around an a2x limitation (internal issue output directory, working around an a2x limitation (internal issue
223). 223).
@ -356,7 +323,6 @@ Other Commits:
* Add validity requirements for flink:vkCmdCopyQueryPoolResults * Add validity requirements for flink:vkCmdCopyQueryPoolResults
pname:dstBuffer parameter. pname:dstBuffer parameter.
* Fix ref page build to generate .3 targets in the right output * Fix ref page build to generate .3 targets in the right output
directory. directory.
@ -396,7 +362,7 @@ Github Issues:
Internal Issues: Internal Issues:
* Link to the fixed-function vertex chapter from the drawing chapter * Link to the fixed-function vertex chapter from the drawing chapter
(internal issue #110) (internal issue 110)
* Fix typo in slink:VkImageCreateInfo validity language: * Fix typo in slink:VkImageCreateInfo validity language:
ptext:maxExtent.sampleCounts -> pname:sampleCounts (internal issue ptext:maxExtent.sampleCounts -> pname:sampleCounts (internal issue
249). 249).
@ -499,3 +465,64 @@ Internal Issues:
* Fix typo in the definition of point sampling for * Fix typo in the definition of point sampling for
elink:VkCullModeFlagBits (internal issue 268). elink:VkCullModeFlagBits (internal issue 268).
-----------------------------------------------------
Change log for April 22, 2016 Vulkan 1.0.11 spec update:
* Bump API patch number and header version number to 11 for this
update.
Github Issues:
* Clarify the WSI extension language by switching from the fuzzier
"ownership" language to more-consistent "acquire" language (public
issue 117).
* Clarify that memory barriers apply to all commands in the dependency
chains in the flink:vkGetRenderAreaGranularity command and the
<<synchronization-execution-and-memory-dependencies,Execution And
Memory Dependencies>> section (public issue 132).
* Clarify that a queue family is a set of queues in the
<<fundamentals-execmodel,Execution Model>> section (public issue
166).
* Removed requirement from valid usage language that
VkPresentInfoKHR::waitSemaphoreCount must be greater than 0 (public
issue 171).
* Fix broken internal links, describe structures consistently, use
consistent style for SPIR-V codewords, and tag normative terms that
were missing asciidoc tags (public issue 183 and ancillary
markup/normative language fixes).
* Fix typos for slink:VkPhysicalDeviceLimits member names in
slink:VkImageCreateInfo validity language (public issue 184).
Internal Issues:
* Document that the requested patch version number specified as part
of slink:VkApplicationInfo::pname:apiVersion is ignored when
creating an instance (internal issue 176).
* Clarify handling of extension structs in the
<<fundamentals-validusageValid Usage>> section (internal issue 254).
* Update required slink:VkImageFormatProperties::pname:maxMipLevels to
be limited to the maximum allowed mipmap pyramid size corresponding
to the actual maximum supported size for the format (internal issue
256).
* Modify the <<features-extentperimagetype,Allowed Extent Values Based
On Image Type>> section so the allowed maximum extent is the maximum
image dimension supported for each dimension of the type of texture
being queried (internal issue 257).
* Clarify in the <<spirvenv-module-validation,Validation Rules within
a Module>> section that at least one of the code:LocalSize execution
mode or code:WorkgroupSize decoration is required for each compute
shader entry point in a shader module (internal issue 279).
* Add validity rules for formats in flink:vkCmdClearColorImage and
flink:vkCmdClearDepthStencilImage (internal issue 283).
* Clarify that slink:VkImageFormatProperties::pname:maxResourceSize is
an upper bound, and that it may not be possible to create an image
anywhere near that size (internal issue 284).
Other Commits:
* Fix various minor markup errors reported by validation scripts.
* Change copyright from Khronos Free Use License to Apache 2.0 license
on relevant script/XML/header files. This does not affect the
specification source copyright.

View File

@ -33,8 +33,8 @@ Status
Version Version
Last Modified Date: 5-Apr-2016 Last Modified Date: 12-Apr-2016
Revision: 29 Revision: 30
Number Number
@ -943,24 +943,25 @@ Changes to Chapter 5 of the OpenGL Shading Language Specification
operators and with another constant or specialization constant, the operators and with another constant or specialization constant, the
result is implicitly a specialization constant. result is implicitly a specialization constant.
- int(), uint(), float(), and bool() constructors for type conversions - int(), uint(), and bool() constructors for type conversions
from any of the following types to any of the following types: from any of the following types to any of the following types:
* int * int
* uint * uint
* float
* double
* bool * bool
- vector versions of the above conversion constructors - vector versions of the above conversion constructors
- allowed implicit conversions of the above - allowed implicit conversions of the above
- The operators - swizzles (e.g., foo.yx)
- The following when applied to integer or unsigned integer types:
* unary negative ( - ) * unary negative ( - )
* not ( ! )
* binary operations ( + , - , * , / , % ) * binary operations ( + , - , * , / , % )
* shift ( <<, >> ) * shift ( <<, >> )
* bitwise operations ( & , | , ^ ) * bitwise operations ( & , | , ^ )
* swizzles (e.g., foo.yx) - The following when applied to integer or unsigned integer scalar types:
* logical operations ( && , || , ^^ )
* comparison ( == , != , > , >= , < , <= ) * comparison ( == , != , > , >= , < , <= )
- The following when applied to the Boolean scalar type:
* not ( ! )
* logical operations ( && , || , ^^ )
* comparison ( == , != )
Changes to Chapter 7 of the OpenGL Shading Language Specification Changes to Chapter 7 of the OpenGL Shading Language Specification
@ -1154,6 +1155,7 @@ Revision History
Rev. Date Author Changes Rev. Date Author Changes
---- ----------- ------- -------------------------------------------- ---- ----------- ------- --------------------------------------------
30 12-Apr-2016 JohnK Restrict spec-const operations to non-float
29 5-Apr-2016 JohnK Clarify disallowance of spec-const arrays in 29 5-Apr-2016 JohnK Clarify disallowance of spec-const arrays in
initializers initializers
28 7-Mar-2016 JohnK Make push_constants not have sets 28 7-Mar-2016 JohnK Make push_constants not have sets

View File

@ -31,8 +31,8 @@ QUIET?=@
ASCIIDOC ?= asciidoc.py ASCIIDOC ?= asciidoc.py
A2X ?= a2x.py A2X ?= a2x.py
DBLATEX ?= dblatex DBLATEX ?= dblatex
# DBLATEXPREFIX can be overriden by setting it as an environment variable if # DBLATEXPREFIX can be overriden by setting it as an environment variable,
# the not installed in the standard location on your distribution # if not installed in the standard location on your distribution
DBLATEXPREFIX ?= /etc/asciidoc/dblatex DBLATEXPREFIX ?= /etc/asciidoc/dblatex
RM=rm -f RM=rm -f
RMRF=rm -rf RMRF=rm -rf
@ -126,7 +126,7 @@ INCLUDES := $(wildcard protos/*.txt structs/*.txt flags/*.txt enums/*.txt funcpo
COMMONDOCS := $(CHAPTERS) $(INCLUDES) COMMONDOCS := $(CHAPTERS) $(INCLUDES)
# A generated included file with the spec version, date, and git commit # A generated included file with the spec version, date, and git commit
SPECVERSION = specversion.txt SPECVERSION = specversion.txt
SPECREVISION = 1.0.10 SPECREVISION = 1.0.11
SPECREMARK = SPECREMARK =
# Spec targets # Spec targets

View File

@ -26,7 +26,7 @@ s, t, and r directions.
=== New Enum Constants === New Enum Constants
* Extending ename:VkSamplerAddressMode: * Extending elink:VkSamplerAddressMode:
** ename:VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE ** ename:VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE
=== Example === Example

View File

@ -445,9 +445,9 @@ all extensions must: define two additional tokens.
extension defined in +vulkan.h+ and the revision supported by the extension defined in +vulkan.h+ and the revision supported by the
{apiname} implementation (the pname:specVersion field of the {apiname} implementation (the pname:specVersion field of the
slink:VkExtensionProperties structure corresponding to the extension and slink:VkExtensionProperties structure corresponding to the extension and
returned by one of the <<debug-extensions,Extension Queries>>) may: returned by one of the <<extended-functionality-extensions,extension
differ. In such cases, only the functionality and behavior of the queries>>) may: differ. In such cases, only the functionality and
lowest-numbered revision can: be used. behavior of the lowest-numbered revision can: be used.
* VK_EXTNAME_EXTENSION_NAME is a string constant which is the name of the * VK_EXTNAME_EXTENSION_NAME is a string constant which is the name of the
extension. extension.

View File

@ -242,7 +242,7 @@ Dynamic Uniform Buffer::
Explicitly-Enabled Layer:: Explicitly-Enabled Layer::
A layer enabled by the application by adding it to the enabled layer A layer enabled by the application by adding it to the enabled layer
list in flink:vkCmdCreateInstance or flink:vkCmdCreateDevice. list in flink:vkCreateInstance or flink:vkCreateDevice.
Event:: Event::
A synchronization primitive that is signalled when execution of previous A synchronization primitive that is signalled when execution of previous
@ -317,6 +317,18 @@ Handle::
An opaque integer or pointer value used to refer to a {apiname} object. An opaque integer or pointer value used to refer to a {apiname} object.
Each object type has a unique handle type. Each object type has a unique handle type.
Happen-after::
A command happens-after a dependency if they are separated by an execution
dependency chain, with the command included in the destination of the last
dependency of the chain. A memory barrier makes visible memory writes to
commands that happen-after it.
Happen-before::
A command happens-before a dependency if they are separated by an execution
dependency chain, with the command included in the source of the first
dependency of the chain. A memory barrier makes available memory writes of
commands that happen-before it.
Helper Invocation:: Helper Invocation::
A fragment shader invocation that is created solely for the purposes of A fragment shader invocation that is created solely for the purposes of
evaluating derivatives for use in non-helper fragment shader evaluating derivatives for use in non-helper fragment shader

View File

@ -26,17 +26,17 @@ described in section 2.3 of the SPIR-V Specification.
== Capabilities == Capabilities
Implementations must: support the following capability operands declared by Implementations must: support the following capability operands declared by
*OpCapability*: code:OpCapability:
- Matrix - code:Matrix
- Shader - code:Shader
- InputAttachment - code:InputAttachment
- Sampled1D - code:Sampled1D
- Image1D - code:Image1D
- SampledBuffer - code:SampledBuffer
- ImageBuffer - code:ImageBuffer
- ImageQuery - code:ImageQuery
- DerivativeControl - code:DerivativeControl
Implementations may: support features that are not required: by the Implementations may: support features that are not required: by the
Specification, as described in the <<features-features,Features>> chapter. Specification, as described in the <<features-features,Features>> chapter.
@ -48,32 +48,32 @@ to that feature must: also be supported.
[options="header"] [options="header"]
|==== |====
| SPIR-V OpCapability | {apiname} feature name | SPIR-V OpCapability | {apiname} feature name
| *Geometry* | <<features-features-geometryShader,geometryShader>> | code:Geometry | <<features-features-geometryShader,geometryShader>>
| *Tessellation* | <<features-features-tessellationShader,tessellationShader>> | code:Tessellation | <<features-features-tessellationShader,tessellationShader>>
| *Float64* | <<features-features-shaderFloat64,shaderFloat64>> | code:Float64 | <<features-features-shaderFloat64,shaderFloat64>>
| *Int64* | <<features-features-shaderInt64,shaderInt64>> | code:Int64 | <<features-features-shaderInt64,shaderInt64>>
| *Int16* | <<features-features-shaderInt16,shaderInt16>> | code:Int16 | <<features-features-shaderInt16,shaderInt16>>
| *TessellationPointSize* | <<features-features-shaderTessellationAndGeometryPointSize,shaderTessellationAndGeometryPointSize>> | code:TessellationPointSize | <<features-features-shaderTessellationAndGeometryPointSize,shaderTessellationAndGeometryPointSize>>
| *GeometryPointSize* | <<features-features-shaderTessellationAndGeometryPointSize,shaderTessellationAndGeometryPointSize>> | code:GeometryPointSize | <<features-features-shaderTessellationAndGeometryPointSize,shaderTessellationAndGeometryPointSize>>
| *ImageGatherExtended* | <<features-features-shaderImageGatherExtended,shaderImageGatherExtended>> | code:ImageGatherExtended | <<features-features-shaderImageGatherExtended,shaderImageGatherExtended>>
| *StorageImageMultisample* | <<features-features-shaderStorageImageMultisample,shaderStorageImageMultisample>> | code:StorageImageMultisample | <<features-features-shaderStorageImageMultisample,shaderStorageImageMultisample>>
| *UniformBufferArrayDynamicIndexing* | <<features-features-shaderUniformBufferArrayDynamicIndexing,shaderUniformBufferArrayDynamicIndexing>> | code:UniformBufferArrayDynamicIndexing | <<features-features-shaderUniformBufferArrayDynamicIndexing,shaderUniformBufferArrayDynamicIndexing>>
| *SampledImageArrayDynamicIndexing* | <<features-features-shaderSampledImageArrayDynamicIndexing,shaderSampledImageArrayDynamicIndexing>> | code:SampledImageArrayDynamicIndexing | <<features-features-shaderSampledImageArrayDynamicIndexing,shaderSampledImageArrayDynamicIndexing>>
| *StorageBufferArrayDynamicIndexing* | <<features-features-shaderStorageBufferArrayDynamicIndexing,shaderStorageBufferArrayDynamicIndexing>> | code:StorageBufferArrayDynamicIndexing | <<features-features-shaderStorageBufferArrayDynamicIndexing,shaderStorageBufferArrayDynamicIndexing>>
| *StorageImageArrayDynamicIndexing* | <<features-features-shaderStorageImageArrayDynamicIndexing,shaderStorageImageArrayDynamicIndexing>> | code:StorageImageArrayDynamicIndexing | <<features-features-shaderStorageImageArrayDynamicIndexing,shaderStorageImageArrayDynamicIndexing>>
| *ClipDistance* | <<features-features-shaderClipDistance,shaderClipDistance>> | code:ClipDistance | <<features-features-shaderClipDistance,shaderClipDistance>>
| *CullDistance* | <<features-features-shaderCullDistance,shaderCullDistance>> | code:CullDistance | <<features-features-shaderCullDistance,shaderCullDistance>>
| *ImageCubeArray* | <<features-features-imageCubeArray,imageCubeArray>> | code:ImageCubeArray | <<features-features-imageCubeArray,imageCubeArray>>
| *SampleRateShading* | <<features-features-sampleRateShading,sampleRateShading>> | code:SampleRateShading | <<features-features-sampleRateShading,sampleRateShading>>
| *SparseResidency* | <<features-features-shaderResourceResidency,shaderResourceResidency>> | code:SparseResidency | <<features-features-shaderResourceResidency,shaderResourceResidency>>
| *MinLod* | <<features-features-shaderResourceMinLod,shaderResourceMinLod>> | code:MinLod | <<features-features-shaderResourceMinLod,shaderResourceMinLod>>
| *SampledCubeArray* | <<features-features-imageCubeArray,imageCubeArray>> | code:SampledCubeArray | <<features-features-imageCubeArray,imageCubeArray>>
| *ImageMSArray* | <<features-features-shaderStorageImageMultisample,shaderStorageImageMultisample>> | code:ImageMSArray | <<features-features-shaderStorageImageMultisample,shaderStorageImageMultisample>>
| *StorageImageExtendedFormats* | <<features-features-shaderStorageImageExtendedFormats,shaderStorageImageExtendedFormats>> | code:StorageImageExtendedFormats | <<features-features-shaderStorageImageExtendedFormats,shaderStorageImageExtendedFormats>>
| *InterpolationFunction* | <<features-features-sampleRateShading,sampleRateShading>> | code:InterpolationFunction | <<features-features-sampleRateShading,sampleRateShading>>
| *StorageImageReadWithoutFormat* | <<features-features-shaderStorageImageReadWithoutFormat,shaderStorageImageReadWithoutFormat>> | code:StorageImageReadWithoutFormat | <<features-features-shaderStorageImageReadWithoutFormat,shaderStorageImageReadWithoutFormat>>
| *StorageImageWriteWithoutFormat* | <<features-features-shaderStorageImageWriteWithoutFormat,shaderStorageImageWriteWithoutFormat>> | code:StorageImageWriteWithoutFormat | <<features-features-shaderStorageImageWriteWithoutFormat,shaderStorageImageWriteWithoutFormat>>
| *MultiViewport* | <<features-features-multiViewport,multiViewport>> | code:MultiViewport | <<features-features-multiViewport,multiViewport>>
|==== |====
The application mustnot: pass a SPIR-V module containing any of the The application mustnot: pass a SPIR-V module containing any of the
@ -100,24 +100,24 @@ following rules:
** *Device* ** *Device*
** *Workgroup* ** *Workgroup*
** *Invocation* ** *Invocation*
* The *OriginLowerLeft* execution mode mustnot: be used; fragment entry * The code:OriginLowerLeft execution mode mustnot: be used; fragment entry
points must: declare *OriginUpperLeft*. points must: declare code:OriginUpperLeft.
* The *PixelCenterInteger* execution mode mustnot: be used. Pixels are * The code:PixelCenterInteger execution mode mustnot: be used. Pixels are
always centered at half-integer coordinates. always centered at half-integer coordinates.
* Images * Images
** *OpTypeImage* must: declare a scalar 32-bit float or 32-bit integer ** code:OpTypeImage must: declare a scalar 32-bit float or 32-bit integer
type for the ``Sampled Type''. (RelaxedPrecision can: be applied to a type for the ``Sampled Type''. (code:RelaxedPrecision can: be applied
sampling instruction and to the variable holding the result of a to a sampling instruction and to the variable holding the result of a
sampling instruction.) sampling instruction.)
** *OpSampledImage* must: only consume an ``Image'' operand whose type has ** code:OpSampledImage must: only consume an ``Image'' operand whose type
its ``Sampled'' operand set to 1. has its ``Sampled'' operand set to 1.
** The ``(u, v)'' coordinates used for a *SubpassData* must: be the <id> ** The ``(u, v)'' coordinates used for a code:SubpassData must: be the <id>
of a constant vector (0, 0), or if a layer coordinate is used, must: be of a constant vector (0, 0), or if a layer coordinate is used, must: be
a vector that was formed with constant 0 for the ``u'' and ``v'' a vector that was formed with constant 0 for the ``u'' and ``v''
components. components.
** The ``Depth'' operand of *OpTypeImage* is ignored. ** The ``Depth'' operand of code:OpTypeImage is ignored.
* Decorations * Decorations
** The *GLSLShared* and *GLSLPacked* decorations mustnot: be used. ** The code:GLSLShared and code:GLSLPacked decorations mustnot: be used.
** The code:Flat, code:NoPerspective, code:Sample, and code:Centroid ** The code:Flat, code:NoPerspective, code:Sample, and code:Centroid
decorations mustnot: be used on variables with storage class other than decorations mustnot: be used on variables with storage class other than
code:Input or on variables used in the interface of non-fragment shader code:Input or on variables used in the interface of non-fragment shader
@ -125,10 +125,14 @@ following rules:
** The code:Patch decoration mustnot: be used on variables in the ** The code:Patch decoration mustnot: be used on variables in the
interface of a vertex, geometry, or fragment shader stage's entry interface of a vertex, geometry, or fragment shader stage's entry
point. point.
- *OpTypeRuntimeArray* must: only be used for the last member of an * code:OpTypeRuntimeArray must: only be used for the last member of an
*OpTypeStruct* in the *Uniform* storage class. code:OpTypeStruct in the code:Uniform storage class.
- Linkage: See <<interfaces,Shader Interfaces>> for additional linking and * Linkage: See <<interfaces,Shader Interfaces>> for additional linking and
validation rules. validation rules.
* Compute Shaders
** For each compute shader entry point, either a code:LocalSize execution mode
or an object decorated with the code:WorkgroupSize decoration must: be
specified.
[[spirvenv-precision-operation]] [[spirvenv-precision-operation]]
@ -156,29 +160,29 @@ required: to be at least as follows, unless decorated with RelaxedPrecision:
.Precision of core SPIR-V Instructions .Precision of core SPIR-V Instructions
[options="header"] [options="header"]
|==== |====
|Instruction | Precision | Instruction | Precision
|*OpFAdd* | Correctly rounded. | code:OpFAdd | Correctly rounded.
|*OpFSub* | Correctly rounded. | code:OpFSub | Correctly rounded.
|*OpFMul* | Correctly rounded. | code:OpFMul | Correctly rounded.
|*OpFOrdEqual*, *OpFUnordEqual* | Correct result. | code:OpFOrdEqual, code:OpFUnordEqual | Correct result.
|*OpFOrdLessThan*, *OpFUnordLessThan* | Correct result. | code:OpFOrdLessThan, code:OpFUnordLessThan | Correct result.
|*OpFOrdGreaterThan*, *OpFUnordGreaterThan* | Correct result. | code:OpFOrdGreaterThan, code:OpFUnordGreaterThan | Correct result.
|*OpFOrdLessThanEqual*, *OpFUnordLessThanEqual* | Correct result. | code:OpFOrdLessThanEqual, code:OpFUnordLessThanEqual | Correct result.
|*OpFOrdGreaterThanEqual*, *OpFUnordGreaterThanEqual*| Correct result. | code:OpFOrdGreaterThanEqual, code:OpFUnordGreaterThanEqual| Correct result.
|*OpFDiv* | 2.5 ULP for b in the range [2^-126^, 2^126^]. | code:OpFDiv | 2.5 ULP for b in the range [2^-126^, 2^126^].
|conversions between types | Correctly rounded. | conversions between types | Correctly rounded.
|==== |====
Precision of GLSL.std.450 Instructions Precision of GLSL.std.450 Instructions
[options="header"] [options="header"]
|==== |====
|Instruction | Precision |Instruction | Precision
|*fma*() | Inherited from *OpFMul* followed by *OpFAdd*. | code:fma() | Inherited from code:OpFMul followed by code:OpFAdd.
|*exp*(x), *exp2*(x) | latexmath:[$(3 + 2 \times \|x\|)$] ULP. | code:exp(x), code:exp2(x) | latexmath:[$(3 + 2 \times \|x\|)$] ULP.
|*log*(), *log2*() | 3 ULP outside the range [0.5, 2.0]. Absolute error < 2^-21^ inside the range [0.5, 2.0]. | code:log(), code:log2() | 3 ULP outside the range [0.5, 2.0]. Absolute error < 2^-21^ inside the range [0.5, 2.0].
|*pow*(x, y) | Inherited from *exp2* (y × *log2* (x)). | code:pow(x, y) | Inherited from code:exp2(y × code:log2(x)).
|*sqrt*() | Inherited from 1.0 / *inversesqrt*(). | code:sqrt() | Inherited from 1.0 / code:inversesqrt().
|*inversesqrt*() | 2 ULP. | code:inversesqrt() | 2 ULP.
|==== |====
GLSL.std.450 extended instructions specifically defined in terms of the GLSL.std.450 extended instructions specifically defined in terms of the

View File

@ -98,7 +98,7 @@ parameters.
include::../validity/protos/vkCmdClearAttachments.txt[] include::../validity/protos/vkCmdClearAttachments.txt[]
The sname:VkClearRect struct is defined as follows: The sname:VkClearRect structure is defined as:
include::../structs/VkClearRect.txt[] include::../structs/VkClearRect.txt[]
@ -111,7 +111,7 @@ counting from the base layer of the attachment image view are cleared.
include::../validity/structs/VkClearRect.txt[] include::../validity/structs/VkClearRect.txt[]
The sname:VkClearAttachment struct is defined as follows: The sname:VkClearAttachment structure is defined as:
include::../structs/VkClearAttachment.txt[] include::../structs/VkClearAttachment.txt[]
@ -147,7 +147,7 @@ include::../validity/structs/VkClearAttachment.txt[]
[[clears-values]] [[clears-values]]
== Clear Values == Clear Values
The definition of sname:VkClearColorValue is as follows: The sname:VkClearColorValue structure is defined as:
include::../structs/VkClearColorValue.txt[] include::../structs/VkClearColorValue.txt[]
@ -170,12 +170,11 @@ The four array elements of the clear color map to R, G, B, and A components
of image formats, in order. of image formats, in order.
If the image has more than one sample, the same value is written to all If the image has more than one sample, the same value is written to all
samples for any pixels being cleared. The ftext:vkClear*Image commands do samples for any pixels being cleared.
not support compressed image formats.
include::../validity/structs/VkClearColorValue.txt[] include::../validity/structs/VkClearColorValue.txt[]
The definition of sname:VkClearDepthStencilValue is as follows: The sname:VkClearDepthStencilValue structure is defined as:
include::../structs/VkClearDepthStencilValue.txt[] include::../structs/VkClearDepthStencilValue.txt[]
@ -190,8 +189,10 @@ include::../structs/VkClearDepthStencilValue.txt[]
include::../validity/structs/VkClearDepthStencilValue.txt[] include::../validity/structs/VkClearDepthStencilValue.txt[]
Some parts of the API require either color or depth/stencil clear values, Some parts of the API require either color or depth/stencil clear values,
depending on the attachment. For this the sname:VkClearValue union is depending on the attachment. The sname:VkClearValue union represents such
defined as follows: values.
The sname:VkClearValue union is defined as:
include::../structs/VkClearValue.txt[] include::../structs/VkClearValue.txt[]

View File

@ -87,15 +87,14 @@ include::../protos/vkCreateCommandPool.txt[]
include::../validity/protos/vkCreateCommandPool.txt[] include::../validity/protos/vkCreateCommandPool.txt[]
The sname:VkCommandPoolCreateInfo structure is defined as follows: The sname:VkCommandPoolCreateInfo structure is defined as:
include::../structs/VkCommandPoolCreateInfo.txt[] include::../structs/VkCommandPoolCreateInfo.txt[]
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is a combination of bitfield flags indicating usage behavior * pname:flags is a bitmask indicating usage behavior for the pool and
for the pool and command buffers allocated from it. Possible values command buffers allocated from it. Bits which can: be set include:
include:
+ +
-- --
include::../enums/VkCommandPoolCreateFlagBits.txt[] include::../enums/VkCommandPoolCreateFlagBits.txt[]
@ -137,7 +136,8 @@ command buffers allocated from the command pool back to the command pool.
All command buffers that have been allocated from the command pool are put All command buffers that have been allocated from the command pool are put
in the initial state. in the initial state.
pname:flags is of type elink:VkCommandPoolResetFlags, which is defined as: pname:flags is a bitmask controlling the operation. Bits which which can: be
set include:
include::../enums/VkCommandPoolResetFlagBits.txt[] include::../enums/VkCommandPoolResetFlagBits.txt[]
@ -174,7 +174,7 @@ include::../protos/vkAllocateCommandBuffers.txt[]
allocation. allocation.
* pname:pCommandBuffers is a pointer to an array of sname:VkCommandBuffer * pname:pCommandBuffers is a pointer to an array of sname:VkCommandBuffer
handles in which the resulting command buffer objects are returned. The handles in which the resulting command buffer objects are returned. The
array must be at least the length specified by the array must: be at least the length specified by the
pname:commandBufferCount member of pname:pAllocateInfo. Each allocated pname:commandBufferCount member of pname:pAllocateInfo. Each allocated
command buffer begins in the initial state. command buffer begins in the initial state.
@ -203,7 +203,8 @@ include::../protos/vkResetCommandBuffer.txt[]
* pname:commandBuffer is the command buffer to reset. The command buffer * pname:commandBuffer is the command buffer to reset. The command buffer
can: be in any state, and is put in the initial state. can: be in any state, and is put in the initial state.
* pname:flags is of type elink:VkCommandBufferResetFlags: * pname:flags is a bitmask controlling the reset operation. Bits which
can: be set include:
+ +
-- --
include::../enums/VkCommandBufferResetFlagBits.txt[] include::../enums/VkCommandBufferResetFlagBits.txt[]
@ -252,8 +253,8 @@ include::../structs/VkCommandBufferBeginInfo.txt[]
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is a combination of bitfield flags indicating usage behavior * pname:flags is a bitmask indicating usage behavior for the command
for the command buffer. Possible values include: buffer. Bits which can: be set include:
+ +
-- --
include::../enums/VkCommandBufferUsageFlagBits.txt[] include::../enums/VkCommandBufferUsageFlagBits.txt[]
@ -292,7 +293,7 @@ include::../structs/VkCommandBufferInheritanceInfo.txt[]
* pname:framebuffer refers to the sname:VkFramebuffer object that the * pname:framebuffer refers to the sname:VkFramebuffer object that the
sname:VkCommandBuffer will be rendering to if it was allocated with sname:VkCommandBuffer will be rendering to if it was allocated with
the ename:VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT set. It can: the ename:VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT set. It can:
be sname:VK_NULL_HANDLE if the framebuffer is not known. be code:VK_NULL_HANDLE if the framebuffer is not known.
+ +
[NOTE] [NOTE]
.Note .Note
@ -399,10 +400,10 @@ include::../protos/vkQueueSubmit.txt[]
which describe the work to submit. All work described by pname:pSubmits which describe the work to submit. All work described by pname:pSubmits
must: be submitted to the queue before the command returns. must: be submitted to the queue before the command returns.
* pname:fence is an optional handle to a fence. If pname:fence is not * pname:fence is an optional handle to a fence. If pname:fence is not
sname:VK_NULL_HANDLE, the fence is signaled when execution of all code:VK_NULL_HANDLE, the fence is signaled when execution of all
sname:VkSubmitInfo::pname:pCommandBuffers members of pname:pSubmits is sname:VkSubmitInfo::pname:pCommandBuffers members of pname:pSubmits is
completed. If pname:submitCount is zero but pname:fence is not completed. If pname:submitCount is zero but pname:fence is not
sname:VK_NULL_HANDLE, the fence will still be submitted to the queue and code:VK_NULL_HANDLE, the fence will still be submitted to the queue and
will become signaled when all work previously submitted to the queue has will become signaled when all work previously submitted to the queue has
completed. completed.
@ -443,8 +444,9 @@ signalled before executing any work, followed by a number of command buffers
that will be executed, and finally, zero or more semaphores that will be that will be executed, and finally, zero or more semaphores that will be
signaled after command buffer execution completes. Each batch is represented signaled after command buffer execution completes. Each batch is represented
as an instance of the slink:VkSubmitInfo structure stored in an array, the as an instance of the slink:VkSubmitInfo structure stored in an array, the
address of which is passed in pname:pSubmitInfo. The definition of address of which is passed in pname:pSubmitInfo.
sname:VkSubmitInfo is:
The sname:VkSubmitInfo structure is defined as:
include::../structs/VkSubmitInfo.txt[] include::../structs/VkSubmitInfo.txt[]

View File

@ -72,7 +72,7 @@ the copy regions overlap in memory.
include::../validity/protos/vkCmdCopyBuffer.txt[] include::../validity/protos/vkCmdCopyBuffer.txt[]
Each element of pname:pRegions is a structure defined as: The sname:VkBufferCopy structure is defined as:
include::../structs/VkBufferCopy.txt[] include::../structs/VkBufferCopy.txt[]
@ -117,7 +117,7 @@ the same image or alias the same memory.
include::../validity/protos/vkCmdCopyImage.txt[] include::../validity/protos/vkCmdCopyImage.txt[]
Each element of pname:pRegions is a structure defined as: The sname:VkImageCopy structure is defined as:
include::../structs/VkImageCopy.txt[] include::../structs/VkImageCopy.txt[]
@ -404,7 +404,7 @@ include::../validity/protos/vkCmdBlitImage.txt[]
fname:vkCmdBlitImage mustnot: be used for multisampled source or destination fname:vkCmdBlitImage mustnot: be used for multisampled source or destination
images. Use flink:vkCmdResolveImage for this purpose. images. Use flink:vkCmdResolveImage for this purpose.
Each element of pname:pRegions is a structure defined as: The sname:VkImageBlit structure is defined as:
include::../structs/VkImageBlit.txt[] include::../structs/VkImageBlit.txt[]
@ -491,7 +491,7 @@ include::../protos/vkCmdResolveImage.txt[]
include::../validity/protos/vkCmdResolveImage.txt[] include::../validity/protos/vkCmdResolveImage.txt[]
Each element of pname:pRegions is a structure defined as: The sname:VkImageResolve structure is defined as:
include::../structs/VkImageResolve.txt[] include::../structs/VkImageResolve.txt[]

View File

@ -99,7 +99,7 @@ from within shaders bound to pipelines.
Loads from storage images do not use samplers and are unfiltered and do not Loads from storage images do not use samplers and are unfiltered and do not
support coordinate wrapping or clamping. Loads are supported in all shader support coordinate wrapping or clamping. Loads are supported in all shader
stages for image formats which report support for the stages for image formats which report support for the
<<features-formats-properties-storage,ename:VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT>> <<features-formats-properties,ename:VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT>>
feature bit via flink:vkGetPhysicalDeviceFormatProperties. feature bit via flink:vkGetPhysicalDeviceFormatProperties.
Stores to storage images are supported in compute shaders for image Stores to storage images are supported in compute shaders for image
@ -108,7 +108,7 @@ ename:VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT feature.
Storage images also support atomic operations in compute shaders for Storage images also support atomic operations in compute shaders for
image formats which report support for the image formats which report support for the
<<features-formats-properties-storageatomic,ename:VK_FORMAT_FEATURE_STORAGE_IMAGE_ATOMIC_BIT>> <<features-formats-properties,ename:VK_FORMAT_FEATURE_STORAGE_IMAGE_ATOMIC_BIT>>
feature. feature.
Load and store operations on storage images can: only be done on images in Load and store operations on storage images can: only be done on images in
@ -578,7 +578,7 @@ include::../structs/VkDescriptorSetLayoutCreateInfo.txt[]
include::../validity/structs/VkDescriptorSetLayoutCreateInfo.txt[] include::../validity/structs/VkDescriptorSetLayoutCreateInfo.txt[]
The definition of the sname:VkDescriptorSetLayoutBinding structure is: The sname:VkDescriptorSetLayoutBinding structure is defined as:
include::../structs/VkDescriptorSetLayoutBinding.txt[] include::../structs/VkDescriptorSetLayoutBinding.txt[]
@ -815,7 +815,7 @@ include::../protos/vkCreatePipelineLayout.txt[]
include::../validity/protos/vkCreatePipelineLayout.txt[] include::../validity/protos/vkCreatePipelineLayout.txt[]
The definition of the slink:VkPipelineLayoutCreateInfo structure is: The slink:VkPipelineLayoutCreateInfo structure is defined as:
include::../structs/VkPipelineLayoutCreateInfo.txt[] include::../structs/VkPipelineLayoutCreateInfo.txt[]
@ -843,7 +843,7 @@ pipelines that is expected to outperform memory-backed resource updates.
include::../validity/structs/VkPipelineLayoutCreateInfo.txt[] include::../validity/structs/VkPipelineLayoutCreateInfo.txt[]
The definition of sname:VkPushConstantRange is: The sname:VkPushConstantRange structure is defined as:
include::../structs/VkPushConstantRange.txt[] include::../structs/VkPushConstantRange.txt[]
@ -1114,7 +1114,7 @@ allocated from the pool mustnot: be individually freed back to the pool,
i.e. only fname:vkAllocateDescriptorSets and fname:vkResetDescriptorPool are i.e. only fname:vkAllocateDescriptorSets and fname:vkResetDescriptorPool are
allowed. allowed.
The definition of the sname:VkDescriptorPoolSize structure is: The sname:VkDescriptorPoolSize structure is defined as:
include::../structs/VkDescriptorPoolSize.txt[] include::../structs/VkDescriptorPoolSize.txt[]
@ -1149,7 +1149,7 @@ include::../protos/vkAllocateDescriptorSets.txt[]
allocation. allocation.
* pname:pDescriptorSets is a pointer to an array of sname:VkDescriptorSet * pname:pDescriptorSets is a pointer to an array of sname:VkDescriptorSet
handles in which the resulting descriptor set objects are returned. The handles in which the resulting descriptor set objects are returned. The
array must be at least the length specified by the array must: be at least the length specified by the
pname:descriptorSetCount member of pname:pAllocateInfo. pname:descriptorSetCount member of pname:pAllocateInfo.
include::../validity/protos/vkAllocateDescriptorSets.txt[] include::../validity/protos/vkAllocateDescriptorSets.txt[]
@ -1191,7 +1191,7 @@ include::../protos/vkFreeDescriptorSets.txt[]
sets were allocated. sets were allocated.
* pname:descriptorSetCount is the number of elements in the * pname:descriptorSetCount is the number of elements in the
pname:pDescriptorSets array. pname:pDescriptorSets array.
* pname:pDescriptorSets is an array of handles to slink:VkDescriptorSet * pname:pDescriptorSets is an array of handles to sname:VkDescriptorSet
objects. All elements of pname:pDescriptorSets must: have been allocated objects. All elements of pname:pDescriptorSets must: have been allocated
from pname:descriptorPool. from pname:descriptorPool.
@ -1219,7 +1219,7 @@ include::../protos/vkResetDescriptorPool.txt[]
* pname:device is the logical device that owns the descriptor pool. * pname:device is the logical device that owns the descriptor pool.
* pname:descriptorPool is the descriptor pool to be reset. * pname:descriptorPool is the descriptor pool to be reset.
* pname:flags is currently unused and must be zero. * pname:flags is currently unused and must: be zero.
include::../validity/protos/vkResetDescriptorPool.txt[] include::../validity/protos/vkResetDescriptorPool.txt[]
@ -1259,7 +1259,7 @@ Each element in the pname:pDescriptorWrites array describes an operation
updating the descriptor set using descriptors for resources specified in the updating the descriptor set using descriptors for resources specified in the
structure. structure.
The definition of sname:VkWriteDescriptorSet is: The sname:VkWriteDescriptorSet structure is defined as:
include::../structs/VkWriteDescriptorSet.txt[] include::../structs/VkWriteDescriptorSet.txt[]
@ -1297,10 +1297,11 @@ structure, as specified below.
If pname:descriptorType is ename:VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER, If pname:descriptorType is ename:VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER,
ename:VK_DESCRIPTOR_TYPE_STORAGE_BUFFER, ename:VK_DESCRIPTOR_TYPE_STORAGE_BUFFER,
ename:VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC, or ename:VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC, or
ename:VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC, the pname:pBufferInfo array ename:VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC, the elements of the
will be used to update the descriptors, and other arrays will be ignored. pname:pBufferInfo array of sname:VkDescriptorBufferInfo structures will be
Each element of pname:pBufferInfo is of type sname:VkDescriptorBufferInfo used to update the descriptors, and other arrays will be ignored.
and is defined as:
The sname:VkDescriptorBufferInfo structure is defined as:
include::../structs/VkDescriptorBufferInfo.txt[] include::../structs/VkDescriptorBufferInfo.txt[]
@ -1329,9 +1330,10 @@ ename:VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
ename:VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE, ename:VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE,
ename:VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, or ename:VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, or
ename:VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT, the elements of the ename:VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT, the elements of the
pname:pImageInfo array will be used to update the descriptors, and other pname:pImageInfo array of sname:VkDescriptorImageInfo structures will be
arrays will be ignored. Each element of pname:pImageInfo is of type used to update the descriptors, and other arrays will be ignored.
sname:VkDescriptorImageInfo and is defined as:
The sname:VkDescriptorImageInfo structure is defined as:
include::../structs/VkDescriptorImageInfo.txt[] include::../structs/VkDescriptorImageInfo.txt[]
@ -1369,7 +1371,9 @@ immutable samplers or must: all not use immutable samplers.
Each element in the pname:pDescriptorCopies array is a Each element in the pname:pDescriptorCopies array is a
slink:VkCopyDescriptorSet structure describing an operation copying slink:VkCopyDescriptorSet structure describing an operation copying
descriptors between sets. The definition of sname:VkCopyDescriptorSet is: descriptors between sets.
The sname:VkCopyDescriptorSet structure is defined as:
include::../structs/VkCopyDescriptorSet.txt[] include::../structs/VkCopyDescriptorSet.txt[]
@ -1408,8 +1412,8 @@ include::../protos/vkCmdBindDescriptorSets.txt[]
bound. bound.
* pname:descriptorSetCount is the number of elements in the * pname:descriptorSetCount is the number of elements in the
pname:pDescriptorSets array. pname:pDescriptorSets array.
* pname:pDescriptorSets is a pointer to an array of slink:VkDescriptorSet * pname:pDescriptorSets is an array of handles to sname:VkDescriptorSet
structures describing the descriptor sets to write to. objects describing the descriptor sets to write to.
* pname:dynamicOffsetCount is the number of dynamic offsets * pname:dynamicOffsetCount is the number of dynamic offsets
in the pname:pDynamicOffsets array. in the pname:pDynamicOffsets array.
* pname:pDynamicOffsets is a pointer to an array of basetype:uint32_t * pname:pDynamicOffsets is a pointer to an array of basetype:uint32_t

View File

@ -26,7 +26,7 @@ include::../protos/vkEnumeratePhysicalDevices.txt[]
* pname:pPhysicalDeviceCount is a pointer to an integer related to the * pname:pPhysicalDeviceCount is a pointer to an integer related to the
number of physical devices available or queried, as described below. number of physical devices available or queried, as described below.
* pname:pPhysicalDevices is either `NULL` or a pointer to an * pname:pPhysicalDevices is either `NULL` or a pointer to an
array of sname:VkPhysicalDevice structures. array of sname:VkPhysicalDevice handles.
If pname:pPhysicalDevices is `NULL`, then the number of physical devices If pname:pPhysicalDevices is `NULL`, then the number of physical devices
available is returned in pname:pPhysicalDeviceCount. Otherwise, available is returned in pname:pPhysicalDeviceCount. Otherwise,
@ -51,17 +51,15 @@ include::../protos/vkGetPhysicalDeviceProperties.txt[]
* pname:physicalDevice is the handle to the physical device whose * pname:physicalDevice is the handle to the physical device whose
properties will be queried. properties will be queried.
* pname:pProperties points to an instance of the * pname:pProperties points to an instance of the
sname:VkPhysicalDeviceProperties structure, that will be filled with slink:VkPhysicalDeviceProperties structure, that will be filled with
returned information. returned information.
include::../validity/protos/vkGetPhysicalDeviceProperties.txt[] include::../validity/protos/vkGetPhysicalDeviceProperties.txt[]
The definition of sname:VkPhysicalDeviceProperties is: The sname:VkPhysicalDeviceProperties structure is defined as:
include::../structs/VkPhysicalDeviceProperties.txt[] include::../structs/VkPhysicalDeviceProperties.txt[]
The members of sname:VkPhysicalDeviceProperties have the following meanings:
* pname:apiVersion is the version of {apiname} supported by the device, * pname:apiVersion is the version of {apiname} supported by the device,
encoded as described in the <<fundamentals-versionnum,API Version encoded as described in the <<fundamentals-versionnum,API Version
Numbers and Semantics>> section. Numbers and Semantics>> section.
@ -77,19 +75,19 @@ The members of sname:VkPhysicalDeviceProperties have the following meanings:
* pname:pipelineCacheUUID is an array of size ename:VK_UUID_SIZE, * pname:pipelineCacheUUID is an array of size ename:VK_UUID_SIZE,
containing 8-bit values that represent a universally unique identifier containing 8-bit values that represent a universally unique identifier
for the device. for the device.
* pname:limits is the sname:VkPhysicalDeviceLimits structure which * pname:limits is the slink:VkPhysicalDeviceLimits structure which
specifies device-specific limits of the physical device. See specifies device-specific limits of the physical device. See
<<features-limits,Limits>> for details. <<features-limits,Limits>> for details.
* pname:sparseProperties is the sname:VkPhysicalDeviceSparseProperties * pname:sparseProperties is the slink:VkPhysicalDeviceSparseProperties
structure which specifies various sparse related properties of the structure which specifies various sparse related properties of the
physical device. See <<features-sparseproperties,Sparse Properties>> for physical device. See <<sparsememory-physicalprops,Sparse Properties>>
details. for details.
include::../validity/structs/VkPhysicalDeviceProperties.txt[] include::../validity/structs/VkPhysicalDeviceProperties.txt[]
The pname:vendorID and pname:deviceID fields are provided to allow The pname:vendorID and pname:deviceID fields are provided to allow
applications to adapt to device characteristics that are not applications to adapt to device characteristics that are not
adequately exposed by other Vulkan queries. These may include adequately exposed by other Vulkan queries. These may: include
performance profiles, hardware errata, or other characteristics. performance profiles, hardware errata, or other characteristics.
In PCI-based implementations, the low sixteen bits of pname:vendorID In PCI-based implementations, the low sixteen bits of pname:vendorID
and pname:deviceID must: contain (respectively) the PCI vendor and and pname:deviceID must: contain (respectively) the PCI vendor and
@ -140,7 +138,7 @@ include::../enums/VkPhysicalDeviceType.txt[]
The physical device type is advertised for informational purposes only, and The physical device type is advertised for informational purposes only, and
does not directly affect the operation of the system. However, the device does not directly affect the operation of the system. However, the device
type may correlate with other advertised properties or capabilities of the type may: correlate with other advertised properties or capabilities of the
system, such as how many memory heaps there are. system, such as how many memory heaps there are.
Properties of queues available on a physical device are queried by calling: Properties of queues available on a physical device are queried by calling:
@ -166,12 +164,10 @@ written.
include::../validity/protos/vkGetPhysicalDeviceQueueFamilyProperties.txt[] include::../validity/protos/vkGetPhysicalDeviceQueueFamilyProperties.txt[]
The definition of sname:VkQueueFamilyProperties is: The sname:VkQueueFamilyProperties structure is defined as:
include::../structs/VkQueueFamilyProperties.txt[] include::../structs/VkQueueFamilyProperties.txt[]
The members of sname:VkQueueFamilyProperties have the following meanings:
* pname:queueFlags contains flags indicating the capabilities of the * pname:queueFlags contains flags indicating the capabilities of the
queues in this queue family. queues in this queue family.
* pname:queueCount is the unsigned integer count of queues in this * pname:queueCount is the unsigned integer count of queues in this
@ -231,10 +227,10 @@ Possible values of pname:minImageTransferGranularity are:
queues. In this case, the following restrictions apply to all offset and queues. In this case, the following restrictions apply to all offset and
extent parameters of image transfer operations: extent parameters of image transfer operations:
** The pname:x, pname:y, and pname:z members of a sname:VkOffset3D ** The pname:x, pname:y, and pname:z members of a slink:VkOffset3D
parameter must: always be zero. parameter must: always be zero.
** The pname:width, pname:height, and pname:depth members of a ** The pname:width, pname:height, and pname:depth members of a
sname:VkExtent3D parameter must: always match the width, height, and slink:VkExtent3D parameter must: always match the width, height, and
depth of the image subresource corresponding to the parameter, depth of the image subresource corresponding to the parameter,
respectively. respectively.
@ -242,18 +238,18 @@ Possible values of pname:minImageTransferGranularity are:
and latexmath:[$Az$] are all integer powers of two. In this case the and latexmath:[$Az$] are all integer powers of two. In this case the
following restrictions apply to all image transfer operations: following restrictions apply to all image transfer operations:
** pname:x, pname:y, and pname:z of a sname:VkOffset3D parameter must: be ** pname:x, pname:y, and pname:z of a slink:VkOffset3D parameter must: be
integer multiples of latexmath:[$Ax$], latexmath:[$Ay$], and integer multiples of latexmath:[$Ax$], latexmath:[$Ay$], and
latexmath:[$Az$], respectively. latexmath:[$Az$], respectively.
** pname:width of a sname:VkExtent3D parameter must: be an integer ** pname:width of a slink:VkExtent3D parameter must: be an integer
multiple of latexmath:[$Ax$], or else latexmath:[$(x + width)$] must: multiple of latexmath:[$Ax$], or else latexmath:[$(x + width)$] must:
equal the width of the image subresource corresponding to the equal the width of the image subresource corresponding to the
parameter. parameter.
** pname:height of a sname:VkExtent3D parameter must: be an integer ** pname:height of a slink:VkExtent3D parameter must: be an integer
multiple of latexmath:[$Ay$], or else latexmath:[$(y + height)$] must: multiple of latexmath:[$Ay$], or else latexmath:[$(y + height)$] must:
equal the height of the image subresource corresponding to the equal the height of the image subresource corresponding to the
parameter. parameter.
** pname:depth of a sname:VkExtent3D parameter must: be an integer ** pname:depth of a slink:VkExtent3D parameter must: be an integer
multiple of latexmath:[$Az$], or else latexmath:[$(z + depth)$] must: multiple of latexmath:[$Az$], or else latexmath:[$(z + depth)$] must:
equal the depth of the image subresource corresponding to the equal the depth of the image subresource corresponding to the
parameter. parameter.
@ -309,7 +305,7 @@ include::../protos/vkCreateDevice.txt[]
call to fname:vkEnumeratePhysicalDevices (see call to fname:vkEnumeratePhysicalDevices (see
<<devsandqueues-physical-device-enumeration, Physical Device <<devsandqueues-physical-device-enumeration, Physical Device
Enumeration>>). Enumeration>>).
* pname:pCreateInfo is a pointer to a sname:VkDeviceCreateInfo structure * pname:pCreateInfo is a pointer to a slink:VkDeviceCreateInfo structure
containing information about how to create the device. containing information about how to create the device.
* pname:pAllocator controls host memory allocation as described in the * pname:pAllocator controls host memory allocation as described in the
<<memory-allocation, Memory Allocation>> chapter. <<memory-allocation, Memory Allocation>> chapter.
@ -318,12 +314,10 @@ include::../protos/vkCreateDevice.txt[]
include::../validity/protos/vkCreateDevice.txt[] include::../validity/protos/vkCreateDevice.txt[]
The definition of sname:VkDeviceCreateInfo is: The sname:VkDeviceCreateInfo structure is defined as:
include::../structs/VkDeviceCreateInfo.txt[] include::../structs/VkDeviceCreateInfo.txt[]
The members of sname:VkDeviceCreateInfo have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -332,7 +326,7 @@ The members of sname:VkDeviceCreateInfo have the following meanings:
<<devsandqueues-queue-creation,Queue Creation>> section below for <<devsandqueues-queue-creation,Queue Creation>> section below for
further details. further details.
* pname:pQueueCreateInfos is a pointer to an array of * pname:pQueueCreateInfos is a pointer to an array of
sname:VkDeviceQueueCreateInfo structures describing the queues that are slink:VkDeviceQueueCreateInfo structures describing the queues that are
requested to be created along with the logical device. Refer to the requested to be created along with the logical device. Refer to the
<<devsandqueues-queue-creation,Queue Creation>> section below for <<devsandqueues-queue-creation,Queue Creation>> section below for
further details. further details.
@ -346,10 +340,10 @@ The members of sname:VkDeviceCreateInfo have the following meanings:
* pname:ppEnabledExtensionNames is a pointer to an array of * pname:ppEnabledExtensionNames is a pointer to an array of
pname:enabledExtensionCount null-terminated UTF-8 strings containing the pname:enabledExtensionCount null-terminated UTF-8 strings containing the
names of extensions to enable for the created device. See the names of extensions to enable for the created device. See the
<<querying-layers-and-extensions,Querying Layers and Extensions>> <<extended-functionality-extensions,Extensions>> section for further
chapter for further details. details.
* pname:pEnabledFeatures is `NULL` or a pointer to a * pname:pEnabledFeatures is `NULL` or a pointer to a
sname:VkPhysicalDeviceFeatures structure that contains boolean slink:VkPhysicalDeviceFeatures structure that contains boolean
indicators of all the features to be enabled. Refer to the indicators of all the features to be enabled. Refer to the
<<features-features,Features>> section for further details. <<features-features,Features>> section for further details.
@ -440,12 +434,12 @@ or that the error is recoverable.
When a device is lost, its child objects are not implicitly destroyed and When a device is lost, its child objects are not implicitly destroyed and
their handles are still valid. Those objects must: still be destroyed before their handles are still valid. Those objects must: still be destroyed before
their parents or the device can: be destroyed (see their parents or the device can: be destroyed (see the
<<objectmodel-lifetime,Lifetime>>). The host address space corresponding to <<fundamentals-objectmodel-lifetime,Object Lifetime>> section). The host
device memory mapped using flink:vkMapMemory is still valid, and host memory address space corresponding to device memory mapped using flink:vkMapMemory
accesses to these mapped regions are still valid, but the contents are is still valid, and host memory accesses to these mapped regions are still
undefined. It is still legal to call any API command on the device and child valid, but the contents are undefined. It is still legal to call any API
objects. command on the device and child objects.
Once a device is lost, command execution may: fail, and commands that return Once a device is lost, command execution may: fail, and commands that return
a basetype:VkResult may: return ename:VK_ERROR_DEVICE_LOST. Commands that do a basetype:VkResult may: return ename:VK_ERROR_DEVICE_LOST. Commands that do
@ -544,14 +538,13 @@ device. This is described in the following section.
Creating a logical device also creates the queues associated with that Creating a logical device also creates the queues associated with that
device. The queues to create are described by a set of device. The queues to create are described by a set of
sname:VkDeviceQueueCreateInfo structures that are passed to slink:VkDeviceQueueCreateInfo structures that are passed to
flink:vkCreateDevice in pname:pQueueCreateInfos. The definition of flink:vkCreateDevice in pname:pQueueCreateInfos.
sname:VkDeviceQueueCreateInfo is:
The sname:VkDeviceQueueCreateInfo structure is defined as:
include::../structs/VkDeviceQueueCreateInfo.txt[] include::../structs/VkDeviceQueueCreateInfo.txt[]
The members of sname:VkDeviceQueueCreateInfo have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -597,7 +590,7 @@ sname:VkQueue handle from as described in the previous section.
When creating a sname:VkCommandPool object (see When creating a sname:VkCommandPool object (see
<<commandbuffers-pools,Command Pools>>), a queue family index is specified <<commandbuffers-pools,Command Pools>>), a queue family index is specified
in the sname:VkCommandPoolCreateInfo structure. Command buffers from this in the slink:VkCommandPoolCreateInfo structure. Command buffers from this
pool can: only be submitted on queues corresponding to this queue family. pool can: only be submitted on queues corresponding to this queue family.
When creating sname:VkImage (see <<resources-images,Images>>) and When creating sname:VkImage (see <<resources-images,Images>>) and
@ -617,7 +610,7 @@ Sharing>> section for details.
=== Queue Priority === Queue Priority
Each queue is assigned a priority, as set in the Each queue is assigned a priority, as set in the
sname:VkDeviceQueueCreateInfo structures when creating the device. The slink:VkDeviceQueueCreateInfo structures when creating the device. The
priority of each queue is a normalized floating point value between 0.0 and priority of each queue is a normalized floating point value between 0.0 and
1.0, which is then translated to a discrete priority level by the 1.0, which is then translated to a discrete priority level by the
implementation. Higher values indicate a higher priority, with 0.0 being the implementation. Higher values indicate a higher priority, with 0.0 being the
@ -663,7 +656,7 @@ chapter.
=== Sparse Memory Binding === Sparse Memory Binding
In {apiname} it is possible to sparsely bind memory to buffers and In {apiname} it is possible to sparsely bind memory to buffers and
images as described in the <<sparsemem,Sparse Resource>> chapter. Sparse images as described in the <<sparsememory,Sparse Resource>> chapter. Sparse
memory binding is a queue operation. A queue whose flags include the memory binding is a queue operation. A queue whose flags include the
ename:VK_QUEUE_SPARSE_BINDING_BIT must: be able to support the ename:VK_QUEUE_SPARSE_BINDING_BIT must: be able to support the
mapping of a virtual address to a physical address on the device. This mapping of a virtual address to a physical address on the device. This

View File

@ -44,7 +44,7 @@ at pname:offset.
include::../validity/protos/vkCmdDispatchIndirect.txt[] include::../validity/protos/vkCmdDispatchIndirect.txt[]
The definition of sname:VkDispatchIndirectCommand is: The sname:VkDispatchIndirectCommand structure is defined as:
include::../structs/VkDispatchIndirectCommand.txt[] include::../structs/VkDispatchIndirectCommand.txt[]

View File

@ -336,8 +336,8 @@ ename:VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY, or
ename:VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP_WITH_ADJACENCY is rendered in ename:VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP_WITH_ADJACENCY is rendered in
one of several ways, such as outlining its border or filling its interior. one of several ways, such as outlining its border or filling its interior.
The order of vertices in such a primitive is significant during The order of vertices in such a primitive is significant during
<<primsrast-polygons-basic,polygon rasterization>> and <<ref-tbd,fragment <<primsrast-polygons-basic,polygon rasterization>> and
shading>>. <<shaders-fragment,fragment shading>>.
=== Programmable Primitive Shading === Programmable Primitive Shading
@ -481,7 +481,7 @@ less than or equal to one, pname:stride is ignored.
include::../validity/protos/vkCmdDrawIndirect.txt[] include::../validity/protos/vkCmdDrawIndirect.txt[]
The definition of sname:VkDrawIndirectCommand is: The sname:VkDrawIndirectCommand structure is defined as:
include::../structs/VkDrawIndirectCommand.txt[] include::../structs/VkDrawIndirectCommand.txt[]
@ -513,7 +513,7 @@ pname:drawCount is less than or equal to one, pname:stride is ignored.
include::../validity/protos/vkCmdDrawIndexedIndirect.txt[] include::../validity/protos/vkCmdDrawIndexedIndirect.txt[]
The definition of sname:VkDrawIndexedIndirectCommand is The sname:VkDrawIndexedIndirectCommand structure is defined as:
include::../structs/VkDrawIndexedIndirectCommand.txt[] include::../structs/VkDrawIndexedIndirectCommand.txt[]

View File

@ -45,7 +45,7 @@ include::../validity/protos/vkEnumerateInstanceLayerProperties.txt[]
To enable a instance layer, the name of the layer should be added to the To enable a instance layer, the name of the layer should be added to the
pname:ppEnabledLayerNames member of slink:VkInstanceCreateInfo when creating pname:ppEnabledLayerNames member of slink:VkInstanceCreateInfo when creating
a slink:VkInstance. a sname:VkInstance.
To query the layers available to a given physical device, call: To query the layers available to a given physical device, call:
@ -61,7 +61,7 @@ include::../validity/protos/vkEnumerateDeviceLayerProperties.txt[]
To enable a device layer, the name of the layer should be added to the To enable a device layer, the name of the layer should be added to the
pname:ppEnabledLayerNames member of slink:VkDeviceCreateInfo when creating pname:ppEnabledLayerNames member of slink:VkDeviceCreateInfo when creating
a slink:VkDevice. a sname:VkDevice.
For both flink:vkEnumerateInstanceLayerProperties and For both flink:vkEnumerateInstanceLayerProperties and
flink:vkEnumerateDeviceLayerProperties, if pname:pProperties is `NULL`, then flink:vkEnumerateDeviceLayerProperties, if pname:pProperties is `NULL`, then
@ -76,7 +76,7 @@ number of layers available, ename:VK_INCOMPLETE will be returned instead of
ename:VK_SUCCESS, to indicate that not all the available layer properties ename:VK_SUCCESS, to indicate that not all the available layer properties
were returned. were returned.
The definition of sname:VkLayerProperties is: The sname:VkLayerProperties structure is defined as:
include::../structs/VkLayerProperties.txt[] include::../structs/VkLayerProperties.txt[]
@ -104,6 +104,7 @@ and explicitly enabled layers differ only in the way they are enabled.
Explicitly enabling a layer that is implicitly enabled has no additional Explicitly enabling a layer that is implicitly enabled has no additional
effect. effect.
[[extended-functionality-extensions]] [[extended-functionality-extensions]]
== Extensions == Extensions
@ -137,7 +138,7 @@ provided by that layer are returned.
To enable a instance extension, the name of the extension should be added to To enable a instance extension, the name of the extension should be added to
the pname:ppEnabledExtensionNames member of slink:VkInstanceCreateInfo when the pname:ppEnabledExtensionNames member of slink:VkInstanceCreateInfo when
creating a slink:VkInstance. creating a sname:VkInstance.
To query the extensions available to a given physical device, call: To query the extensions available to a given physical device, call:
@ -160,7 +161,7 @@ provided by that layer are returned.
To enable a device layer, the name of the layer should be added to the To enable a device layer, the name of the layer should be added to the
pname:ppEnabledExtensionNames member of slink:VkDeviceCreateInfo when pname:ppEnabledExtensionNames member of slink:VkDeviceCreateInfo when
creating a slink:VkDevice. creating a sname:VkDevice.
For both flink:vkEnumerateInstanceExtensionProperties and For both flink:vkEnumerateInstanceExtensionProperties and
flink:vkEnumerateDeviceExtensionProperties, if pname:pProperties is `NULL`, flink:vkEnumerateDeviceExtensionProperties, if pname:pProperties is `NULL`,
@ -175,7 +176,7 @@ pname:pPropertyCount is smaller than the number of extensions available,
ename:VK_INCOMPLETE will be returned instead of ename:VK_SUCCESS, to ename:VK_INCOMPLETE will be returned instead of ename:VK_SUCCESS, to
indicate that not all the available properties were returned. indicate that not all the available properties were returned.
The definition of sname:VkExtensionProperties is: The sname:VkExtensionProperties structure is defined as:
include::../structs/VkExtensionProperties.txt[] include::../structs/VkExtensionProperties.txt[]

View File

@ -77,7 +77,7 @@ performance cost. Application writers should: carefully consider the
implications of enabling all supported features. implications of enabling all supported features.
==== ====
The definition of sname:VkPhysicalDeviceFeatures is: The sname:VkPhysicalDeviceFeatures structure is defined as:
include::../structs/VkPhysicalDeviceFeatures.txt[] include::../structs/VkPhysicalDeviceFeatures.txt[]
@ -112,7 +112,7 @@ following features:
* [[features-features-imageCubeArray]] pname:imageCubeArray indicates * [[features-features-imageCubeArray]] pname:imageCubeArray indicates
whether image views with a elink:VkImageViewType of whether image views with a elink:VkImageViewType of
ename:VK_IMAGE_VIEW_TYPE_CUBE_ARRAY can: be created, and that the ename:VK_IMAGE_VIEW_TYPE_CUBE_ARRAY can: be created, and that the
corresponding *SampledCubeArray* and *ImageCubeArray* SPIR-V corresponding code:SampledCubeArray and code:ImageCubeArray SPIR-V
capabilities can: be used in shader code. capabilities can: be used in shader code.
* [[features-features-independentBlend]] pname:independentBlend indicates * [[features-features-independentBlend]] pname:independentBlend indicates
whether the sname:VkPipelineColorBlendAttachmentState settings are whether the sname:VkPipelineColorBlendAttachmentState settings are
@ -556,7 +556,7 @@ check for the supported properties of individual formats.
the same multisample rate. This has no effect in situations where a the same multisample rate. This has no effect in situations where a
subpass uses any attachments. subpass uses any attachments.
* [[features-features-inheritedQueries]] pname:inheritedQueries indicates * [[features-features-inheritedQueries]] pname:inheritedQueries indicates
whether a secondary command buffer may be executed while a query is whether a secondary command buffer may: be executed while a query is
active. active.
include::../validity/structs/VkPhysicalDeviceFeatures.txt[] include::../validity/structs/VkPhysicalDeviceFeatures.txt[]
@ -582,7 +582,7 @@ device. These are available in the pname:limits member of the
slink:VkPhysicalDeviceProperties structure which is returned from slink:VkPhysicalDeviceProperties structure which is returned from
flink:vkGetPhysicalDeviceProperties. flink:vkGetPhysicalDeviceProperties.
The definition of sname:VkPhysicalDeviceLimits is: The sname:VkPhysicalDeviceLimits structure is defined as:
include::../structs/VkPhysicalDeviceLimits.txt[] include::../structs/VkPhysicalDeviceLimits.txt[]
@ -1212,8 +1212,8 @@ range.
// End of list // End of list
1:: 1::
For all bitmasks of type elink:VkSampleCountFlags above, the bits which For all bitmasks of type ename:VkSampleCountFlags above, possible
can: be set include: values include:
+ +
-- --
include::../enums/VkSampleCountFlagBits.txt[] include::../enums/VkSampleCountFlagBits.txt[]
@ -3147,7 +3147,7 @@ include::../validity/structs/VkFormatProperties.txt[]
Implementations must: support at least the following set of Implementations must: support at least the following set of
features on the listed formats. For images, these features must: features on the listed formats. For images, these features must:
be supported for every slink:VkImageType (including arrayed and cube be supported for every elink:VkImageType (including arrayed and cube
variants) unless otherwise noted. These features are supported variants) unless otherwise noted. These features are supported
on existing formats without needing to advertise an extension or on existing formats without needing to advertise an extension or
needing to explicitly enable them. Support for additional functionality needing to explicitly enable them. Support for additional functionality
@ -3481,7 +3481,7 @@ ename:VK_FORMAT_D24_UNORM_S8_UINT and ename:VK_FORMAT_D32_SFLOAT_S8_UINT.
<<< <<<
[[features-formats-mandatory-features-bcn]] [[features-formats-mandatory-features-bcn]]
.Mandatory format support: BC compressed formats with slink:VkImageType ename:VK_IMAGE_TYPE_2D and ename:VK_IMAGE_TYPE_3D .Mandatory format support: BC compressed formats with elink:VkImageType ename:VK_IMAGE_TYPE_2D and ename:VK_IMAGE_TYPE_3D
[width="100%",cols="62,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1",options="unbreakable"] [width="100%",cols="62,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1",options="unbreakable"]
|========================================= |=========================================
14+>| ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT 14+>| ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT
@ -3525,7 +3525,7 @@ one of: this table, <<features-formats-mandatory-features-etc>>, or
<<< <<<
[[features-formats-mandatory-features-etc]] [[features-formats-mandatory-features-etc]]
.Mandatory format support: ETC2 and EAC compressed formats with slink:VkImageType ename:VK_IMAGE_TYPE_2D .Mandatory format support: ETC2 and EAC compressed formats with elink:VkImageType ename:VK_IMAGE_TYPE_2D
[width="100%",cols="62,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1",options="unbreakable"] [width="100%",cols="62,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1",options="unbreakable"]
|========================================= |=========================================
14+>| ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT 14+>| ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT
@ -3563,7 +3563,7 @@ one of: this table, <<features-formats-mandatory-features-bcn>>, or
<<< <<<
[[features-formats-mandatory-features-astc]] [[features-formats-mandatory-features-astc]]
.Mandatory format support: ASTC LDR compressed formats with slink:VkImageType ename:VK_IMAGE_TYPE_2D .Mandatory format support: ASTC LDR compressed formats with elink:VkImageType ename:VK_IMAGE_TYPE_2D
[width="100%",cols="62,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1",options="unbreakable"] [width="100%",cols="62,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1,^1",options="unbreakable"]
|========================================= |=========================================
14+>| ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT 14+>| ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT
@ -3651,19 +3651,23 @@ flink:vkCreateImage.
include::../validity/protos/vkGetPhysicalDeviceImageFormatProperties.txt[] include::../validity/protos/vkGetPhysicalDeviceImageFormatProperties.txt[]
The definition of the sname:VkImageFormatProperties structure is: The sname:VkImageFormatProperties structure is defined as:
include::../structs/VkImageFormatProperties.txt[] include::../structs/VkImageFormatProperties.txt[]
* pname:maxExtent are the maximum image dimensions. See the * pname:maxExtent are the maximum image dimensions. See the
<<features-extentperimagetype,Allowed extent values based on imageType>> <<features-extentperimagetype,Allowed Extent Values>> section below for
table below for how these values are constrained by pname:type. how these values are constrained by pname:type.
* pname:maxMipLevels is the maximum number of mipmap levels. * pname:maxMipLevels is the maximum number of mipmap levels.
pname:maxMipLevels must: either be equal to 1 (valid only if pname:maxMipLevels must: either be equal to 1 (valid only if
pname:tiling is ename:VK_IMAGE_TILING_LINEAR) or be greater than or pname:tiling is ename:VK_IMAGE_TILING_LINEAR) or be
equal to the latexmath:[$log_2$] of the pname:maxImageDimension1D, equal to
pname:maxImageDimension2D, or pname:maxImageDimension3D (depending on latexmath:[$\left\lceil\log_2(\max(
pname:type) members of slink:VkPhysicalDeviceLimits. \mathit{width},\mathit{height},\mathit{depth}))
\right\rceil + 1$]
where latexmath:[$\mathit{width}$], latexmath:[$\mathit{height}$], and
latexmath:[$\mathit{depth}$] are taken from the corresponding members of
pname:maxExtent.
* pname:maxArrayLayers is the maximum number of array layers. * pname:maxArrayLayers is the maximum number of array layers.
pname:maxArrayLayers must: either be equal to 1 or be greater than or pname:maxArrayLayers must: either be equal to 1 or be greater than or
equal to the pname:maxImageArrayLayers member of equal to the pname:maxImageArrayLayers member of
@ -3685,7 +3689,7 @@ include::../structs/VkImageFormatProperties.txt[]
pname:storageImageSampleCounts. For depth/stencil images with both a pname:storageImageSampleCounts. For depth/stencil images with both a
depth and stencil component, both the depth and stencil limits must: be depth and stencil component, both the depth and stencil limits must: be
satisfied. satisfied.
* pname:maxResourceSize is the maximum total image size in bytes, * pname:maxResourceSize is an upper bound on the total image size in bytes,
inclusive of all image subresources. Implementations may: have an inclusive of all image subresources. Implementations may: have an
address space limit on total size of a resource, which is advertised by address space limit on total size of a resource, which is advertised by
this property. pname:maxResourceSize must: be at least 2^31^. this property. pname:maxResourceSize must: be at least 2^31^.
@ -3696,7 +3700,9 @@ include::../structs/VkImageFormatProperties.txt[]
There is no mechanism to query the size of an image before creating it, to There is no mechanism to query the size of an image before creating it, to
compare that size against pname:maxResourceSize. If an application attempts compare that size against pname:maxResourceSize. If an application attempts
to create an image that exceeds this limit, the creation will fail or the to create an image that exceeds this limit, the creation will fail or the
image will be invalid. image will be invalid. While the advertised limit must: be at least 2^31^,
it may: not be possible to create an image that approaches that size,
particularly for ename:VK_IMAGE_TYPE_1D.
==== ====
If the combination of parameters to If the combination of parameters to
@ -3706,25 +3712,6 @@ sname:VkImageFormatProperties will be filled with zero.
include::../validity/structs/VkImageFormatProperties.txt[] include::../validity/structs/VkImageFormatProperties.txt[]
[[features-extentperimagetype]]
.Allowed extent values based on imageType
[cols="1a,1a", options="header"]
|====
| VkImageType | maxExtent values
| VK_IMAGE_TYPE_1D |
width >= 1 +
height = 1 +
depth = 1 +
| VK_IMAGE_TYPE_2D |
width >= 1 +
height >= 1 +
depth = 1 +
| VK_IMAGE_TYPE_3D |
width >= 1 +
height >= 1 +
depth >= 1 +
|====
If pname:format is not a supported image format, or if the combination of If pname:format is not a supported image format, or if the combination of
pname:format, pname:type, pname:tiling, pname:usage, and pname:flags is not pname:format, pname:type, pname:tiling, pname:usage, and pname:flags is not
supported for images, then fname:vkGetPhysicalDeviceImageFormatProperties supported for images, then fname:vkGetPhysicalDeviceImageFormatProperties
@ -3732,10 +3719,37 @@ returns ename:VK_ERROR_FORMAT_NOT_SUPPORTED.
The limitations on an image format that are reported by The limitations on an image format that are reported by
fname:vkGetPhysicalDeviceImageFormatProperties have the following property: fname:vkGetPhysicalDeviceImageFormatProperties have the following property:
if code:usage1 and code:usage2 of type elink:VkImageUsageFlags are such that if code:usage1 and code:usage2 of type ename:VkImageUsageFlags are such that
the bits set in code:usage1 are a subset of the bits set in code:usage2, and the bits set in code:usage1 are a subset of the bits set in code:usage2, and
code:flags1 and code:flags2 of type elink:VkImageCreateFlags are such that code:flags1 and code:flags2 of type ename:VkImageCreateFlags are such that
the bits set in code:flags1 are a subset of the bits set in code:flags2, the bits set in code:flags1 are a subset of the bits set in code:flags2,
then the limitations for code:usage1 and code:flags1 must: be no more strict then the limitations for code:usage1 and code:flags1 must: be no more strict
than the limitations for code:usage2 and code:flags2, for all values of than the limitations for code:usage2 and code:flags2, for all values of
pname:format, pname:type, and pname:tiling. pname:format, pname:type, and pname:tiling.
[[features-extentperimagetype]]
=== Allowed Extent Values Based On Image Type
For ename:VK_IMAGE_TYPE_1D:
* pname:maxExtent.width >=
slink:VkPhysicalDeviceLimits::pname:maxImageDimension1D
* pname:maxExtent.height = 1
* pname:maxExtent.depth = 1
For ename:VK_IMAGE_TYPE_2D:
* pname:maxExtent.width >=
slink:VkPhysicalDeviceLimits::pname:maxImageDimension2D
* pname:maxExtent.height >=
slink:VkPhysicalDeviceLimits::pname:maxImageDimension2D
* pname:maxExtent.depth = 1
For ename:VK_IMAGE_TYPE_3D:
* pname:maxExtent.width >=
slink:VkPhysicalDeviceLimits::pname:maxImageDimension3D
* pname:maxExtent.height >=
slink:VkPhysicalDeviceLimits::pname:maxImageDimension3D
* pname:maxExtent.depth >=
slink:VkPhysicalDeviceLimits::pname:maxImageDimension3D

View File

@ -140,10 +140,20 @@ latexmath:[$(x_f,y_f)$] and depth latexmath:[$z$], as described in
fragment processing, which adds associated data as described in fragment processing, which adds associated data as described in
<<shaders,Shaders>>. The fragment is then further modified, and possibly <<shaders,Shaders>>. The fragment is then further modified, and possibly
discarded by the late per-fragment operations described in this chapter. discarded by the late per-fragment operations described in this chapter.
These operations are diagrammed in figure <<fig-fragops,Fragment Finally, if the fragment was not discarded, it is used to update the
Operations>>, in the order in which they are performed. Finally, if the framebuffer at the fragment's framebuffer coordinates for any samples that
fragment was not discarded, it is used to update the framebuffer at the remain covered.
fragment's framebuffer coordinates for any samples that remain covered.
ifdef::editing-notes[]
[NOTE]
.editing-note
==================
There used to be a sentence of form "These operations are diagrammed in
figure ((fig-fragops,Fragment Operations)), in the order in which they are
performed" following "described in this chapter." above, but the referred
figure doesn't yet exist.
==================
endif::editing-notes[]
The depth bounds test, stencil test, and depth test are performed for each The depth bounds test, stencil test, and depth test are performed for each
pixel sample, rather than just once for each fragment. Stencil and depth pixel sample, rather than just once for each fragment. Stencil and depth
@ -186,9 +196,9 @@ of the slink:VkPipelineMultisampleStateCreateInfo structure.
All alpha values in this section refer only to the alpha component of the All alpha values in this section refer only to the alpha component of the
fragment shader output that has a code:Location and code:Index decoration of fragment shader output that has a code:Location and code:Index decoration of
zero (see <<pipelines-linking-fragmentoutput,Fragment Output Interface>>). zero (see the <<interfaces-fragmentoutput,Fragment Output Interface>>
If that shader output has an integer or unsigned integer type, then these section). If that shader output has an integer or unsigned integer type,
operations are skipped. then these operations are skipped.
If pname:alphaToCoverageEnable is enabled, a temporary coverage value is If pname:alphaToCoverageEnable is enabled, a temporary coverage value is
generated where each bit is determined by the fragment's alpha value. The generated where each bit is determined by the fragment's alpha value. The
@ -213,19 +223,19 @@ Next, if pname:alphaToOneEnable is enabled, each alpha value is replaced by
the maximum representable alpha value for fixed-point color buffers, or by the maximum representable alpha value for fixed-point color buffers, or by
1.0 for floating-point buffers. Otherwise, the alpha values are not changed. 1.0 for floating-point buffers. Otherwise, the alpha values are not changed.
[[fragops-ds-state]] [[fragops-ds-state]]
== Depth and Stencil Operations == Depth and Stencil Operations
Pipeline state controlling the <<fragops-dbt,depth bounds tests>>, Pipeline state controlling the <<fragops-dbt,depth bounds tests>>,
<<fragops-stencil,stencil test>>, and <<fragops-depth,depth test>> is <<fragops-stencil,stencil test>>, and <<fragops-depth,depth test>> is
specified through the members of specified through the members of the
sname:VkPipelineDepthStencilStateCreateInfo: sname:VkPipelineDepthStencilStateCreateInfo structure.
The sname:VkPipelineDepthStencilStateCreateInfo structure is defined as:
include::../structs/VkPipelineDepthStencilStateCreateInfo.txt[] include::../structs/VkPipelineDepthStencilStateCreateInfo.txt[]
The members of sname:VkPipelineDepthStencilStateCreateInfo structure are as
follows:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -297,12 +307,10 @@ The stencil test is controlled with the pname:front and pname:back members
of sname:VkPipelineDepthStencilStateCreateInfo which are of type of sname:VkPipelineDepthStencilStateCreateInfo which are of type
sname:VkStencilOpState. sname:VkStencilOpState.
The definition of sname:VkStencilOpState is: The sname:VkStencilOpState structure is defined as:
include::../structs/VkStencilOpState.txt[] include::../structs/VkStencilOpState.txt[]
The members of sname:VkStencilOpState structure are as follows:
* pname:failOp is the action performed on samples that fail the stencil * pname:failOp is the action performed on samples that fail the stencil
test. test.
* pname:passOp is the action performed on samples that pass both the depth * pname:passOp is the action performed on samples that pass both the depth
@ -328,7 +336,7 @@ back-facing polygon primitives. For the purposes of stencil testing, a
primitive is still considered a polygon even if the polygon is to be primitive is still considered a polygon even if the polygon is to be
rasterized as points or lines due to the current elink:VkPolygonMode. rasterized as points or lines due to the current elink:VkPolygonMode.
Whether a polygon is front- or back-facing is determined in the same manner Whether a polygon is front- or back-facing is determined in the same manner
used for face culling (see <<primsrast-triangles-basic,Basic Triangle used for face culling (see <<primsrast-polygons-basic,Basic Polygon
Rasterization>>). Rasterization>>).
The operation of the stencil test is also affected by the The operation of the stencil test is also affected by the
@ -349,7 +357,7 @@ include::../protos/vkCmdSetStencilCompareMask.txt[]
* pname:commandBuffer is the command buffer into which the command will be * pname:commandBuffer is the command buffer into which the command will be
recorded. recorded.
* pname:faceMask is a bitmask specifying the set of stencil state for * pname:faceMask is a bitmask specifying the set of stencil state for
which to update the compare mask, and may include the bits: which to update the compare mask. Bits which can: be set include:
+ +
-- --
include::../enums/VkStencilFaceFlagBits.txt[] include::../enums/VkStencilFaceFlagBits.txt[]
@ -426,7 +434,7 @@ include::../enums/VkCompareOp.txt[]
As described earlier, the pname:failOp, pname:passOp, and pname:depthFailOp As described earlier, the pname:failOp, pname:passOp, and pname:depthFailOp
members of pname:VkStencilOpState indicate what happens to the stored members of pname:VkStencilOpState indicate what happens to the stored
stencil value if this or certain subsequent tests fail or pass. Each enum is stencil value if this or certain subsequent tests fail or pass. Each enum is
of type ename:VkStencilOp, which is defined as: of type elink:VkStencilOp, which is defined as:
include::../enums/VkStencilOp.txt[] include::../enums/VkStencilOp.txt[]

View File

@ -34,13 +34,12 @@ Blending applies only to fixed-point and floating-point color attachments.
If the color attachment has an integer format, blending is not applied. If the color attachment has an integer format, blending is not applied.
The pipeline blend state is included in the The pipeline blend state is included in the
sname:VkPipelineColorBlendStateCreateInfo struct during graphics pipeline sname:VkPipelineColorBlendStateCreateInfo structure during graphics pipeline
creation: creation:
include::../structs/VkPipelineColorBlendStateCreateInfo.txt[] The sname:VkPipelineColorBlendStateCreateInfo structure is defined as:
The members of the sname:VkPipelineColorBlendStateCreateInfo structure are include::../structs/VkPipelineColorBlendStateCreateInfo.txt[]
as follows:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
@ -60,19 +59,17 @@ as follows:
include::../validity/structs/VkPipelineColorBlendStateCreateInfo.txt[] include::../validity/structs/VkPipelineColorBlendStateCreateInfo.txt[]
The elements of the pname:pAttachments array specify per-target blending Each element of the pname:pAttachments array is a
state, and are of type: slink:VkPipelineColorBlendAttachmentState structure specifying per-target
blending state for each individual color attachment. If the
<<features-features-independentBlend,independent blending>> feature is not
enabled on the device, all slink:VkPipelineColorBlendAttachmentState
elements in the pname:pAttachments array must: be identical.
The sname:VkPipelineColorBlendAttachmentState structure is defined as:
include::../structs/VkPipelineColorBlendAttachmentState.txt[] include::../structs/VkPipelineColorBlendAttachmentState.txt[]
Blending of each individual color attachment is controlled by the
corresponding element of the pname:pAttachments array. If the
<<features-features-independent-blending,independent blending>> feature is
not enabled on the device, all sname:VkPipelineColorBlendAttachmentState
elements in the pname:pAttachments array must: be identical. The members of
the sname:VkPipelineColorBlendAttachmentState struct have the following
meanings:
* pname:blendEnable controls whether blending is enabled for the * pname:blendEnable controls whether blending is enabled for the
corresponding color attachment. If blending is not enabled, the source corresponding color attachment. If blending is not enabled, the source
fragment's color for that attachment is passed through unmodified. fragment's color for that attachment is passed through unmodified.

View File

@ -59,9 +59,9 @@ This section outlines the execution model of a {apiname} system.
{apiname} exposes one or more _devices_, {apiname} exposes one or more _devices_,
each of which exposes one or more _queues_ which may: process work each of which exposes one or more _queues_ which may: process work
asynchronously to one another. The queues supported by a device are divided asynchronously to one another. The set of queues supported by a device is
into _families_, each of which supports one or more types of functionality partitioned into _families_. Each family supports one or more types of
and may: functionality and may:
contain multiple queues with similar characteristics. Queues within a single contain multiple queues with similar characteristics. Queues within a single
family are considered _compatible_ with one another, and work produced for a family are considered _compatible_ with one another, and work produced for a
family of queues can: be executed on any queue within that family. This family of queues can: be executed on any queue within that family. This
@ -71,8 +71,8 @@ graphics, compute, transfer, and sparse memory management.
[NOTE] [NOTE]
.Note .Note
==== ====
It is possible that a single device may: report multiple similar queue A single device may: report multiple similar queue
families rather than, or as well as reporting multiple members of one or families rather than, or as well as, reporting multiple members of one or
more of those families. This indicates that while members of those families more of those families. This indicates that while members of those families
have similar capabilities, they are _not_ directly compatible with one have similar capabilities, they are _not_ directly compatible with one
another. another.
@ -186,7 +186,7 @@ commands depends on the first set of commands. These dependencies enforce
that both the execution of certain that both the execution of certain
<<synchronization-pipeline-stage-flags,pipeline stages>> in the later set <<synchronization-pipeline-stage-flags,pipeline stages>> in the later set
occur after the execution of certain stages in the source set, and that the occur after the execution of certain stages in the source set, and that the
effects of <<synchronization-access-flags,memory accesses>> performed by effects of <<synchronization-global-memory-barrier,memory accesses>> performed by
certain pipeline stages occur in order and are visible to each other. When certain pipeline stages occur in order and are visible to each other. When
not enforced by an explicit dependency or otherwise forbidden by the not enforced by an explicit dependency or otherwise forbidden by the
specification, action commands may: overlap execution or execute out of specification, action commands may: overlap execution or execute out of
@ -293,7 +293,7 @@ the commands that consume it have returned.
The following object types are consumed when they are passed into a The following object types are consumed when they are passed into a
{apiname} command and not further accessed by the objects they are used to {apiname} command and not further accessed by the objects they are used to
create. They can be destroyed at any time they are not in use by an API create. They can: be destroyed at any time they are not in use by an API
command: command:
* sname:VkShaderModule * sname:VkShaderModule
@ -304,7 +304,7 @@ sname:VkDescriptorSetLayout objects may: be accessed by commands that
operate on descriptor sets allocated using that layout, and those descriptor operate on descriptor sets allocated using that layout, and those descriptor
sets mustnot: be updated with flink:vkUpdateDescriptorSets after the sets mustnot: be updated with flink:vkUpdateDescriptorSets after the
descriptor set layout has been destroyed. Otherwise, descriptor set layouts descriptor set layout has been destroyed. Otherwise, descriptor set layouts
can be destroyed any time they are not in use by an API command. can: be destroyed any time they are not in use by an API command.
The application mustnot: destroy any other type of {apiname} object until The application mustnot: destroy any other type of {apiname} object until
all uses of that object by the device (such as via command buffer execution) all uses of that object by the device (such as via command buffer execution)
@ -433,7 +433,7 @@ ftext:vkGet*.
Commands are recorded into a command buffer by calling API commands of the Commands are recorded into a command buffer by calling API commands of the
form ftext:vkCmd*. Each such command may: have different restrictions on form ftext:vkCmd*. Each such command may: have different restrictions on
where it can be used: in a primary and/or secondary command buffer, inside where it can: be used: in a primary and/or secondary command buffer, inside
and/or outside a render pass, and in one or more of the supported queue and/or outside a render pass, and in one or more of the supported queue
types. These restrictions are documented together with the definition of types. These restrictions are documented together with the definition of
each such command. each such command.
@ -556,10 +556,10 @@ object handle, unless otherwise specified. An object handle is valid if:
* Any objects used by that object, either as part of creation or * Any objects used by that object, either as part of creation or
execution, must: also be valid. execution, must: also be valid.
The reserved handle sname:VK_NULL_HANDLE can: be passed in place of valid The reserved handle code:VK_NULL_HANDLE can: be passed in place of valid
object handles when _explicitly called out in the specification_. Any object handles when _explicitly called out in the specification_. Any
command that creates an object successfully mustnot: return command that creates an object successfully mustnot: return
sname:VK_NULL_HANDLE. It is valid to pass sname:VK_NULL_HANDLE to any code:VK_NULL_HANDLE. It is valid to pass code:VK_NULL_HANDLE to any
ftext:vkDestroy* or ftext:vkFree* command, which will silently ignore these ftext:vkDestroy* or ftext:vkFree* command, which will silently ignore these
values. values.
@ -584,7 +584,7 @@ flags. A bit flag is valid if:
* The flag is defined as part of the bits type, where the bits type is * The flag is defined as part of the bits type, where the bits type is
obtained by taking the flag type and replacing the trailing etext:Flags obtained by taking the flag type and replacing the trailing etext:Flags
with etext:FlagBits. For example, a flag value of type with etext:FlagBits. For example, a flag value of type
elink:VkColorComponentFlags must: contain only values selected from the ename:VkColorComponentFlags must: contain only values selected from the
bit flags in elink:VkColorComponentFlagBits. bit flags in elink:VkColorComponentFlagBits.
* The flag is allowed in the context in which it is being used. For * The flag is allowed in the context in which it is being used. For
example, in some cases, certain bit flags or combinations of bit flags example, in some cases, certain bit flags or combinations of bit flags
@ -606,11 +606,16 @@ use by the loader, and don't have corresponding {apiname} structures in this
specification. specification.
Any parameter that is a structure containing a basetype:void* ptext:pNext Any parameter that is a structure containing a basetype:void* ptext:pNext
member must: have a value of ptext:pNext that is either `NULL`, or points to member must: have a value of ptext:pNext that is either `NULL`, or points to a
a valid structure that is defined by an enabled extension. Extension valid structure defined by an extension. If that extension is supported by
structures are not described in the base {apiname} specification, but either the implementation, then it must: be enabled.
in layered specifications incorporating those extensions, or in separate Any component of the implementation (the loader, any enabled layers, and
vendor-provided documents. drivers) must: ignore extension structures with pname:sType values defined
by extensions not supported by that component.
Extension structures are not described in the base {apiname} specification,
but either in layered specifications incorporating those extensions,
or in separate vendor-provided documents.
The above rules also apply recursively to members of structures provided as The above rules also apply recursively to members of structures provided as
input to a command, either as a direct argument to the command, or input to a command, either as a direct argument to the command, or
@ -734,11 +739,11 @@ ifdef::editing-notes[]
.editing-note .editing-note
==== ====
(Jon, Bug 14966) This is a rat's nest of complexity, both in terms of (Jon, Bug 14966) This is a rat's nest of complexity, both in terms of
describing/enumerating places such computation may take place (other than describing/enumerating places such computation may: take place (other than
``not shader code'') and in how implementations may do it. We have consciously ``not shader code'') and in how implementations may: do it. We have consciously
deferred the resolution of this issue to post-1.0, and in the meantime, the deferred the resolution of this issue to post-1.0, and in the meantime, the
following language inherited from the OpenGL Specification is inserted as a following language inherited from the OpenGL Specification is inserted as a
placeholder. Hopefully it can be tightened up considerably. placeholder. Hopefully it can: be tightened up considerably.
==== ====
endif::editing-notes[] endif::editing-notes[]

View File

@ -258,15 +258,14 @@ will result in an invalid pipeline.
== Vertex Input Description == Vertex Input Description
Applications specify vertex input attribute and vertex input binding Applications specify vertex input attribute and vertex input binding
descriptions as part of graphics pipeline creation, via the descriptions as part of graphics pipeline creation. The
pname:pVertexInputState member of sname:VkGraphicsPipelineCreateInfo, which slink:VkGraphicsPipelineCreateInfo::pname:pVertexInputState points to a
is of type sname:VkPipelineVertexInputStateCreateInfo: structure of type sname:VkPipelineVertexInputStateCreateInfo.
The sname:VkPipelineVertexInputStateCreateInfo structure is defined as:
include::../structs/VkPipelineVertexInputStateCreateInfo.txt[] include::../structs/VkPipelineVertexInputStateCreateInfo.txt[]
The members of sname:VkPipelineVertexInputStateCreateInfo have the following
meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -282,13 +281,12 @@ meanings:
include::../validity/structs/VkPipelineVertexInputStateCreateInfo.txt[] include::../validity/structs/VkPipelineVertexInputStateCreateInfo.txt[]
Each vertex input binding is specified by an instance of the Each vertex input binding is specified by an instance of the
sname:VkVertexInputBindingDescription structure: sname:VkVertexInputBindingDescription structure.
The sname:VkVertexInputBindingDescription structure is defined as:
include::../structs/VkVertexInputBindingDescription.txt[] include::../structs/VkVertexInputBindingDescription.txt[]
The members of sname:VkVertexInputBindingDescription have the following
meanings:
* pname:binding is the binding number that this structure * pname:binding is the binding number that this structure
describes. describes.
* pname:stride is the distance in bytes between two * pname:stride is the distance in bytes between two
@ -299,7 +297,7 @@ meanings:
include::../validity/structs/VkVertexInputBindingDescription.txt[] include::../validity/structs/VkVertexInputBindingDescription.txt[]
The definition of elink:VkVertexInputRate is: elink:VkVertexInputRate is defined as:
include::../enums/VkVertexInputRate.txt[] include::../enums/VkVertexInputRate.txt[]
@ -311,13 +309,12 @@ The values of elink:VkVertexInputRate have the following meanings:
addressing is a function of the instance index. addressing is a function of the instance index.
Each vertex input attribute is specified by an instance of the Each vertex input attribute is specified by an instance of the
sname:VkVertexInputAttributeDescription structure: sname:VkVertexInputAttributeDescription structure.
The sname:VkVertexInputAttributeDescription structure is defined as:
include::../structs/VkVertexInputAttributeDescription.txt[] include::../structs/VkVertexInputAttributeDescription.txt[]
The members of sname:VkVertexInputAttributeDescription have the following
meanings:
* pname:location is the shader binding location number for this * pname:location is the shader binding location number for this
attribute. attribute.
* pname:binding is the binding number which this attribute takes * pname:binding is the binding number which this attribute takes

View File

@ -5,7 +5,7 @@
= Initialization = Initialization
Before using {apiname}, an application must: initialize it by loading the Before using {apiname}, an application must: initialize it by loading the
{apiname} commands, and creating a slink:VkInstance object. {apiname} commands, and creating a sname:VkInstance object.
[[initialization-functionpointers]] [[initialization-functionpointers]]
== Command Function Pointers == Command Function Pointers
@ -34,9 +34,9 @@ Function pointers to commands that don't operate on a specific instance can:
be obtained by using this command with pname:instance equal to `NULL`. The be obtained by using this command with pname:instance equal to `NULL`. The
following commands can: be accessed this way: following commands can: be accessed this way:
* fname:vkEnumerateInstanceExtensionProperties * flink:vkEnumerateInstanceExtensionProperties
* fname:vkEnumerateInstanceLayerProperties * flink:vkEnumerateInstanceLayerProperties
* fname:vkCreateInstance * flink:vkCreateInstance
If pname:instance is a valid sname:VkInstance, function pointers to any If pname:instance is a valid sname:VkInstance, function pointers to any
commands that operate on pname:instance or a child of pname:instance can: be commands that operate on pname:instance or a child of pname:instance can: be
@ -112,7 +112,7 @@ include::../protos/vkCreateInstance.txt[]
include::../validity/protos/vkCreateInstance.txt[] include::../validity/protos/vkCreateInstance.txt[]
The definition of sname:VkInstanceCreateInfo is: The sname:VkInstanceCreateInfo structure is defined as:
include::../structs/VkInstanceCreateInfo.txt[] include::../structs/VkInstanceCreateInfo.txt[]
@ -142,7 +142,9 @@ is provided by a layer, both the layer and extension must: be specified at
fname:vkCreateInstance time. fname:vkCreateInstance time.
The pname:pApplicationInfo member of slink:VkInstanceCreateInfo can: point The pname:pApplicationInfo member of slink:VkInstanceCreateInfo can: point
to an instance of sname:VkApplicationInfo. This structure is defined as: to an instance of sname:VkApplicationInfo.
The sname:VkApplicationInfo structure is defined as:
include::../structs/VkApplicationInfo.txt[] include::../structs/VkApplicationInfo.txt[]
@ -162,8 +164,11 @@ include::../structs/VkApplicationInfo.txt[]
application expects to run, encoded as described in the application expects to run, encoded as described in the
<<fundamentals-versionnum,API Version Numbers and Semantics>> section. <<fundamentals-versionnum,API Version Numbers and Semantics>> section.
If pname:apiVersion is 0 the implementation must: ignore it, otherwise If pname:apiVersion is 0 the implementation must: ignore it, otherwise
if the implementation does not support the requested pname:apiVersion if the implementation does not support the requested pname:apiVersion it
it must: return VK_ERROR_INCOMPATIBLE_DRIVER. must: return VK_ERROR_INCOMPATIBLE_DRIVER. The patch version number
specified in pname:apiVersion is ignored when creating an instance
object. Only the major and minor versions of the instance must: match
those requested in pname:apiVersion.
include::../validity/structs/VkApplicationInfo.txt[] include::../validity/structs/VkApplicationInfo.txt[]

View File

@ -288,7 +288,7 @@ Components of the output variables are assigned as described in
Output components identified as 0, 1, 2, and 3 will be directed Output components identified as 0, 1, 2, and 3 will be directed
to the R, G, B, and A inputs to the blending unit, respectively, to the R, G, B, and A inputs to the blending unit, respectively,
or to the output attachment if blending is disabled. or to the output attachment if blending is disabled.
If two variables are placed within the same location, they must If two variables are placed within the same location, they must:
have the same underlying type (floating-point or integer). have the same underlying type (floating-point or integer).
Fragment outputs identified with an code:Index of zero are directed Fragment outputs identified with an code:Index of zero are directed
@ -355,7 +355,7 @@ See <<descriptorsets-inputattachment>> for more details.
When a shader stage accesses buffer or image resources, as described When a shader stage accesses buffer or image resources, as described
in the <<descriptorsets,Resource Descriptors>> section, the shader in the <<descriptorsets,Resource Descriptors>> section, the shader
resource variables must be matched with the resource variables must: be matched with the
<<descriptorsets-pipelinelayout,pipeline layout>> that is provided <<descriptorsets-pipelinelayout,pipeline layout>> that is provided
at pipeline creation time. at pipeline creation time.
@ -365,9 +365,8 @@ with the storage class of code:Uniform, code:UniformConstant, or
code:PushConstant. For the fragment shader, this includes the code:PushConstant. For the fragment shader, this includes the
<<interfaces-inputattachment, fragment input attachment interface>>. <<interfaces-inputattachment, fragment input attachment interface>>.
The shader resource interface can be further broken down into two The shader resource interface consists of two sub-interfaces: the push
sub-interfaces: the push constant interface and the descriptor constant interface and the descriptor set interface.
set interface.
[[interfaces-resources-pushconst]] [[interfaces-resources-pushconst]]
@ -479,7 +478,7 @@ space required for that variable to extend outside the range
latexmath:[$[0, \mathit{maxStorageBufferRange})$]. latexmath:[$[0, \mathit{maxStorageBufferRange})$].
Variables identified with a storage class of code:UniformConstant and a Variables identified with a storage class of code:UniformConstant and a
decoration of code:InputAttachmentIndex must be declared as described in decoration of code:InputAttachmentIndex must: be declared as described in
<<interfaces-inputattachment,Fragment Input Attachment Interface>>. <<interfaces-inputattachment,Fragment Input Attachment Interface>>.
Each shader variable declaration must: refer to the same type of resource as Each shader variable declaration must: refer to the same type of resource as
@ -559,7 +558,7 @@ and descriptor set <<descriptorsets-updates,operations>>, if a resource
variable is not an array, it is treated as if it has an arrayElement of variable is not an array, it is treated as if it has an arrayElement of
zero. zero.
The binding can be any 32-bit unsigned integer value, as described in The binding can: be any 32-bit unsigned integer value, as described in
<<descriptorsets-setlayout>>. Each descriptor set has its own binding <<descriptorsets-setlayout>>. Each descriptor set has its own binding
name space. name space.
@ -574,7 +573,7 @@ multiple limits.
If multiple entry points in the same pipeline refer to the same set and If multiple entry points in the same pipeline refer to the same set and
binding, all variable definitions with that code:DescriptorSet and binding, all variable definitions with that code:DescriptorSet and
code:Binding must have the same basic type. code:Binding must: have the same basic type.
Not all descriptor sets and bindings specified in a pipeline layout need to Not all descriptor sets and bindings specified in a pipeline layout need to
be used in a particular shader stage or pipeline, but if a be used in a particular shader stage or pipeline, but if a
@ -611,7 +610,7 @@ elink:VkShaderStageFlagBits for that stage.
[[interfaces-resources-layout]] [[interfaces-resources-layout]]
=== Offset and Stride Assignment === Offset and Stride Assignment
All variables with a storage class of code:PushConstant or code:Uniform must All variables with a storage class of code:PushConstant or code:Uniform must:
be explicitly laid out using the code:Offset, code:ArrayStride, and be explicitly laid out using the code:Offset, code:ArrayStride, and
code:MatrixStride decorations. There are two different layouts requirements code:MatrixStride decorations. There are two different layouts requirements
depending on the specific resources. depending on the specific resources.
@ -623,7 +622,7 @@ Member variables of an code:OpTypeStruct with storage class of
code:Uniform and a decoration of code:Block (uniform buffers) must: be laid code:Uniform and a decoration of code:Block (uniform buffers) must: be laid
out according to the following rules. out according to the following rules.
* The code:Offset Decoration must be a multiple of its base alignment, * The code:Offset Decoration must: be a multiple of its base alignment,
computed recursively as follows: computed recursively as follows:
+ +
** a scalar of size latexmath:[$N$] has a base alignment of ** a scalar of size latexmath:[$N$] has a base alignment of
@ -668,7 +667,6 @@ The *std430 layout* in GLSL satisfies these rules.
==== ====
[[interfaces-builtin-variables]] [[interfaces-builtin-variables]]
== Built-In Variables == Built-In Variables

View File

@ -96,7 +96,7 @@ Please tag issues with appropriate labels, such as ``Specification'',
``Ref Pages'' or ``Registry'', to help us triage and assign them ``Ref Pages'' or ``Registry'', to help us triage and assign them
appropriately. Unfortunately, Github does not currently let users who do not appropriately. Unfortunately, Github does not currently let users who do not
have write access to the repository set Github labels on issues. In the have write access to the repository set Github labels on issues. In the
meantime, they can be added to the title line of the issue set in brackets, meantime, they can: be added to the title line of the issue set in brackets,
e.g. ''[Specification]''. e.g. ''[Specification]''.

View File

@ -74,15 +74,15 @@ with the pointer value being a multiple of pname:alignment.
[NOTE] [NOTE]
==== ====
Correct Vulkan operation cannot be assumed if the application doesn't Correct Vulkan operation cannot: be assumed if the application doesn't
follow these rules. follow these rules.
For example, pname:pfnAllocation (or pname:pfnReallocation) could cause For example, pname:pfnAllocation (or pname:pfnReallocation) could cause
termination of running Vulkan instance(s) on a failed allocation for termination of running Vulkan instance(s) on a failed allocation for
debugging purposes, either directly or indirectly. In these circumstances, debugging purposes, either directly or indirectly. In these circumstances,
it cannot be assumed that any part of any affected VkInstance objects are it cannot: be assumed that any part of any affected VkInstance objects are
going to operate correctly (even flink:vkDestroyInstance), and the going to operate correctly (even flink:vkDestroyInstance), and the
application must ensure it cleans up properly via other means (e.g. application must: ensure it cleans up properly via other means (e.g.
process termination). process termination).
==== ====
@ -369,7 +369,7 @@ include::../protos/vkGetPhysicalDeviceMemoryProperties.txt[]
include::../validity/protos/vkGetPhysicalDeviceMemoryProperties.txt[] include::../validity/protos/vkGetPhysicalDeviceMemoryProperties.txt[]
The definition of sname:VkPhysicalDeviceMemoryProperties is: The sname:VkPhysicalDeviceMemoryProperties structure is defined as:
include::../structs/VkPhysicalDeviceMemoryProperties.txt[] include::../structs/VkPhysicalDeviceMemoryProperties.txt[]
@ -377,7 +377,7 @@ ifdef::editing-notes[]
[NOTE] [NOTE]
.editing-note .editing-note
==== ====
TODO (Jon) - Need to restructure description like other structs. TODO (Jon) - Need to restructure description like other structures.
==== ====
endif::editing-notes[] endif::editing-notes[]
@ -403,7 +403,7 @@ pname:memoryTypeCount and is less than or equal to
ename:VK_MAX_MEMORY_TYPES. Each memory type is described by an element of ename:VK_MAX_MEMORY_TYPES. Each memory type is described by an element of
the pname:memoryTypes array, as a sname:VkMemoryType structure. the pname:memoryTypes array, as a sname:VkMemoryType structure.
The definition of sname:VkMemoryHeap is: The sname:VkMemoryHeap structure is defined as:
include::../structs/VkMemoryHeap.txt[] include::../structs/VkMemoryHeap.txt[]
@ -427,7 +427,7 @@ In a unified memory architecture (UMA) system, there is often only a single
memory heap which is considered to be equally ``local'' to the host and to the memory heap which is considered to be equally ``local'' to the host and to the
device, and such an implementation must: advertise the heap as device-local. device, and such an implementation must: advertise the heap as device-local.
The definition of sname:VkMemoryType is: The sname:VkMemoryType structure is defined as:
include::../structs/VkMemoryType.txt[] include::../structs/VkMemoryType.txt[]
@ -557,7 +557,7 @@ include::../protos/vkAllocateMemory.txt[]
include::../validity/protos/vkAllocateMemory.txt[] include::../validity/protos/vkAllocateMemory.txt[]
sname:VkMemoryAllocateInfo is defined as: The sname:VkMemoryAllocateInfo structure is defined as:
include::../structs/VkMemoryAllocateInfo.txt[] include::../structs/VkMemoryAllocateInfo.txt[]
@ -746,7 +746,7 @@ include::../protos/vkInvalidateMappedMemoryRanges.txt[]
include::../validity/protos/vkInvalidateMappedMemoryRanges.txt[] include::../validity/protos/vkInvalidateMappedMemoryRanges.txt[]
sname:VkMappedMemoryRange is defined as: The sname:VkMappedMemoryRange structure is defined as:
include::../structs/VkMappedMemoryRange.txt[] include::../structs/VkMappedMemoryRange.txt[]

View File

@ -93,7 +93,7 @@ Compute pipelines are created by calling:
include::../protos/vkCreateComputePipelines.txt[] include::../protos/vkCreateComputePipelines.txt[]
* pname:device is the logical device that creates the compute pipelines. * pname:device is the logical device that creates the compute pipelines.
* pname:pipelineCache is either sname:VK_NULL_HANDLE, indicating that * pname:pipelineCache is either code:VK_NULL_HANDLE, indicating that
pipeline caching is disabled; or the handle of a valid pipeline caching is disabled; or the handle of a valid
<<pipelines-cache,pipeline cache>> object, in which case use of that <<pipelines-cache,pipeline cache>> object, in which case use of that
cache is enabled for the duration of the command. cache is enabled for the duration of the command.
@ -120,7 +120,7 @@ endif::editing-notes[]
include::../validity/protos/vkCreateComputePipelines.txt[] include::../validity/protos/vkCreateComputePipelines.txt[]
The definition of sname:VkComputePipelineCreateInfo is: The sname:VkComputePipelineCreateInfo structure is defined as:
include::../structs/VkComputePipelineCreateInfo.txt[] include::../structs/VkComputePipelineCreateInfo.txt[]
@ -142,14 +142,13 @@ The parameters pname:basePipelineHandle and pname:basePipelineIndex are
described in more detail in described in more detail in
<<pipelines-pipeline-derivatives,Pipeline Derivatives>>. <<pipelines-pipeline-derivatives,Pipeline Derivatives>>.
The parameter pname:stage member of type pname:stage points to a structure of type
sname:VkPipelineShaderStageCreateInfo is: sname:VkPipelineShaderStageCreateInfo.
The sname:VkPipelineShaderStageCreateInfo structure is defined as:
include::../structs/VkPipelineShaderStageCreateInfo.txt[] include::../structs/VkPipelineShaderStageCreateInfo.txt[]
The members of the sname:VkPipelineShaderStageCreateInfo structure are as
follows:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -179,7 +178,7 @@ calling fname:vkCreateGraphicsPipelines:
include::../protos/vkCreateGraphicsPipelines.txt[] include::../protos/vkCreateGraphicsPipelines.txt[]
* pname:device is the logical device that creates the graphics pipelines. * pname:device is the logical device that creates the graphics pipelines.
* pname:pipelineCache is either sname:VK_NULL_HANDLE, indicating that * pname:pipelineCache is either code:VK_NULL_HANDLE, indicating that
pipeline caching is disabled; or the handle of a valid pipeline caching is disabled; or the handle of a valid
<<pipelines-cache,pipeline cache>> object, in which case use of that <<pipelines-cache,pipeline cache>> object, in which case use of that
cache is enabled for the duration of the command. cache is enabled for the duration of the command.
@ -197,7 +196,9 @@ include::../validity/protos/vkCreateGraphicsPipelines.txt[]
The sname:VkGraphicsPipelineCreateInfo structure includes an array of shader The sname:VkGraphicsPipelineCreateInfo structure includes an array of shader
create info structures containing all the desired active shader stages, as create info structures containing all the desired active shader stages, as
well as creation info to define all relevant fixed-function stages, and a well as creation info to define all relevant fixed-function stages, and a
pipeline layout. The definition of sname:VkGraphicsPipelineCreateInfo is: pipeline layout.
The sname:VkGraphicsPipelineCreateInfo structure is defined as:
include::../structs/VkGraphicsPipelineCreateInfo.txt[] include::../structs/VkGraphicsPipelineCreateInfo.txt[]
@ -281,14 +282,13 @@ parent and possibly a child in a pipeline hierarchy. See
<<pipelines-pipeline-derivatives,Pipeline Derivatives>> for more <<pipelines-pipeline-derivatives,Pipeline Derivatives>> for more
information. information.
The definition of the pname:pDynamicState member of type pname:pDynamicState points to a structure of type
sname:VkPipelineDynamicStateCreateInfo is: sname:VkPipelineDynamicStateCreateInfo.
The sname:VkPipelineDynamicStateCreateInfo structure is defined as:
include::../structs/VkPipelineDynamicStateCreateInfo.txt[] include::../structs/VkPipelineDynamicStateCreateInfo.txt[]
The members of the sname:VkPipelineDynamicStateCreateInfo structure are as
follows:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -300,7 +300,7 @@ follows:
include::../validity/structs/VkPipelineDynamicStateCreateInfo.txt[] include::../validity/structs/VkPipelineDynamicStateCreateInfo.txt[]
The definition of the elink:VkDynamicState enumeration is as follows: The elink:VkDynamicState enumerants are defined as:
include::../enums/VkDynamicState.txt[] include::../enums/VkDynamicState.txt[]
@ -453,10 +453,10 @@ group-create.
When an application attempts to create many pipelines in a single command, When an application attempts to create many pipelines in a single command,
it is possible that some subset may: fail creation. In that case, the it is possible that some subset may: fail creation. In that case, the
corresponding entries in the pname:pPipelines output array will be filled corresponding entries in the pname:pPipelines output array will be filled
with sname:VK_NULL_HANDLE values. If any pipeline fails creation (for with code:VK_NULL_HANDLE values. If any pipeline fails creation (for
example, due to out of memory errors), the ftext:vkCreate*Pipelines commands example, due to out of memory errors), the ftext:vkCreate*Pipelines commands
will return an error code. The implementation will attempt to create all will return an error code. The implementation will attempt to create all
pipelines, and only return sname:VK_NULL_HANDLE values for those that pipelines, and only return code:VK_NULL_HANDLE values for those that
actually failed. actually failed.
@ -476,7 +476,7 @@ pname:basePipelineHandle or pname:basePipelineIndex members of the structure
must: have a valid handle/index, and indicates the parent pipeline. If must: have a valid handle/index, and indicates the parent pipeline. If
pname:basePipelineHandle is used, the parent pipeline must: have already pname:basePipelineHandle is used, the parent pipeline must: have already
been created. If pname:basePipelineIndex is used, then the parent is being been created. If pname:basePipelineIndex is used, then the parent is being
created in the same command. sname:VK_NULL_HANDLE acts as the invalid handle created in the same command. code:VK_NULL_HANDLE acts as the invalid handle
for pname:basePipelineHandle, and -1 is the invalid index for for pname:basePipelineHandle, and -1 is the invalid index for
pname:basePipelineIndex. If pname:basePipelineIndex is used, the base pname:basePipelineIndex. If pname:basePipelineIndex is used, the base
pipeline must: appear earlier in the array. The base pipeline must: have pipeline must: appear earlier in the array. The base pipeline must: have
@ -513,7 +513,7 @@ include::../protos/vkCreatePipelineCache.txt[]
include::../validity/protos/vkCreatePipelineCache.txt[] include::../validity/protos/vkCreatePipelineCache.txt[]
The definition of sname:VkPipelineCacheCreateInfo is: The sname:VkPipelineCacheCreateInfo structure is defined as:
include::../structs/VkPipelineCacheCreateInfo.txt[] include::../structs/VkPipelineCacheCreateInfo.txt[]
@ -533,7 +533,7 @@ include::../validity/structs/VkPipelineCacheCreateInfo.txt[]
Once created, a pipeline cache can: be passed to the Once created, a pipeline cache can: be passed to the
fname:vkCreateGraphicsPipelines and fname:vkCreateComputePipelines commands. fname:vkCreateGraphicsPipelines and fname:vkCreateComputePipelines commands.
If the pipeline cache passed into these commands is not If the pipeline cache passed into these commands is not
sname:VK_NULL_HANDLE, the implementation will query it for possible reuse code:VK_NULL_HANDLE, the implementation will query it for possible reuse
opportunities and update it with new content. The use of the pipeline cache opportunities and update it with new content. The use of the pipeline cache
object in these commands is internally synchronized, and the same pipeline object in these commands is internally synchronized, and the same pipeline
cache object can: be used in multiple threads simultaneously. cache object can: be used in multiple threads simultaneously.
@ -579,7 +579,7 @@ include::../protos/vkGetPipelineCacheData.txt[]
the pipeline cache, as described below. the pipeline cache, as described below.
* pname:pData is either `NULL` or a pointer to a buffer. * pname:pData is either `NULL` or a pointer to a buffer.
If pname:pData is `NULL`, then the maximum size of the data that can be If pname:pData is `NULL`, then the maximum size of the data that can: be
retrieved from the pipeline cache, in bytes, is returned in pname:pDataSize. retrieved from the pipeline cache, in bytes, is returned in pname:pDataSize.
Otherwise, pname:pDataSize must: point to a variable set by the user to the Otherwise, pname:pDataSize must: point to a variable set by the user to the
size of the buffer, in bytes, pointed to by pname:pData, and on return the size of the buffer, in bytes, pointed to by pname:pData, and on return the
@ -675,13 +675,13 @@ its local workgroup size changed at runtime by the user, for example.
Each instance of the sname:VkPipelineShaderStageCreateInfo structure Each instance of the sname:VkPipelineShaderStageCreateInfo structure
contains a parameter pname:pSpecializationInfo, which can: be `NULL` to contains a parameter pname:pSpecializationInfo, which can: be `NULL` to
indicate no specialization constants. The definition of the indicate no specialization constants, or point to a
sname:VkSpecializationInfo structure is: sname:VkSpecializationInfo structure.
The sname:VkSpecializationInfo structure is defined as:
include::../structs/VkSpecializationInfo.txt[] include::../structs/VkSpecializationInfo.txt[]
The members of sname:VkSpecializationInfo are as follows:
* pname:mapEntryCount is the number of entries in the pname:pMapEntries * pname:mapEntryCount is the number of entries in the pname:pMapEntries
array. array.
* pname:pMapEntries is a pointer to an array of * pname:pMapEntries is a pointer to an array of
@ -692,13 +692,13 @@ The members of sname:VkSpecializationInfo are as follows:
include::../validity/structs/VkSpecializationInfo.txt[] include::../validity/structs/VkSpecializationInfo.txt[]
The definition of the pname:pMapEntries member of type pname:pMapEntries points to a structure of type
sname:VkSpecializationMapEntry is: sname:VkSpecializationMapEntry.
The sname:VkSpecializationMapEntry structure is defined as:
include::../structs/VkSpecializationMapEntry.txt[] include::../structs/VkSpecializationMapEntry.txt[]
The members of sname:VkSpecializationMapEntry are as follows:
* pname:constantID ID of the specialization constant in SPIR-V. * pname:constantID ID of the specialization constant in SPIR-V.
* pname:offset byte offset of the specialization constant value within the * pname:offset byte offset of the specialization constant value within the
supplied data buffer. supplied data buffer.

View File

@ -67,9 +67,6 @@ The sname:VkPipelineMultisampleStateCreateInfo structure is defined as:
include::../structs/VkPipelineMultisampleStateCreateInfo.txt[] include::../structs/VkPipelineMultisampleStateCreateInfo.txt[]
The members of the sname:VkPipelineMultisampleStateCreateInfo structure are
as follows:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.

View File

@ -37,12 +37,10 @@ include::../protos/vkCreateQueryPool.txt[]
include::../validity/protos/vkCreateQueryPool.txt[] include::../validity/protos/vkCreateQueryPool.txt[]
The definition of sname:VkQueryPoolCreateInfo is: The sname:VkQueryPoolCreateInfo structure is defined as:
include::../structs/VkQueryPoolCreateInfo.txt[] include::../structs/VkQueryPoolCreateInfo.txt[]
The members of sname:VkQueryPoolCreateInfo have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -133,15 +131,16 @@ compute commands. Timestamp queries write timestamps to a query pool.
A query must: begin and end in the same command buffer, although if it is a A query must: begin and end in the same command buffer, although if it is a
primary command buffer, and the primary command buffer, and the
<<features-features-inherited-queries,inherited queries>> feature is <<features-features-inheritedQueries,inherited queries>> feature is
enabled, it can: execute secondary command buffers during the query enabled, it can: execute secondary command buffers during the query
operation. For a secondary command buffer to be executed while a query is operation. For a secondary command buffer to be executed while a query is
active, it must: set the pname:occlusionQueryEnable, pname:queryFlags, active, it must: set the pname:occlusionQueryEnable, pname:queryFlags,
and/or pname:pipelineStatistics members of slink:VkCommandBufferInheritanceInfo and/or pname:pipelineStatistics members of
to conservative values, as described in the <<commandbuffers-recording, Command slink:VkCommandBufferInheritanceInfo to conservative values, as described in
Buffer Recording>> section. A query must: either begin and end inside the the <<commandbuffers-recording, Command Buffer Recording>> section. A query
same subpass of a render pass instance, or must: both begin and end outside must: either begin and end inside the same subpass of a render pass
of a render pass instance (i.e. contain entire render pass instances). instance, or must: both begin and end outside of a render pass instance
(i.e. contain entire render pass instances).
Begin a query by calling: Begin a query by calling:

View File

@ -91,7 +91,7 @@ include::../protos/vkCreateRenderPass.txt[]
* pname:device is the logical device that creates the render pass. * pname:device is the logical device that creates the render pass.
* pname:pCreateInfo is a pointer to an instance of the * pname:pCreateInfo is a pointer to an instance of the
sname:VkRenderPassCreateInfo structure that describes the parameters of slink:VkRenderPassCreateInfo structure that describes the parameters of
the render pass. the render pass.
* pname:pAllocator controls host memory allocation as described in the * pname:pAllocator controls host memory allocation as described in the
<<memory-allocation, Memory Allocation>> chapter. <<memory-allocation, Memory Allocation>> chapter.
@ -127,7 +127,7 @@ include::../structs/VkRenderPassCreateInfo.txt[]
include::../validity/structs/VkRenderPassCreateInfo.txt[] include::../validity/structs/VkRenderPassCreateInfo.txt[]
sname:VkAttachmentDescription is defined as: The sname:VkAttachmentDescription structure is defined as:
include::../structs/VkAttachmentDescription.txt[] include::../structs/VkAttachmentDescription.txt[]
@ -271,7 +271,7 @@ until a framebuffer is created using the render pass, so the above
conditions cannot: be validated at render pass creation time. conditions cannot: be validated at render pass creation time.
==== ====
sname:VkSubpassDescription is defined as: The sname:VkSubpassDescription structure is defined as:
include::../structs/VkSubpassDescription.txt[] include::../structs/VkSubpassDescription.txt[]
@ -299,7 +299,7 @@ include::../structs/VkSubpassDescription.txt[]
i.e. if the shader declared an output variable `layout(location=X)` then i.e. if the shader declared an output variable `layout(location=X)` then
it uses the attachment provided in pname:pColorAttachments[X]. it uses the attachment provided in pname:pColorAttachments[X].
* pname:pResolveAttachments is `NULL` or a pointer to an array of * pname:pResolveAttachments is `NULL` or a pointer to an array of
sname:VkAttachmentReference structures. If pname:pResolveAttachments is slink:VkAttachmentReference structures. If pname:pResolveAttachments is
not `NULL`, each of its elements corresponds to a color attachment (the not `NULL`, each of its elements corresponds to a color attachment (the
element in pname:pColorAttachments at the same index). At the end of element in pname:pColorAttachments at the same index). At the end of
each subpass, the subpass's color attachments are resolved to each subpass, the subpass's color attachments are resolved to
@ -500,7 +500,7 @@ It will be common for a render pass to consist of a simple linear graph of
dependencies, where subpass N depends on subpass N-1 for all N, and the dependencies, where subpass N depends on subpass N-1 for all N, and the
operation of the memory barriers and layout transitions is fairly operation of the memory barriers and layout transitions is fairly
straightforward to reason about for those simple cases. But for more complex straightforward to reason about for those simple cases. But for more complex
graphs, there are some rules that govern when there must be dependencies graphs, there are some rules that govern when there must: be dependencies
between subpasses. between subpasses.
As stated earlier, render passes must: include subpass dependencies which As stated earlier, render passes must: include subpass dependencies which
@ -641,7 +641,7 @@ An application creates a framebuffer by calling:
include::../protos/vkCreateFramebuffer.txt[] include::../protos/vkCreateFramebuffer.txt[]
* pname:device is the logical device that creates the framebuffer. * pname:device is the logical device that creates the framebuffer.
* pname:pCreateInfo points to a sname:VkFramebufferCreateInfo structure * pname:pCreateInfo points to a slink:VkFramebufferCreateInfo structure
which describes additional information about framebuffer creation. which describes additional information about framebuffer creation.
* pname:pAllocator controls host memory allocation as described in the * pname:pAllocator controls host memory allocation as described in the
<<memory-allocation, Memory Allocation>> chapter. <<memory-allocation, Memory Allocation>> chapter.
@ -687,12 +687,12 @@ rather use shader side effects such as image stores and atomics to produce
an output. In this case, the subpass continues to use the pname:width, an output. In this case, the subpass continues to use the pname:width,
pname:height, and pname:layers of the framebuffer to define the dimensions pname:height, and pname:layers of the framebuffer to define the dimensions
of the rendering area, and the pname:rasterizationSamples from each of the rendering area, and the pname:rasterizationSamples from each
pipeline's sname:VkPipelineMultisampleStateCreateInfo to define the number pipeline's slink:VkPipelineMultisampleStateCreateInfo to define the number
of samples used in rasterization; however, if of samples used in rasterization; however, if
sname:VkPhysicalDeviceFeatures::pname:variableMultisampleRate is slink:VkPhysicalDeviceFeatures::pname:variableMultisampleRate is
code:VK_FALSE, then all pipelines to be bound with a given zero-attachment code:VK_FALSE, then all pipelines to be bound with a given zero-attachment
subpass must: have the same value for subpass must: have the same value for
sname:VkPipelineMultisampleStateCreateInfo::pname:rasterizationSamples. slink:VkPipelineMultisampleStateCreateInfo::pname:rasterizationSamples.
To destroy a framebuffer, call: To destroy a framebuffer, call:
@ -720,7 +720,7 @@ include::../protos/vkCmdBeginRenderPass.txt[]
* pname:commandBuffer is the command buffer in which to record the * pname:commandBuffer is the command buffer in which to record the
command. command.
* pname:pRenderPassBegin is a pointer to a sname:VkRenderPassBeginInfo * pname:pRenderPassBegin is a pointer to a slink:VkRenderPassBeginInfo
structure (defined below) which indicates the render pass to begin an structure (defined below) which indicates the render pass to begin an
instance of, and the framebuffer the instance uses. instance of, and the framebuffer the instance uses.
* pname:contents specifies how the commands in the first subpass will be * pname:contents specifies how the commands in the first subpass will be
@ -743,7 +743,6 @@ include::../validity/protos/vkCmdBeginRenderPass.txt[]
After beginning a render pass instance, the command buffer is ready to After beginning a render pass instance, the command buffer is ready to
record the commands for the first subpass of that render pass. record the commands for the first subpass of that render pass.
[[renderpass-VkRenderPassBeginInfo]]
The sname:VkRenderPassBeginInfo structure is defined as: The sname:VkRenderPassBeginInfo structure is defined as:
include::../structs/VkRenderPassBeginInfo.txt[] include::../structs/VkRenderPassBeginInfo.txt[]
@ -756,7 +755,7 @@ include::../structs/VkRenderPassBeginInfo.txt[]
* pname:renderArea is the render area that is affected by the render pass * pname:renderArea is the render area that is affected by the render pass
instance, and is described in more detail below. instance, and is described in more detail below.
* pname:clearValueCount is the number of elements in pname:pClearValues. * pname:clearValueCount is the number of elements in pname:pClearValues.
* pname:pClearValues is an array of sname:VkClearValue structures that * pname:pClearValues is an array of slink:VkClearValue structures that
contains clear values for each attachment, if the attachment uses a contains clear values for each attachment, if the attachment uses a
pname:loadOp value of ename:VK_ATTACHMENT_LOAD_OP_CLEAR. The array is pname:loadOp value of ename:VK_ATTACHMENT_LOAD_OP_CLEAR. The array is
indexed by attachment number, with elements corresponding to uncleared indexed by attachment number, with elements corresponding to uncleared
@ -788,7 +787,7 @@ include::../protos/vkGetRenderAreaGranularity.txt[]
* pname:device is the logical device that owns the render pass. * pname:device is the logical device that owns the render pass.
* pname:renderPass is a handle to a render pass. * pname:renderPass is a handle to a render pass.
* pname:pGranularity points to a sname:VkExtent2D structure in which the * pname:pGranularity points to a slink:VkExtent2D structure in which the
granularity is returned. granularity is returned.
include::../validity/protos/vkGetRenderAreaGranularity.txt[] include::../validity/protos/vkGetRenderAreaGranularity.txt[]
@ -796,19 +795,23 @@ include::../validity/protos/vkGetRenderAreaGranularity.txt[]
The conditions leading to an optimal pname:renderArea are: The conditions leading to an optimal pname:renderArea are:
* the pname:offset.x member in pname:renderArea is a multiple of the * the pname:offset.x member in pname:renderArea is a multiple of the
pname:width member of the returned sname:VkExtent2D (the horizontal pname:width member of the returned slink:VkExtent2D (the horizontal
granularity). granularity).
* the pname:offset.y member in pname:renderArea is a multiple of the * the pname:offset.y member in pname:renderArea is a multiple of the
pname:height of the returned sname:VkExtent2D (the vertical pname:height of the returned slink:VkExtent2D (the vertical
granularity). granularity).
* either the pname:offset.width member in pname:renderArea is a multiple * either the pname:offset.width member in pname:renderArea is a multiple
of the horizontal granularity or pname:offset.x+pname:offset.width is of the horizontal granularity or pname:offset.x+pname:offset.width is
equal to the pname:width of the pname:framebuffer in the equal to the pname:width of the pname:framebuffer in the
sname:VkRenderPassBeginInfo. slink:VkRenderPassBeginInfo.
* either the pname:offset.height member in pname:renderArea is a multiple * either the pname:offset.height member in pname:renderArea is a multiple
of the vertical granularity or pname:offset.y+pname:offset.height is of the vertical granularity or pname:offset.y+pname:offset.height is
equal to the pname:height of the pname:framebuffer in the equal to the pname:height of the pname:framebuffer in the
sname:VkRenderPassBeginInfo. slink:VkRenderPassBeginInfo.
Subpass dependencies are not affected by the render area, and apply to the
entire image subresources attached to the framebuffer. Similarly, pipeline
barriers are valid even if their effect extends outside the render area.
After recording the commands for a subpass, an application transitions to After recording the commands for a subpass, an application transitions to
the next subpass in the render pass instance by calling: the next subpass in the render pass instance by calling:

View File

@ -34,12 +34,10 @@ include::../protos/vkCreateBuffer.txt[]
include::../validity/protos/vkCreateBuffer.txt[] include::../validity/protos/vkCreateBuffer.txt[]
The definition of sname:VkBufferCreateInfo is: The sname:VkBufferCreateInfo structure is defined as:
include::../structs/VkBufferCreateInfo.txt[] include::../structs/VkBufferCreateInfo.txt[]
The members of sname:VkBufferCreateInfo have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is a bitfield describing additional parameters of the * pname:flags is a bitfield describing additional parameters of the
@ -163,12 +161,10 @@ include::../protos/vkCreateBufferView.txt[]
include::../validity/protos/vkCreateBufferView.txt[] include::../validity/protos/vkCreateBufferView.txt[]
The definition of sname:VkBufferViewCreateInfo is: The sname:VkBufferViewCreateInfo structure is defined as:
include::../structs/VkBufferViewCreateInfo.txt[] include::../structs/VkBufferViewCreateInfo.txt[]
The members of sname:VkBufferViewCreateInfo have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -221,12 +217,10 @@ include::../protos/vkCreateImage.txt[]
include::../validity/protos/vkCreateImage.txt[] include::../validity/protos/vkCreateImage.txt[]
The definition of sname:VkImageCreateInfo is: The sname:VkImageCreateInfo structure is defined as:
include::../structs/VkImageCreateInfo.txt[] include::../structs/VkImageCreateInfo.txt[]
The members of sname:VkImageCreateInfo have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is a bitfield describing additional parameters of the image. * pname:flags is a bitfield describing additional parameters of the image.
@ -372,10 +366,10 @@ See <<sparsememory-sparseresourcefeatures,Sparse Resource Features>> and
more details. more details.
* ename:VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT indicates that the image can: * ename:VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT indicates that the image can:
be used to create a slink:VkImageView with a different format from the be used to create a sname:VkImageView with a different format from the
image. image.
* ename:VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT indicates that the image can: * ename:VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT indicates that the image can:
be used to create a slink:VkImageView of type be used to create a sname:VkImageView of type
ename:VK_IMAGE_VIEW_TYPE_CUBE or ename:VK_IMAGE_VIEW_TYPE_CUBE_ARRAY. ename:VK_IMAGE_VIEW_TYPE_CUBE or ename:VK_IMAGE_VIEW_TYPE_CUBE_ARRAY.
The layout of an image subresource (mipLevel/arrayLayer) of an image created The layout of an image subresource (mipLevel/arrayLayer) of an image created
@ -392,11 +386,11 @@ include::../protos/vkGetImageSubresourceLayout.txt[]
include::../validity/protos/vkGetImageSubresourceLayout.txt[] include::../validity/protos/vkGetImageSubresourceLayout.txt[]
The definition of the sname:VkImageSubresource structure is: The sname:VkImageSubresource structure is defined as:
include::../structs/VkImageSubresource.txt[] include::../structs/VkImageSubresource.txt[]
* pname:aspectMask is a elink:VkImageAspectFlags selecting the image * pname:aspectMask is a ename:VkImageAspectFlags selecting the image
aspect. aspect.
* pname:mipLevel selects the mipmap level. * pname:mipLevel selects the mipmap level.
* pname:arrayLayer selects the array layer. * pname:arrayLayer selects the array layer.
@ -762,8 +756,9 @@ baseArrayLayer = 0 +
arrayLayers = 1 arrayLayers = 1
|======================================== |========================================
The pname:subresourceRange member is of type sname:VkImageSubresourceRange The pname:subresourceRange member is of type sname:VkImageSubresourceRange.
and is defined as:
The sname:VkImageSubresourceRange structure is defined as:
include::../structs/VkImageSubresourceRange.txt[] include::../structs/VkImageSubresourceRange.txt[]
@ -818,7 +813,9 @@ depth/stencil image is used as a depth/stencil framebuffer attachment, the
pname:aspectMask is ignored and both depth and stencil image subresources pname:aspectMask is ignored and both depth and stencil image subresources
are used. are used.
The pname:components member is defined as follows: The pname:components member is of type sname:VkComponentMapping.
The sname:VkComponentMapping structure is defined as:
include::../structs/VkComponentMapping.txt[] include::../structs/VkComponentMapping.txt[]
@ -891,7 +888,7 @@ details on resource memory association for sparse resources is described in
<<sparsememory>>. <<sparsememory>>.
Non-sparse resources must: be bound completely and contiguously to a single Non-sparse resources must: be bound completely and contiguously to a single
slink:VkDeviceMemory object before the resource is passed as a parameter to sname:VkDeviceMemory object before the resource is passed as a parameter to
any of the following operations: any of the following operations:
* creating image or buffer views * creating image or buffer views
@ -925,9 +922,7 @@ include::../protos/vkGetImageMemoryRequirements.txt[]
include::../validity/protos/vkGetImageMemoryRequirements.txt[] include::../validity/protos/vkGetImageMemoryRequirements.txt[]
The sname:VkMemoryRequirements structure returned by The sname:VkMemoryRequirements structure is defined as:
flink:vkGetBufferMemoryRequirements and flink:vkGetImageMemoryRequirements
is defined as follows:
include::../structs/VkMemoryRequirements.txt[] include::../structs/VkMemoryRequirements.txt[]
@ -963,7 +958,7 @@ flink:vkGetImageMemoryRequirements:
objects created with the same value for the pname:flags and pname:usage objects created with the same value for the pname:flags and pname:usage
members in the sname:VkBufferCreateInfo structure passed to members in the sname:VkBufferCreateInfo structure passed to
fname:vkCreateBuffer. Further, if code:usage1 and code:usage2 of type fname:vkCreateBuffer. Further, if code:usage1 and code:usage2 of type
elink:VkBufferUsageFlags are such that the bits set in code:usage2 are a ename:VkBufferUsageFlags are such that the bits set in code:usage2 are a
subset of the bits set in code:usage1, and they have the same subset of the bits set in code:usage1, and they have the same
pname:flags, then the bits set in pname:memoryTypeBits returned for pname:flags, then the bits set in pname:memoryTypeBits returned for
code:usage1 must: be a subset of the bits set in pname:memoryTypeBits code:usage1 must: be a subset of the bits set in pname:memoryTypeBits
@ -1178,7 +1173,7 @@ Buffers, and linear image subresources in either the
ename:VK_IMAGE_LAYOUT_PREINITIALIZED or ename:VK_IMAGE_LAYOUT_GENERAL ename:VK_IMAGE_LAYOUT_PREINITIALIZED or ename:VK_IMAGE_LAYOUT_GENERAL
layouts, are _host-accessible subresources_. That is, the host has a layouts, are _host-accessible subresources_. That is, the host has a
well-defined addressing scheme to interpret the contents, and thus the well-defined addressing scheme to interpret the contents, and thus the
layout of the data in memory can be consistently interpreted across aliases layout of the data in memory can: be consistently interpreted across aliases
if each of those aliases is a host-accessible subresource. Opaque images and if each of those aliases is a host-accessible subresource. Opaque images and
linear image subresources in other layouts are not host-accessible. linear image subresources in other layouts are not host-accessible.

View File

@ -23,12 +23,10 @@ include::../protos/vkCreateSampler.txt[]
include::../validity/protos/vkCreateSampler.txt[] include::../validity/protos/vkCreateSampler.txt[]
The sname:VkSamplerCreateInfo structure is defined as follows: The sname:VkSamplerCreateInfo structure is defined as:
include::../structs/VkSamplerCreateInfo.txt[] include::../structs/VkSamplerCreateInfo.txt[]
The members of sname:VkSamplerCreateInfo are described as follows:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -123,7 +121,7 @@ ename:VK_SAMPLER_MIPMAP_MODE_NEAREST correspond to
code:GL_LINEAR_MIPMAP_NEAREST). code:GL_LINEAR_MIPMAP_NEAREST).
There are no {apiname} filter modes that directly correspond to OpenGL There are no {apiname} filter modes that directly correspond to OpenGL
minification filters of code:GL_LINEAR or code:GL_NEAREST, but they can be minification filters of code:GL_LINEAR or code:GL_NEAREST, but they can: be
emulated using ename:VK_SAMPLER_MIPMAP_MODE_NEAREST, pname:minLod = 0, and emulated using ename:VK_SAMPLER_MIPMAP_MODE_NEAREST, pname:minLod = 0, and
pname:maxLod = 0.25, and using pname:minFilter = ename:VK_FILTER_LINEAR or pname:maxLod = 0.25, and using pname:minFilter = ename:VK_FILTER_LINEAR or
pname:minFilter = ename:VK_FILTER_NEAREST, respectively. pname:minFilter = ename:VK_FILTER_NEAREST, respectively.

View File

@ -424,7 +424,7 @@ be assigned to that variable for all samples in the pixel, but that value
must: be interpolated to a location that lies in both the pixel and in the must: be interpolated to a location that lies in both the pixel and in the
primitive being rendered, including any of the pixel's samples covered by primitive being rendered, including any of the pixel's samples covered by
the primitive. Because the location at which the variable is interpolated the primitive. Because the location at which the variable is interpolated
may be different in neighboring pixels, and derivatives may be computed by may: be different in neighboring pixels, and derivatives may: be computed by
computing differences between neighboring pixels, derivatives of computing differences between neighboring pixels, derivatives of
centroid-sampled inputs may: be less accurate than those for non-centroid centroid-sampled inputs may: be less accurate than those for non-centroid
interpolated variables. If a fragment shader input is decorated with interpolated variables. If a fragment shader input is decorated with

View File

@ -463,12 +463,12 @@ must: abide by the following guidelines:
* All sparse resources that are bound to aliased physical memory must: be * All sparse resources that are bound to aliased physical memory must: be
created with the ename:VK_BUFFER_CREATE_SPARSE_ALIASED_BIT / created with the ename:VK_BUFFER_CREATE_SPARSE_ALIASED_BIT /
ename:VK_IMAGE_CREATE_SPARSE_ALIASED_BIT flag. ename:VK_IMAGE_CREATE_SPARSE_ALIASED_BIT flag.
* All resources that access aliased physical memory must interpret the * All resources that access aliased physical memory must: interpret the
memory in the same way. This implies the following: memory in the same way. This implies the following:
** Buffers and images cannot: alias the same physical memory in a data ** Buffers and images cannot: alias the same physical memory in a data
consistent fashion. The physical memory ranges must be used exclusively consistent fashion. The physical memory ranges must: be used
by buffers or used exclusively by images for data consistency to be exclusively by buffers or used exclusively by images for data
guaranteed. consistency to be guaranteed.
** Memory in sparse image mip tail regions cannot: access ** Memory in sparse image mip tail regions cannot: access
aliased memory in a data consistent fashion. aliased memory in a data consistent fashion.
** Sparse images that alias the same physical memory must: have compatible ** Sparse images that alias the same physical memory must: have compatible
@ -477,7 +477,7 @@ must: abide by the following guidelines:
Failure to follow any of the above guidelines will require the application Failure to follow any of the above guidelines will require the application
to abide by the normal, non-sparse resource <<resources-memory-aliasing, to abide by the normal, non-sparse resource <<resources-memory-aliasing,
aliasing rules>>. In this case memory cannot be accessed in a data aliasing rules>>. In this case memory cannot: be accessed in a data
consistent fashion. consistent fashion.
[NOTE] [NOTE]
@ -667,8 +667,10 @@ features.
Some features of the implementation are not possible to disable, and are Some features of the implementation are not possible to disable, and are
reported to allow applications to alter their sparse resource usage reported to allow applications to alter their sparse resource usage
accordingly. These read-only capabilites are reported in the accordingly. These read-only capabilites are reported in the
pname:sparseProperties member of slink:VkPhysicalDeviceProperties. slink:VkPhysicalDeviceProperties::pname:sparseProperties member, which is a
The definition of pname:sparseProperties is structure of type sname:VkPhysicalDeviceSparseProperties.
The sname:VkPhysicalDeviceSparseProperties structure is defined as:
include::../structs/VkPhysicalDeviceSparseProperties.txt[] include::../structs/VkPhysicalDeviceSparseProperties.txt[]
@ -734,12 +736,12 @@ supported and what the sparse image block shape will be.
include::../structs/VkSparseImageFormatProperties.txt[] include::../structs/VkSparseImageFormatProperties.txt[]
* pname:aspectMask is a elink:VkImageAspectFlags specifying which * pname:aspectMask is a bitmask of elink:VkImageAspectFlagBits specifying
aspects of the image the properties apply to. which aspects of the image the properties apply to.
* pname:imageGranularity is the width, height, and depth of the * pname:imageGranularity is the width, height, and depth of the
sparse image block in texels or compressed texel blocks. sparse image block in texels or compressed texel blocks.
* pname:flags is a bitmask specifying additional information about * pname:flags is a bitmask specifying additional information about the
the sparse resource. Bits which can: be set include: sparse resource. Bits which can: be set include:
+ +
-- --
include::../enums/VkSparseImageFormatFlagBits.txt[] include::../enums/VkSparseImageFormatFlagBits.txt[]
@ -877,8 +879,8 @@ include::../structs/VkSparseImageMemoryRequirements.txt[]
single bindable sparse image block in pixel units. For aspect single bindable sparse image block in pixel units. For aspect
ename:VK_IMAGE_ASPECT_METADATA_BIT, all dimensions will be zero ename:VK_IMAGE_ASPECT_METADATA_BIT, all dimensions will be zero
pixels. All metadata is located in the mip tail region. pixels. All metadata is located in the mip tail region.
* pname:formatProperties.flags contains members of * pname:formatProperties.flags is a bitmask of
elink:VkSparseImageFormatFlags: elink:VkSparseImageFormatFlagBits:
** If ename:VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT is set the image ** If ename:VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT is set the image
uses a single mip tail region for all array layers. uses a single mip tail region for all array layers.
** If ename:VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT is set the ** If ename:VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT is set the
@ -954,8 +956,8 @@ resource.
Non-sparse resources are backed by a single physical allocation prior to Non-sparse resources are backed by a single physical allocation prior to
device use (via fname:vkBindImageMemory or fname:vkBindBufferMemory), and device use (via fname:vkBindImageMemory or fname:vkBindBufferMemory), and
their backing mustnot: be changed. On the other hand, sparse resources can their backing mustnot: be changed. On the other hand, sparse resources can:
be bound to memory non-contiguously and these bindings can be altered be bound to memory non-contiguously and these bindings can: be altered
during the lifetime of the resource. during the lifetime of the resource.
[NOTE] [NOTE]
@ -1045,10 +1047,10 @@ include::../structs/VkSparseMemoryBind.txt[]
* pname:resourceOffset is the offset into the resource. * pname:resourceOffset is the offset into the resource.
* pname:size is the size of the memory region to be bound. * pname:size is the size of the memory region to be bound.
* pname:memory is the sname:VkDeviceMemory object that the range of the * pname:memory is the sname:VkDeviceMemory object that the range of the
resource is bound to. If pname:memory is sname:VK_NULL_HANDLE, the range resource is bound to. If pname:memory is code:VK_NULL_HANDLE, the range
is unbound. is unbound.
* pname:memoryOffset is the offset into the sname:VkDeviceMemory object to * pname:memoryOffset is the offset into the sname:VkDeviceMemory object to
bind the resource range to. If pname:memory is sname:VK_NULL_HANDLE, bind the resource range to. If pname:memory is code:VK_NULL_HANDLE,
this value is ignored. this value is ignored.
* pname:flags are sparse memory binding flags. * pname:flags are sparse memory binding flags.
@ -1155,7 +1157,7 @@ include::../structs/VkSparseImageMemoryBindInfo.txt[]
include::../validity/structs/VkSparseImageMemoryBindInfo.txt[] include::../validity/structs/VkSparseImageMemoryBindInfo.txt[]
Where sname:VkSparseImageMemoryBind is defined as follows: The sname:VkSparseImageMemoryBind structure is defined as:
include::../structs/VkSparseImageMemoryBind.txt[] include::../structs/VkSparseImageMemoryBind.txt[]
@ -1169,10 +1171,10 @@ include::../structs/VkSparseImageMemoryBind.txt[]
latexmath:[$\mathit{offset} + \mathit{extent}$] equals the corresponding latexmath:[$\mathit{offset} + \mathit{extent}$] equals the corresponding
dimensions of the image subresource. dimensions of the image subresource.
* pname:memory is the sname:VkDeviceMemory object that the sparse image * pname:memory is the sname:VkDeviceMemory object that the sparse image
blocks of the image are bound to. If pname:memory is sname:VK_NULL_HANDLE, blocks of the image are bound to. If pname:memory is code:VK_NULL_HANDLE,
the sparse image blocks are unbound. the sparse image blocks are unbound.
* pname:memoryOffset is an offset into sname:VkDeviceMemory object. If * pname:memoryOffset is an offset into sname:VkDeviceMemory object. If
pname:memory is sname:VK_NULL_HANDLE, this value is ignored. pname:memory is code:VK_NULL_HANDLE, this value is ignored.
* pname:flags are sparse memory binding flags. * pname:flags are sparse memory binding flags.
include::../validity/structs/VkSparseImageMemoryBind.txt[] include::../validity/structs/VkSparseImageMemoryBind.txt[]
@ -1188,7 +1190,7 @@ include::../protos/vkQueueBindSparse.txt[]
* pname:pBindInfo is an array of slink:VkBindSparseInfo structures * pname:pBindInfo is an array of slink:VkBindSparseInfo structures
each specifying the parameters of a sparse binding operation batch as each specifying the parameters of a sparse binding operation batch as
described below. described below.
* pname:fence, if not ename:VK_NULL_HANDLE, is a fence to be signaled * pname:fence, if not code:VK_NULL_HANDLE, is a fence to be signaled
once the sparse binding operation completes. once the sparse binding operation completes.
Each batch of sparse binding operations is represented by a list of Each batch of sparse binding operations is represented by a list of

View File

@ -59,7 +59,7 @@ include::../protos/vkCreateFence.txt[]
include::../validity/protos/vkCreateFence.txt[] include::../validity/protos/vkCreateFence.txt[]
The definition of sname:VkFenceCreateInfo is: The sname:VkFenceCreateInfo structure is defined as:
include::../structs/VkFenceCreateInfo.txt[] include::../structs/VkFenceCreateInfo.txt[]
@ -201,12 +201,10 @@ include::../protos/vkCreateSemaphore.txt[]
include::../validity/protos/vkCreateSemaphore.txt[] include::../validity/protos/vkCreateSemaphore.txt[]
The definition of sname:VkSemaphoreCreateInfo is: The sname:VkSemaphoreCreateInfo structure is defined as:
include::../structs/VkSemaphoreCreateInfo.txt[] include::../structs/VkSemaphoreCreateInfo.txt[]
The members of sname:VkSemaphoreCreateInfo have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
@ -271,7 +269,7 @@ Some implementations may: be able to execute transfer operations and/or
vertex processing work before the semaphore is signaled. vertex processing work before the semaphore is signaled.
If an image layout transition needs to be performed on a swapchain image If an image layout transition needs to be performed on a swapchain image
before it is used in a framebuffer, that can be performed as the first before it is used in a framebuffer, that can: be performed as the first
operation submitted to the queue after acquiring the image, operation submitted to the queue after acquiring the image,
and shouldnot: prevent other work from overlapping with the presentation and shouldnot: prevent other work from overlapping with the presentation
operation. For example, a sname:VkImageMemoryBarrier could use: operation. For example, a sname:VkImageMemoryBarrier could use:
@ -336,7 +334,7 @@ include::../protos/vkCreateEvent.txt[]
include::../validity/protos/vkCreateEvent.txt[] include::../validity/protos/vkCreateEvent.txt[]
The definition of sname:VkEventCreateInfo is: The sname:VkEventCreateInfo structure is defined as:
include::../structs/VkEventCreateInfo.txt[] include::../structs/VkEventCreateInfo.txt[]
@ -554,6 +552,43 @@ conditions:
** pname:dstStageMask of the previous dependency includes ** pname:dstStageMask of the previous dependency includes
ename:VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT, and pname:srcStageMask of the ename:VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT, and pname:srcStageMask of the
current dependency includes at least one graphics pipeline stage. current dependency includes at least one graphics pipeline stage.
* for each dependency in the sequence (except the first), at least one of the
following conditions is true:
** the current dependency is a fname:vkCmdSetEvent/fname:vkCmdWaitEvents pair
(where the fname:vkCmdWaitEvents may: be inside or outside a render pass
instance), or a fname:vkCmdPipelineBarrier outside of a render pass instance,
or a subpass dependency with pname:srcSubpass equal to
ename:VK_SUBPASS_EXTERNAL for a render pass instance that begins with a
fname:vkCmdBeginRenderPass command, and the previous dependency is any of:
*** a fname:vkCmdSetEvent/fname:vkCmdWaitEvents pair or a
fname:vkCmdPipelineBarrier, either one outside of a render pass instance,
that precedes the current dependency in the queue execution order. Or,
*** a subpass dependency, with pname:dstSubpass equal to
ename:VK_SUBPASS_EXTERNAL, for a renderpass instance that was ended with a
fname:vkCmdEndRenderPass command that precedes the current dependency in
the queue execution order.
** the current dependency is a subpass dependency for a render pass instance,
and the previous dependency is any of:
*** another dependency for the same render pass instance, with a
pname:dstSubpass equal to the pname:srcSubpass of the current dependency.
Or,
*** a fname:vkCmdPipelineBarrier of the same render pass instance, recorded
for the subpass indicated by the pname:srcSubpass of the current
dependency. Or,
*** a fname:vkCmdSetEvent/fname:vkCmdWaitEvents pair, where the
fname:vkCmdWaitEvents is inside the same render pass instance, recorded
for the subpass indicated by the pname:srcSubpass of the current
dependency.
** the current dependency is a fname:vkCmdPipelineBarrier inside a subpass of
a render pass instance, and the previous dependency is any of:
*** a subpass dependency for the same render pass instance, with a
pname:dstSubpass equal to the subpass of the fname:vkCmdPipelineBarrier.
Or,
*** a fname:vkCmdPipelineBarrier of the same render pass instance, recorded
for the same subpass, before the current dependency. Or,
*** a fname:vkCmdSetEvent/fname:vkCmdWaitEvents pair, where the
fname:vkCmdWaitEvents is inside the same render pass instance, recorded
for the same subpass, before the current dependency.
A pair of consecutive execution dependencies in an execution dependency A pair of consecutive execution dependencies in an execution dependency
chain accomplishes a dependency between the stages latexmath:[$A$] and chain accomplishes a dependency between the stages latexmath:[$A$] and
@ -566,6 +601,29 @@ pipeline stages latexmath:[$A$] in the first set of commands completes
before the work performed by pipeline stages latexmath:[$B$] in the second before the work performed by pipeline stages latexmath:[$B$] in the second
set of commands begins. set of commands begins.
A command latexmath:[$C_1$] is said to _happen-before_ an execution dependency
latexmath:[$D_2$] for a pipeline stage latexmath:[$S$] if all the following
conditions are true:
* latexmath:[$C_1$] is in the first set of commands for an execution dependency
latexmath:[$D_1$] that includes latexmath:[$S$] in its pname:srcStageMask.
And,
* there exists an execution dependency chain that includes latexmath:[$D_1$]
and latexmath:[$D_2$], where latexmath:[$D_2$] follows latexmath:[$D_1$] in the
execution dependency sequence.
Similarly, a command latexmath:[$C_2$] is said to _happen-after_ an execution
dependency latexmath:[$D_1$] for a pipeline stage latexmath:[$S$] if all the
following conditions are true:
* latexmath:[$C_2$] is in the second set of commands for an execution dependency
latexmath:[$D_2$] that includes latexmath:[$S$] in its pname:dstStageMask.
And,
* there exists an execution dependency chain that includes latexmath:[$D_1$]
and latexmath:[$D_2$], where latexmath:[$D_2$] follows latexmath:[$D_1$] in the
execution dependency sequence.
An execution dependency is _by-region_ if its pname:dependencyFlags An execution dependency is _by-region_ if its pname:dependencyFlags
parameter includes ename:VK_DEPENDENCY_BY_REGION_BIT. Such a barrier parameter includes ename:VK_DEPENDENCY_BY_REGION_BIT. Such a barrier
describes a per-region (x,y,layer) dependency. That is, for each region, the describes a per-region (x,y,layer) dependency. That is, for each region, the
@ -581,22 +639,23 @@ stages must: have completed for preceding commands before any destination
stages starts for subsequent commands. stages starts for subsequent commands.
[[synchronization-execution-and-memory-dependencies-available-and-visible]] [[synchronization-execution-and-memory-dependencies-available-and-visible]]
_Memory dependencies_ synchronize accesses to memory between two sets of _Memory dependencies_ are coupled to execution dependencies, and synchronize
commands. They operate according to two ``halves'' of a dependency to accesses to memory between two sets of commands. They operate according to two
synchronize two sets of commands, the commands that execute first vs the ``halves'' of a dependency to synchronize two sets of commands, the commands
commands that execute second, as described above. The first half of the that happen-before the execution dependency for the pname:srcStageMask vs the
dependency makes memory accesses using the set of access types in commands that happen-after the execution dependency for the pname:dstStageMask,
pname:srcAccessMask performed in pipeline stages in pname:srcStageMask by as described above. The first half of the dependency makes memory accesses using
the first set of commands complete and writes be _available_ for subsequent the set of access types in pname:srcAccessMask performed in pipeline stages in
commands. The second half of the dependency makes any available writes from pname:srcStageMask by the first set of commands complete and writes be
previous commands _visible_ to pipeline stages in pname:dstStageMask using _available_ for subsequent commands. The second half of the dependency makes any
the set of access types in pname:dstAccessMask for the second set of available writes from previous commands _visible_ to pipeline stages in
commands, if those writes have been made available with the first half of pname:dstStageMask using the set of access types in pname:dstAccessMask for the
the same or a previous dependency. The two halves of a memory dependency second set of commands, if those writes have been made available with the first
half of the same or a previous dependency. The two halves of a memory dependency
can: either be expressed as part of a single command, or can: be part of can: either be expressed as part of a single command, or can: be part of
separate barriers as long as there is an execution dependency chain between separate barriers as long as there is an execution dependency chain between
them. The application must: use memory dependencies to make writes visible them. The application must: use memory dependencies to make writes visible
before subsequent reads can rely on them, and before subsequent writes can before subsequent reads can: rely on them, and before subsequent writes can:
overwrite them. Failure to do so causes the result of the reads to be overwrite them. Failure to do so causes the result of the reads to be
undefined, and the order of writes to be undefined. undefined, and the order of writes to be undefined.
@ -812,7 +871,8 @@ ename:VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT is useful for accomplishing
memory barriers and layout transitions when the next accesses will be done memory barriers and layout transitions when the next accesses will be done
in a different queue or by a presentation engine; in these cases subsequent in a different queue or by a presentation engine; in these cases subsequent
commands in the same queue do not need to wait, but the barrier or commands in the same queue do not need to wait, but the barrier or
transition must complete before semaphores associated with the batch signal. transition must: complete before semaphores associated with the batch
signal.
==== ====
[NOTE] [NOTE]
@ -886,18 +946,18 @@ memory, and image memory.
The global memory barrier type is specified with an instance of the The global memory barrier type is specified with an instance of the
sname:VkMemoryBarrier structure. This type of barrier applies to memory sname:VkMemoryBarrier structure. This type of barrier applies to memory
accesses involving all memory objects that exist at the time of its accesses involving all memory objects that exist at the time of its
execution. The definition of sname:VkMemoryBarrier is: execution.
The sname:VkMemoryBarrier structure is defined as:
include::../structs/VkMemoryBarrier.txt[] include::../structs/VkMemoryBarrier.txt[]
The members of sname:VkMemoryBarrier have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:srcAccessMask is a mask of the classes of memory accesses * pname:srcAccessMask is a bitmask of the classes of memory accesses
performed by the first set of commands that will participate in performed by the first set of commands that will participate in
the dependency. the dependency.
* pname:dstAccessMask is a mask of the classes of memory accesses * pname:dstAccessMask is a bitmask of the classes of memory accesses
performed by the second set of commands that will participate in performed by the second set of commands that will participate in
the dependency. the dependency.
@ -1046,18 +1106,16 @@ specified range of the buffer. It is also used to transfer ownership of a
buffer range from one queue family to another, as described in the buffer range from one queue family to another, as described in the
<<resources-sharing,Resource Sharing>> section. <<resources-sharing,Resource Sharing>> section.
sname:VkBufferMemoryBarrier has the following definition: The sname:VkBufferMemoryBarrier structure is defined as:
include::../structs/VkBufferMemoryBarrier.txt[] include::../structs/VkBufferMemoryBarrier.txt[]
The members of sname:VkBufferMemoryBarrier have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:srcAccessMask is a mask of the classes of memory accesses * pname:srcAccessMask is a bitmask of the classes of memory accesses
performed by the first set of commands that will participate in performed by the first set of commands that will participate in
the dependency. the dependency.
* pname:dstAccessMask is a mask of the classes of memory accesses * pname:dstAccessMask is a bitmask of the classes of memory accesses
performed by the second set of commands that will participate in performed by the second set of commands that will participate in
the dependency. the dependency.
* pname:srcQueueFamilyIndex is the queue family that is relinquishing * pname:srcQueueFamilyIndex is the queue family that is relinquishing
@ -1092,18 +1150,16 @@ layout transition for an image subresource range, or to transfer ownership
of an image subresource range from one queue family to another as described of an image subresource range from one queue family to another as described
in the <<resources-sharing,Resource Sharing>> section. in the <<resources-sharing,Resource Sharing>> section.
sname:VkImageMemoryBarrier has the following definition: The sname:VkImageMemoryBarrier structure is defined as:
include::../structs/VkImageMemoryBarrier.txt[] include::../structs/VkImageMemoryBarrier.txt[]
The members of sname:VkImageMemoryBarrier have the following meanings:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:srcAccessMask is a mask of the classes of memory accesses * pname:srcAccessMask is a bitmask of the classes of memory accesses
performed by the first set of commands that will participate in performed by the first set of commands that will participate in
the dependency. the dependency.
* pname:dstAccessMask is a mask of the classes of memory accesses * pname:dstAccessMask is a bitmask of the classes of memory accesses
performed by the second set of commands that will participate in performed by the second set of commands that will participate in
the dependency. the dependency.
* pname:oldLayout describes the current layout of the image * pname:oldLayout describes the current layout of the image

View File

@ -423,14 +423,13 @@ segment are both implementation-dependent.
== Tessellation Pipeline State == Tessellation Pipeline State
The pname:pTessellationState member of slink:VkGraphicsPipelineCreateInfo is The pname:pTessellationState member of slink:VkGraphicsPipelineCreateInfo
of type sname:VkPipelineTessellationStateCreateInfo: points to a structure of type sname:VkPipelineTessellationStateCreateInfo.
The sname:VkPipelineTessellationStateCreateInfo structure is defined as:
include::../structs/VkPipelineTessellationStateCreateInfo.txt[] include::../structs/VkPipelineTessellationStateCreateInfo.txt[]
The members of the sname:VkPipelineTessellationStateCreateInfo structure are
as follows:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.

View File

@ -365,7 +365,7 @@ These cases include:
pname:shaderStorageImageReadWithoutFormat feature is not enabled, or the pname:shaderStorageImageReadWithoutFormat feature is not enabled, or the
instruction is code:OpImageWrite and the instruction is code:OpImageWrite and the
pname:shaderStorageImageWriteWithoutFormat feature is not enabled, then pname:shaderStorageImageWriteWithoutFormat feature is not enabled, then
the SPIR-V Image Format must be <<spirvenv-image-formats,compatible>> the SPIR-V Image Format must: be <<spirvenv-image-formats,compatible>>
with the image view's pname:format. with the image view's pname:format.
* The sampler pname:unnormalizedCoordinates is ename:VK_TRUE and any of * The sampler pname:unnormalizedCoordinates is ename:VK_TRUE and any of
the <<samplers-unnormalizedCoordinates,limitations of unnormalized the <<samplers-unnormalizedCoordinates,limitations of unnormalized
@ -726,7 +726,7 @@ the value of the texel after swizzle is undefined.
[[textures-sparse-residency]] [[textures-sparse-residency]]
=== Sparse Residency === Sparse Residency
code:OpImageSparse* instructions return a struct which includes a code:OpImageSparse* instructions return a structure which includes a
_residency code_ indicating whether any texels accessed by the instruction _residency code_ indicating whether any texels accessed by the instruction
are sparse unbound texels. This code can: be interpreted by the are sparse unbound texels. This code can: be interpreted by the
code:OpImageSparseTexelsResident instruction which converts the residency code:OpImageSparseTexelsResident instruction which converts the residency
@ -759,7 +759,7 @@ There are a series of validations that the texel undergoes.
[[textures-format-validation]] [[textures-format-validation]]
==== Texel Format Validation ==== Texel Format Validation
If the image format of the pname:OpTypeImage is not compatible with the If the image format of the code:OpTypeImage is not compatible with the
sname:VkImageView's pname:format, the effect of the write on the image sname:VkImageView's pname:format, the effect of the write on the image
view's memory is undefined, but the write mustnot: access memory outside of view's memory is undefined, but the write mustnot: access memory outside of
the image view. the image view.
@ -800,7 +800,7 @@ Each component is converted based on its type and size (as defined in the
<<features-formats-definition,Format Definition>> section for each <<features-formats-definition,Format Definition>> section for each
elink:VkFormat), using the appropriate equations in elink:VkFormat), using the appropriate equations in
<<fundamentals-fp16,16-Bit Floating-Point Numbers>> and <<fundamentals-fp16,16-Bit Floating-Point Numbers>> and
<<fundamentals-fixedconf,Fixed-Point Data Conversion>>. <<fundamentals-fixedconv,Fixed-Point Data Conversion>>.
== Derivative Operations == Derivative Operations

View File

@ -17,7 +17,7 @@ operations are applied to vertices of the resulting primitives:
* Viewport mapping, including depth range scaling (see * Viewport mapping, including depth range scaling (see
<<vertexpostproc-viewport,Controlling the Viewport>>). <<vertexpostproc-viewport,Controlling the Viewport>>).
* Front face determination for polygon primitives (see * Front face determination for polygon primitives (see
<<primsrast-triangles-basic,Basic Triangle Rasterization>>). <<primsrast-polygons-basic,Basic Polygon Rasterization>>).
ifdef::editing-notes[] ifdef::editing-notes[]
[NOTE] [NOTE]
@ -288,24 +288,23 @@ Multiple viewports are available, numbered zero up to
sname:VkPhysicalDeviceLimits::pname:maxViewports minus one. The number of sname:VkPhysicalDeviceLimits::pname:maxViewports minus one. The number of
viewports used by a pipeline is controlled by the pname:viewportCount member viewports used by a pipeline is controlled by the pname:viewportCount member
of the sname:VkPipelineViewportStateCreateInfo structure used in pipeline of the sname:VkPipelineViewportStateCreateInfo structure used in pipeline
creation: creation.
The sname:VkPipelineViewportStateCreateInfo structure is defined as:
include::../structs/VkPipelineViewportStateCreateInfo.txt[] include::../structs/VkPipelineViewportStateCreateInfo.txt[]
The members of the sname:VkPipelineViewportStateCreateInfo structure are as
follows:
* pname:sType is the type of this structure. * pname:sType is the type of this structure.
* pname:pNext is `NULL` or a pointer to an extension-specific structure. * pname:pNext is `NULL` or a pointer to an extension-specific structure.
* pname:flags is reserved for future use. * pname:flags is reserved for future use.
* pname:viewportCount is the number of viewports used by the pipeline. * pname:viewportCount is the number of viewports used by the pipeline.
* pname:pViewports is a pointer to an array of slink:VkViewport structs, * pname:pViewports is a pointer to an array of slink:VkViewport
defining the viewport transforms. If the viewport state is dynamic, this structures, defining the viewport transforms. If the viewport state is
member is ignored. dynamic, this member is ignored.
* pname:scissorCount is the number of <<fragops-scissor,scissors>> and * pname:scissorCount is the number of <<fragops-scissor,scissors>> and
must: match the number of viewports. must: match the number of viewports.
* pname:pScissors is a pointer to an array of sname:VkRect2D structs which * pname:pScissors is a pointer to an array of sname:VkRect2D structures
define the rectangular bounds of the scissor for the corresponding which define the rectangular bounds of the scissor for the corresponding
viewport. If the scissor state is dynamic, this member is ignored. viewport. If the scissor state is dynamic, this member is ignored.
include::../validity/structs/VkPipelineViewportStateCreateInfo.txt[] include::../validity/structs/VkPipelineViewportStateCreateInfo.txt[]

View File

@ -2,24 +2,17 @@
# #
# Copyright (c) 2015-2016 The Khronos Group Inc. # Copyright (c) 2015-2016 The Khronos Group Inc.
# #
# Permission is hereby granted, free of charge, to any person obtaining a # Licensed under the Apache License, Version 2.0 (the "License");
# copy of this software and/or associated documentation files (the # you may not use this file except in compliance with the License.
# "Materials"), to deal in the Materials without restriction, including # You may obtain a copy of the License at
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Materials, and to
# permit persons to whom the Materials are furnished to do so, subject to
# the following conditions:
# #
# The above copyright notice and this permission notice shall be included # http://www.apache.org/licenses/LICENSE-2.0
# in all copies or substantial portions of the Materials.
# #
# THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # Unless required by applicable law or agreed to in writing, software
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # distributed under the License is distributed on an "AS IS" BASIS,
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY # See the License for the specific language governing permissions and
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, # limitations under the License.
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
# checkLinks.py - validate link/reference API constructs in files # checkLinks.py - validate link/reference API constructs in files
# #

View File

@ -79,7 +79,7 @@ should be clear. Secondary command buffers may be referenced at most once from
a primary command buffer (even the same primary command buffer) unless a primary command buffer (even the same primary command buffer) unless
ename:VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT is set. ename:VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT is set.
The pname:renderPass and pname:framebuffer members must be sname:VK_NULL_HANDLE The pname:renderPass and pname:framebuffer members must be code:VK_NULL_HANDLE
for primary command buffers. For secondary command buffers, they must refer to for primary command buffers. For secondary command buffers, they must refer to
the render pass and framebuffer that will be active when the secondary command the render pass and framebuffer that will be active when the secondary command
buffer is called. buffer is called.

View File

@ -58,7 +58,7 @@ of the slink:VkClearValue union, the definition of which is:
include::../structs/VkClearValue.txt[] include::../structs/VkClearValue.txt[]
If the attachment and aspect referenced by ptext:aspectMask and If the attachment and aspect referenced by ptext:aspectMask and
ptext:colorAttachment is a color attachment, the the values contained in the ptext:colorAttachment is a color attachment, the values contained in the
pname:color field of slink:VkClearValue is used to clear the attachment pname:color field of slink:VkClearValue is used to clear the attachment
regions. If the attachment and aspect referenced by ptext:aspectMask and regions. If the attachment and aspect referenced by ptext:aspectMask and
ptext:colorAttachment is a depth, stencil or depth-stencil attachment, then ptext:colorAttachment is a depth, stencil or depth-stencil attachment, then

View File

@ -41,7 +41,7 @@ slink:VkClearDepthStencilValue structure, the definition of which is:
include::../structs/VkClearDepthStencilValue.txt[] include::../structs/VkClearDepthStencilValue.txt[]
The pname:depth and pname:stencil members contain the value to clear the the The pname:depth and pname:stencil members contain the value to clear the
depth and stencil aspects of the image to, respectively. pname:imageLayout depth and stencil aspects of the image to, respectively. pname:imageLayout
specifies the layout of the image being cleared. pname:pRanges points to an specifies the layout of the image being cleared. pname:pRanges points to an
array pname:rangeCount regions of the image are cleared, each of which is described array pname:rangeCount regions of the image are cleared, each of which is described

View File

@ -38,7 +38,7 @@ indirect command consumes pname:drawCount structures, stored at pname:offset
bytes into the buffer object whose handle is specified in pname:buffer. bytes into the buffer object whose handle is specified in pname:buffer.
The beginning of each structure is pname:stride bytes from the previous. The beginning of each structure is pname:stride bytes from the previous.
The data structures have the a layout in memory which may be represented by The data structures have the a layout in memory which may be represented by
the the slink:VkDrawIndirectCommand structure, the definition of which is: the slink:VkDrawIndirectCommand structure, the definition of which is:
include::../structs/VkDrawIndirectCommand.txt[] include::../structs/VkDrawIndirectCommand.txt[]

View File

@ -58,7 +58,7 @@ compute shader.
pipeline and the descritor sets. pipeline and the descritor sets.
- pname:basePipelineHandle the pipeline to derive from (can be - pname:basePipelineHandle the pipeline to derive from (can be
VK_NULL_HANDLE, if pipeline is not derived). code:VK_NULL_HANDLE, if pipeline is not derived).
- pname:basePipelineIndex the index into the pname:pCreateInfos parameter - pname:basePipelineIndex the index into the pname:pCreateInfos parameter
to fname:vkCreateComputePipelines. to fname:vkCreateComputePipelines.
@ -71,7 +71,7 @@ earlier than the current sname:VkComputePipelineCreateInfo in the list. The
parameters pname:basePipelineHandle and pname:basePipelineIndex are mutually parameters pname:basePipelineHandle and pname:basePipelineIndex are mutually
exclusive. If you specify a valid pname:basePipelineHandle, exclusive. If you specify a valid pname:basePipelineHandle,
pname:basePipelineIndex must be set to -1. If you specify a valid pname:basePipelineIndex must be set to -1. If you specify a valid
pname:basePipelineIndex, pname:basePipelineHandle must be VK_NULL_HANDLE. pname:basePipelineIndex, pname:basePipelineHandle must be code:VK_NULL_HANDLE.
include::../validity/protos/vkCreateComputePipelines.txt[] include::../validity/protos/vkCreateComputePipelines.txt[]

View File

@ -48,7 +48,7 @@ The ename:VK_IMAGE_ASPECT_COLOR_BIT aspect is valid only for image formats that
ename:VK_IMAGE_ASPECT_DEPTH_BIT aspect is valid for formats containing depth information and the ename:VK_IMAGE_ASPECT_DEPTH_BIT aspect is valid for formats containing depth information and the
ename:VK_IMAGE_ASPECT_STENCIL_BIT aspect is valid only for formats containing stencil information. Note ename:VK_IMAGE_ASPECT_STENCIL_BIT aspect is valid only for formats containing stencil information. Note
that some formats contain both depth and stencil information, and that some formats contain both depth and stencil information, and
in this case, pname:aspectMask is is used to select which to query. It is not legal to include more than in this case, pname:aspectMask is used to select which to query. It is not legal to include more than
one member of elink:VkImageAspectFlagBits in pname:aspectMask. Some formats also include metadata one member of elink:VkImageAspectFlagBits in pname:aspectMask. Some formats also include metadata
which may be implementation dependent but is queryable by specifying ename:VK_IMAGE_ASPECT_METADATA_BIT. which may be implementation dependent but is queryable by specifying ename:VK_IMAGE_ASPECT_METADATA_BIT.

View File

@ -271,9 +271,11 @@ following table:
slink:VkCommandPoolCreateInfo. slink:VkCommandPoolCreateInfo.
| sname{cl} | Formats the macro argument like slink{cl}. Does not | sname{cl} | Formats the macro argument like slink{cl}. Does not
generate a cross-reference. May also be an abstract generate a cross-reference. May also be an abstract
structure name. Examples: sname{cl}VkCommandPoolCreateInfo structure or handle name. Example:
-> sname:VkCommandPoolCreateInfo, sname{cl}VK_NULL_HANDLE sname{cl}VkCommandPoolCreateInfo ->
-> sname:VK_NULL_HANDLE. The slink{cl} macro is preferred. sname:VkCommandPoolCreateInfo. The slink{cl} macro is
preferred if a definition of the target type with an
anchor exists in the document.
| stext{cl} | Formats the macro argument like sname{cl}. May contain | stext{cl} | Formats the macro argument like sname{cl}. May contain
asterisks for wildcards. Not validated. Example: asterisks for wildcards. Not validated. Example:
stext{cl}Vk*CreateInfo -> stext:Vk*CreateInfo. stext{cl}Vk*CreateInfo -> stext:Vk*CreateInfo.
@ -323,7 +325,8 @@ following table:
basetype{cl}VkDeviceSize -> basetype:VkDeviceSize. basetype{cl}VkDeviceSize -> basetype:VkDeviceSize.
| code{cl} | Formats the macro argument as a code sample. Primarily | code{cl} | Formats the macro argument as a code sample. Primarily
used for SPIR-V keywords. Examples: code{cl}ClipDistance used for SPIR-V keywords. Examples: code{cl}ClipDistance
-> code:ClipDistance, code{cl}NULL -> code:NULL. -> code:ClipDistance, code{cl}VK_NULL_HANDLE ->
code:VK_NULL_HANDLE, code{cl}NULL -> code:NULL.
|===== |=====

View File

@ -21,6 +21,7 @@ endif::doctype-manpage[]
* pname:imageLayout must: specify the layout of the image subresource ranges of pname:image specified in pname:pRanges at the time this command is executed on a sname:VkDevice * pname:imageLayout must: specify the layout of the image subresource ranges of pname:image specified in pname:pRanges at the time this command is executed on a sname:VkDevice
* pname:imageLayout must: be either of ename:VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or ename:VK_IMAGE_LAYOUT_GENERAL * pname:imageLayout must: be either of ename:VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or ename:VK_IMAGE_LAYOUT_GENERAL
* The image range of any given element of pname:pRanges must: be a image subresource range that is contained within pname:image * The image range of any given element of pname:pRanges must: be a image subresource range that is contained within pname:image
* pname:image mustnot: have a compressed or depth/stencil format
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -21,6 +21,7 @@ endif::doctype-manpage[]
* pname:imageLayout must: specify the layout of the image subresource ranges of pname:image specified in pname:pRanges at the time this command is executed on a sname:VkDevice * pname:imageLayout must: specify the layout of the image subresource ranges of pname:image specified in pname:pRanges at the time this command is executed on a sname:VkDevice
* pname:imageLayout must: be either of ename:VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or ename:VK_IMAGE_LAYOUT_GENERAL * pname:imageLayout must: be either of ename:VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or ename:VK_IMAGE_LAYOUT_GENERAL
* The image range of any given element of pname:pRanges must: be a image subresource range that is contained within pname:image * The image range of any given element of pname:pRanges must: be a image subresource range that is contained within pname:image
* pname:image must: have a depth/stencil format
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -18,10 +18,10 @@ endif::doctype-manpage[]
* pname:dstOffset must: be less than the size of pname:dstBuffer * pname:dstOffset must: be less than the size of pname:dstBuffer
* pname:firstQuery must: be less than the number of queries in pname:queryPool * pname:firstQuery must: be less than the number of queries in pname:queryPool
* The sum of pname:firstQuery and pname:queryCount must: be less than or equal to the number of queries in pname:queryPool * The sum of pname:firstQuery and pname:queryCount must: be less than or equal to the number of queries in pname:queryPool
* If ename:VK_QUERY_RESULT_64_BIT is not set in pname:flags then pname:dstOffset and pname:stride must be multiples of `4` * If ename:VK_QUERY_RESULT_64_BIT is not set in pname:flags then pname:dstOffset and pname:stride must: be multiples of `4`
* If ename:VK_QUERY_RESULT_64_BIT is set in pname:flags then pname:dstOffset and pname:stride must be multiples of `8` * If ename:VK_QUERY_RESULT_64_BIT is set in pname:flags then pname:dstOffset and pname:stride must: be multiples of `8`
* pname:dstBuffer must: have enough storage, from pname:dstOffset, to contain the result of each query, as described <<queries-operation-memorylayout,here>> * pname:dstBuffer must: have enough storage, from pname:dstOffset, to contain the result of each query, as described <<queries-operation-memorylayout,here>>
* pname:dstBuffer must: have been created with pname:VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag * pname:dstBuffer must: have been created with ename:VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag
* If the pname:queryType used to create pname:queryPool was ename:VK_QUERY_TYPE_TIMESTAMP, pname:flags mustnot: contain ename:VK_QUERY_RESULT_PARTIAL_BIT * If the pname:queryType used to create pname:queryPool was ename:VK_QUERY_TYPE_TIMESTAMP, pname:flags mustnot: contain ename:VK_QUERY_RESULT_PARTIAL_BIT
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************

View File

@ -23,7 +23,7 @@ endif::doctype-manpage[]
* If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage * If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties * Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -25,7 +25,7 @@ endif::doctype-manpage[]
* If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage * If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties * Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -24,7 +24,7 @@ endif::doctype-manpage[]
* If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage * If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties * Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -25,7 +25,7 @@ endif::doctype-manpage[]
* If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage * If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties * Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -32,7 +32,7 @@ endif::doctype-manpage[]
* If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage * If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties * Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -32,7 +32,7 @@ endif::doctype-manpage[]
* If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage * If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set * If the <<features-features-robustBufferAccess,robust buffer access>> feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set
* Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties * Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -21,7 +21,7 @@ endif::doctype-manpage[]
* If the <<features-features-geometryShader,geometry shaders>> feature is not enabled, pname:srcStageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT * If the <<features-features-geometryShader,geometry shaders>> feature is not enabled, pname:srcStageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
* If the <<features-features-geometryShader,geometry shaders>> feature is not enabled, pname:dstStageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT * If the <<features-features-geometryShader,geometry shaders>> feature is not enabled, pname:dstStageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
* If the <<features-features-tessellationShader,tessellation shaders>> feature is not enabled, pname:srcStageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or ename:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT * If the <<features-features-tessellationShader,tessellation shaders>> feature is not enabled, pname:srcStageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or ename:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
* If the <<features-features-tessellationShader,tessellation shaders>> feature is not enabled, pname:dstStageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or pname:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT * If the <<features-features-tessellationShader,tessellation shaders>> feature is not enabled, pname:dstStageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or ename:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
* If fname:vkCmdPipelineBarrier is called within a render pass instance, the render pass must: declare at least one self-dependency from the current subpass to itself - see <<synchronization-pipeline-barriers-subpass-self-dependencies,Subpass Self-dependency>> * If fname:vkCmdPipelineBarrier is called within a render pass instance, the render pass must: declare at least one self-dependency from the current subpass to itself - see <<synchronization-pipeline-barriers-subpass-self-dependencies,Subpass Self-dependency>>
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************

View File

@ -15,8 +15,8 @@ endif::doctype-manpage[]
* pname:queryPool must: have been created, allocated or retrieved from pname:device * pname:queryPool must: have been created, allocated or retrieved from pname:device
* Each of pname:device and pname:queryPool must: have been created, allocated or retrieved from the same sname:VkPhysicalDevice * Each of pname:device and pname:queryPool must: have been created, allocated or retrieved from the same sname:VkPhysicalDevice
* pname:firstQuery must: be less than the number of queries in pname:queryPool * pname:firstQuery must: be less than the number of queries in pname:queryPool
* If ename:VK_QUERY_RESULT_64_BIT is not set in pname:flags then pname:pData and pname:stride must be multiples of `4` * If ename:VK_QUERY_RESULT_64_BIT is not set in pname:flags then pname:pData and pname:stride must: be multiples of `4`
* If ename:VK_QUERY_RESULT_64_BIT is set in pname:flags then pname:pData and pname:stride must be multiples of `8` * If ename:VK_QUERY_RESULT_64_BIT is set in pname:flags then pname:pData and pname:stride must: be multiples of `8`
* The sum of pname:firstQuery and pname:queryCount must: be less than or equal to the number of queries in pname:queryPool * The sum of pname:firstQuery and pname:queryCount must: be less than or equal to the number of queries in pname:queryPool
* pname:dataSize must: be large enough to contain the result of each query, as described <<queries-operation-memorylayout,here>> * pname:dataSize must: be large enough to contain the result of each query, as described <<queries-operation-memorylayout,here>>
* If the pname:queryType used to create pname:queryPool was ename:VK_QUERY_TYPE_TIMESTAMP, pname:flags mustnot: contain ename:VK_QUERY_RESULT_PARTIAL_BIT * If the pname:queryType used to create pname:queryPool was ename:VK_QUERY_TYPE_TIMESTAMP, pname:flags mustnot: contain ename:VK_QUERY_RESULT_PARTIAL_BIT

View File

@ -23,7 +23,7 @@ endif::doctype-manpage[]
* pname:imageExtent.width must: be a multiple of the compressed texel block width or (pname:imageExtent.width + pname:imageOffset.x) must: equal the image subresource width * pname:imageExtent.width must: be a multiple of the compressed texel block width or (pname:imageExtent.width + pname:imageOffset.x) must: equal the image subresource width
* pname:imageExtent.height must: be a multiple of the compressed texel block height or (pname:imageExtent.height + pname:imageOffset.y) must: equal the image subresource height * pname:imageExtent.height must: be a multiple of the compressed texel block height or (pname:imageExtent.height + pname:imageOffset.y) must: equal the image subresource height
* pname:imageExtent.depth must: be a multiple of the compressed texel block depth or (pname:imageExtent.depth + pname:imageOffset.z) must: equal the image subresource depth * pname:imageExtent.depth must: be a multiple of the compressed texel block depth or (pname:imageExtent.depth + pname:imageOffset.z) must: equal the image subresource depth
* pname:bufferOffset, pname:bufferRowLength, pname:bufferImageHeight and all members of pname:imageOffset and pname:imageExtent must: respect the image transfer granularity requirements of the queue family that it will be submitted against, as described in <<execution-physical-device-enumeration,Physical Device Enumeration>> * pname:bufferOffset, pname:bufferRowLength, pname:bufferImageHeight and all members of pname:imageOffset and pname:imageExtent must: respect the image transfer granularity requirements of the queue family that it will be submitted against, as described in <<devsandqueues-physical-device-enumeration,Physical Device Enumeration>>
* The pname:aspectMask member of pname:imageSubresource must: specify aspects present in the calling command's sname:VkImage parameter * The pname:aspectMask member of pname:imageSubresource must: specify aspects present in the calling command's sname:VkImage parameter
* The pname:aspectMask member of pname:imageSubresource must: only have a single bit set * The pname:aspectMask member of pname:imageSubresource must: only have a single bit set
* If the calling command's sname:VkImage parameter is of elink:VkImageType ename:VK_IMAGE_TYPE_3D, the pname:baseArrayLayer and pname:layerCount members of pname:imageSubresource must: be `0` and `1`, respectively * If the calling command's sname:VkImage parameter is of elink:VkImageType ename:VK_IMAGE_TYPE_3D, the pname:baseArrayLayer and pname:layerCount members of pname:imageSubresource must: be `0` and `1`, respectively

View File

@ -30,7 +30,7 @@ endif::doctype-manpage[]
* pname:extent.width must: be a multiple of the compressed texel block width or (pname:extent.width + pname:dstOffset.x) must: equal the destination image subresource width * pname:extent.width must: be a multiple of the compressed texel block width or (pname:extent.width + pname:dstOffset.x) must: equal the destination image subresource width
* pname:extent.height must: be a multiple of the compressed texel block height or (pname:extent.height + pname:dstOffset.y) must: equal the destination image subresource height * pname:extent.height must: be a multiple of the compressed texel block height or (pname:extent.height + pname:dstOffset.y) must: equal the destination image subresource height
* pname:extent.depth must: be a multiple of the compressed texel block depth or (pname:extent.depth + pname:dstOffset.z) must: equal the destination image subresource depth * pname:extent.depth must: be a multiple of the compressed texel block depth or (pname:extent.depth + pname:dstOffset.z) must: equal the destination image subresource depth
* pname:srcOffset, pname:dstOffset, and pname:extent must: respect the image transfer granularity requirements of the queue family that it will be submitted against, as described in <<execution-physical-device-enumeration,Physical Device Enumeration>> * pname:srcOffset, pname:dstOffset, and pname:extent must: respect the image transfer granularity requirements of the queue family that it will be submitted against, as described in <<devsandqueues-physical-device-enumeration,Physical Device Enumeration>>
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -37,13 +37,13 @@ endif::doctype-manpage[]
* pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampleCounts returned by flink:vkGetPhysicalDeviceProperties, or sname:VkImageFormatProperties::pname:sampleCounts returned by fname:vkGetPhysicalDeviceImageFormatProperties with pname:format, pname:type, pname:tiling, pname:usage and pname:flags equal to those in this structure * pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampleCounts returned by flink:vkGetPhysicalDeviceProperties, or sname:VkImageFormatProperties::pname:sampleCounts returned by fname:vkGetPhysicalDeviceImageFormatProperties with pname:format, pname:type, pname:tiling, pname:usage and pname:flags equal to those in this structure
* If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT or ename:VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, pname:extent.width must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxFramebufferWidth * If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT or ename:VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, pname:extent.width must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxFramebufferWidth
* If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT or ename:VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, pname:extent.height must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxFramebufferHeight * If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT or ename:VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, pname:extent.height must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxFramebufferHeight
* If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxFramebufferColorSamples * If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:framebufferColorSampleCounts
* If pname:usage includes ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, and pname:format includes a depth aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxFramebufferDepthSamples * If pname:usage includes ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, and pname:format includes a depth aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:framebufferDepthSampleCounts
* If pname:usage includes ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, and pname:format includes a stencil aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxFramebufferStencilSamples * If pname:usage includes ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, and pname:format includes a stencil aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:framebufferStencilSampleCounts
* If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format includes a color aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxSampledImageColorSamples * If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format includes a color aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampledImageColorSampleCounts
* If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format includes a depth aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxSampledImageDepthSamples * If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format includes a depth aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampledImageDepthSampleCounts
* If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format is an integer format, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxSampledImageIntegerSamples * If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format is an integer format, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampledImageIntegerSampleCounts
* If pname:usage includes ename:VK_IMAGE_USAGE_STORAGE_BIT, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxStorageImageSamples * If pname:usage includes ename:VK_IMAGE_USAGE_STORAGE_BIT, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:storageImageSampleCounts
* If the <<features-features-textureCompressionETC2,ETC2 texture compression>> feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK, ename:VK_FORMAT_EAC_R11_UNORM_BLOCK, ename:VK_FORMAT_EAC_R11_SNORM_BLOCK, ename:VK_FORMAT_EAC_R11G11_UNORM_BLOCK, or ename:VK_FORMAT_EAC_R11G11_SNORM_BLOCK * If the <<features-features-textureCompressionETC2,ETC2 texture compression>> feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK, ename:VK_FORMAT_EAC_R11_UNORM_BLOCK, ename:VK_FORMAT_EAC_R11_SNORM_BLOCK, ename:VK_FORMAT_EAC_R11G11_UNORM_BLOCK, or ename:VK_FORMAT_EAC_R11G11_SNORM_BLOCK
* If the <<features-features-textureCompressionASTC_LDR,ASTC LDR texture compression>> feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_ASTC_4x4_UNORM_BLOCK, ename:VK_FORMAT_ASTC_4x4_SRGB_BLOCK, ename:VK_FORMAT_ASTC_5x4_UNORM_BLOCK, ename:VK_FORMAT_ASTC_5x4_SRGB_BLOCK, ename:VK_FORMAT_ASTC_5x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_5x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_6x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_6x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_6x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_6x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x8_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x8_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x8_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x8_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x10_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x10_SRGB_BLOCK, ename:VK_FORMAT_ASTC_12x10_UNORM_BLOCK, ename:VK_FORMAT_ASTC_12x10_SRGB_BLOCK, ename:VK_FORMAT_ASTC_12x12_UNORM_BLOCK, or ename:VK_FORMAT_ASTC_12x12_SRGB_BLOCK * If the <<features-features-textureCompressionASTC_LDR,ASTC LDR texture compression>> feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_ASTC_4x4_UNORM_BLOCK, ename:VK_FORMAT_ASTC_4x4_SRGB_BLOCK, ename:VK_FORMAT_ASTC_5x4_UNORM_BLOCK, ename:VK_FORMAT_ASTC_5x4_SRGB_BLOCK, ename:VK_FORMAT_ASTC_5x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_5x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_6x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_6x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_6x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_6x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x8_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x8_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x8_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x8_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x10_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x10_SRGB_BLOCK, ename:VK_FORMAT_ASTC_12x10_UNORM_BLOCK, ename:VK_FORMAT_ASTC_12x10_SRGB_BLOCK, ename:VK_FORMAT_ASTC_12x12_UNORM_BLOCK, or ename:VK_FORMAT_ASTC_12x12_SRGB_BLOCK
* If the <<features-features-textureCompressionBC,BC texture compression>> feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_BC1_RGB_UNORM_BLOCK, ename:VK_FORMAT_BC1_RGB_SRGB_BLOCK, ename:VK_FORMAT_BC1_RGBA_UNORM_BLOCK, ename:VK_FORMAT_BC1_RGBA_SRGB_BLOCK, ename:VK_FORMAT_BC2_UNORM_BLOCK, ename:VK_FORMAT_BC2_SRGB_BLOCK, ename:VK_FORMAT_BC3_UNORM_BLOCK, ename:VK_FORMAT_BC3_SRGB_BLOCK, ename:VK_FORMAT_BC4_UNORM_BLOCK, ename:VK_FORMAT_BC4_SNORM_BLOCK, ename:VK_FORMAT_BC5_UNORM_BLOCK, ename:VK_FORMAT_BC5_SNORM_BLOCK, ename:VK_FORMAT_BC6H_UFLOAT_BLOCK, ename:VK_FORMAT_BC6H_SFLOAT_BLOCK, ename:VK_FORMAT_BC7_UNORM_BLOCK, or ename:VK_FORMAT_BC7_SRGB_BLOCK * If the <<features-features-textureCompressionBC,BC texture compression>> feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_BC1_RGB_UNORM_BLOCK, ename:VK_FORMAT_BC1_RGB_SRGB_BLOCK, ename:VK_FORMAT_BC1_RGBA_UNORM_BLOCK, ename:VK_FORMAT_BC1_RGBA_SRGB_BLOCK, ename:VK_FORMAT_BC2_UNORM_BLOCK, ename:VK_FORMAT_BC2_SRGB_BLOCK, ename:VK_FORMAT_BC3_UNORM_BLOCK, ename:VK_FORMAT_BC3_SRGB_BLOCK, ename:VK_FORMAT_BC4_UNORM_BLOCK, ename:VK_FORMAT_BC4_SNORM_BLOCK, ename:VK_FORMAT_BC5_UNORM_BLOCK, ename:VK_FORMAT_BC5_SNORM_BLOCK, ename:VK_FORMAT_BC6H_UFLOAT_BLOCK, ename:VK_FORMAT_BC6H_SFLOAT_BLOCK, ename:VK_FORMAT_BC7_UNORM_BLOCK, or ename:VK_FORMAT_BC7_SRGB_BLOCK

View File

@ -14,10 +14,10 @@ endif::doctype-manpage[]
* pname:dstAlphaBlendFactor must: be a valid elink:VkBlendFactor value * pname:dstAlphaBlendFactor must: be a valid elink:VkBlendFactor value
* pname:alphaBlendOp must: be a valid elink:VkBlendOp value * pname:alphaBlendOp must: be a valid elink:VkBlendOp value
* pname:colorWriteMask must: be a valid combination of elink:VkColorComponentFlagBits values * pname:colorWriteMask must: be a valid combination of elink:VkColorComponentFlagBits values
* If the <<features-features-dualSrcBlend,dual source blending>> feature is not enabled, pname:srcColorBlendFactor mustnot: be ename:VK_BLEND_SRC1_COLOR, ename:VK_BLEND_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_SRC1_ALPHA, or ename:VK_BLEND_ONE_MINUS_SRC1_ALPHA * If the <<features-features-dualSrcBlend,dual source blending>> feature is not enabled, pname:srcColorBlendFactor mustnot: be ename:VK_BLEND_FACTOR_SRC1_COLOR, ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_FACTOR_SRC1_ALPHA, or ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA
* If the <<features-features-dualSrcBlend,dual source blending>> feature is not enabled, pname:dstColorBlendFactor mustnot: be ename:VK_BLEND_SRC1_COLOR, ename:VK_BLEND_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_SRC1_ALPHA, or ename:VK_BLEND_ONE_MINUS_SRC1_ALPHA * If the <<features-features-dualSrcBlend,dual source blending>> feature is not enabled, pname:dstColorBlendFactor mustnot: be ename:VK_BLEND_FACTOR_SRC1_COLOR, ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_FACTOR_SRC1_ALPHA, or ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA
* If the <<features-features-dualSrcBlend,dual source blending>> feature is not enabled, pname:srcAlphaBlendFactor mustnot: be ename:VK_BLEND_SRC1_COLOR, ename:VK_BLEND_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_SRC1_ALPHA, or ename:VK_BLEND_ONE_MINUS_SRC1_ALPHA * If the <<features-features-dualSrcBlend,dual source blending>> feature is not enabled, pname:srcAlphaBlendFactor mustnot: be ename:VK_BLEND_FACTOR_SRC1_COLOR, ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_FACTOR_SRC1_ALPHA, or ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA
* If the <<features-features-dualSrcBlend,dual source blending>> feature is not enabled, pname:dstAlphaBlendFactor mustnot: be ename:VK_BLEND_SRC1_COLOR, ename:VK_BLEND_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_SRC1_ALPHA, or ename:VK_BLEND_ONE_MINUS_SRC1_ALPHA * If the <<features-features-dualSrcBlend,dual source blending>> feature is not enabled, pname:dstAlphaBlendFactor mustnot: be ename:VK_BLEND_FACTOR_SRC1_COLOR, ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_FACTOR_SRC1_ALPHA, or ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -10,7 +10,7 @@ endif::doctype-manpage[]
* If pname:mapEntryCount is not `0`, pname:pMapEntries must: be a pointer to an array of pname:mapEntryCount sname:VkSpecializationMapEntry structures * If pname:mapEntryCount is not `0`, pname:pMapEntries must: be a pointer to an array of pname:mapEntryCount sname:VkSpecializationMapEntry structures
* If pname:dataSize is not `0`, pname:pData must: be a pointer to an array of pname:dataSize bytes * If pname:dataSize is not `0`, pname:pData must: be a pointer to an array of pname:dataSize bytes
* The pname:offset member of any given element of pname:pMapEntries must: be less than pname:dataSize * The pname:offset member of any given element of pname:pMapEntries must: be less than pname:dataSize
* For any given element of pname:pMapEntries, pname:size must be less than or equal to pname:dataSize minus pname:offset * For any given element of pname:pMapEntries, pname:size must: be less than or equal to pname:dataSize minus pname:offset
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -25,7 +25,7 @@ endif::doctype-manpage[]
* If any input attachments are ename:VK_ATTACHMENT_UNUSED, then any pipelines bound during the subpass mustnot: accesss those input attachments from the fragment shader * If any input attachments are ename:VK_ATTACHMENT_UNUSED, then any pipelines bound during the subpass mustnot: accesss those input attachments from the fragment shader
* The pname:attachment member of any element of pname:pPreserveAttachments mustnot: be ename:VK_ATTACHMENT_UNUSED * The pname:attachment member of any element of pname:pPreserveAttachments mustnot: be ename:VK_ATTACHMENT_UNUSED
* Any given element of pname:pPreserveAttachments mustnot: also be an element of any other member of the subpass description * Any given element of pname:pPreserveAttachments mustnot: also be an element of any other member of the subpass description
* If any attachment is used as both an input attachment and a color or depth/stencil attachment, then each use must use the same pname:layout * If any attachment is used as both an input attachment and a color or depth/stencil attachment, then each use must: use the same pname:layout
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -1,23 +1,16 @@
# Copyright (c) 2013-2016 The Khronos Group Inc. # Copyright (c) 2013-2016 The Khronos Group Inc.
# #
# Permission is hereby granted, free of charge, to any person obtaining a # Licensed under the Apache License, Version 2.0 (the "License");
# copy of this software and/or associated documentation files (the # you may not use this file except in compliance with the License.
# "Materials"), to deal in the Materials without restriction, including # You may obtain a copy of the License at
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Materials, and to
# permit persons to whom the Materials are furnished to do so, subject to
# the following conditions:
# #
# The above copyright notice and this permission notice shall be included # http://www.apache.org/licenses/LICENSE-2.0
# in all copies or substantial portions of the Materials.
# #
# THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # Unless required by applicable law or agreed to in writing, software
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # distributed under the License is distributed on an "AS IS" BASIS,
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY # See the License for the specific language governing permissions and
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, # limitations under the License.
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
# Generator scripts and options # Generator scripts and options
# GENOPTS can be e.g. '-noprotect' # GENOPTS can be e.g. '-noprotect'

View File

@ -2,24 +2,17 @@
# #
# Copyright (c) 2013-2016 The Khronos Group Inc. # Copyright (c) 2013-2016 The Khronos Group Inc.
# #
# Permission is hereby granted, free of charge, to any person obtaining a # Licensed under the Apache License, Version 2.0 (the "License");
# copy of this software and/or associated documentation files (the # you may not use this file except in compliance with the License.
# "Materials"), to deal in the Materials without restriction, including # You may obtain a copy of the License at
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Materials, and to
# permit persons to whom the Materials are furnished to do so, subject to
# the following conditions:
# #
# The above copyright notice and this permission notice shall be included # http://www.apache.org/licenses/LICENSE-2.0
# in all copies or substantial portions of the Materials.
# #
# THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # Unless required by applicable law or agreed to in writing, software
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # distributed under the License is distributed on an "AS IS" BASIS,
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY # See the License for the specific language governing permissions and
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, # limitations under the License.
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
import os,re,sys import os,re,sys

View File

@ -2,24 +2,17 @@
# #
# Copyright (c) 2013-2016 The Khronos Group Inc. # Copyright (c) 2013-2016 The Khronos Group Inc.
# #
# Permission is hereby granted, free of charge, to any person obtaining a # Licensed under the Apache License, Version 2.0 (the "License");
# copy of this software and/or associated documentation files (the # you may not use this file except in compliance with the License.
# "Materials"), to deal in the Materials without restriction, including # You may obtain a copy of the License at
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Materials, and to
# permit persons to whom the Materials are furnished to do so, subject to
# the following conditions:
# #
# The above copyright notice and this permission notice shall be included # http://www.apache.org/licenses/LICENSE-2.0
# in all copies or substantial portions of the Materials.
# #
# THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # Unless required by applicable law or agreed to in writing, software
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # distributed under the License is distributed on an "AS IS" BASIS,
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY # See the License for the specific language governing permissions and
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, # limitations under the License.
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
import sys, time, pdb, string, cProfile import sys, time, pdb, string, cProfile
from reg import * from reg import *
@ -125,24 +118,17 @@ prefixStrings = [
'/*', '/*',
'** Copyright (c) 2015-2016 The Khronos Group Inc.', '** Copyright (c) 2015-2016 The Khronos Group Inc.',
'**', '**',
'** Permission is hereby granted, free of charge, to any person obtaining a', '** Licensed under the Apache License, Version 2.0 (the "License");',
'** copy of this software and/or associated documentation files (the', '** you may not use this file except in compliance with the License.',
'** "Materials"), to deal in the Materials without restriction, including', '** You may obtain a copy of the License at',
'** without limitation the rights to use, copy, modify, merge, publish,',
'** distribute, sublicense, and/or sell copies of the Materials, and to',
'** permit persons to whom the Materials are furnished to do so, subject to',
'** the following conditions:',
'**', '**',
'** The above copyright notice and this permission notice shall be included', '** http://www.apache.org/licenses/LICENSE-2.0',
'** in all copies or substantial portions of the Materials.',
'**', '**',
'** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,', '** Unless required by applicable law or agreed to in writing, software',
'** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF', '** distributed under the License is distributed on an "AS IS" BASIS,',
'** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.', '** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.',
'** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY', '** See the License for the specific language governing permissions and',
'** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,', '** limitations under the License.',
'** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE',
'** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.',
'*/', '*/',
'' ''
] ]

View File

@ -1,23 +1,16 @@
% Copyright (c) 2013-2016 The Khronos Group Inc. % Copyright (c) 2013-2016 The Khronos Group Inc.
% %
% Permission is hereby granted, free of charge, to any person obtaining a % Licensed under the Apache License, Version 2.0 (the "License");
% copy of this software and/or associated documentation files (the % you may not use this file except in compliance with the License.
% "Materials"), to deal in the Materials without restriction, including % You may obtain a copy of the License at
% without limitation the rights to use, copy, modify, merge, publish,
% distribute, sublicense, and/or sell copies of the Materials, and to
% permit persons to whom the Materials are furnished to do so, subject to
% the following conditions:
% %
% The above copyright notice and this permission notice shall be included % http://www.apache.org/licenses/LICENSE-2.0
% in all copies or substantial portions of the Materials.
% %
% THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, % Unless required by applicable law or agreed to in writing, software
% EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF % distributed under the License is distributed on an "AS IS" BASIS,
% MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. % WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
% IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY % See the License for the specific language governing permissions and
% CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, % limitations under the License.
% TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
% MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
\documentclass{article} \documentclass{article}

View File

@ -2,24 +2,17 @@
# #
# Copyright (c) 2013-2016 The Khronos Group Inc. # Copyright (c) 2013-2016 The Khronos Group Inc.
# #
# Permission is hereby granted, free of charge, to any person obtaining a # Licensed under the Apache License, Version 2.0 (the "License");
# copy of this software and/or associated documentation files (the # you may not use this file except in compliance with the License.
# "Materials"), to deal in the Materials without restriction, including # You may obtain a copy of the License at
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Materials, and to
# permit persons to whom the Materials are furnished to do so, subject to
# the following conditions:
# #
# The above copyright notice and this permission notice shall be included # http://www.apache.org/licenses/LICENSE-2.0
# in all copies or substantial portions of the Materials.
# #
# THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # Unless required by applicable law or agreed to in writing, software
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # distributed under the License is distributed on an "AS IS" BASIS,
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY # See the License for the specific language governing permissions and
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, # limitations under the License.
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
# Usage: realign [infile] > outfile # Usage: realign [infile] > outfile
# Used to realign XML tags in the Vulkan registry after it's operated on by # Used to realign XML tags in the Vulkan registry after it's operated on by

View File

@ -2,24 +2,17 @@
# #
# Copyright (c) 2013-2016 The Khronos Group Inc. # Copyright (c) 2013-2016 The Khronos Group Inc.
# #
# Permission is hereby granted, free of charge, to any person obtaining a # Licensed under the Apache License, Version 2.0 (the "License");
# copy of this software and/or associated documentation files (the # you may not use this file except in compliance with the License.
# "Materials"), to deal in the Materials without restriction, including # You may obtain a copy of the License at
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Materials, and to
# permit persons to whom the Materials are furnished to do so, subject to
# the following conditions:
# #
# The above copyright notice and this permission notice shall be included # http://www.apache.org/licenses/LICENSE-2.0
# in all copies or substantial portions of the Materials.
# #
# THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # Unless required by applicable law or agreed to in writing, software
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # distributed under the License is distributed on an "AS IS" BASIS,
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY # See the License for the specific language governing permissions and
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, # limitations under the License.
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
import io,os,re,string,sys,copy import io,os,re,string,sys,copy
from lxml import etree from lxml import etree

View File

@ -1,23 +1,16 @@
# Copyright (c) 2013-2016 The Khronos Group Inc. # Copyright (c) 2013-2016 The Khronos Group Inc.
# #
# Permission is hereby granted, free of charge, to any person obtaining a # Licensed under the Apache License, Version 2.0 (the "License");
# copy of this software and/or associated documentation files (the # you may not use this file except in compliance with the License.
# "Materials"), to deal in the Materials without restriction, including # You may obtain a copy of the License at
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Materials, and to
# permit persons to whom the Materials are furnished to do so, subject to
# the following conditions:
# #
# The above copyright notice and this permission notice shall be included # http://www.apache.org/licenses/LICENSE-2.0
# in all copies or substantial portions of the Materials.
# #
# THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # Unless required by applicable law or agreed to in writing, software
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # distributed under the License is distributed on an "AS IS" BASIS,
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY # See the License for the specific language governing permissions and
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, # limitations under the License.
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
# Relax NG schema for Khronos Vulkan API Registry XML # Relax NG schema for Khronos Vulkan API Registry XML
# #

View File

@ -101,7 +101,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<type category="define">// Vulkan 1.0 version number <type category="define">// Vulkan 1.0 version number
#define <name>VK_API_VERSION_1_0</name> <type>VK_MAKE_VERSION</type>(1, 0, 0)</type> <!-- The patch version here should never be set to anything other than 0 --> #define <name>VK_API_VERSION_1_0</name> <type>VK_MAKE_VERSION</type>(1, 0, 0)</type> <!-- The patch version here should never be set to anything other than 0 -->
<type category="define">// Version of this file <type category="define">// Version of this file
#define <name>VK_HEADER_VERSION</name> 10</type> #define <name>VK_HEADER_VERSION</name> 11</type>
<type category="define"> <type category="define">
#define <name>VK_DEFINE_HANDLE</name>(object) typedef struct object##_T* object;</type> #define <name>VK_DEFINE_HANDLE</name>(object) typedef struct object##_T* object;</type>
@ -822,13 +822,13 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampleCounts returned by flink:vkGetPhysicalDeviceProperties, or sname:VkImageFormatProperties::pname:sampleCounts returned by fname:vkGetPhysicalDeviceImageFormatProperties with pname:format, pname:type, pname:tiling, pname:usage and pname:flags equal to those in this structure</usage> <usage>pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampleCounts returned by flink:vkGetPhysicalDeviceProperties, or sname:VkImageFormatProperties::pname:sampleCounts returned by fname:vkGetPhysicalDeviceImageFormatProperties with pname:format, pname:type, pname:tiling, pname:usage and pname:flags equal to those in this structure</usage>
<usage>If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT or ename:VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, pname:extent.width must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxFramebufferWidth</usage> <usage>If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT or ename:VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, pname:extent.width must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxFramebufferWidth</usage>
<usage>If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT or ename:VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, pname:extent.height must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxFramebufferHeight</usage> <usage>If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, ename:VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT or ename:VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, pname:extent.height must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxFramebufferHeight</usage>
<usage>If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxFramebufferColorSamples</usage> <usage>If pname:usage includes ename:VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:framebufferColorSampleCounts</usage>
<usage>If pname:usage includes ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, and pname:format includes a depth aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxFramebufferDepthSamples</usage> <usage>If pname:usage includes ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, and pname:format includes a depth aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:framebufferDepthSampleCounts</usage>
<usage>If pname:usage includes ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, and pname:format includes a stencil aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxFramebufferStencilSamples</usage> <usage>If pname:usage includes ename:VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, and pname:format includes a stencil aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:framebufferStencilSampleCounts</usage>
<usage>If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format includes a color aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxSampledImageColorSamples</usage> <usage>If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format includes a color aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampledImageColorSampleCounts</usage>
<usage>If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format includes a depth aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxSampledImageDepthSamples</usage> <usage>If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format includes a depth aspect, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampledImageDepthSampleCounts</usage>
<usage>If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format is an integer format, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxSampledImageIntegerSamples</usage> <usage>If pname:usage includes ename:VK_IMAGE_USAGE_SAMPLED_BIT, and pname:format is an integer format, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:sampledImageIntegerSampleCounts</usage>
<usage>If pname:usage includes ename:VK_IMAGE_USAGE_STORAGE_BIT, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:maxStorageImageSamples</usage> <usage>If pname:usage includes ename:VK_IMAGE_USAGE_STORAGE_BIT, pname:samples must: be a bit value that is set in sname:VkPhysicalDeviceLimits::pname:storageImageSampleCounts</usage>
<usage>If the &lt;&lt;features-features-textureCompressionETC2,ETC2 texture compression&gt;&gt; feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK, ename:VK_FORMAT_EAC_R11_UNORM_BLOCK, ename:VK_FORMAT_EAC_R11_SNORM_BLOCK, ename:VK_FORMAT_EAC_R11G11_UNORM_BLOCK, or ename:VK_FORMAT_EAC_R11G11_SNORM_BLOCK</usage> <usage>If the &lt;&lt;features-features-textureCompressionETC2,ETC2 texture compression&gt;&gt; feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK, ename:VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK, ename:VK_FORMAT_EAC_R11_UNORM_BLOCK, ename:VK_FORMAT_EAC_R11_SNORM_BLOCK, ename:VK_FORMAT_EAC_R11G11_UNORM_BLOCK, or ename:VK_FORMAT_EAC_R11G11_SNORM_BLOCK</usage>
<usage>If the &lt;&lt;features-features-textureCompressionASTC_LDR,ASTC LDR texture compression&gt;&gt; feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_ASTC_4x4_UNORM_BLOCK, ename:VK_FORMAT_ASTC_4x4_SRGB_BLOCK, ename:VK_FORMAT_ASTC_5x4_UNORM_BLOCK, ename:VK_FORMAT_ASTC_5x4_SRGB_BLOCK, ename:VK_FORMAT_ASTC_5x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_5x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_6x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_6x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_6x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_6x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x8_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x8_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x8_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x8_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x10_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x10_SRGB_BLOCK, ename:VK_FORMAT_ASTC_12x10_UNORM_BLOCK, ename:VK_FORMAT_ASTC_12x10_SRGB_BLOCK, ename:VK_FORMAT_ASTC_12x12_UNORM_BLOCK, or ename:VK_FORMAT_ASTC_12x12_SRGB_BLOCK</usage> <usage>If the &lt;&lt;features-features-textureCompressionASTC_LDR,ASTC LDR texture compression&gt;&gt; feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_ASTC_4x4_UNORM_BLOCK, ename:VK_FORMAT_ASTC_4x4_SRGB_BLOCK, ename:VK_FORMAT_ASTC_5x4_UNORM_BLOCK, ename:VK_FORMAT_ASTC_5x4_SRGB_BLOCK, ename:VK_FORMAT_ASTC_5x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_5x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_6x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_6x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_6x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_6x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_8x8_UNORM_BLOCK, ename:VK_FORMAT_ASTC_8x8_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x5_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x5_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x6_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x6_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x8_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x8_SRGB_BLOCK, ename:VK_FORMAT_ASTC_10x10_UNORM_BLOCK, ename:VK_FORMAT_ASTC_10x10_SRGB_BLOCK, ename:VK_FORMAT_ASTC_12x10_UNORM_BLOCK, ename:VK_FORMAT_ASTC_12x10_SRGB_BLOCK, ename:VK_FORMAT_ASTC_12x12_UNORM_BLOCK, or ename:VK_FORMAT_ASTC_12x12_SRGB_BLOCK</usage>
<usage>If the &lt;&lt;features-features-textureCompressionBC,BC texture compression&gt;&gt; feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_BC1_RGB_UNORM_BLOCK, ename:VK_FORMAT_BC1_RGB_SRGB_BLOCK, ename:VK_FORMAT_BC1_RGBA_UNORM_BLOCK, ename:VK_FORMAT_BC1_RGBA_SRGB_BLOCK, ename:VK_FORMAT_BC2_UNORM_BLOCK, ename:VK_FORMAT_BC2_SRGB_BLOCK, ename:VK_FORMAT_BC3_UNORM_BLOCK, ename:VK_FORMAT_BC3_SRGB_BLOCK, ename:VK_FORMAT_BC4_UNORM_BLOCK, ename:VK_FORMAT_BC4_SNORM_BLOCK, ename:VK_FORMAT_BC5_UNORM_BLOCK, ename:VK_FORMAT_BC5_SNORM_BLOCK, ename:VK_FORMAT_BC6H_UFLOAT_BLOCK, ename:VK_FORMAT_BC6H_SFLOAT_BLOCK, ename:VK_FORMAT_BC7_UNORM_BLOCK, or ename:VK_FORMAT_BC7_SRGB_BLOCK</usage> <usage>If the &lt;&lt;features-features-textureCompressionBC,BC texture compression&gt;&gt; feature is not enabled, pname:format mustnot: be ename:VK_FORMAT_BC1_RGB_UNORM_BLOCK, ename:VK_FORMAT_BC1_RGB_SRGB_BLOCK, ename:VK_FORMAT_BC1_RGBA_UNORM_BLOCK, ename:VK_FORMAT_BC1_RGBA_SRGB_BLOCK, ename:VK_FORMAT_BC2_UNORM_BLOCK, ename:VK_FORMAT_BC2_SRGB_BLOCK, ename:VK_FORMAT_BC3_UNORM_BLOCK, ename:VK_FORMAT_BC3_SRGB_BLOCK, ename:VK_FORMAT_BC4_UNORM_BLOCK, ename:VK_FORMAT_BC4_SNORM_BLOCK, ename:VK_FORMAT_BC5_UNORM_BLOCK, ename:VK_FORMAT_BC5_SNORM_BLOCK, ename:VK_FORMAT_BC6H_UFLOAT_BLOCK, ename:VK_FORMAT_BC6H_SFLOAT_BLOCK, ename:VK_FORMAT_BC7_UNORM_BLOCK, or ename:VK_FORMAT_BC7_SRGB_BLOCK</usage>
@ -987,7 +987,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage> pname:extent.width must: be a multiple of the compressed texel block width or (pname:extent.width + pname:dstOffset.x) must: equal the destination image subresource width</usage> <usage> pname:extent.width must: be a multiple of the compressed texel block width or (pname:extent.width + pname:dstOffset.x) must: equal the destination image subresource width</usage>
<usage> pname:extent.height must: be a multiple of the compressed texel block height or (pname:extent.height + pname:dstOffset.y) must: equal the destination image subresource height</usage> <usage> pname:extent.height must: be a multiple of the compressed texel block height or (pname:extent.height + pname:dstOffset.y) must: equal the destination image subresource height</usage>
<usage> pname:extent.depth must: be a multiple of the compressed texel block depth or (pname:extent.depth + pname:dstOffset.z) must: equal the destination image subresource depth</usage> <usage> pname:extent.depth must: be a multiple of the compressed texel block depth or (pname:extent.depth + pname:dstOffset.z) must: equal the destination image subresource depth</usage>
<usage>pname:srcOffset, pname:dstOffset, and pname:extent must: respect the image transfer granularity requirements of the queue family that it will be submitted against, as described in &lt;&lt;execution-physical-device-enumeration,Physical Device Enumeration&gt;&gt;</usage> <usage>pname:srcOffset, pname:dstOffset, and pname:extent must: respect the image transfer granularity requirements of the queue family that it will be submitted against, as described in &lt;&lt;devsandqueues-physical-device-enumeration,Physical Device Enumeration&gt;&gt;</usage>
</validity> </validity>
</type> </type>
<type category="struct" name="VkImageBlit"> <type category="struct" name="VkImageBlit">
@ -1032,7 +1032,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage> pname:imageExtent.width must: be a multiple of the compressed texel block width or (pname:imageExtent.width + pname:imageOffset.x) must: equal the image subresource width</usage> <usage> pname:imageExtent.width must: be a multiple of the compressed texel block width or (pname:imageExtent.width + pname:imageOffset.x) must: equal the image subresource width</usage>
<usage> pname:imageExtent.height must: be a multiple of the compressed texel block height or (pname:imageExtent.height + pname:imageOffset.y) must: equal the image subresource height</usage> <usage> pname:imageExtent.height must: be a multiple of the compressed texel block height or (pname:imageExtent.height + pname:imageOffset.y) must: equal the image subresource height</usage>
<usage> pname:imageExtent.depth must: be a multiple of the compressed texel block depth or (pname:imageExtent.depth + pname:imageOffset.z) must: equal the image subresource depth</usage> <usage> pname:imageExtent.depth must: be a multiple of the compressed texel block depth or (pname:imageExtent.depth + pname:imageOffset.z) must: equal the image subresource depth</usage>
<usage>pname:bufferOffset, pname:bufferRowLength, pname:bufferImageHeight and all members of pname:imageOffset and pname:imageExtent must: respect the image transfer granularity requirements of the queue family that it will be submitted against, as described in &lt;&lt;execution-physical-device-enumeration,Physical Device Enumeration&gt;&gt;</usage> <usage>pname:bufferOffset, pname:bufferRowLength, pname:bufferImageHeight and all members of pname:imageOffset and pname:imageExtent must: respect the image transfer granularity requirements of the queue family that it will be submitted against, as described in &lt;&lt;devsandqueues-physical-device-enumeration,Physical Device Enumeration&gt;&gt;</usage>
<usage>The pname:aspectMask member of pname:imageSubresource must: specify aspects present in the calling command's sname:VkImage parameter</usage> <usage>The pname:aspectMask member of pname:imageSubresource must: specify aspects present in the calling command's sname:VkImage parameter</usage>
<usage>The pname:aspectMask member of pname:imageSubresource must: only have a single bit set</usage> <usage>The pname:aspectMask member of pname:imageSubresource must: only have a single bit set</usage>
<usage>If the calling command's sname:VkImage parameter is of elink:VkImageType ename:VK_IMAGE_TYPE_3D, the pname:baseArrayLayer and pname:layerCount members of pname:imageSubresource must: be `0` and `1`, respectively</usage> <usage>If the calling command's sname:VkImage parameter is of elink:VkImageType ename:VK_IMAGE_TYPE_3D, the pname:baseArrayLayer and pname:layerCount members of pname:imageSubresource must: be `0` and `1`, respectively</usage>
@ -1125,7 +1125,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<member len="dataSize">const <type>void</type>* <name>pData</name></member> <!-- Pointer to SpecConstant data --> <member len="dataSize">const <type>void</type>* <name>pData</name></member> <!-- Pointer to SpecConstant data -->
<validity> <validity>
<usage>The pname:offset member of any given element of pname:pMapEntries must: be less than pname:dataSize</usage> <usage>The pname:offset member of any given element of pname:pMapEntries must: be less than pname:dataSize</usage>
<usage>For any given element of pname:pMapEntries, pname:size must be less than or equal to pname:dataSize minus pname:offset</usage> <usage>For any given element of pname:pMapEntries, pname:size must: be less than or equal to pname:dataSize minus pname:offset</usage>
</validity> </validity>
</type> </type>
<type category="struct" name="VkPipelineShaderStageCreateInfo"> <type category="struct" name="VkPipelineShaderStageCreateInfo">
@ -1294,10 +1294,10 @@ maintained in the master branch of the Khronos Vulkan Github project.
<member><type>VkBlendOp</type> <name>alphaBlendOp</name></member> <member><type>VkBlendOp</type> <name>alphaBlendOp</name></member>
<member optional="true"><type>VkColorComponentFlags</type> <name>colorWriteMask</name></member> <member optional="true"><type>VkColorComponentFlags</type> <name>colorWriteMask</name></member>
<validity> <validity>
<usage>If the &lt;&lt;features-features-dualSrcBlend,dual source blending&gt;&gt; feature is not enabled, pname:srcColorBlendFactor mustnot: be ename:VK_BLEND_SRC1_COLOR, ename:VK_BLEND_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_SRC1_ALPHA, or ename:VK_BLEND_ONE_MINUS_SRC1_ALPHA</usage> <usage>If the &lt;&lt;features-features-dualSrcBlend,dual source blending&gt;&gt; feature is not enabled, pname:srcColorBlendFactor mustnot: be ename:VK_BLEND_FACTOR_SRC1_COLOR, ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_FACTOR_SRC1_ALPHA, or ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA</usage>
<usage>If the &lt;&lt;features-features-dualSrcBlend,dual source blending&gt;&gt; feature is not enabled, pname:dstColorBlendFactor mustnot: be ename:VK_BLEND_SRC1_COLOR, ename:VK_BLEND_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_SRC1_ALPHA, or ename:VK_BLEND_ONE_MINUS_SRC1_ALPHA</usage> <usage>If the &lt;&lt;features-features-dualSrcBlend,dual source blending&gt;&gt; feature is not enabled, pname:dstColorBlendFactor mustnot: be ename:VK_BLEND_FACTOR_SRC1_COLOR, ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_FACTOR_SRC1_ALPHA, or ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA</usage>
<usage>If the &lt;&lt;features-features-dualSrcBlend,dual source blending&gt;&gt; feature is not enabled, pname:srcAlphaBlendFactor mustnot: be ename:VK_BLEND_SRC1_COLOR, ename:VK_BLEND_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_SRC1_ALPHA, or ename:VK_BLEND_ONE_MINUS_SRC1_ALPHA</usage> <usage>If the &lt;&lt;features-features-dualSrcBlend,dual source blending&gt;&gt; feature is not enabled, pname:srcAlphaBlendFactor mustnot: be ename:VK_BLEND_FACTOR_SRC1_COLOR, ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_FACTOR_SRC1_ALPHA, or ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA</usage>
<usage>If the &lt;&lt;features-features-dualSrcBlend,dual source blending&gt;&gt; feature is not enabled, pname:dstAlphaBlendFactor mustnot: be ename:VK_BLEND_SRC1_COLOR, ename:VK_BLEND_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_SRC1_ALPHA, or ename:VK_BLEND_ONE_MINUS_SRC1_ALPHA</usage> <usage>If the &lt;&lt;features-features-dualSrcBlend,dual source blending&gt;&gt; feature is not enabled, pname:dstAlphaBlendFactor mustnot: be ename:VK_BLEND_FACTOR_SRC1_COLOR, ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR, ename:VK_BLEND_FACTOR_SRC1_ALPHA, or ename:VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA</usage>
</validity> </validity>
</type> </type>
<type category="struct" name="VkPipelineColorBlendStateCreateInfo"> <type category="struct" name="VkPipelineColorBlendStateCreateInfo">
@ -1596,7 +1596,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If any input attachments are ename:VK_ATTACHMENT_UNUSED, then any pipelines bound during the subpass mustnot: accesss those input attachments from the fragment shader</usage> <usage>If any input attachments are ename:VK_ATTACHMENT_UNUSED, then any pipelines bound during the subpass mustnot: accesss those input attachments from the fragment shader</usage>
<usage>The pname:attachment member of any element of pname:pPreserveAttachments mustnot: be ename:VK_ATTACHMENT_UNUSED</usage> <usage>The pname:attachment member of any element of pname:pPreserveAttachments mustnot: be ename:VK_ATTACHMENT_UNUSED</usage>
<usage>Any given element of pname:pPreserveAttachments mustnot: also be an element of any other member of the subpass description</usage> <usage>Any given element of pname:pPreserveAttachments mustnot: also be an element of any other member of the subpass description</usage>
<usage>If any attachment is used as both an input attachment and a color or depth/stencil attachment, then each use must use the same pname:layout</usage> <usage>If any attachment is used as both an input attachment and a color or depth/stencil attachment, then each use must: use the same pname:layout</usage>
</validity> </validity>
</type> </type>
<type category="struct" name="VkSubpassDependency"> <type category="struct" name="VkSubpassDependency">
@ -1967,8 +1967,8 @@ maintained in the master branch of the Khronos Vulkan Github project.
<member optional="true"><type>VkDisplayModeCreateFlagsKHR</type> <name>flags</name></member> <!-- Reserved --> <member optional="true"><type>VkDisplayModeCreateFlagsKHR</type> <name>flags</name></member> <!-- Reserved -->
<member><type>VkDisplayModeParametersKHR</type> <name>parameters</name></member> <!-- The parameters this mode uses. --> <member><type>VkDisplayModeParametersKHR</type> <name>parameters</name></member> <!-- The parameters this mode uses. -->
<validity> <validity>
<usage>The pname:width and pname:height members of the pname:visibleRegion member of pname:parameters must be greater than `0`</usage> <usage>The pname:width and pname:height members of the pname:visibleRegion member of pname:parameters must: be greater than `0`</usage>
<usage>The pname:refreshRate member of pname:parameters must be greater than `0`</usage> <usage>The pname:refreshRate member of pname:parameters must: be greater than `0`</usage>
</validity> </validity>
</type> </type>
<type category="struct" name="VkDisplayPlaneCapabilitiesKHR"> <type category="struct" name="VkDisplayPlaneCapabilitiesKHR">
@ -1998,7 +1998,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If the pname:planeReorderPossible member of the sname:VkDisplayPropertiesKHR structure returned by fname:vkGetPhysicalDeviceDisplayPropertiesKHR for the display corresponding to pname:displayMode is ename:VK_TRUE then pname:planeStackIndex must: be less than the number of display planes supported by the device as determined by calling fname:vkGetPhysicalDeviceDisplayPlanePropertiesKHR; otherwise pname:planeStackIndex must: equal the pname:currentStackIndex member of sname:VkDisplayPlanePropertiesKHR returned by fname:vkGetPhysicalDeviceDisplayPlanePropertiesKHR for the display plane corresponding to pname:displayMode</usage> <usage>If the pname:planeReorderPossible member of the sname:VkDisplayPropertiesKHR structure returned by fname:vkGetPhysicalDeviceDisplayPropertiesKHR for the display corresponding to pname:displayMode is ename:VK_TRUE then pname:planeStackIndex must: be less than the number of display planes supported by the device as determined by calling fname:vkGetPhysicalDeviceDisplayPlanePropertiesKHR; otherwise pname:planeStackIndex must: equal the pname:currentStackIndex member of sname:VkDisplayPlanePropertiesKHR returned by fname:vkGetPhysicalDeviceDisplayPlanePropertiesKHR for the display plane corresponding to pname:displayMode</usage>
<usage>If pname:alphaMode is ename:VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR then pname:globalAlpha must: be between `0` and `1`, inclusive</usage> <usage>If pname:alphaMode is ename:VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR then pname:globalAlpha must: be between `0` and `1`, inclusive</usage>
<usage>pname:alphaMode must: be `0` or one of the bits present in the pname:supportedAlpha member of sname:VkDisplayPlaneCapabilitiesKHR returned by fname:vkGetDisplayPlaneCapabilitiesKHR for the display plane corresponding to pname:displayMode</usage> <usage>pname:alphaMode must: be `0` or one of the bits present in the pname:supportedAlpha member of sname:VkDisplayPlaneCapabilitiesKHR returned by fname:vkGetDisplayPlaneCapabilitiesKHR for the display plane corresponding to pname:displayMode</usage>
<usage>The pname:width and pname:height members of pname:imageExtent must be less than the pname:maxImageDimensions2D member of sname:VkPhysicalDeviceLimits</usage> <usage>The pname:width and pname:height members of pname:imageExtent must: be less than the pname:maxImageDimensions2D member of sname:VkPhysicalDeviceLimits</usage>
</validity> </validity>
</type> </type>
<type category="struct" name="VkDisplayPresentInfoKHR"> <type category="struct" name="VkDisplayPresentInfoKHR">
@ -2111,14 +2111,14 @@ maintained in the master branch of the Khronos Vulkan Github project.
<type category="struct" name="VkPresentInfoKHR"> <type category="struct" name="VkPresentInfoKHR">
<member><type>VkStructureType</type> <name>sType</name></member> <!-- Must be VK_STRUCTURE_TYPE_PRESENT_INFO_KHR --> <member><type>VkStructureType</type> <name>sType</name></member> <!-- Must be VK_STRUCTURE_TYPE_PRESENT_INFO_KHR -->
<member>const <type>void</type>* <name>pNext</name></member> <!-- Pointer to next structure --> <member>const <type>void</type>* <name>pNext</name></member> <!-- Pointer to next structure -->
<member><type>uint32_t</type> <name>waitSemaphoreCount</name></member> <!-- Number of semaphores to wait for before presenting --> <member optional="true"><type>uint32_t</type> <name>waitSemaphoreCount</name></member> <!-- Number of semaphores to wait for before presenting -->
<member optional="true" len="waitSemaphoreCount">const <type>VkSemaphore</type>* <name>pWaitSemaphores</name></member> <!-- Semaphores to wait for before presenting --> <member optional="true" len="waitSemaphoreCount">const <type>VkSemaphore</type>* <name>pWaitSemaphores</name></member> <!-- Semaphores to wait for before presenting -->
<member><type>uint32_t</type> <name>swapchainCount</name></member> <!-- Number of swap chains to present in this call --> <member><type>uint32_t</type> <name>swapchainCount</name></member> <!-- Number of swap chains to present in this call -->
<member len="swapchainCount">const <type>VkSwapchainKHR</type>* <name>pSwapchains</name></member> <!-- Swapchains to present an image from --> <member len="swapchainCount">const <type>VkSwapchainKHR</type>* <name>pSwapchains</name></member> <!-- Swapchains to present an image from -->
<member len="swapchainCount">const <type>uint32_t</type>* <name>pImageIndices</name></member> <!-- Indices of which swapchain images to present --> <member len="swapchainCount">const <type>uint32_t</type>* <name>pImageIndices</name></member> <!-- Indices of which swapchain images to present -->
<member optional="true" len="swapchainCount"><type>VkResult</type>* <name>pResults</name></member> <!-- Optional (i.e. if non-NULL) VkResult for each swapchain --> <member optional="true" len="swapchainCount"><type>VkResult</type>* <name>pResults</name></member> <!-- Optional (i.e. if non-NULL) VkResult for each swapchain -->
<validity> <validity>
<usage>Any given element of pname:pImageIndices must: be the index of a presentable image acquired from the swapchain specified by the corresponding element of the pname:pSwapchains array that is owned by the application</usage> <usage>Any given element of pname:pImageIndices must: be the index of a presentable image acquired from the swapchain specified by the corresponding element of the pname:pSwapchains array</usage>
<usage>Any given element of sname:VkSemaphore in pname:pWaitSemaphores must: refer to a prior signal of that sname:VkSemaphore that won't be consumed by any other wait on that semaphore</usage> <usage>Any given element of sname:VkSemaphore in pname:pWaitSemaphores must: refer to a prior signal of that sname:VkSemaphore that won't be consumed by any other wait on that semaphore</usage>
</validity> </validity>
</type> </type>
@ -3358,8 +3358,8 @@ maintained in the master branch of the Khronos Vulkan Github project.
<param optional="true"><type>VkQueryResultFlags</type> <name>flags</name></param> <param optional="true"><type>VkQueryResultFlags</type> <name>flags</name></param>
<validity> <validity>
<usage>pname:firstQuery must: be less than the number of queries in pname:queryPool</usage> <usage>pname:firstQuery must: be less than the number of queries in pname:queryPool</usage>
<usage>If ename:VK_QUERY_RESULT_64_BIT is not set in pname:flags then pname:pData and pname:stride must be multiples of `4`</usage> <usage>If ename:VK_QUERY_RESULT_64_BIT is not set in pname:flags then pname:pData and pname:stride must: be multiples of `4`</usage>
<usage>If ename:VK_QUERY_RESULT_64_BIT is set in pname:flags then pname:pData and pname:stride must be multiples of `8`</usage> <usage>If ename:VK_QUERY_RESULT_64_BIT is set in pname:flags then pname:pData and pname:stride must: be multiples of `8`</usage>
<usage>The sum of pname:firstQuery and pname:queryCount must: be less than or equal to the number of queries in pname:queryPool</usage> <usage>The sum of pname:firstQuery and pname:queryCount must: be less than or equal to the number of queries in pname:queryPool</usage>
<usage>pname:dataSize must: be large enough to contain the result of each query, as described &lt;&lt;queries-operation-memorylayout,here&gt;&gt;</usage> <usage>pname:dataSize must: be large enough to contain the result of each query, as described &lt;&lt;queries-operation-memorylayout,here&gt;&gt;</usage>
<usage>If the pname:queryType used to create pname:queryPool was ename:VK_QUERY_TYPE_TIMESTAMP, pname:flags mustnot: contain ename:VK_QUERY_RESULT_PARTIAL_BIT</usage> <usage>If the pname:queryType used to create pname:queryPool was ename:VK_QUERY_TYPE_TIMESTAMP, pname:flags mustnot: contain ename:VK_QUERY_RESULT_PARTIAL_BIT</usage>
@ -3918,7 +3918,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage> <usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage> <usage>Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage>
</validity> </validity>
</command> </command>
<command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary"> <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary">
@ -3944,7 +3944,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage> <usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage> <usage>Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage>
</validity> </validity>
</command> </command>
<command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary"> <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary">
@ -3974,7 +3974,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage> <usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage> <usage>Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage>
</validity> </validity>
</command> </command>
<command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary"> <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary">
@ -4004,7 +4004,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage> <usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage> <usage>Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage>
</validity> </validity>
</command> </command>
<command queues="compute" renderpass="outside" cmdbufferlevel="primary,secondary"> <command queues="compute" renderpass="outside" cmdbufferlevel="primary,secondary">
@ -4026,7 +4026,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage> <usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage> <usage>Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage>
</validity> </validity>
</command> </command>
<command queues="compute" renderpass="outside" cmdbufferlevel="primary,secondary"> <command queues="compute" renderpass="outside" cmdbufferlevel="primary,secondary">
@ -4047,7 +4047,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage> <usage>If any sname:VkSampler object that is accessed from a shader by the sname:VkPipeline currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates, it mustnot: be used with any of the SPIR-V `OpImageSample*` or `OpImageSparseSample*` instructions that includes a lod bias or any offset values, in any shader stage</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage> <usage>If the &lt;&lt;features-features-robustBufferAccess,robust buffer access&gt;&gt; feature is not enabled, and any shader stage in the sname:VkPipeline object currently bound to ename:VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it mustnot: access values outside of the range of that buffer specified in the currently bound descriptor set</usage>
<usage>Any slink:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage> <usage>Any sname:VkImage being sampled with ename:VK_FILTER_LINEAR as a result of this command must: be of a format which supports linear filtering, as specified by the ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in sname:VkFormatProperties::pname:linearTilingFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage>
</validity> </validity>
</command> </command>
<command queues="transfer,graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary"> <command queues="transfer,graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary">
@ -4204,6 +4204,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>pname:imageLayout must: specify the layout of the image subresource ranges of pname:image specified in pname:pRanges at the time this command is executed on a sname:VkDevice</usage> <usage>pname:imageLayout must: specify the layout of the image subresource ranges of pname:image specified in pname:pRanges at the time this command is executed on a sname:VkDevice</usage>
<usage>pname:imageLayout must: be either of ename:VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or ename:VK_IMAGE_LAYOUT_GENERAL</usage> <usage>pname:imageLayout must: be either of ename:VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or ename:VK_IMAGE_LAYOUT_GENERAL</usage>
<usage>The image range of any given element of pname:pRanges must: be a image subresource range that is contained within pname:image</usage> <usage>The image range of any given element of pname:pRanges must: be a image subresource range that is contained within pname:image</usage>
<usage>pname:image mustnot: have a compressed or depth/stencil format</usage>
</validity> </validity>
</command> </command>
<command queues="graphics" renderpass="outside" cmdbufferlevel="primary,secondary"> <command queues="graphics" renderpass="outside" cmdbufferlevel="primary,secondary">
@ -4219,6 +4220,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>pname:imageLayout must: specify the layout of the image subresource ranges of pname:image specified in pname:pRanges at the time this command is executed on a sname:VkDevice</usage> <usage>pname:imageLayout must: specify the layout of the image subresource ranges of pname:image specified in pname:pRanges at the time this command is executed on a sname:VkDevice</usage>
<usage>pname:imageLayout must: be either of ename:VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or ename:VK_IMAGE_LAYOUT_GENERAL</usage> <usage>pname:imageLayout must: be either of ename:VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or ename:VK_IMAGE_LAYOUT_GENERAL</usage>
<usage>The image range of any given element of pname:pRanges must: be a image subresource range that is contained within pname:image</usage> <usage>The image range of any given element of pname:pRanges must: be a image subresource range that is contained within pname:image</usage>
<usage>pname:image must: have a depth/stencil format</usage>
</validity> </validity>
</command> </command>
<command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary"> <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary">
@ -4316,7 +4318,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If the &lt;&lt;features-features-geometryShader,geometry shaders&gt;&gt; feature is not enabled, pname:srcStageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</usage> <usage>If the &lt;&lt;features-features-geometryShader,geometry shaders&gt;&gt; feature is not enabled, pname:srcStageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</usage>
<usage>If the &lt;&lt;features-features-geometryShader,geometry shaders&gt;&gt; feature is not enabled, pname:dstStageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</usage> <usage>If the &lt;&lt;features-features-geometryShader,geometry shaders&gt;&gt; feature is not enabled, pname:dstStageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</usage>
<usage>If the &lt;&lt;features-features-tessellationShader,tessellation shaders&gt;&gt; feature is not enabled, pname:srcStageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or ename:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</usage> <usage>If the &lt;&lt;features-features-tessellationShader,tessellation shaders&gt;&gt; feature is not enabled, pname:srcStageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or ename:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</usage>
<usage>If the &lt;&lt;features-features-tessellationShader,tessellation shaders&gt;&gt; feature is not enabled, pname:dstStageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or pname:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</usage> <usage>If the &lt;&lt;features-features-tessellationShader,tessellation shaders&gt;&gt; feature is not enabled, pname:dstStageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or ename:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</usage>
<usage>If fname:vkCmdPipelineBarrier is called within a render pass instance, the render pass must: declare at least one self-dependency from the current subpass to itself - see &lt;&lt;synchronization-pipeline-barriers-subpass-self-dependencies,Subpass Self-dependency&gt;&gt;</usage> <usage>If fname:vkCmdPipelineBarrier is called within a render pass instance, the render pass must: declare at least one self-dependency from the current subpass to itself - see &lt;&lt;synchronization-pipeline-barriers-subpass-self-dependencies,Subpass Self-dependency&gt;&gt;</usage>
</validity> </validity>
</command> </command>
@ -4383,10 +4385,10 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>pname:dstOffset must: be less than the size of pname:dstBuffer</usage> <usage>pname:dstOffset must: be less than the size of pname:dstBuffer</usage>
<usage>pname:firstQuery must: be less than the number of queries in pname:queryPool</usage> <usage>pname:firstQuery must: be less than the number of queries in pname:queryPool</usage>
<usage>The sum of pname:firstQuery and pname:queryCount must: be less than or equal to the number of queries in pname:queryPool</usage> <usage>The sum of pname:firstQuery and pname:queryCount must: be less than or equal to the number of queries in pname:queryPool</usage>
<usage>If ename:VK_QUERY_RESULT_64_BIT is not set in pname:flags then pname:dstOffset and pname:stride must be multiples of `4`</usage> <usage>If ename:VK_QUERY_RESULT_64_BIT is not set in pname:flags then pname:dstOffset and pname:stride must: be multiples of `4`</usage>
<usage>If ename:VK_QUERY_RESULT_64_BIT is set in pname:flags then pname:dstOffset and pname:stride must be multiples of `8`</usage> <usage>If ename:VK_QUERY_RESULT_64_BIT is set in pname:flags then pname:dstOffset and pname:stride must: be multiples of `8`</usage>
<usage>pname:dstBuffer must: have enough storage, from pname:dstOffset, to contain the result of each query, as described &lt;&lt;queries-operation-memorylayout,here&gt;&gt;</usage> <usage>pname:dstBuffer must: have enough storage, from pname:dstOffset, to contain the result of each query, as described &lt;&lt;queries-operation-memorylayout,here&gt;&gt;</usage>
<usage>pname:dstBuffer must: have been created with pname:VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag</usage> <usage>pname:dstBuffer must: have been created with ename:VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag</usage>
<usage>If the pname:queryType used to create pname:queryPool was ename:VK_QUERY_TYPE_TIMESTAMP, pname:flags mustnot: contain ename:VK_QUERY_RESULT_PARTIAL_BIT</usage> <usage>If the pname:queryType used to create pname:queryPool was ename:VK_QUERY_TYPE_TIMESTAMP, pname:flags mustnot: contain ename:VK_QUERY_RESULT_PARTIAL_BIT</usage>
</validity> </validity>
</command> </command>
@ -4497,7 +4499,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<proto><type>VkResult</type> <name>vkCreateDisplayModeKHR</name></proto> <proto><type>VkResult</type> <name>vkCreateDisplayModeKHR</name></proto>
<param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param> <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
<param externsync="true"><type>VkDisplayKHR</type> <name>display</name></param> <param externsync="true"><type>VkDisplayKHR</type> <name>display</name></param>
<param>const <type>VkDisplayModeCreateInfoKHR</type>*<name>pCreateInfo</name></param> <param>const <type>VkDisplayModeCreateInfoKHR</type>* <name>pCreateInfo</name></param>
<param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param> <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
<param><type>VkDisplayModeKHR</type>* <name>pMode</name></param> <param><type>VkDisplayModeKHR</type>* <name>pMode</name></param>
</command> </command>
@ -4593,7 +4595,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<param optional="true" externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></param> <param optional="true" externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></param>
<param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param> <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
<validity> <validity>
<usage>All uses of presentable images acquired from pname:swapchain and owned by the application must: have completed execution</usage> <usage>All uses of presentable images acquired from pname:swapchain must: have completed execution</usage>
<usage>If sname:VkAllocationCallbacks were provided when pname:swapchain was created, a compatible set of callbacks must: be provided here</usage> <usage>If sname:VkAllocationCallbacks were provided when pname:swapchain was created, a compatible set of callbacks must: be provided here</usage>
<usage>If no sname:VkAllocationCallbacks were provided when pname:swapchain was created, pname:pAllocator must: be `NULL`</usage> <usage>If no sname:VkAllocationCallbacks were provided when pname:swapchain was created, pname:pAllocator must: be `NULL`</usage>
</validity> </validity>
@ -4605,7 +4607,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<param optional="false,true"><type>uint32_t</type>* <name>pSwapchainImageCount</name></param> <param optional="false,true"><type>uint32_t</type>* <name>pSwapchainImageCount</name></param>
<param optional="true" len="pSwapchainImageCount"><type>VkImage</type>* <name>pSwapchainImages</name></param> <param optional="true" len="pSwapchainImageCount"><type>VkImage</type>* <name>pSwapchainImages</name></param>
</command> </command>
<command successcodes="VK_SUCCESS,VK_SUBOPTIMAL_KHR" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST,VK_ERROR_OUT_OF_DATE_KHR,VK_ERROR_SURFACE_LOST_KHR"> <command successcodes="VK_SUCCESS,VK_TIMEOUT,VK_NOT_READY,VK_SUBOPTIMAL_KHR" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST,VK_ERROR_OUT_OF_DATE_KHR,VK_ERROR_SURFACE_LOST_KHR">
<proto><type>VkResult</type> <name>vkAcquireNextImageKHR</name></proto> <proto><type>VkResult</type> <name>vkAcquireNextImageKHR</name></proto>
<param><type>VkDevice</type> <name>device</name></param> <param><type>VkDevice</type> <name>device</name></param>
<param externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></param> <param externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></param>
@ -4720,9 +4722,9 @@ maintained in the master branch of the Khronos Vulkan Github project.
<param>const <type>char</type>* <name>pMessage</name></param> <param>const <type>char</type>* <name>pMessage</name></param>
<validity> <validity>
<usage>pname:instance must: be a valid sname:VkInstance handle</usage> <usage>pname:instance must: be a valid sname:VkInstance handle</usage>
<usage>pname:flags must be a combination of one or more of sname:VkDebugReportFlagBitsEXT</usage> <usage>pname:flags must: be a combination of one or more of sname:VkDebugReportFlagBitsEXT</usage>
<usage>pname:objType must be one of sname:VkDebugReportObjectTypeEXT, ename:VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT if pname:object is `NULL`</usage> <usage>pname:objType must: be one of sname:VkDebugReportObjectTypeEXT, ename:VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT if pname:object is `NULL`</usage>
<usage>pname:object may be a {apiname} object</usage> <usage>pname:object may: be a {apiname} object</usage>
<usage>pname:pLayerPrefix must: be a `NULL` terminated string.</usage> <usage>pname:pLayerPrefix must: be a `NULL` terminated string.</usage>
<usage>pname:pMsg must: be a `NULL` terminated string.</usage> <usage>pname:pMsg must: be a `NULL` terminated string.</usage>
</validity> </validity>
@ -4977,7 +4979,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
</extension> </extension>
<extension name="VK_KHR_swapchain" number="2" supported="vulkan"> <extension name="VK_KHR_swapchain" number="2" supported="vulkan">
<require> <require>
<enum value="67" name="VK_KHR_SWAPCHAIN_SPEC_VERSION"/> <enum value="68" name="VK_KHR_SWAPCHAIN_SPEC_VERSION"/>
<enum value="&quot;VK_KHR_swapchain&quot;" name="VK_KHR_SWAPCHAIN_EXTENSION_NAME"/> <enum value="&quot;VK_KHR_swapchain&quot;" name="VK_KHR_SWAPCHAIN_EXTENSION_NAME"/>
<enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR"/> <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR"/>
<enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PRESENT_INFO_KHR"/> <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PRESENT_INFO_KHR"/>

View File

@ -4,24 +4,17 @@
/* /*
** Copyright (c) 2014-2015 The Khronos Group Inc. ** Copyright (c) 2014-2015 The Khronos Group Inc.
** **
** Permission is hereby granted, free of charge, to any person obtaining a ** Licensed under the Apache License, Version 2.0 (the "License");
** copy of this software and/or associated documentation files (the ** you may not use this file except in compliance with the License.
** "Materials"), to deal in the Materials without restriction, including ** You may obtain a copy of the License at
** without limitation the rights to use, copy, modify, merge, publish,
** distribute, sublicense, and/or sell copies of the Materials, and to
** permit persons to whom the Materials are furnished to do so, subject to
** the following conditions:
** **
** The above copyright notice and this permission notice shall be included ** http://www.apache.org/licenses/LICENSE-2.0
** in all copies or substantial portions of the Materials.
** **
** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ** Unless required by applicable law or agreed to in writing, software
** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF ** distributed under the License is distributed on an "AS IS" BASIS,
** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY ** See the License for the specific language governing permissions and
** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, ** limitations under the License.
** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
*/ */

View File

@ -8,24 +8,17 @@ extern "C" {
/* /*
** Copyright (c) 2015-2016 The Khronos Group Inc. ** Copyright (c) 2015-2016 The Khronos Group Inc.
** **
** Permission is hereby granted, free of charge, to any person obtaining a ** Licensed under the Apache License, Version 2.0 (the "License");
** copy of this software and/or associated documentation files (the ** you may not use this file except in compliance with the License.
** "Materials"), to deal in the Materials without restriction, including ** You may obtain a copy of the License at
** without limitation the rights to use, copy, modify, merge, publish,
** distribute, sublicense, and/or sell copies of the Materials, and to
** permit persons to whom the Materials are furnished to do so, subject to
** the following conditions:
** **
** The above copyright notice and this permission notice shall be included ** http://www.apache.org/licenses/LICENSE-2.0
** in all copies or substantial portions of the Materials.
** **
** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ** Unless required by applicable law or agreed to in writing, software
** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF ** distributed under the License is distributed on an "AS IS" BASIS,
** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY ** See the License for the specific language governing permissions and
** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, ** limitations under the License.
** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
*/ */
/* /*
@ -50,7 +43,7 @@ extern "C" {
#define VK_VERSION_MINOR(version) (((uint32_t)(version) >> 12) & 0x3ff) #define VK_VERSION_MINOR(version) (((uint32_t)(version) >> 12) & 0x3ff)
#define VK_VERSION_PATCH(version) ((uint32_t)(version) & 0xfff) #define VK_VERSION_PATCH(version) ((uint32_t)(version) & 0xfff)
// Version of this file // Version of this file
#define VK_HEADER_VERSION 10 #define VK_HEADER_VERSION 11
#define VK_NULL_HANDLE 0 #define VK_NULL_HANDLE 0
@ -3278,7 +3271,7 @@ VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfacePresentModesKHR(
#define VK_KHR_swapchain 1 #define VK_KHR_swapchain 1
VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSwapchainKHR) VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSwapchainKHR)
#define VK_KHR_SWAPCHAIN_SPEC_VERSION 67 #define VK_KHR_SWAPCHAIN_SPEC_VERSION 68
#define VK_KHR_SWAPCHAIN_EXTENSION_NAME "VK_KHR_swapchain" #define VK_KHR_SWAPCHAIN_EXTENSION_NAME "VK_KHR_swapchain"
typedef VkFlags VkSwapchainCreateFlagsKHR; typedef VkFlags VkSwapchainCreateFlagsKHR;
@ -3434,7 +3427,7 @@ typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceDisplayPropertiesKHR)(VkPhys
typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceDisplayPlanePropertiesKHR)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPlanePropertiesKHR* pProperties); typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceDisplayPlanePropertiesKHR)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPlanePropertiesKHR* pProperties);
typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneSupportedDisplaysKHR)(VkPhysicalDevice physicalDevice, uint32_t planeIndex, uint32_t* pDisplayCount, VkDisplayKHR* pDisplays); typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneSupportedDisplaysKHR)(VkPhysicalDevice physicalDevice, uint32_t planeIndex, uint32_t* pDisplayCount, VkDisplayKHR* pDisplays);
typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayModePropertiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, uint32_t* pPropertyCount, VkDisplayModePropertiesKHR* pProperties); typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayModePropertiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, uint32_t* pPropertyCount, VkDisplayModePropertiesKHR* pProperties);
typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayModeKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, const VkDisplayModeCreateInfoKHR*pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDisplayModeKHR* pMode); typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayModeKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, const VkDisplayModeCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDisplayModeKHR* pMode);
typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneCapabilitiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayModeKHR mode, uint32_t planeIndex, VkDisplayPlaneCapabilitiesKHR* pCapabilities); typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneCapabilitiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayModeKHR mode, uint32_t planeIndex, VkDisplayPlaneCapabilitiesKHR* pCapabilities);
typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayPlaneSurfaceKHR)(VkInstance instance, const VkDisplaySurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface); typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayPlaneSurfaceKHR)(VkInstance instance, const VkDisplaySurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);