Change log for April 29, 2016 Vulkan 1.0.12 spec update:

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

Github Issues:

  * Change valid usage statements intended to be "sub-points" to
    be actual sub-points (public issue 66).
  * Replace double negation in description of
    slink:VkRenderPassBeginInfo::pname:pClearValues (based on public
    merge 142).
  * Cleanup minor typos in spec, ref pages and XML, including those
    proposed in public pull requests 144, 150, 151, 167, 168, 181, and
    186.
  * Use *strict subset* in describing the partial order of memory
    property types for slink:VkMemoryType, and update the style guide
    accordingly (public issue 190).
  * Fix various "a image" -> "an image" typos (public issue 191).
  * Note in the <<fundamentals-validusage,Valid Usage>> and
    <<extensions-interactions,Extension Interactions>> sections that
    structures defined by extensions which may be passed in structure
    chains using the ptext:pNext member must: include initial
    ptext:sType and ptext:pNext members (public issue 192).

Internal Issues:

  * Remove duplicate language from the description of the pname:fence
    parameter to flink:vkQueueSubmit and improve validity language
    (internal issue 91).
  * Added documentation for "optional" attribute to XML readme.tex/pdf
    (internal issue 149).
  * Clarify the host-side data validity rules and behavior of
    flink:vkFlushMappedMemoryRanges and
    flink:vkInvalidateMappedMemoryRanges (internal issue 266).

Other Commits:

  * Added clarification to flink:vkCmdFillBuffer regarding the use of
    ename:VK_WHOLE_SIZE.
  * Fixed and documented implementation of "validextensionstructs"
    attribute. in XML processing scripts and readme.tex/pdf.
  * Add missing validity statements to flink:vkResetEvent and
    flink:vkCmdResetEvent.
  * Fix validity for the
    ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag.
    Correct all the draw/dispatch commands to mention optimally tiled
    images as well as linear tiled images, and say image VIEWS instead
    of images. Add validity statement to flink:vkCmdBlitImage
  * Replace the {apiname} macro with hardcoded "Vulkan", now that we've
    committed to that name.
  * Add the VK_AMD_rasterization_order extension to vk.xml.
This commit is contained in:
Jon Leech 2016-04-29 14:53:46 +02:00
parent 6db51e9241
commit 75bbb5f4d5
69 changed files with 2270 additions and 1453 deletions

View File

@ -526,3 +526,57 @@ Other Commits:
on relevant script/XML/header files. This does not affect the on relevant script/XML/header files. This does not affect the
specification source copyright. specification source copyright.
-----------------------------------------------------
Change log for April 29, 2016 Vulkan 1.0.12 spec update:
* Bump API patch number and header version number to 12 for this
update.
Github Issues:
* Change valid usage statements intended to be "sub-points" to
be actual sub-points (public issue 66).
* Replace double negation in description of
slink:VkRenderPassBeginInfo::pname:pClearValues (based on public
merge 142).
* Cleanup minor typos in spec, ref pages and XML, including those
proposed in public pull requests 144, 150, 151, 167, 168, 181, and
186.
* Use *strict subset* in describing the partial order of memory
property types for slink:VkMemoryType, and update the style guide
accordingly (public issue 190).
* Fix various "a image" -> "an image" typos (public issue 191).
* Note in the <<fundamentals-validusage,Valid Usage>> and
<<extensions-interactions,Extension Interactions>> sections that
structures defined by extensions which may be passed in structure
chains using the ptext:pNext member must: include initial
ptext:sType and ptext:pNext members (public issue 192).
Internal Issues:
* Remove duplicate language from the description of the pname:fence
parameter to flink:vkQueueSubmit and improve validity language
(internal issue 91).
* Added documentation for "optional" attribute to XML readme.tex/pdf
(internal issue 149).
* Clarify the host-side data validity rules and behavior of
flink:vkFlushMappedMemoryRanges and
flink:vkInvalidateMappedMemoryRanges (internal issue 266).
Other Commits:
* Added clarification to flink:vkCmdFillBuffer regarding the use of
ename:VK_WHOLE_SIZE.
* Fixed and documented implementation of "validextensionstructs"
attribute. in XML processing scripts and readme.tex/pdf.
* Add missing validity statements to flink:vkResetEvent and
flink:vkCmdResetEvent.
* Fix validity for the
ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag.
Correct all the draw/dispatch commands to mention optimally tiled
images as well as linear tiled images, and say image VIEWS instead
of images. Add validity statement to flink:vkCmdBlitImage
* Replace the {apiname} macro with hardcoded "Vulkan", now that we've
committed to that name.
* Add the VK_AMD_rasterization_order extension to vk.xml.

View File

@ -26,7 +26,6 @@ allchecks: checkinc checklinks
# Note that the := assignments below are immediate, not deferred, and # Note that the := assignments below are immediate, not deferred, and
# are therefore order-dependent in the Makefile # are therefore order-dependent in the Makefile
APINAME=Vulkan
QUIET?=@ QUIET?=@
ASCIIDOC ?= asciidoc.py ASCIIDOC ?= asciidoc.py
A2X ?= a2x.py A2X ?= a2x.py
@ -64,14 +63,14 @@ KEEP =
# asciidoc / a2x attributes to set. # asciidoc / a2x attributes to set.
# XMLLINT normally unset - to detect problems with intermediate files # XMLLINT normally unset - to detect problems with intermediate files
# NOTEOPTS sets options controlling which NOTEs are generated # NOTEOPTS sets options controlling which NOTEs are generated
# ATTRIBOPTS sets {apiname} to "Vulkan" and enables MathJax generation # ATTRIBOPTS sets the api revision and enables MathJax generation
# VKCONF contains Vulkan-specific Asciidoc macros # VKCONF contains Vulkan-specific Asciidoc macros
# ADOCOPTS options for asciidoc->HTML output # ADOCOPTS options for asciidoc->HTML output
# ADOCPDFOPTS options for asciidoc->PDF output via dblatex (not using a2x) # ADOCPDFOPTS options for asciidoc->PDF output via dblatex (not using a2x)
# A2XOPTS options for a2x->{HTML,PDF} output # A2XOPTS options for a2x->{HTML,PDF} output
XMLLINT = --no-xmllint XMLLINT = --no-xmllint
NOTEOPTS = -a editing-notes -a implementation-guide NOTEOPTS = -a editing-notes -a implementation-guide
ATTRIBOPTS = -a apiname=$(APINAME)@ -a apirevision="$(SPECREVISION)" -a mathjax ATTRIBOPTS = -a apirevision="$(SPECREVISION)" -a mathjax
VKCONF = config/vkspec.conf VKCONF = config/vkspec.conf
ADOCOPTS = $(ATTRIBOPTS) $(NOTEOPTS) -f config/mathjax-asciidoc.conf \ ADOCOPTS = $(ATTRIBOPTS) $(NOTEOPTS) -f config/mathjax-asciidoc.conf \
-f $(VKCONF) $(VERBOSE) -f $(VKCONF) $(VERBOSE)
@ -126,7 +125,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.11 SPECREVISION = 1.0.12
SPECREMARK = SPECREMARK =
# Spec targets # Spec targets

View File

@ -7,7 +7,7 @@
*Last Modified Date*:: 16/02/2016 *Last Modified Date*:: 16/02/2016
*Revision*:: 1 *Revision*:: 1
*Dependencies*:: *Dependencies*::
- This extension is written against version 1.0. of the {apiname} API. - This extension is written against version 1.0. of the Vulkan API.
*Contributors*:: *Contributors*::
- Tobias Hector, Imagination Technologies - Tobias Hector, Imagination Technologies
*Contacts*:: *Contacts*::

View File

@ -26,7 +26,7 @@ Format Specification.
[[appendix-compressedtex-bc]] [[appendix-compressedtex-bc]]
== Block-Compressed Image Formats == Block-Compressed Image Formats
.Mapping of {apiname} BC formats to descriptions .Mapping of Vulkan BC formats to descriptions
[width="90%",options="header",cols="5,4"] [width="90%",options="header",cols="5,4"]
|============================== |==============================
| VkFormat | Data Format Specification description | VkFormat | Data Format Specification description
@ -59,7 +59,7 @@ Format Specification.
The following formats are described in the ``ETC2 Compressed Texture Image The following formats are described in the ``ETC2 Compressed Texture Image
Formats'' chapter of the Khronos Data Format Specification. Formats'' chapter of the Khronos Data Format Specification.
.Mapping of {apiname} ETC formats to descriptions .Mapping of Vulkan ETC formats to descriptions
[options="header",cols="1,1"] [options="header",cols="1,1"]
|============================== |==============================
| VkFormat | Data Format Specification description | VkFormat | Data Format Specification description
@ -83,7 +83,7 @@ Formats'' chapter of the Khronos Data Format Specification.
ASTC formats are described in the ``ASTC Compressed Texture Image Formats'' ASTC formats are described in the ``ASTC Compressed Texture Image Formats''
chapter of the Khronos Data Format Specification. chapter of the Khronos Data Format Specification.
.Mapping of {apiname} ASTC formats to descriptions .Mapping of Vulkan ASTC formats to descriptions
[width="75%",options="header",cols="63%,15%,22%"] [width="75%",options="header",cols="63%,15%,22%"]
|============================== |==============================
| VkFormat ^| Compressed texel block dimensions ^| sRGB-encoded | VkFormat ^| Compressed texel block dimensions ^| sRGB-encoded

View File

@ -6,9 +6,9 @@
[[extensions]] [[extensions]]
= Layers & Extensions = Layers & Extensions
Extensions to the {apiname} API can: be defined by authors, groups of Extensions to the Vulkan API can: be defined by authors, groups of
authors, and the Khronos {apiname} Working Group. In order not to compromise authors, and the Khronos Vulkan Working Group. In order not to compromise
the readability of the {apiname} Specification, the core Specification does the readability of the Vulkan Specification, the core Specification does
not incorporate most extensions. The online registry of extensions is not incorporate most extensions. The online registry of extensions is
available at URL available at URL
@ -41,7 +41,7 @@ several purposes:
* Provides a central repository for documentation and header changes * Provides a central repository for documentation and header changes
associated with extensions associated with extensions
{apiname}'s design and general software development trends introduces two Vulkan's design and general software development trends introduces two
new paradigms that require rethinking the existing mechanisms: new paradigms that require rethinking the existing mechanisms:
* Layers, and with them a focus on a more open ecosystem where non-Khronos * Layers, and with them a focus on a more open ecosystem where non-Khronos
@ -63,7 +63,7 @@ Some general rules to simplify the specific rules below:
* All extensions must: be registered with Khronos. * All extensions must: be registered with Khronos.
* Extensions must: be strictly additive and backwards-compatible. That is, * Extensions must: be strictly additive and backwards-compatible. That is,
extensions mustnot: remove existing functionality, or change existing extensions mustnot: remove existing functionality, or change existing
default behaviors. A {apiname} implementation may: support any default behaviors. A Vulkan implementation may: support any
combination of extensions, but applications written using only the core combination of extensions, but applications written using only the core
API, or a subset of the supported extensions, must: continue to work in API, or a subset of the supported extensions, must: continue to work in
such an implementation without changes in behavior. such an implementation without changes in behavior.
@ -78,8 +78,8 @@ Both extensions and layer names include a +VK_+ prefix. In addition, layers
add a +LAYER_+ prefix. Extension and layer names also contain an _author add a +LAYER_+ prefix. Extension and layer names also contain an _author
prefix_ identifying the author of the extension/layer. This prefix is a prefix_ identifying the author of the extension/layer. This prefix is a
short, capitalized, registered string identifying an author, such as a short, capitalized, registered string identifying an author, such as a
Khronos member developing {apiname} implementations for their devices, or a Khronos member developing Vulkan implementations for their devices, or a
non-Khronos developer creating {apiname} layers. non-Khronos developer creating Vulkan layers.
Some authors have platform communities they wish to distinguish between, and Some authors have platform communities they wish to distinguish between, and
can: register additional author prefixes for that purpose. For example, can: register additional author prefixes for that purpose. For example,
@ -98,7 +98,7 @@ only for layers.
will use the prefix +VK_KHR_+. will use the prefix +VK_KHR_+.
** The following author prefixes are reserved and mustnot: be used: ** The following author prefixes are reserved and mustnot: be used:
*** +VK+ - To avoid confusion with the top-level +VK_+ prefix. *** +VK+ - To avoid confusion with the top-level +VK_+ prefix.
*** +VULKAN+ - To avoid confusion with the name of the {apiname} API. *** +VULKAN+ - To avoid confusion with the name of the Vulkan API.
*** +LAYER+ - To avoid confusion with the higher-level ``LAYER'' prefix. *** +LAYER+ - To avoid confusion with the higher-level ``LAYER'' prefix.
*** +KHRONOS+ - To avoid confusion with the Khronos organization. *** +KHRONOS+ - To avoid confusion with the Khronos organization.
** Multi-author extensions that have not been ratified by Khronos (those ** Multi-author extensions that have not been ratified by Khronos (those
@ -143,7 +143,7 @@ browser.
== Extension Command, Type, and Token Naming Conventions == Extension Command, Type, and Token Naming Conventions
Extensions may: add new commands, types, and tokens, or collectively Extensions may: add new commands, types, and tokens, or collectively
``objects'', to the {apiname} API. These objects are given globally unique ``objects'', to the Vulkan API. These objects are given globally unique
names by appending the author prefix defined above for the extension name names by appending the author prefix defined above for the extension name
according to the following templates. according to the following templates.
@ -184,10 +184,10 @@ enum VkSomeValuesGRPHX {
[[extensions-api-registry]] [[extensions-api-registry]]
== The {apiname} Registry == The Vulkan Registry
The canonical definition of the {apiname} APIs is kept in an XML file known The canonical definition of the Vulkan APIs is kept in an XML file known
as the *{apiname} registry*. The registry is kept in +src/spec/vk.xml+ in as the *Vulkan registry*. The registry is kept in +src/spec/vk.xml+ in
the branch of the vulkan project containing the most recently released core the branch of the vulkan project containing the most recently released core
API specification. The registry contains reserved author prefixes, core and API specification. The registry contains reserved author prefixes, core and
extension interface definitions, definitions of individual commands and extension interface definitions, definitions of individual commands and
@ -202,7 +202,7 @@ documentation used in generating the API specification and reference pages.
== Registering an Author Prefix with Khronos == Registering an Author Prefix with Khronos
Previous Khronos APIs could only officially be modified by Khronos members. Previous Khronos APIs could only officially be modified by Khronos members.
In an effort to build a more flexible platform, {apiname} allows non-Khronos In an effort to build a more flexible platform, Vulkan allows non-Khronos
developers to extend and modify the API via layers and extensions in the developers to extend and modify the API via layers and extensions in the
same manner as Khronos members. However, extensions must: still be same manner as Khronos members. However, extensions must: still be
registered with Khronos. A mechanism for non-members to register layers and registered with Khronos. A mechanism for non-members to register layers and
@ -222,7 +222,7 @@ contact email address, respectively. The author prefix will be reserved only
once this merge request is accepted. once this merge request is accepted.
Please do not try to reserve author names which clearly belong to another Please do not try to reserve author names which clearly belong to another
existing company or software project which may: wish to develop {apiname} existing company or software project which may: wish to develop Vulkan
extensions or layers in the future, as a matter of courtesy and respect. extensions or layers in the future, as a matter of courtesy and respect.
Khronos may: decline to register author names that are not requested in good Khronos may: decline to register author names that are not requested in good
faith. faith.
@ -231,7 +231,7 @@ faith.
[[extensions-vendor-id]] [[extensions-vendor-id]]
== Registering a Vendor ID with Khronos == Registering a Vendor ID with Khronos
{apiname} implementers must report a valid vendor ID for their Vulkan implementers must report a valid vendor ID for their
implementation, as reported by implementation, as reported by
<<devsandqueues-physical-device-enumeration,physical device queries>>. If <<devsandqueues-physical-device-enumeration,physical device queries>>. If
there is no valid PCI vendor ID defined for the physical device, there is no valid PCI vendor ID defined for the physical device,
@ -251,7 +251,7 @@ available ID in the list of +<vendorid>+ tags. The vendor ID will be
reserved only once this merge request has been accepted. reserved only once this merge request has been accepted.
Please do not try to reserve vendor IDs unless you are making a good faith Please do not try to reserve vendor IDs unless you are making a good faith
effort to develop a {apiname} implementation and require one for that effort to develop a Vulkan implementation and require one for that
purpose. purpose.
@ -264,7 +264,7 @@ registration is strongly recommended. Registration means:
* Adding the extension or layer name to the list in +vk.xml+ and appearing * Adding the extension or layer name to the list in +vk.xml+ and appearing
on the Khronos registry website, which will link to associated on the Khronos registry website, which will link to associated
documentation hosted on Khronos. documentation hosted on Khronos.
* For extensions which add to the {apiname} API, including definitions of * For extensions which add to the Vulkan API, including definitions of
those additions to +vk.xml+. those additions to +vk.xml+.
Registration for Khronos members is handled by filing a merge request in the Registration for Khronos members is handled by filing a merge request in the
@ -298,7 +298,7 @@ extension number assignment prior to extension publication:
* Develop and test the extension using the registered extension number. * Develop and test the extension using the registered extension number.
* Publish the extension to Khronos using the previously registered * Publish the extension to Khronos using the previously registered
extension number, by creating a branch of the repository with extension number, by creating a branch of the repository with
appropriate changes relative to the core {apiname} API branch. appropriate changes relative to the core Vulkan API branch.
* Mark the extension as enabled, by proposing a merge to master changing * Mark the extension as enabled, by proposing a merge to master changing
the +supported+ attribute value of the +<extension>+ to the +supported+ attribute value of the +<extension>+ to
+supported="vulkan"+. This should: be completely automated and under the +supported="vulkan"+. This should: be completely automated and under the
@ -326,15 +326,15 @@ endif::editing-notes[]
== Documenting Extensions == Documenting Extensions
Extensions are documented as modifications to the {apiname} specification. Extensions are documented as modifications to the Vulkan specification.
These modifications will be on Git branches that are named with the These modifications will be on Git branches that are named with the
following syntax: +<major.minor core spec version>-<extension_name>+ following syntax: +<major.minor core spec version>-<extension_name>+
For example, the VK_KHR_surface extension will be documented relative For example, the VK_KHR_surface extension will be documented relative
to version 1.0 of the {apiname} specification. As such, the branch name will to version 1.0 of the Vulkan specification. As such, the branch name will
be: +1.0-VK_KHR_surface+ be: +1.0-VK_KHR_surface+
If the extension modifies an existing section of the {apiname} If the extension modifies an existing section of the Vulkan
specification, those modifications are made in-place. Since the changes are specification, those modifications are made in-place. Since the changes are
on a branch, the core-only specification can: be easily produced. A on a branch, the core-only specification can: be easily produced. A
specification with an extension is created by merging in the extension's specification with an extension is created by merging in the extension's
@ -347,7 +347,7 @@ higher-numbered extension should: take care to deal with any conflicts.
The WSI extensions were used to help pioneer what should: be done for The WSI extensions were used to help pioneer what should: be done for
extensions. This includes the following: extensions. This includes the following:
* All extensions should: add to the appendix of the {apiname} * All extensions should: add to the appendix of the Vulkan
specification. This should: be modeled after what was done for the specification. This should: be modeled after what was done for the
+VK_KHR_surface+ extension, which contains some high-level information +VK_KHR_surface+ extension, which contains some high-level information
about the extension (as well as code examples, and revision history) in about the extension (as well as code examples, and revision history) in
@ -360,12 +360,12 @@ extensions. This includes the following:
multiple extensions' branches are merged in order to create the ``full'' multiple extensions' branches are merged in order to create the ``full''
branch specification. branch specification.
* If there are any other places where 2 or more extensions will extend the * If there are any other places where 2 or more extensions will extend the
{apiname} specification, it is best to put that content in a file, and Vulkan specification, it is best to put that content in a file, and
use an +include+ statement to put that content into the spec. Again, use an +include+ statement to put that content into the spec. Again,
this +include+ line should: be put on the master branch in order to this +include+ line should: be put on the master branch in order to
avoid merge conflicts. avoid merge conflicts.
* If an extension is more of an addition to the {apiname} specification, * If an extension is more of an addition to the Vulkan specification,
the extension should: add a chapter to the {apiname} specification. the extension should: add a chapter to the Vulkan specification.
== Assigning Extension Token Values == Assigning Extension Token Values
@ -443,7 +443,7 @@ all extensions must: define two additional tokens.
extension specification, and is incremented when significant changes extension specification, and is incremented when significant changes
(bugfixes or added functionality) are made. Note that the revision of an (bugfixes or added functionality) are made. Note that the revision of an
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 Vulkan 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 <<extended-functionality-extensions,extension returned by one of the <<extended-functionality-extensions,extension
queries>>) may: differ. In such cases, only the functionality and queries>>) may: differ. In such cases, only the functionality and
@ -472,7 +472,7 @@ be included in the +vulkan.h+ header supplied by Khronos.
.Note .Note
==== ====
Application developers are encouraged to be careful when using +switch+ Application developers are encouraged to be careful when using +switch+
statements with {apiname} API enums. This is because extensions can: add new statements with Vulkan API enums. This is because extensions can: add new
values to existing enums. The use of a +default:+ statement, within a values to existing enums. The use of a +default:+ statement, within a
+switch+, may: avoid future compilation issues. +switch+, may: avoid future compilation issues.
==== ====
@ -481,23 +481,23 @@ values to existing enums. The use of a +default:+ statement, within a
[[extension-function_prototypes]] [[extension-function_prototypes]]
== Extension Function Prototypes == Extension Function Prototypes
Function pointer declarations and function prototypes for all core {apiname} Function pointer declarations and function prototypes for all core Vulkan
API commands are included in the +vulkan.h+ file. These come from the API commands are included in the +vulkan.h+ file. These come from the
official XML specification of the {apiname} API hosted by Khronos. official XML specification of the Vulkan API hosted by Khronos.
Function pointer declarations are also included in the +vulkan.h+ file for Function pointer declarations are also included in the +vulkan.h+ file for
all commands defined by registered extensions. Function prototypes for all commands defined by registered extensions. Function prototypes for
extensions may: be included in +vulkan.h+. Extension commands that are part extensions may: be included in +vulkan.h+. Extension commands that are part
of the {apiname} ABI must: be flagged in the XML. Function prototypes will of the Vulkan ABI must: be flagged in the XML. Function prototypes will
be included in +vulkan.h+ for all extension commands that are part of the be included in +vulkan.h+ for all extension commands that are part of the
{apiname} ABI. Vulkan ABI.
An extension can: be considered platform specific, in which case its An extension can: be considered platform specific, in which case its
interfaces in +vulkan.h+ are protected by #ifdefs. This is orthogonal to interfaces in +vulkan.h+ are protected by #ifdefs. This is orthogonal to
whether an extension command is considered to be part of the {apiname} ABI. whether an extension command is considered to be part of the Vulkan ABI.
The initial set of WSI extension commands are considered to be part of the The initial set of WSI extension commands are considered to be part of the
{apiname} ABI. Function prototypes for these WSI commands are included in Vulkan ABI. Function prototypes for these WSI commands are included in
the +vulkan.h+ provided by Khronos, though the platform-specific portions of the +vulkan.h+ provided by Khronos, though the platform-specific portions of
+vulkan.h+ are protected by #ifdefs. +vulkan.h+ are protected by #ifdefs.
@ -505,7 +505,7 @@ the +vulkan.h+ provided by Khronos, though the platform-specific portions of
.Note .Note
==== ====
Based on feedback from implementers, Khronos expects that the Android, Based on feedback from implementers, Khronos expects that the Android,
Linux, and Windows {apiname} SDKs will include our +vulkan.h+ and export Linux, and Windows Vulkan SDKs will include our +vulkan.h+ and export
the supported WSI functions for those platforms from their loader the supported WSI functions for those platforms from their loader
libraries. Other implementations can: make different choices for their libraries. Other implementations can: make different choices for their
headers and loader libraries, but are encouraged to be consistent with headers and loader libraries, but are encouraged to be consistent with
@ -518,8 +518,8 @@ these implementations.
flink:vkGetInstanceProcAddr and flink:vkGetDeviceProcAddr can: be used in flink:vkGetInstanceProcAddr and flink:vkGetDeviceProcAddr can: be used in
order to obtain function pointer addresses for core and extension commands order to obtain function pointer addresses for core and extension commands
(per the description in <<initialization-functionpointers,Command Function (per the description in <<initialization-functionpointers,Command Function
Pointers>>). Different {apiname} API loaders can: choose to statically Pointers>>). Different Vulkan API loaders can: choose to statically
export functions for some or all of the core {apiname} API commands, and export functions for some or all of the core Vulkan API commands, and
can: statically export functions for some or all extension commands. If a can: statically export functions for some or all extension commands. If a
loader statically exports a function, an application can: link against that loader statically exports a function, an application can: link against that
function without needing to call one of the ftext:vkGet*ProcAddr commands. function without needing to call one of the ftext:vkGet*ProcAddr commands.
@ -527,8 +527,8 @@ function without needing to call one of the ftext:vkGet*ProcAddr commands.
[NOTE] [NOTE]
.Note .Note
==== ====
The Khronos-provided {apiname} API loader for Android, Linux, and Windows The Khronos-provided Vulkan API loader for Android, Linux, and Windows
exports functions for all core {apiname} API and WSI extension commands. The exports functions for all core Vulkan API and WSI extension commands. The
WSI functions are considered special, because they are required for many WSI functions are considered special, because they are required for many
applications. applications.
==== ====
@ -556,6 +556,7 @@ defined and locked down, it's safest to refer to the listed contact.
==== ====
[[extensions-interactions]]
== Extension Interactions == Extension Interactions
Extensions modifying the behavior of existing commands should: provide Extensions modifying the behavior of existing commands should: provide
@ -563,7 +564,14 @@ additional parameters by using the pname:pNext field of an existing
structure, pointing to a new structure defined by the extension, as structure, pointing to a new structure defined by the extension, as
described in the <<fundamentals-validusage,Valid Usage>> section. Extension described in the <<fundamentals-validusage,Valid Usage>> section. Extension
structures defined by multiple extensions affecting the same structure can structures defined by multiple extensions affecting the same structure can
be chained together in this fashion. be chained together in this fashion. Any structure which can: be chained
in this fashion must: begin with the following two members:
["source","{basebackend@docbook:c++:cpp}",title=""]
------------------------------------------------------------------------------
VkStructureType sType;
const void* pNext;
------------------------------------------------------------------------------
It is in principle possible for extensions to provide additional parameters It is in principle possible for extensions to provide additional parameters
through alternate means, such as passing a handle parameter to a structure through alternate means, such as passing a handle parameter to a structure

View File

@ -216,7 +216,7 @@ Device-Local Memory::
Dispatchable Handle:: Dispatchable Handle::
A handle of a pointer handle type which may: be used by layers as part A handle of a pointer handle type which may: be used by layers as part
of intercepting API commands. The first argument to each {apiname} of intercepting API commands. The first argument to each Vulkan
command is a dispatchable handle type. command is a dispatchable handle type.
Dispatching Commands:: Dispatching Commands::
@ -229,7 +229,7 @@ Drawing Commands::
flink:vkCmdDrawIndexedIndirect. flink:vkCmdDrawIndexedIndirect.
Duration (Command):: Duration (Command)::
The _duration_ of a {apiname} command refers to the interval between The _duration_ of a Vulkan command refers to the interval between
calling the command and its return to the caller. calling the command and its return to the caller.
Dynamic Storage Buffer:: Dynamic Storage Buffer::
@ -314,7 +314,7 @@ Global Workgroup::
A collection of local workgroups dispatched by a single dispatch command. A collection of local workgroups dispatched by a single dispatch command.
Handle:: 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 Vulkan object.
Each object type has a unique handle type. Each object type has a unique handle type.
Happen-after:: Happen-after::
@ -378,7 +378,7 @@ Immutable Sampler::
the layout, and cannot be changed. the layout, and cannot be changed.
Implicitly-Enabled Layer:: Implicitly-Enabled Layer::
A layer enabled by a loader-defined mechanism outside the {apiname} API, A layer enabled by a loader-defined mechanism outside the Vulkan API,
rather than explicitly by the application during instance or device rather than explicitly by the application during instance or device
creation. creation.
@ -402,7 +402,7 @@ Input Attachment::
view. view.
Instance:: Instance::
The top-level {apiname} object, which represents the application's The top-level Vulkan object, which represents the application's
connection to the implementation. Represented by a sname:VkInstance connection to the implementation. Represented by a sname:VkInstance
object. object.
@ -427,7 +427,7 @@ Local Workgroup::
Logical Device:: Logical Device::
An object that represents the application's interface to the physical An object that represents the application's interface to the physical
device. The logical device is the parent of most {apiname} objects. device. The logical device is the parent of most Vulkan objects.
Represented by a sname:VkDevice object. Represented by a sname:VkDevice object.
Logical Operation:: Logical Operation::
@ -802,7 +802,7 @@ A::
= Prefixes = Prefixes
Prefixes are used in the API to denote specific semantic meaning of Prefixes are used in the API to denote specific semantic meaning of
{apiname} names, or as a label to avoid name clashes, and are explained Vulkan names, or as a label to avoid name clashes, and are explained
here: here:
VK/Vk/vk:: VK/Vk/vk::

View File

@ -4,8 +4,8 @@
[appendix] [appendix]
= Invariance = Invariance
The {apiname} specification is not pixel exact. It therefore does not The Vulkan specification is not pixel exact. It therefore does not
guarantee an exact match between images produced by different {apiname} guarantee an exact match between images produced by different Vulkan
implementations. However, the specification does specify exact matches, in implementations. However, the specification does specify exact matches, in
some cases, for images produced by the same implementation. The purpose of some cases, for images produced by the same implementation. The purpose of
this appendix is to identify and provide justification for those cases that this appendix is to identify and provide justification for those cases that
@ -14,10 +14,10 @@ require exact matches.
== Repeatability == Repeatability
The obvious and most fundamental case is repeated issuance of a series of The obvious and most fundamental case is repeated issuance of a series of
{apiname} commands. For any given {apiname} and framebuffer state vector, Vulkan commands. For any given Vulkan and framebuffer state vector,
and for any {apiname} command, the resulting {apiname} and framebuffer state and for any Vulkan command, the resulting Vulkan and framebuffer state
must: be identical whenever the command is executed on that initial must: be identical whenever the command is executed on that initial
{apiname} and framebuffer state. This repeatability requirement doesn't Vulkan and framebuffer state. This repeatability requirement doesn't
apply when using shaders containing side effects (image and buffer variable apply when using shaders containing side effects (image and buffer variable
stores and atomic operations), because these memory operations are not stores and atomic operations), because these memory operations are not
guaranteed to be processed in a defined order. guaranteed to be processed in a defined order.
@ -38,7 +38,7 @@ Additional invariance rules are desirable to ensure useful operation.
== Multi-pass Algorithms == Multi-pass Algorithms
Invariance is necessary for a whole set of useful multi-pass algorithms. Invariance is necessary for a whole set of useful multi-pass algorithms.
Such algorithms render multiple times, each time with a different {apiname} Such algorithms render multiple times, each time with a different Vulkan
mode vector, to eventually produce a result in the framebuffer. Examples of mode vector, to eventually produce a result in the framebuffer. Examples of
these algorithms include: these algorithms include:
@ -49,11 +49,11 @@ these algorithms include:
== Invariance Rules == Invariance Rules
For a given instantiation of an {apiname} rendering context: For a given instantiation of an Vulkan rendering context:
*Rule 1* _For any given {apiname} and framebuffer state vector, and for any *Rule 1* _For any given Vulkan and framebuffer state vector, and for any
given {apiname} command, the resulting {apiname} and framebuffer state must: given Vulkan command, the resulting Vulkan and framebuffer state must:
be identical each time the command is executed on that initial {apiname} and be identical each time the command is executed on that initial Vulkan and
framebuffer state._ framebuffer state._
*Rule 2* _Changes to the following state values have no side effects (the *Rule 2* _Changes to the following state values have no side effects (the
@ -89,7 +89,7 @@ sequence, are pixel identical._
when run multiple times with the same input. The wording ``the same shader'' when run multiple times with the same input. The wording ``the same shader''
means a program object that is populated with the same SPIR-V binary, which means a program object that is populated with the same SPIR-V binary, which
is used to create pipelines, possibly multiple times, and which program is used to create pipelines, possibly multiple times, and which program
object is then executed using the same {apiname} state vector. Invariance is object is then executed using the same Vulkan state vector. Invariance is
relaxed for shaders with side effects, such as performing stores or relaxed for shaders with side effects, such as performing stores or
atomics._ atomics._
@ -98,19 +98,19 @@ assign_ code:FragCoord.z _to_ code:FragDepth _are depth-invariant with
respect to each other, for those fragments where the assignment to_ respect to each other, for those fragments where the assignment to_
code:FragDepth _actually is done._ code:FragDepth _actually is done._
If a sequence of {apiname} commands specifies primitives to be rendered with If a sequence of Vulkan commands specifies primitives to be rendered with
shaders containing side effects (image and buffer variable stores and atomic shaders containing side effects (image and buffer variable stores and atomic
operations), invariance rules are relaxed. In particular, rule 1, corollary operations), invariance rules are relaxed. In particular, rule 1, corollary
2, and rule 4 do not apply in the presence of shader side effects. 2, and rule 4 do not apply in the presence of shader side effects.
The following weaker versions of rules 1 and 4 apply to {apiname} commands The following weaker versions of rules 1 and 4 apply to Vulkan commands
involving shader side effects: involving shader side effects:
*Rule 6* _For any given {apiname} and framebuffer state vector, and for any *Rule 6* _For any given Vulkan and framebuffer state vector, and for any
given {apiname} command, the contents of any framebuffer state not directly given Vulkan command, the contents of any framebuffer state not directly
or indirectly affected by results of shader image or buffer variable stores or indirectly affected by results of shader image or buffer variable stores
or atomic operations must: be identical each time the command is executed on or atomic operations must: be identical each time the command is executed on
that initial {apiname} and framebuffer state._ that initial Vulkan and framebuffer state._
*Rule 7* _The same vertex or fragment shader will produce the same result *Rule 7* _The same vertex or fragment shader will produce the same result
when run multiple times with the same input as long as:_ when run multiple times with the same input as long as:_
@ -121,8 +121,8 @@ when run multiple times with the same input as long as:_
* _no shader invocation, or other operation performed to process the * _no shader invocation, or other operation performed to process the
sequence of commands, reads memory written to by an image store._ sequence of commands, reads memory written to by an image store._
When any sequence of {apiname} commands triggers shader invocations that When any sequence of Vulkan commands triggers shader invocations that
perform image stores or atomic operations, and subsequent {apiname} commands perform image stores or atomic operations, and subsequent Vulkan commands
read the memory written by those shader invocations, these operations must: read the memory written by those shader invocations, these operations must:
be explicitly synchronized. be explicitly synchronized.

View File

@ -3,16 +3,16 @@
[appendix] [appendix]
[[spirvenv]] [[spirvenv]]
= {apiname} Environment for SPIR-V = Vulkan Environment for SPIR-V
Shaders for {apiname} are defined by the <<Khronos SPIR-V Specification>> as Shaders for Vulkan are defined by the <<Khronos SPIR-V Specification>> as
well as the <<Khronos SPIR-V Extended Instructions for GLSL Specification>>. well as the <<Khronos SPIR-V Extended Instructions for GLSL Specification>>.
This appendix defines additional SPIR-V requirements applying to {apiname} This appendix defines additional SPIR-V requirements applying to Vulkan
shaders. shaders.
== Required Versions and Formats == Required Versions and Formats
A {apiname} 1.0 implementation must: support the 1.0 version of SPIR-V and A Vulkan 1.0 implementation must: support the 1.0 version of SPIR-V and
the 1.0 version of the SPIR-V Extended Instructions for GLSL. the 1.0 version of the SPIR-V Extended Instructions for GLSL.
A SPIR-V module passed into flink:vkCreateShaderModule is interpreted as A SPIR-V module passed into flink:vkCreateShaderModule is interpreted as
@ -47,7 +47,7 @@ to that feature must: also be supported.
.SPIR-V Capabilities which are not required:, and corresponding feature names .SPIR-V Capabilities which are not required:, and corresponding feature names
[options="header"] [options="header"]
|==== |====
| SPIR-V OpCapability | {apiname} feature name | SPIR-V OpCapability | Vulkan feature name
| code:Geometry | <<features-features-geometryShader,geometryShader>> | code:Geometry | <<features-features-geometryShader,geometryShader>>
| code:Tessellation | <<features-features-tessellationShader,tessellationShader>> | code:Tessellation | <<features-features-tessellationShader,tessellationShader>>
| code:Float64 | <<features-features-shaderFloat64,shaderFloat64>> | code:Float64 | <<features-features-shaderFloat64,shaderFloat64>>
@ -81,7 +81,7 @@ following to flink:vkCreateShaderModule:
- any OpCapability not listed above, - any OpCapability not listed above,
- an unsupported capability, or - an unsupported capability, or
- a capability which corresponds to a {apiname} feature which has not been - a capability which corresponds to a Vulkan feature which has not been
enabled. enabled.
@ -198,18 +198,18 @@ negative the result is undefined.
.Note .Note
==== ====
While the code:OpSRem and code:OpSMod instructions are supported by the While the code:OpSRem and code:OpSMod instructions are supported by the
{apiname} environment, they require non-negative values and thus do not Vulkan environment, they require non-negative values and thus do not
enable additional functionality beyond what code:OpUMod provides. enable additional functionality beyond what code:OpUMod provides.
==== ====
[[spirvenv-image-formats]] [[spirvenv-image-formats]]
Compatibility Between SPIR-V Image Formats And {apiname} Formats Compatibility Between SPIR-V Image Formats And Vulkan Formats
---------------------------------------------------------------- -------------------------------------------------------------
[cols="2*", options="header"] [cols="2*", options="header"]
|=== |===
|SPIR-V Image Format |{apiname} Format |SPIR-V Image Format |Vulkan Format
|code:Rgba32f |ename:VK_FORMAT_R32G32B32A32_SFLOAT |code:Rgba32f |ename:VK_FORMAT_R32G32B32A32_SFLOAT
|code:Rgba16f |ename:VK_FORMAT_R16G16B16A16_SFLOAT |code:Rgba16f |ename:VK_FORMAT_R16G16B16A16_SFLOAT
|code:R32f |ename:VK_FORMAT_R32_SFLOAT |code:R32f |ename:VK_FORMAT_R32_SFLOAT

View File

@ -221,7 +221,9 @@ include::../protos/vkCmdFillBuffer.txt[]
filling, and must: be a multiple of 4. filling, and must: be a multiple of 4.
* pname:size is the number of bytes to fill, and must: be either a * pname:size is the number of bytes to fill, and must: be either a
multiple of 4, or ename:VK_WHOLE_SIZE to fill the range from multiple of 4, or ename:VK_WHOLE_SIZE to fill the range from
pname:offset to the end of the buffer. pname:offset to the end of the buffer. If ename:VK_WHOLE_SIZE is used
and the remaining size of the buffer is not a multiple of 4, then the
nearest smaller multiple is used.
* pname:data is the 4-byte word written repeatedly to the buffer to fill * pname:data is the 4-byte word written repeatedly to the buffer to fill
pname:size bytes of data. The data word is written to memory according pname:size bytes of data. The data word is written to memory according
to the host endianness. to the host endianness.

View File

@ -400,25 +400,13 @@ 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
code:VK_NULL_HANDLE, the fence is signaled when execution of all code:VK_NULL_HANDLE, the fence is signaled when execution of all command
sname:VkSubmitInfo::pname:pCommandBuffers members of pname:pSubmits is buffers specified in the sname:VkSubmitInfo::pname:pCommandBuffers
completed. If pname:submitCount is zero but pname:fence is not members of pname:pSubmits is complete, providing certain
code:VK_NULL_HANDLE, the fence will still be submitted to the queue and <<synchronization-implicit-ordering,implicit ordering guarantees>>. If
will become signaled when all work previously submitted to the queue has pname:submitCount is zero but pname:fence is not code:VK_NULL_HANDLE,
completed. the fence will still be submitted to the queue and will become signaled
when all work previously submitted to the queue has completed.
ifdef::editing-notes[]
[NOTE]
.editing-note
====
(Jon) The description of pname:fence here was added from the ref page
because it was missing from the starting point of MR #1048, which is just
about cleaning up the markup of command parameters. It needs to be resolved
with the description far below of pname:fence, as noted by @jbolz, because
they're not very similar and because most of the second description belongs
in validity XML language.
====
endif::editing-notes[]
include::../validity/protos/vkQueueSubmit.txt[] include::../validity/protos/vkQueueSubmit.txt[]
@ -444,7 +432,7 @@ 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. address of which is passed in pname:pSubmits.
The sname:VkSubmitInfo structure is defined as: The sname:VkSubmitInfo structure is defined as:
@ -473,13 +461,6 @@ include::../structs/VkSubmitInfo.txt[]
include::../validity/structs/VkSubmitInfo.txt[] include::../validity/structs/VkSubmitInfo.txt[]
If pname:fence is provided, it must: be in the unsignaled state (see
<<synchronization-fences,Fences>>) and a fence must: only be associated with
a single submission until that submission completes, and the fence is
subsequently reset. When all command buffers in pname:pCommandBuffers have
completed execution, the status of pname:fence is set to signaled, providing
certain <<synchronization-implicit-ordering,implicit ordering guarantees>>.
[[commandbuffers-submission-progress]] [[commandbuffers-submission-progress]]
== Queue Forward Progress == Queue Forward Progress

View File

@ -197,7 +197,7 @@ pname:extent.height is not a multiple of the compressed texel block height
then (pname:extent.height + pname:srcOffset.y) must: equal the image then (pname:extent.height + pname:srcOffset.y) must: equal the image
subresource height and if pname:extent.depth is not a multiple of the subresource height and if pname:extent.depth is not a multiple of the
compressed texel block depth then (pname:extent.depth + pname:srcOffset.z) compressed texel block depth then (pname:extent.depth + pname:srcOffset.z)
must: equal the image subresource depth. Similarily if the pname:dstImage is must: equal the image subresource depth. Similarly, if the pname:dstImage is
compressed and if pname:extent.width is not a multiple of the compressed compressed and if pname:extent.width is not a multiple of the compressed
texel block width then (pname:extent.width + pname:dstOffset.x) must: equal texel block width then (pname:extent.width + pname:dstOffset.x) must: equal
the image subresource width, if pname:extent.height is not a multiple of the the image subresource width, if pname:extent.height is not a multiple of the

View File

@ -79,7 +79,7 @@ layout (set=m, binding=n) uniform sampler2D variableNameArray[L];
== Descriptor Types == Descriptor Types
The following sections outline the various descriptor types supported by The following sections outline the various descriptor types supported by
{apiname}. Each section defines a descriptor type, and each descriptor type Vulkan. Each section defines a descriptor type, and each descriptor type
has a manifestation in the shading language and SPIR-V as well as in has a manifestation in the shading language and SPIR-V as well as in
descriptor sets. There is mostly a one-to-one correspondence between descriptor sets. There is mostly a one-to-one correspondence between
descriptor types and classes of opaque types in the shading language, where descriptor types and classes of opaque types in the shading language, where
@ -1478,7 +1478,7 @@ include::../validity/protos/vkCmdBindDescriptorSets.txt[]
As described above in section <<descriptorsets-pipelinelayout, Pipeline As described above in section <<descriptorsets-pipelinelayout, Pipeline
Layouts>>, the pipeline layout defines shader push constants which are Layouts>>, the pipeline layout defines shader push constants which are
updated via {apiname} commands rather than via writes to memory or copy updated via Vulkan commands rather than via writes to memory or copy
commands. commands.
[NOTE] [NOTE]

View File

@ -4,10 +4,10 @@
[[devsandqueues]] [[devsandqueues]]
= Devices and Queues = Devices and Queues
Once {apiname} is initialized, devices and queues are the primary objects Once Vulkan is initialized, devices and queues are the primary objects
used to interact with a {apiname} implementation. used to interact with a Vulkan implementation.
{apiname} separates the concept of _physical_ and _logical_ devices. A Vulkan separates the concept of _physical_ and _logical_ devices. A
physical device usually represents a single device in a system (perhaps made physical device usually represents a single device in a system (perhaps made
up of several individual hardware devices working together), of which there up of several individual hardware devices working together), of which there
are a finite number. A logical device represents an application's view of are a finite number. A logical device represents an application's view of
@ -21,7 +21,7 @@ physical devices installed in the system, call:
include::../protos/vkEnumeratePhysicalDevices.txt[] include::../protos/vkEnumeratePhysicalDevices.txt[]
* pname:instance is a handle to a {apiname} instance previously created * pname:instance is a handle to a Vulkan instance previously created
with fname:vkCreateInstance. with fname:vkCreateInstance.
* 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.
@ -60,7 +60,7 @@ The sname:VkPhysicalDeviceProperties structure is defined as:
include::../structs/VkPhysicalDeviceProperties.txt[] include::../structs/VkPhysicalDeviceProperties.txt[]
* pname:apiVersion is the version of {apiname} supported by the device, * pname:apiVersion is the version of Vulkan 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.
* pname:driverVersion is the vendor-specified version of the driver. * pname:driverVersion is the vendor-specified version of the driver.
@ -279,7 +279,7 @@ device exposes a number of _queue families_ each having one or more
_queues_. All queues in a queue family support the same operations. _queues_. All queues in a queue family support the same operations.
As described in <<devsandqueues-physical-device-enumeration,Physical As described in <<devsandqueues-physical-device-enumeration,Physical
Devices>>, a {apiname} application will first query for all physical devices Devices>>, a Vulkan application will first query for all physical devices
in a system. Each physical device can: then be queried for its capabilities, in a system. Each physical device can: then be queried for its capabilities,
including its queue and queue family properties. Once an acceptable physical including its queue and queue family properties. Once an acceptable physical
device is identified, an application will create a corresponding logical device is identified, an application will create a corresponding logical
@ -418,7 +418,7 @@ error is largely informational and intended only to inform the user that
their hardware has probably developed a fault or become physically their hardware has probably developed a fault or become physically
disconnected, and should: be investigated further. In many cases, physical disconnected, and should: be investigated further. In many cases, physical
device loss may: cause other more serious issues such as the operating device loss may: cause other more serious issues such as the operating
system crashing; in which case it may: not be reported via the {apiname} system crashing; in which case it may: not be reported via the Vulkan
API. API.
==== ====
@ -482,7 +482,7 @@ include::../validity/protos/vkDestroyDevice.txt[]
To ensure that no work is active on the device, flink:vkDeviceWaitIdle To ensure that no work is active on the device, flink:vkDeviceWaitIdle
can: be used to gate the destruction of the device. Prior to destroying a can: be used to gate the destruction of the device. Prior to destroying a
device, an application is responsible for destroying/freeing any {apiname} device, an application is responsible for destroying/freeing any Vulkan
objects that were created using that device as the first parameter of the objects that were created using that device as the first parameter of the
corresponding ftext:vkCreate* or ftext:vkAllocate* command. corresponding ftext:vkCreate* or ftext:vkAllocate* command.
@ -581,7 +581,7 @@ include::../validity/protos/vkGetDeviceQueue.txt[]
[[devsandqueues-index]] [[devsandqueues-index]]
=== Queue Family Index === Queue Family Index
The queue family index is used in multiple places in {apiname} in order to The queue family index is used in multiple places in Vulkan in order to
tie operations to a specific family of queues. tie operations to a specific family of queues.
When retrieving a handle to the queue via fname:vkGetDeviceQueue, the queue When retrieving a handle to the queue via fname:vkGetDeviceQueue, the queue
@ -647,7 +647,7 @@ binding operations in the queue have completed.
include::../validity/protos/vkQueueWaitIdle.txt[] include::../validity/protos/vkQueueWaitIdle.txt[]
Synchronization between queues is done using {apiname} semaphores as Synchronization between queues is done using Vulkan semaphores as
described in the <<synchronization,Synchronization and Cache Control>> described in the <<synchronization,Synchronization and Cache Control>>
chapter. chapter.
@ -655,7 +655,7 @@ chapter.
[[devsandqueues-sparsebinding]] [[devsandqueues-sparsebinding]]
=== Sparse Memory Binding === Sparse Memory Binding
In {apiname} it is possible to sparsely bind memory to buffers and In Vulkan it is possible to sparsely bind memory to buffers and
images as described in the <<sparsememory,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

View File

@ -5,7 +5,7 @@
= Extended Functionality = Extended Functionality
Additional functionality may: be provided by layers or extensions. A layer Additional functionality may: be provided by layers or extensions. A layer
cannot: add or modify {apiname} commands, while an extension may: do so. cannot: add or modify Vulkan commands, while an extension may: do so.
There are two kinds of layers and extensions, instance and device. Instance There are two kinds of layers and extensions, instance and device. Instance
layers and extensions are general purpose and do not depend on a specific layers and extensions are general purpose and do not depend on a specific
@ -24,10 +24,10 @@ extensions tend to be hardware-specific. Examples of these might be:
[[extended-functionality-layers]] [[extended-functionality-layers]]
== Layers == Layers
When a layer is enabled, it inserts itself into the call chain for {apiname} When a layer is enabled, it inserts itself into the call chain for Vulkan
commands the layer is interested in. A common use of layers is to validate commands the layer is interested in. A common use of layers is to validate
application behavior during development. For example, the implementation application behavior during development. For example, the implementation
will not check that {apiname} enums used by the application fall within will not check that Vulkan enums used by the application fall within
allowed ranges. Instead, a validation layer would do those checks and flag allowed ranges. Instead, a validation layer would do those checks and flag
issues. This avoids a performance penalty during production use of the issues. This avoids a performance penalty during production use of the
application because those layers would not be enabled in production. application because those layers would not be enabled in production.
@ -85,7 +85,7 @@ include::../structs/VkLayerProperties.txt[]
in the slink:VkInstanceCreateInfo and slink:VkDeviceCreateInfo in the slink:VkInstanceCreateInfo and slink:VkDeviceCreateInfo
structures passed to flink:vkCreateInstance and flink:vkCreateDevice, structures passed to flink:vkCreateInstance and flink:vkCreateDevice,
respectively, to enable this layer for an instance or device. respectively, to enable this layer for an instance or device.
* pname:specVersion is the {apiname} version the layer was written to, * pname:specVersion is the Vulkan version the layer was written to,
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.
* pname:implementationVersion is the version of this layer. It is an * pname:implementationVersion is the version of this layer. It is an
@ -95,7 +95,7 @@ include::../structs/VkLayerProperties.txt[]
include::../validity/structs/VkLayerProperties.txt[] include::../validity/structs/VkLayerProperties.txt[]
Loader implementations may: provide mechanisms outside the {apiname} API for Loader implementations may: provide mechanisms outside the Vulkan API for
enabling specific layers. Layers enabled through such a mechanism are enabling specific layers. Layers enabled through such a mechanism are
_implicitly enabled_, while layers enabled by including the layer name in _implicitly enabled_, while layers enabled by including the layer name in
the pname:ppEnabledLayerNames member of slink:VkDeviceCreateInfo are the pname:ppEnabledLayerNames member of slink:VkDeviceCreateInfo are
@ -108,7 +108,7 @@ effect.
[[extended-functionality-extensions]] [[extended-functionality-extensions]]
== Extensions == Extensions
Extensions may: define new {apiname} commands, structures, and enumerants. Extensions may: define new Vulkan commands, structures, and enumerants.
For compilation purposes, the interfaces defined by registered extensions, For compilation purposes, the interfaces defined by registered extensions,
including new structures and enumerants as well as function pointer types including new structures and enumerants as well as function pointer types
for new commands, are defined in the Khronos-supplied +vulkan.h+ together for new commands, are defined in the Khronos-supplied +vulkan.h+ together
@ -116,7 +116,7 @@ with the core API. However, commands defined by extensions may: not be
available for static linking - in which case function pointers to these available for static linking - in which case function pointers to these
commands should: be queried at runtime as described in commands should: be queried at runtime as described in
<<initialization-functionpointers>>. Extensions may: be provided by layers <<initialization-functionpointers>>. Extensions may: be provided by layers
as well as by a {apiname} implementation. as well as by a Vulkan implementation.
To query the available instance extensions, call: To query the available instance extensions, call:
@ -131,7 +131,7 @@ include::../protos/vkEnumerateInstanceExtensionProperties.txt[]
include::../validity/protos/vkEnumerateInstanceExtensionProperties.txt[] include::../validity/protos/vkEnumerateInstanceExtensionProperties.txt[]
When pLayerName parameter is NULL, only extensions provided by the {apiname} When pLayerName parameter is NULL, only extensions provided by the Vulkan
implementation or by implicitly enabled layers are returned. implementation or by implicitly enabled layers are returned.
When pname:pLayerName is the name of a layer, the instance extensions When pname:pLayerName is the name of a layer, the instance extensions
provided by that layer are returned. provided by that layer are returned.
@ -154,7 +154,7 @@ include::../protos/vkEnumerateDeviceExtensionProperties.txt[]
include::../validity/protos/vkEnumerateDeviceExtensionProperties.txt[] include::../validity/protos/vkEnumerateDeviceExtensionProperties.txt[]
When pLayerName parameter is NULL, only extensions provided by the {apiname} When pLayerName parameter is NULL, only extensions provided by the Vulkan
implementation or by implicitly enabled layers are returned. implementation or by implicitly enabled layers are returned.
When pname:pLayerName is the name of a layer, the device extensions When pname:pLayerName is the name of a layer, the device extensions
provided by that layer are returned. provided by that layer are returned.

View File

@ -4,7 +4,7 @@
[[features]] [[features]]
= Features, Limits, and Formats = Features, Limits, and Formats
{apiname} is designed to support a wide range of hardware and as such there Vulkan is designed to support a wide range of hardware and as such there
are a number of features, limits, and formats which are not supported on all are a number of features, limits, and formats which are not supported on all
hardware. Features describe functionality that is not required: and which hardware. Features describe functionality that is not required: and which
must: be explicitly enabled. Limits describe implementation-dependent must: be explicitly enabled. Limits describe implementation-dependent
@ -20,7 +20,7 @@ by the implementation.
The features and limits are reported via basic structures (that is The features and limits are reported via basic structures (that is
slink:VkPhysicalDeviceFeatures and slink:VkPhysicalDeviceLimits). slink:VkPhysicalDeviceFeatures and slink:VkPhysicalDeviceLimits).
It is expected that when new features or limits are added in a future It is expected that when new features or limits are added in a future
{apiname} version, new structure(s) and entry point(s) will be added as Vulkan version, new structure(s) and entry point(s) will be added as
necessary to query these. New functionality added by necessary to query these. New functionality added by
<<extended-functionality-extensions,extensions>> is not expected to <<extended-functionality-extensions,extensions>> is not expected to
modify the core feature and limit structures. modify the core feature and limit structures.
@ -30,7 +30,7 @@ modify the core feature and limit structures.
== Features == Features
The Specification defines a set of fine-grained features that are not The Specification defines a set of fine-grained features that are not
required:, but may: be supported by a {apiname} implementation. Support for required:, but may: be supported by a Vulkan implementation. Support for
features is reported and enabled on a per-feature basis. Features are features is reported and enabled on a per-feature basis. Features are
properties of the physical device. properties of the physical device.
@ -565,7 +565,7 @@ include::../validity/structs/VkPhysicalDeviceFeatures.txt[]
[[features-features-requirements]] [[features-features-requirements]]
=== Feature Requirements === Feature Requirements
All {apiname} graphics implementations must: support the following features: All Vulkan graphics implementations must: support the following features:
* robustBufferAccess. * robustBufferAccess.
@ -1233,7 +1233,7 @@ include::../validity/structs/VkPhysicalDeviceLimits.txt[]
[[features-limits-minmax]] [[features-limits-minmax]]
=== Limit Requirements === Limit Requirements
The following table specifies the required minimum/maximum for all {apiname} The following table specifies the required minimum/maximum for all Vulkan
graphics implementations. Where a limit corresponds to a fine-grained graphics implementations. Where a limit corresponds to a fine-grained
device feature which is optional:, the feature name is listed with two device feature which is optional:, the feature name is listed with two
required limits, one when the feature is supported and one when it is not required limits, one when the feature is supported and one when it is not
@ -3097,11 +3097,16 @@ ename:VK_FORMAT_FEATURE_BLIT_DST_BIT::
fname:vkCmdBlitImage command. fname:vkCmdBlitImage command.
ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT:: ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT::
sname:VkImage can: be used with a sampler that has either of If ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT is also set,
sname:VkImageView can: be used with a sampler that has either of
pname:magFilter or pname:minFilter set to ename:VK_FILTER_LINEAR, pname:magFilter or pname:minFilter set to ename:VK_FILTER_LINEAR,
or pname:mipmapMode set to ename:VK_SAMPLER_MIPMAP_MODE_LINEAR. This bit or pname:mipmapMode set to ename:VK_SAMPLER_MIPMAP_MODE_LINEAR.
must: only be exposed for formats that also support the If ename:VK_FORMAT_FEATURE_BLIT_SRC_BIT is also set, sname:VkImage
ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT. can be used as the pname:srcImage to flink:vkCmdBlitImage
with a pname:filter of ename:VK_FILTER_LINEAR. This bit must: only be
exposed for formats that also support the
ename:VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT or
ename:VK_FORMAT_FEATURE_BLIT_SRC_BIT.
+ +
If the format being queried is a depth/stencil format, this bit only indicates If the format being queried is a depth/stencil format, this bit only indicates
that the depth aspect (not the stencil aspect) supports linear filtering, that the depth aspect (not the stencil aspect) supports linear filtering,

View File

@ -432,7 +432,7 @@ include::../enums/VkCompareOp.txt[]
* ename:VK_COMPARE_OP_ALWAYS: the test always passes. * ename:VK_COMPARE_OP_ALWAYS: the test always passes.
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 slink: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 elink:VkStencilOp, which is defined as: of type elink:VkStencilOp, which is defined as:

View File

@ -326,7 +326,7 @@ include::../enums/VkLogicOp.txt[]
<<< <<<
The logical operations supported by {apiname} are summarized in the The logical operations supported by Vulkan are summarized in the
following table in which following table in which
* latexmath:[$\lnot$] is bitwise invert, * latexmath:[$\lnot$] is bitwise invert,

View File

@ -4,7 +4,7 @@
[[fundamentals]] [[fundamentals]]
= Fundamentals = Fundamentals
This chapter introduces fundamental concepts including the {apiname} This chapter introduces fundamental concepts including the Vulkan
architecture and execution model, API syntax, queues, pipeline architecture and execution model, API syntax, queues, pipeline
configurations, numeric representation, state and state queries, and the configurations, numeric representation, state and state queries, and the
different types of objects and shaders. It provides a framework for different types of objects and shaders. It provides a framework for
@ -55,9 +55,9 @@ external standards such as the Linux Standard Base.
[[fundamentals-execmodel]] [[fundamentals-execmodel]]
== Execution Model == Execution Model
This section outlines the execution model of a {apiname} system. This section outlines the execution model of a Vulkan system.
{apiname} exposes one or more _devices_, Vulkan 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 set of queues supported by a device is asynchronously to one another. The set of queues supported by a device is
partitioned into _families_. Each family supports one or more types of partitioned into _families_. Each family supports one or more types of
@ -94,8 +94,8 @@ an implementation include:
On other architectures, there may: only be a single heap that can: be used On other architectures, there may: only be a single heap that can: be used
for any purpose. for any purpose.
A {apiname} application controls a set of devices through the submission of A Vulkan application controls a set of devices through the submission of
command buffers which have recorded device commands issued via {apiname} command buffers which have recorded device commands issued via Vulkan
library calls. The content of command buffers is specific to the underlying library calls. The content of command buffers is specific to the underlying
hardware and is opaque to the application. Once constructed, a command hardware and is opaque to the application. Once constructed, a command
buffer can: be submitted once or many times to a queue for execution. buffer can: be submitted once or many times to a queue for execution.
@ -115,7 +115,7 @@ the responsibility of the application.
[[fundamentals-queueoperation]] [[fundamentals-queueoperation]]
=== Queue Operation === Queue Operation
{apiname} queues provide an interface to the execution engines of a device. Vulkan queues provide an interface to the execution engines of a device.
Commands are recorded into command buffers ahead of execution time. Commands are recorded into command buffers ahead of execution time.
These command buffers are then submitted to queues for execution. Command These command buffers are then submitted to queues for execution. Command
buffers submitted to a single queue are played back in the order they were buffers submitted to a single queue are played back in the order they were
@ -128,7 +128,7 @@ specified. Therefore, the application must: explicitly synchronize work
between queues when needed. between queues when needed.
In order to control relative order of execution of work both within a queue In order to control relative order of execution of work both within a queue
and across multiple queues, {apiname} provides several synchronization and across multiple queues, Vulkan provides several synchronization
primitives, which include _semaphores_, _events_, _pipeline barriers_, and primitives, which include _semaphores_, _events_, _pipeline barriers_, and
_fences_. These are covered in depth in <<synchronization,Synchronization _fences_. These are covered in depth in <<synchronization,Synchronization
and Cache Control>>. In broad terms, semaphores are used to synchronize work and Cache Control>>. In broad terms, semaphores are used to synchronize work
@ -142,7 +142,7 @@ to synchronize work between the device and the host.
==== ====
Implementations have significant freedom to overlap execution of work Implementations have significant freedom to overlap execution of work
submitted to a queue, and this is common due to deep pipelining and submitted to a queue, and this is common due to deep pipelining and
parallelism in {apiname} devices. parallelism in Vulkan devices.
==== ====
Work is submitted to queues using queue submission commands that typically Work is submitted to queues using queue submission commands that typically
@ -246,8 +246,8 @@ command buffers to execute. This is covered in more detail in
[[fundamentals-objectmodel-overview]] [[fundamentals-objectmodel-overview]]
== Object Model == Object Model
The devices, queues, and other entities in {apiname} are represented by The devices, queues, and other entities in Vulkan are represented by
{apiname} objects. At the API level, all objects are referred to by handles. Vulkan objects. At the API level, all objects are referred to by handles.
There are two classes of handles, dispatchable and non-dispatchable. There are two classes of handles, dispatchable and non-dispatchable.
_Dispatchable_ handle types are a pointer to an opaque type. This pointer _Dispatchable_ handle types are a pointer to an opaque type. This pointer
may: be used by layers as part of intercepting API commands, and thus each may: be used by layers as part of intercepting API commands, and thus each
@ -280,19 +280,19 @@ ftext:vkDestroy* and ftext:vkFree* commands, respectively.
Objects that are allocated (rather than created) take resources from an Objects that are allocated (rather than created) take resources from an
existing pool object or memory heap, and when freed return resources to that existing pool object or memory heap, and when freed return resources to that
pool or heap. While object creation and destruction are generally expected pool or heap. While object creation and destruction are generally expected
to be low-frequency occurences during runtime, allocating and freeing to be low-frequency occurrences during runtime, allocating and freeing
objects can: occur at high frequency. Pool objects help accommodate improved objects can: occur at high frequency. Pool objects help accommodate improved
performance of the allocations and frees. performance of the allocations and frees.
It is an application's responsibility to track the lifetime of {apiname} It is an application's responsibility to track the lifetime of Vulkan
objects, and not to destroy them while they are still in use. objects, and not to destroy them while they are still in use.
Application-owned memory is immediately consumed by any {apiname} command it Application-owned memory is immediately consumed by any Vulkan command it
is passed into. The application can: alter or free this memory as soon as is passed into. The application can: alter or free this memory as soon as
the commands that consume it have returned. 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 Vulkan 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:
@ -306,11 +306,11 @@ 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 Vulkan 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)
have completed. have completed.
The following {apiname} objects can: be destroyed when no command buffers The following Vulkan objects can: be destroyed when no command buffers
using the object are executing: using the object are executing:
* sname:VkEvent * sname:VkEvent
@ -328,7 +328,7 @@ using the object are executing:
* sname:VkDeviceMemory * sname:VkDeviceMemory
* sname:VkDescriptorSet * sname:VkDescriptorSet
The following {apiname} objects can: be destroyed when work on the queue The following Vulkan objects can: be destroyed when work on the queue
that uses the object has been completed: that uses the object has been completed:
* sname:VkFence * sname:VkFence
@ -354,7 +354,7 @@ sname:VkDescriptorPool objects are parents of sname:VkDescriptorSet objects.
sname:VkDevice objects are parents of many object types (all that take a sname:VkDevice objects are parents of many object types (all that take a
sname:VkDevice as a parameter to their creation). sname:VkDevice as a parameter to their creation).
The following {apiname} objects have specific restrictions for when they The following Vulkan objects have specific restrictions for when they
can: be destroyed: can: be destroyed:
* sname:VkQueue objects cannot: be explicitly destroyed. Instead, they are * sname:VkQueue objects cannot: be explicitly destroyed. Instead, they are
@ -399,32 +399,32 @@ can: be destroyed:
[[fundamentals-commandsyntax]] [[fundamentals-commandsyntax]]
== Command Syntax and Duration == Command Syntax and Duration
The Specification describes {apiname} commands as functions or procedures The Specification describes Vulkan commands as functions or procedures
using C99 syntax. Language bindings for other languages such as C++ and using C99 syntax. Language bindings for other languages such as C++ and
Javascript may: allow for stricter parameter passing, or object-oriented Javascript may: allow for stricter parameter passing, or object-oriented
interfaces. interfaces.
With few exceptions, {apiname} uses the standard C types for parameters (int With few exceptions, Vulkan uses the standard C types for parameters (int
types from stdint.h, etc). Exceptions to this are using basetype:VkResult types from stdint.h, etc). Exceptions to this are using basetype:VkResult
for return values, using basetype:VkBool32 for boolean values, for return values, using basetype:VkBool32 for boolean values,
basetype:VkDeviceSize for sizes and offsets pertaining to device address basetype:VkDeviceSize for sizes and offsets pertaining to device address
space, and basetype:VkFlags for passing bits or sets of bits of predefined space, and basetype:VkFlags for passing bits or sets of bits of predefined
values. values.
Commands that create {apiname} objects are of the form ftext:vkCreate* and Commands that create Vulkan objects are of the form ftext:vkCreate* and
take stext:Vk*CreateInfo structures with the parameters needed to create the take stext:Vk*CreateInfo structures with the parameters needed to create the
object. These {apiname} objects are destroyed with commands of the form object. These Vulkan objects are destroyed with commands of the form
ftext:vkDestroy*. ftext:vkDestroy*.
The last in-parameter to each command that creates or destroys a {apiname} The last in-parameter to each command that creates or destroys a Vulkan
object is pname:pAllocator. The pname:pAllocator parameter can: be set to a object is pname:pAllocator. The pname:pAllocator parameter can: be set to a
non-`NULL` value such that allocations for the given object are delegated to non-`NULL` value such that allocations for the given object are delegated to
an application provided callback; refer to the <<memory-allocation,Memory an application provided callback; refer to the <<memory-allocation,Memory
Allocation>> chapter for further details. Allocation>> chapter for further details.
Commands that allocate {apiname} objects owned by pool objects are of the Commands that allocate Vulkan objects owned by pool objects are of the
form ftext:vkAllocate*, and take stext:Vk*AllocateInfo structures. These form ftext:vkAllocate*, and take stext:Vk*AllocateInfo structures. These
{apiname} objects are freed with commands of the form ftext:vkFree*. Vulkan objects are freed with commands of the form ftext:vkFree*.
These objects do not take allocators; if host memory is needed, they will These objects do not take allocators; if host memory is needed, they will
use the allocator that was specified when their parent pool was created. use the allocator that was specified when their parent pool was created.
@ -438,21 +438,21 @@ 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.
The _duration_ of a {apiname} command refers to the interval between calling The _duration_ of a Vulkan command refers to the interval between calling
the command and its return to the caller. the command and its return to the caller.
[[fundamentals-threadingbehavior]] [[fundamentals-threadingbehavior]]
== Threading Behavior == Threading Behavior
{apiname} is intended to provide scalable performance when used on multiple Vulkan is intended to provide scalable performance when used on multiple
host threads. All commands support being called concurrently from multiple host threads. All commands support being called concurrently from multiple
threads, but certain parameters, or components of parameters are defined to threads, but certain parameters, or components of parameters are defined to
be _externally synchronized_. This means that the caller must: guarantee be _externally synchronized_. This means that the caller must: guarantee
that no more than one thread is using such a parameter at a given time. that no more than one thread is using such a parameter at a given time.
More precisely, {apiname} commands use simple stores to update software More precisely, Vulkan commands use simple stores to update software
structures representing {apiname} objects. A parameter declared as structures representing Vulkan objects. A parameter declared as
externally synchronized may: have its software externally synchronized may: have its software
structures updated at any time during the host execution of the command. If structures updated at any time during the host execution of the command. If
two commands operate on the same object and at least one of the commands two commands operate on the same object and at least one of the commands
@ -468,7 +468,7 @@ Memory barriers are particularly relevant on the ARM CPU architecture
which is more weakly ordered than many developers are accustomed to from which is more weakly ordered than many developers are accustomed to from
x86/x64 programming. Fortunately, most higher-level synchronization x86/x64 programming. Fortunately, most higher-level synchronization
primitives (like the pthread library) perform memory barriers as a part of primitives (like the pthread library) perform memory barriers as a part of
mutual exclusion, so mutexing {apiname} objects via these primitives will mutual exclusion, so mutexing Vulkan objects via these primitives will
have the desired effect. have the desired effect.
==== ====
@ -513,11 +513,11 @@ include::../hostsynctable/implicit.txt[]
[[fundamentals-errors]] [[fundamentals-errors]]
== Errors == Errors
{apiname} is a layered API. The lowest layer is the core {apiname} layer, as Vulkan is a layered API. The lowest layer is the core Vulkan layer, as
defined by this Specification. The application can: use additional layers defined by this Specification. The application can: use additional layers
above the core for debugging, validation, and other purposes. above the core for debugging, validation, and other purposes.
One of the core principles of {apiname} is that building and submitting One of the core principles of Vulkan is that building and submitting
command buffers should: be highly efficient. Thus error checking and command buffers should: be highly efficient. Thus error checking and
validation of state in the core layer is minimal, although more rigorous validation of state in the core layer is minimal, although more rigorous
validation can: be enabled through the use of layers. validation can: be enabled through the use of layers.
@ -602,18 +602,21 @@ ename:VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO.
The values ename:VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO and The values ename:VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO and
ename:VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO are reserved for internal ename:VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO are reserved for internal
use by the loader, and don't have corresponding {apiname} structures in this use by the loader, and don't have corresponding Vulkan 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 a member must: have a value of ptext:pNext that is either `NULL`, or points to
valid structure defined by an extension. If that extension is supported by a valid structure defined by an extension, containing ptext:sType and
the implementation, then it must: be enabled. ptext:pNext members as described in the <<extensions-interactions,Extension
Any component of the implementation (the loader, any enabled layers, and Interactions>> section. If that extension is supported by the
drivers) must: ignore extension structures with pname:sType values defined implementation, then it must: be enabled. Any component of the
by extensions not supported by that component. implementation (the loader, any enabled layers, and drivers) must: skip
over, without processing (other than reading the pname:sType and pname:pNext
members) any chained structures with pname:sType values not defined by
extensions supported by that component.
Extension structures are not described in the base {apiname} specification, Extension structures are not described in the base Vulkan specification,
but either in layered specifications incorporating those extensions, but either in layered specifications incorporating those extensions,
or in separate vendor-provided documents. or in separate vendor-provided documents.
@ -628,8 +631,8 @@ sections.
[[fundamentals-returncodes]] [[fundamentals-returncodes]]
=== Return Codes === Return Codes
While the core {apiname} API is not designed to capture incorrect usage, While the core Vulkan API is not designed to capture incorrect usage,
some circumstances still require return codes. Commands in {apiname} return some circumstances still require return codes. Commands in Vulkan return
their status via return codes that are in one of two categories: their status via return codes that are in one of two categories:
* Successful completion codes are returned when a command needs to * Successful completion codes are returned when a command needs to
@ -639,7 +642,7 @@ their status via return codes that are in one of two categories:
failure that could only be detected at run time. All run time error failure that could only be detected at run time. All run time error
codes are negative values. codes are negative values.
All return codes in {apiname} are reported via basetype:VkResult return All return codes in Vulkan are reported via basetype:VkResult return
values. The possible codes are: values. The possible codes are:
include::../enums/VkResult.txt[] include::../enums/VkResult.txt[]
@ -680,7 +683,7 @@ include::../enums/VkResult.txt[]
* ename:VK_ERROR_FEATURE_NOT_PRESENT * ename:VK_ERROR_FEATURE_NOT_PRESENT
A requested feature is not supported. A requested feature is not supported.
* ename:VK_ERROR_INCOMPATIBLE_DRIVER * ename:VK_ERROR_INCOMPATIBLE_DRIVER
The requested version of {apiname} is not supported by the driver or The requested version of Vulkan is not supported by the driver or
is otherwise incompatible for implementation-specific reasons. is otherwise incompatible for implementation-specific reasons.
* ename:VK_ERROR_TOO_MANY_OBJECTS * ename:VK_ERROR_TOO_MANY_OBJECTS
Too many objects of the type have already been created. Too many objects of the type have already been created.
@ -690,7 +693,7 @@ include::../enums/VkResult.txt[]
If a command returns a run time error, it will leave any result pointers If a command returns a run time error, it will leave any result pointers
unmodified. unmodified.
Out of memory errors do not damage any currently existing {apiname} objects. Out of memory errors do not damage any currently existing Vulkan objects.
Objects that have already been successfully created can: still be used by Objects that have already been successfully created can: still be used by
the application. the application.
@ -707,7 +710,7 @@ Implementations normally perform computations in floating-point, and must:
meet the range and precision requirements defined under meet the range and precision requirements defined under
``Floating-Point Computation'' below. ``Floating-Point Computation'' below.
These requirements only apply to computations performed in {apiname} These requirements only apply to computations performed in Vulkan
operations outside of shader execution, such as texture image operations outside of shader execution, such as texture image
specification and sampling, and per-fragment operations. Range and specification and sampling, and per-fragment operations. Range and
precision requirements during shader execution differ and are specified precision requirements during shader execution differ and are specified
@ -716,7 +719,7 @@ Instructions>> section.
In some cases, the representation and/or precision of operations is In some cases, the representation and/or precision of operations is
implicitly limited by the specified format of vertex or texel implicitly limited by the specified format of vertex or texel
data consumed by {apiname}. Specific floating-point formats are data consumed by Vulkan. Specific floating-point formats are
described later in this section. described later in this section.
@ -765,12 +768,12 @@ arithmetic operations such as latexmath:[$0 / 0$]. Implementations may:
support latexmath:[$Inf$]s and latexmath:[$NaN$]s in their floating-point support latexmath:[$Inf$]s and latexmath:[$NaN$]s in their floating-point
computations. computations.
Any representable floating-point value is legal as input to a {apiname} Any representable floating-point value is legal as input to a Vulkan
command that requires floating-point data. The result of providing a value command that requires floating-point data. The result of providing a value
that is not a floating-point number to such a command is unspecified, but that is not a floating-point number to such a command is unspecified, but
mustnot: lead to {apiname} interruption or termination. In <<IEEE 754>> mustnot: lead to Vulkan interruption or termination. In <<IEEE 754>>
arithmetic, for example, providing a negative zero or a denormalized number arithmetic, for example, providing a negative zero or a denormalized number
to an {apiname} command must: yield deterministic results, while providing a to an Vulkan command must: yield deterministic results, while providing a
latexmath:[$NaN$] or latexmath:[$Inf$] yields unspecified results. latexmath:[$NaN$] or latexmath:[$Inf$] yields unspecified results.
@ -782,11 +785,11 @@ latexmath:[$NaN$] or latexmath:[$Inf$] yields unspecified results.
section of the Khronos Data Format Specification. section of the Khronos Data Format Specification.
Any representable 16-bit floating-point value is legal as input to a Any representable 16-bit floating-point value is legal as input to a
{apiname} command that accepts 16-bit floating-point data. The result of Vulkan command that accepts 16-bit floating-point data. The result of
providing a value that is not a floating-point number (such as providing a value that is not a floating-point number (such as
latexmath:[$Inf$] or latexmath:[$NaN$]) to such a command is latexmath:[$Inf$] or latexmath:[$NaN$]) to such a command is
unspecified, but mustnot: lead to {apiname} interruption or termination. unspecified, but mustnot: lead to Vulkan interruption or termination.
Providing a denormalized number or negative zero to {apiname} must: yield Providing a denormalized number or negative zero to Vulkan must: yield
deterministic results. deterministic results.
@ -810,11 +813,11 @@ converted to positive infinity; and both positive and negative
latexmath:[$NaN$] are converted to positive latexmath:[$NaN$]. latexmath:[$NaN$] are converted to positive latexmath:[$NaN$].
Any representable unsigned 11-bit floating-point value is legal as input Any representable unsigned 11-bit floating-point value is legal as input
to a {apiname} command that accepts 11-bit floating-point data. The to a Vulkan command that accepts 11-bit floating-point data. The
result of providing a value that is not a floating-point number (such as result of providing a value that is not a floating-point number (such as
latexmath:[$Inf$] or latexmath:[$NaN$]) to such a command is latexmath:[$Inf$] or latexmath:[$NaN$]) to such a command is
unspecified, but mustnot: lead to {apiname} interruption or termination. unspecified, but mustnot: lead to Vulkan interruption or termination.
Providing a denormalized number to {apiname} must: yield deterministic Providing a denormalized number to Vulkan must: yield deterministic
results. results.
@ -838,11 +841,11 @@ converted to positive infinity; and both positive and negative
latexmath:[$NaN$] are converted to positive latexmath:[$NaN$]. latexmath:[$NaN$] are converted to positive latexmath:[$NaN$].
Any representable unsigned 10-bit floating-point value is legal as input to Any representable unsigned 10-bit floating-point value is legal as input to
a {apiname} command that accepts 10-bit floating-point data. The result of a Vulkan command that accepts 10-bit floating-point data. The result of
providing a value that is not a floating-point number (such as providing a value that is not a floating-point number (such as
latexmath:[$Inf$] or latexmath:[$NaN$]) to such a command is unspecified, latexmath:[$Inf$] or latexmath:[$NaN$]) to such a command is unspecified,
but mustnot: lead to {apiname} interruption or termination. Providing a but mustnot: lead to Vulkan interruption or termination. Providing a
denormalized number to {apiname} must: yield deterministic results. denormalized number to Vulkan must: yield deterministic results.
[[fundamentals-general]] [[fundamentals-general]]
@ -850,7 +853,7 @@ denormalized number to {apiname} must: yield deterministic results.
Some calculations require division. In such cases (including implied Some calculations require division. In such cases (including implied
divisions performed by vector normalization), division by zero produces an divisions performed by vector normalization), division by zero produces an
unspecified result but mustnot: lead to {apiname} interruption or unspecified result but mustnot: lead to Vulkan interruption or
termination. termination.
@ -907,7 +910,7 @@ representation, one value (latexmath:[$-128$] in the example) is outside the
representable range, and must: be clamped before use. This equation is used representable range, and must: be clamped before use. This equation is used
everywhere that signed normalized fixed-point values are converted to everywhere that signed normalized fixed-point values are converted to
floating-point, including for all signed normalized fixed-point parameters floating-point, including for all signed normalized fixed-point parameters
in {apiname} commands, such as vertex attribute values, as well as for in Vulkan commands, such as vertex attribute values, as well as for
specifying texture or framebuffer values using signed normalized specifying texture or framebuffer values using signed normalized
fixed-point. fixed-point.
@ -963,7 +966,7 @@ or framebuffer values using floating-point.
[[fundamentals-versionnum]] [[fundamentals-versionnum]]
== API Version Numbers and Semantics == API Version Numbers and Semantics
The {apiname} version number is used in several places in the API. In each The Vulkan version number is used in several places in the API. In each
such use, the API _major version number_, _minor version number_, and _patch such use, the API _major version number_, _minor version number_, and _patch
version number_ are packed into a 32-bit integer as follows: version number_ are packed into a 32-bit integer as follows:
@ -971,7 +974,7 @@ version number_ are packed into a 32-bit integer as follows:
* The minor version number is a 10-bit integer packed into bits 21-12. * The minor version number is a 10-bit integer packed into bits 21-12.
* The patch version number is a 12-bit integer packed into bits 11-0. * The patch version number is a 12-bit integer packed into bits 11-0.
Differences in any of the {apiname} version numbers indicates a change to Differences in any of the Vulkan version numbers indicates a change to
the API in some way, with each part of the version number indicating a the API in some way, with each part of the version number indicating a
different scope of changes. different scope of changes.
@ -1001,7 +1004,7 @@ significant modification to an application in order for it to function.
[[fundamentals-common-objects]] [[fundamentals-common-objects]]
== Common Object Types == Common Object Types
Some types of {apiname} objects are used in many different structures and Some types of Vulkan objects are used in many different structures and
command parameters, and are described here. These types include _offsets_, command parameters, and are described here. These types include _offsets_,
_extents_, and _rectangles_. _extents_, and _rectangles_.

View File

@ -6,7 +6,7 @@
Some implementations have specialized fixed-function hardware for fetching Some implementations have specialized fixed-function hardware for fetching
and format-converting vertex input data from buffers, rather than performing and format-converting vertex input data from buffers, rather than performing
the fetch as part of the vertex shader. {apiname} includes a vertex the fetch as part of the vertex shader. Vulkan includes a vertex
attribute fetch stage in the graphics pipeline in order to take advantage of attribute fetch stage in the graphics pipeline in order to take advantage of
this. this.

View File

@ -4,14 +4,14 @@
[[initialization]] [[initialization]]
= Initialization = Initialization
Before using {apiname}, an application must: initialize it by loading the Before using Vulkan, an application must: initialize it by loading the
{apiname} commands, and creating a sname:VkInstance object. Vulkan commands, and creating a sname:VkInstance object.
[[initialization-functionpointers]] [[initialization-functionpointers]]
== Command Function Pointers == Command Function Pointers
{apiname} commands are not necessarily exposed statically on a platform. Vulkan commands are not necessarily exposed statically on a platform.
Function pointers for all {apiname} commands can: be obtained with the Function pointers for all Vulkan commands can: be obtained with the
command: command:
include::../protos/vkGetInstanceProcAddr.txt[] include::../protos/vkGetInstanceProcAddr.txt[]
@ -27,8 +27,8 @@ specific manner. Typically, the loader library will export this command as a
function symbol, so applications can: link against the loader library, or function symbol, so applications can: link against the loader library, or
load it dynamically and look up the symbol using platform-specific APIs. load it dynamically and look up the symbol using platform-specific APIs.
Loaders are encouraged to export function symbols for all other core Loaders are encouraged to export function symbols for all other core
{apiname} commands as well; if this is done, then applications that use only Vulkan commands as well; if this is done, then applications that use only
the core {apiname} commands have no need to use fname:vkGetInstanceProcAddr. the core Vulkan commands have no need to use fname:vkGetInstanceProcAddr.
Function pointers to commands that don't operate on a specific instance can: 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
@ -43,7 +43,7 @@ commands that operate on pname:instance or a child of pname:instance can: be
obtained. The returned function pointer must: only be called with a obtained. The returned function pointer must: only be called with a
dispatchable object (the first parameter) that is a child of pname:instance. dispatchable object (the first parameter) that is a child of pname:instance.
If pname:pName is not the name of a core {apiname} command, or is an If pname:pName is not the name of a core Vulkan command, or is an
extension command for any extension not supported by any available layer or extension command for any extension not supported by any available layer or
implementation, then fname:vkGetInstanceProcAddr will return `NULL`. implementation, then fname:vkGetInstanceProcAddr will return `NULL`.
@ -66,7 +66,7 @@ it.
==== ====
endif::editing-notes[] endif::editing-notes[]
In order to support systems with multiple {apiname} implementations In order to support systems with multiple Vulkan implementations
comprising heterogeneous collections of hardware and software, the function comprising heterogeneous collections of hardware and software, the function
pointers returned by fname:vkGetInstanceProcAddr may: point to dispatch pointers returned by fname:vkGetInstanceProcAddr may: point to dispatch
code, which calls a different real implementation for different code, which calls a different real implementation for different
@ -79,13 +79,13 @@ command:
include::../protos/vkGetDeviceProcAddr.txt[] include::../protos/vkGetDeviceProcAddr.txt[]
* pname:device is the logical device that provides the function pointer. * pname:device is the logical device that provides the function pointer.
* pname:pName is the name of any {apiname} command whose first parameter * pname:pName is the name of any Vulkan command whose first parameter
is one of is one of
** sname:VkDevice ** sname:VkDevice
** sname:VkQueue ** sname:VkQueue
** sname:VkCommandBuffer ** sname:VkCommandBuffer
If pname:pName is not the name of one of these {apiname} commands, and is If pname:pName is not the name of one of these Vulkan commands, and is
not the name of an extension command belonging to an extension enabled for not the name of an extension command belonging to an extension enabled for
pname:device, then fname:vkGetDeviceProcAddr will return `NULL`. pname:device, then fname:vkGetDeviceProcAddr will return `NULL`.
@ -94,9 +94,9 @@ include::../validity/protos/vkGetDeviceProcAddr.txt[]
[[initialization-instances]] [[initialization-instances]]
== Instances == Instances
There is no global state in {apiname} and all per-application state is There is no global state in Vulkan and all per-application state is
stored in a sname:VkInstance object. Creating a sname:VkInstance object stored in a sname:VkInstance object. Creating a sname:VkInstance object
initializes the {apiname} library and allows the application to pass initializes the Vulkan library and allows the application to pass
information about itself to the implementation. information about itself to the implementation.
To create an instance object, call: To create an instance object, call:
@ -160,7 +160,7 @@ include::../structs/VkApplicationInfo.txt[]
* pname:engineVersion is an unsigned integer variable containing the * pname:engineVersion is an unsigned integer variable containing the
developer-supplied version number of the engine used to create the developer-supplied version number of the engine used to create the
application. application.
* pname:apiVersion is the version of the {apiname} API against which the * pname:apiVersion is the version of the Vulkan API against which the
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

View File

@ -889,9 +889,9 @@ within the local workgroup. The range of possible values for each component
of LocalInvocationID range from zero through the size of the workgroup in that of LocalInvocationID range from zero through the size of the workgroup in that
dimension minus one. If the size of the workgroup in a particular dimension is dimension minus one. If the size of the workgroup in a particular dimension is
one, then LocalInvocationID in that dimension will be zero. That is, if the one, then LocalInvocationID in that dimension will be zero. That is, if the
workgroup is effectively two-dimensional, then pname:LocalInvocationID.z will workgroup is effectively two-dimensional, then code:LocalInvocationID.z will
be zero, and if the workgroup is one-dimensional, then both be zero, and if the workgroup is one-dimensional, then both
pname:LocalInvocationID.y and pname:LocalInvocationID.z will be zero. code:LocalInvocationID.y and code:LocalInvocationID.z will be zero.
+ +
The code:LocalInvocationID decoration is only supported in compute shaders. The code:LocalInvocationID decoration is only supported in compute shaders.
+ +

View File

@ -7,23 +7,23 @@
This chapter is Informative except for the sections on Terminology and This chapter is Informative except for the sections on Terminology and
Normative References. Normative References.
This document, referred to as the ``{apiname} Specification'' or just the This document, referred to as the ``Vulkan Specification'' or just the
``Specification'' hereafter, describes the {apiname} graphics system: what ``Specification'' hereafter, describes the Vulkan graphics system: what
it is, how it acts, and what is required to implement it. We assume that the it is, how it acts, and what is required to implement it. We assume that the
reader has at least a rudimentary understanding of computer graphics. This reader has at least a rudimentary understanding of computer graphics. This
means familiarity with the essentials of computer graphics algorithms and means familiarity with the essentials of computer graphics algorithms and
terminology as well as with modern GPUs (Graphic Processing Units). terminology as well as with modern GPUs (Graphic Processing Units).
The canonical version of the Specification is available in the official The canonical version of the Specification is available in the official
{apiname} Registry, located at URL Vulkan Registry, located at URL
http://www.khronos.org/registry/vulkan/ http://www.khronos.org/registry/vulkan/
[[introduction-whatis]] [[introduction-whatis]]
== What is the {apiname} Graphics System? == What is the Vulkan Graphics System?
{apiname} is an API (Application Programming Interface) for graphics and Vulkan is an API (Application Programming Interface) for graphics and
compute hardware. The API consists of many commands that compute hardware. The API consists of many commands that
allow a programmer to specify shader programs, compute kernels, objects, and allow a programmer to specify shader programs, compute kernels, objects, and
operations involved in producing high-quality graphical images, specifically operations involved in producing high-quality graphical images, specifically
@ -31,18 +31,18 @@ color images of three-dimensional objects.
[[introduction-programmer]] [[introduction-programmer]]
=== The Programmer's View of {apiname} === The Programmer's View of Vulkan
To the programmer, {apiname} is a set of commands that allow the To the programmer, Vulkan is a set of commands that allow the
specification of _shader programs_ or _shaders_, _kernels_, data used by specification of _shader programs_ or _shaders_, _kernels_, data used by
kernels or shaders, and state controlling aspects of {apiname} outside the kernels or shaders, and state controlling aspects of Vulkan outside the
scope of shaders. Typically, the data represents geometry in two or three scope of shaders. Typically, the data represents geometry in two or three
dimensions and texture images, while the shaders and kernels control the dimensions and texture images, while the shaders and kernels control the
processing of the data, rasterization of the geometry, and the lighting and processing of the data, rasterization of the geometry, and the lighting and
shading of _fragments_ generated by rasterization, resulting in the shading of _fragments_ generated by rasterization, resulting in the
rendering of geometry into the framebuffer. rendering of geometry into the framebuffer.
A typical {apiname} program begins with platform-specific calls to open a A typical Vulkan program begins with platform-specific calls to open a
window or otherwise prepare a display device onto which the program will window or otherwise prepare a display device onto which the program will
draw. Then, calls are made to open _queues_ to which _command buffers_ are draw. Then, calls are made to open _queues_ to which _command buffers_ are
submitted. The command buffers contain lists of commands which will be submitted. The command buffers contain lists of commands which will be
@ -56,24 +56,24 @@ transfer the resulting image to a display device or window.
[[introduction-implementor]] [[introduction-implementor]]
=== The Implementor's View of {apiname} === The Implementor's View of Vulkan
To the implementor, {apiname} is a set of commands that allow the To the implementor, Vulkan is a set of commands that allow the
construction and submission of command buffers to a device. Modern devices construction and submission of command buffers to a device. Modern devices
accelerate virtually all {apiname} operations, storing data and framebuffer accelerate virtually all Vulkan operations, storing data and framebuffer
images in high-speed memory and executing shaders in dedicated GPU images in high-speed memory and executing shaders in dedicated GPU
processing resources. processing resources.
The implementor's task is to provide a software library on the host which The implementor's task is to provide a software library on the host which
implements the {apiname} API, while mapping the work for each {apiname} implements the Vulkan API, while mapping the work for each Vulkan
command to the graphics hardware as appropriate for the capabilities of the command to the graphics hardware as appropriate for the capabilities of the
device. device.
[[introduction-ourview]] [[introduction-ourview]]
=== Our View of {apiname} === Our View of Vulkan
We view {apiname} as a pipeline having some programmable stages and some We view Vulkan as a pipeline having some programmable stages and some
state-driven fixed-function stages that are invoked by a set of specific state-driven fixed-function stages that are invoked by a set of specific
drawing operations. We expect this model to result in a specification that drawing operations. We expect this model to result in a specification that
satisfies the needs of both programmers and implementors. It does not, satisfies the needs of both programmers and implementors. It does not,
@ -86,7 +86,7 @@ efficient than the one specified.
[[introduction-bugs]] [[introduction-bugs]]
== Filing Bug Reports == Filing Bug Reports
Issues with and bug reports on the {apiname} Specification and the API Issues with and bug reports on the Vulkan Specification and the API
Registry can: be filed in the Khronos Vulkan Github repository, located at Registry can: be filed in the Khronos Vulkan Github repository, located at
URL URL
@ -173,7 +173,7 @@ endif::editing-notes[]
== Normative References == Normative References
Normative references are references to external documents or resources to Normative references are references to external documents or resources to
which implementers of {apiname} must: comply. which implementers of Vulkan must: comply.
[[IEEE 754]]:: _IEEE Standard for Floating-Point Arithmetic_, [[IEEE 754]]:: _IEEE Standard for Floating-Point Arithmetic_,
IEEE Std 754-2008, IEEE Std 754-2008,

View File

@ -4,20 +4,20 @@
[[memory]] [[memory]]
= Memory Allocation = Memory Allocation
{apiname} memory is broken up into two categories, _host memory_ and Vulkan memory is broken up into two categories, _host memory_ and
_device memory_. _device memory_.
[[memory-host]] [[memory-host]]
== Host Memory == Host Memory
Host memory is memory needed by the {apiname} implementation for Host memory is memory needed by the Vulkan implementation for
non-device-visible storage. This storage may: be used for e.g. internal non-device-visible storage. This storage may: be used for e.g. internal
software structures. software structures.
[[memory-allocation]] [[memory-allocation]]
{apiname} provides applications the opportunity to perform host memory Vulkan provides applications the opportunity to perform host memory
allocations on behalf of the {apiname} implementation. If this feature is allocations on behalf of the Vulkan implementation. If this feature is
not used, the implementation will perform its own memory allocations. Since not used, the implementation will perform its own memory allocations. Since
most memory allocations are off the critical path, this is not meant as a most memory allocations are off the critical path, this is not meant as a
performance feature. Rather, this can: be useful for certain embedded performance feature. Rather, this can: be useful for certain embedded
@ -31,7 +31,7 @@ include::../structs/VkAllocationCallbacks.txt[]
* pname:pUserData is a value to be interpreted by the implementation of * pname:pUserData is a value to be interpreted by the implementation of
the callbacks. When any of the callbacks in sname:VkAllocationCallbacks the callbacks. When any of the callbacks in sname:VkAllocationCallbacks
are called, the {apiname} implementation will pass this value as the are called, the Vulkan implementation will pass this value as the
first parameter to the callback. This value can: vary each time an first parameter to the callback. This value can: vary each time an
allocator is passed into a command, even when the same object takes an allocator is passed into a command, even when the same object takes an
allocator in multiple commands. allocator in multiple commands.
@ -190,17 +190,17 @@ parameter and takes a value of type elink:VkSystemAllocationScope:
include::../enums/VkSystemAllocationScope.txt[] include::../enums/VkSystemAllocationScope.txt[]
* ename:VK_SYSTEM_ALLOCATION_SCOPE_COMMAND - The allocation is scoped to * ename:VK_SYSTEM_ALLOCATION_SCOPE_COMMAND - The allocation is scoped to
the duration of the {apiname} command. the duration of the Vulkan command.
* ename:VK_SYSTEM_ALLOCATION_SCOPE_OBJECT - The allocation is scoped to * ename:VK_SYSTEM_ALLOCATION_SCOPE_OBJECT - The allocation is scoped to
the lifetime of the {apiname} object that is being created or used. the lifetime of the Vulkan object that is being created or used.
* ename:VK_SYSTEM_ALLOCATION_SCOPE_CACHE - The allocation is scoped to the * ename:VK_SYSTEM_ALLOCATION_SCOPE_CACHE - The allocation is scoped to the
lifetime of a sname:VkPipelineCache object. lifetime of a sname:VkPipelineCache object.
* ename:VK_SYSTEM_ALLOCATION_SCOPE_DEVICE - The allocation is scoped to * ename:VK_SYSTEM_ALLOCATION_SCOPE_DEVICE - The allocation is scoped to
the lifetime of the {apiname} device. the lifetime of the Vulkan device.
* ename:VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE - The allocation is scoped to * ename:VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE - The allocation is scoped to
the lifetime of the {apiname} instance. the lifetime of the Vulkan instance.
Most {apiname} commands operate on a single object, or there is a sole Most Vulkan commands operate on a single object, or there is a sole
object that is being created or manipulated. When an allocation uses a scope object that is being created or manipulated. When an allocation uses a scope
of ename:VK_SYSTEM_ALLOCATION_SCOPE_OBJECT or of ename:VK_SYSTEM_ALLOCATION_SCOPE_OBJECT or
ename:VK_SYSTEM_ALLOCATION_SCOPE_CACHE, the allocation is scoped to the ename:VK_SYSTEM_ALLOCATION_SCOPE_CACHE, the allocation is scoped to the
@ -292,7 +292,7 @@ If pname:pfnAllocation or pname:pfnReallocation fail, the implementation
may: fail object creation and/or generate an may: fail object creation and/or generate an
ename:VK_ERROR_OUT_OF_HOST_MEMORY error, as appropriate. ename:VK_ERROR_OUT_OF_HOST_MEMORY error, as appropriate.
Allocation callbacks must: not call any {apiname} commands. Allocation callbacks must: not call any Vulkan commands.
The following sets of rules define when an implementation is permitted to The following sets of rules define when an implementation is permitted to
call the allocator callbacks. call the allocator callbacks.
@ -493,8 +493,8 @@ The memory types are sorted according to a preorder which serves to aid
in easily selecting an appropriate memory type. Given two memory types X and in easily selecting an appropriate memory type. Given two memory types X and
Y, the preorder defines latexmath:[$X \leq Y$] if: Y, the preorder defines latexmath:[$X \leq Y$] if:
* the memory property bits set for X are a subset of the memory property * the memory property bits set for X are a strict subset of the memory
bits set for Y. Or, property bits set for Y. Or,
* the memory property bits set for X are the same as the memory property * the memory property bits set for X are the same as the memory property
bits set for Y, and X uses a memory heap with greater or equal bits set for Y, and X uses a memory heap with greater or equal
performance (as determined in an implementation-specific manner). performance (as determined in an implementation-specific manner).
@ -539,7 +539,7 @@ accesses, as appropriate for the intended usage, and if such a memory type is
not present can: fallback to searching for a less optimal but guaranteed set of not present can: fallback to searching for a less optimal but guaranteed set of
properties such as "0" or "host-visible and coherent". properties such as "0" or "host-visible and coherent".
A {apiname} device operates on data in device memory via memory objects that A Vulkan device operates on data in device memory via memory objects that
are represented in the API by a sname:VkDeviceMemory handle. Memory objects are represented in the API by a sname:VkDeviceMemory handle. Memory objects
are allocated by calling fname:vkAllocateMemory: are allocated by calling fname:vkAllocateMemory:
@ -657,16 +657,6 @@ include::../validity/protos/vkMapMemory.txt[]
It is an application error to call fname:vkMapMemory on a memory object that It is an application error to call fname:vkMapMemory on a memory object that
is already mapped. is already mapped.
ifdef::editing-notes[]
[NOTE]
.editing-note
====
TODO (Tobias) - There's a circular section reference in this next section.
The information is all covered by both places, but it seems a bit weird to
have them reference each other. Not sure how to resolve it.
====
endif::editing-notes[]
[[memory-device-hostaccess-hazards]] [[memory-device-hostaccess-hazards]]
fname:vkMapMemory does not check whether the device memory is currently in fname:vkMapMemory does not check whether the device memory is currently in
use before returning the host-accessible pointer. The application use before returning the host-accessible pointer. The application
@ -696,35 +686,11 @@ familiar with all of the mechanisms described in the chapter on
to maintaining memory access ordering. to maintaining memory access ordering.
==== ====
Host-visible memory types that advertise the Two commands are provided to enable applications to work with
ename:VK_MEMORY_PROPERTY_HOST_COHERENT_BIT property still require non-coherent memory allocations: fname:vkFlushMappedMemoryRanges and
<<synchronization-pipeline-barriers,memory barriers>> between host and fname:vkInvalidateMappedMemoryRanges.
device in order to be coherent, but do not require additional cache
management operations (fname:vkFlushMappedMemoryRanges or
fname:vkInvalidateMappedMemoryRanges) to achieve coherency. For host writes
to be seen by subsequent command buffer operations, a pipeline barrier from
a source of ename:VK_ACCESS_HOST_WRITE_BIT and
ename:VK_PIPELINE_STAGE_HOST_BIT to a destination of the relevant device
pipeline stages and access types must: be performed. Note that such a
barrier is performed
<<synchronization-implicit-ordering-hostwrites,implicitly>> upon each
command buffer submission, so an explicit barrier is only rarely needed
(e.g. if a command buffer waits upon an event signaled by the host, where
the host wrote some data after submission). For device writes to be seen by
subsequent host reads, a pipeline barrier is required: to
<<synchronization-fences-devicewrites,make the writes visible>>.
In order to enable applications to work with non-coherent memory To flush ranges of non-coherent memory from the host caches, call:
allocations, two entry points are provided. To flush host write caches, an
application must: use fname:vkFlushMappedMemoryRanges, while
fname:vkInvalidateMappedMemoryRanges allows invalidating host input caches
so that device writes become visible to the host.
fname:vkFlushMappedMemoryRanges must: be called after the host writes to
non-coherent memory have completed and before command buffers that will read
or write any of those memory locations are submitted to a queue. Similarly,
fname:vkInvalidateMappedMemoryRanges must: be called after command buffers
that execute and flush (via memory barriers) the device writes have
completed, and before the host will read or write any of those locations.
include::../protos/vkFlushMappedMemoryRanges.txt[] include::../protos/vkFlushMappedMemoryRanges.txt[]
@ -736,6 +702,13 @@ include::../protos/vkFlushMappedMemoryRanges.txt[]
include::../validity/protos/vkFlushMappedMemoryRanges.txt[] include::../validity/protos/vkFlushMappedMemoryRanges.txt[]
fname:vkFlushMappedMemoryRanges must: be used to guarantee that host writes to
non-coherent memory are visible to the device. It must: be called after the host
writes to non-coherent memory have completed and before command buffers that will
read or write any of those memory locations are submitted to a queue.
To invalidate ranges of non-coherent memory from the host caches, call:
include::../protos/vkInvalidateMappedMemoryRanges.txt[] include::../protos/vkInvalidateMappedMemoryRanges.txt[]
* pname:device is the logical device that owns the memory ranges. * pname:device is the logical device that owns the memory ranges.
@ -770,8 +743,42 @@ fname:vkFlushMappedMemoryRanges and fname:vkInvalidateMappedMemoryRanges are
unnecessary and may: have performance cost. unnecessary and may: have performance cost.
==== ====
fname:vkInvalidateMappedMemoryRanges must: be used to guarantee that device writes to
non-coherent memory are visible to the host. It must: be called after command buffers
that execute and flush (via memory barriers) the device writes have completed, and
before the host will read or write any of those locations. If a range of non-coherent
memory is written by the host and then invalidated without first being flushed, its
contents are undefined.
ifdef::editing-notes[]
[NOTE]
.editing-note
====
TODO (Tobias) - There's a circular section reference between this next section
and the <<synchronization-fences-devicewrites,synchronization section>>. The
information is all covered by both places, but it seems a bit weird to have them
reference each other. Not sure how to resolve it.
====
endif::editing-notes[]
Host-visible memory types that advertise the
ename:VK_MEMORY_PROPERTY_HOST_COHERENT_BIT property still require
<<synchronization-pipeline-barriers,memory barriers>> between host and device
in order to be coherent, but do not require additional cache management
operations to achieve coherency. For host writes to
be seen by subsequent command buffer operations, a pipeline barrier from
a source of ename:VK_ACCESS_HOST_WRITE_BIT and ename:VK_PIPELINE_STAGE_HOST_BIT
to a destination of the relevant device pipeline stages and access types must:
be performed. Note that such a barrier is performed
<<synchronization-implicit-ordering-hostwrites,implicitly>> upon each
command buffer submission, so an explicit barrier is only rarely needed
(e.g. if a command buffer waits upon an event signaled by the host, where
the host wrote some data after submission). For device writes to be seen by
subsequent host reads, a pipeline barrier is required: to
<<synchronization-fences-devicewrites,make the writes visible>>.
Once host access to a memory object is no longer needed by the application, Once host access to a memory object is no longer needed by the application,
it can: be unmapped by calling : it can: be unmapped by calling:
include::../protos/vkUnmapMemory.txt[] include::../protos/vkUnmapMemory.txt[]

View File

@ -5,7 +5,7 @@
= Pipelines = Pipelines
The following <<pipelines-block-diagram,figure>> shows a block diagram of The following <<pipelines-block-diagram,figure>> shows a block diagram of
the {apiname} pipelines. Some {apiname} commands specify geometric objects the Vulkan pipelines. Some Vulkan commands specify geometric objects
to be drawn or computational work to be performed, while others specify to be drawn or computational work to be performed, while others specify
state controlling how objects are handled by the various pipeline stages, or state controlling how objects are handled by the various pipeline stages, or
control data transfer between memory organized as images and buffers. control data transfer between memory organized as images and buffers.
@ -46,8 +46,8 @@ The <<pipelines-compute,compute pipeline>> is a separate pipeline from the
graphics pipeline, which operates on one-, two-, or three-dimensional graphics pipeline, which operates on one-, two-, or three-dimensional
workgroups which can: read from and write to buffer and image memory. workgroups which can: read from and write to buffer and image memory.
This ordering is meant only as a tool for describing {apiname}, not as a This ordering is meant only as a tool for describing Vulkan, not as a
strict rule of how {apiname} is implemented, and we present it only as a strict rule of how Vulkan is implemented, and we present it only as a
means to organize the various operations of the pipelines. means to organize the various operations of the pipelines.
[[pipelines-block-diagram]] [[pipelines-block-diagram]]
@ -98,7 +98,7 @@ include::../protos/vkCreateComputePipelines.txt[]
<<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.
* pname:createInfoCount is the length of the pname:pCreateInfos and * pname:createInfoCount is the length of the pname:pCreateInfos and
pname:Pipelines arrays. pname:pPipelines arrays.
* pname:pCreateInfos is an array of sname:VkComputePipelineCreateInfo * pname:pCreateInfos is an array of sname:VkComputePipelineCreateInfo
structures. structures.
* pname:pAllocator controls host memory allocation as described in the * pname:pAllocator controls host memory allocation as described in the
@ -183,7 +183,7 @@ include::../protos/vkCreateGraphicsPipelines.txt[]
<<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.
* pname:createInfoCount is the length of the pname:pCreateInfos and * pname:createInfoCount is the length of the pname:pCreateInfos and
pname:Pipelines arrays. pname:pPipelines arrays.
* pname:pCreateInfos is an array of sname:VkGraphicsPipelineCreateInfo * pname:pCreateInfos is an array of sname:VkGraphicsPipelineCreateInfo
structures. structures.
* pname:pAllocator controls host memory allocation as described in the * pname:pAllocator controls host memory allocation as described in the

View File

@ -122,7 +122,7 @@ stage in the pipeline before rasterization.
[[primsrast-multisampling]] [[primsrast-multisampling]]
== Multisampling == Multisampling
Multisampling is a mechanism to antialias all {apiname} primitives: points, Multisampling is a mechanism to antialias all Vulkan primitives: points,
lines, and polygons. The technique is to sample all primitives multiple lines, and polygons. The technique is to sample all primitives multiple
times at each pixel. Each sample in each framebuffer attachment has storage times at each pixel. Each sample in each framebuffer attachment has storage
for a color, depth, and/or stencil value, such that per-fragment operations for a color, depth, and/or stencil value, such that per-fragment operations
@ -131,7 +131,7 @@ _resolved_ to a single color (see <<copies-resolve,Resolving Multisample
Images>> and the <<renderpass,Render Pass>> chapter for more details on how Images>> and the <<renderpass,Render Pass>> chapter for more details on how
to resolve multisample images to non-multisample images). to resolve multisample images to non-multisample images).
{apiname} defines rasterization rules for single-sample modes in a way that Vulkan defines rasterization rules for single-sample modes in a way that
is equivalent to a multisample mode with a single sample in the center of is equivalent to a multisample mode with a single sample in the center of
each pixel. each pixel.

View File

@ -5,7 +5,7 @@
= Queries = Queries
_Queries_ provide a mechanism to return information about the processing of _Queries_ provide a mechanism to return information about the processing of
a sequence of {apiname} commands. Query operations are asynchronous, and as a sequence of Vulkan commands. Query operations are asynchronous, and as
such, their results are not returned immediately. Instead, their results, such, their results are not returned immediately. Instead, their results,
and their availability status, are stored in a <<queries-pools, Query and their availability status, are stored in a <<queries-pools, Query
Pool>>. The state of these queries can: be read back on the host, or copied Pool>>. The state of these queries can: be read back on the host, or copied
@ -246,7 +246,7 @@ These bits have the following meanings:
* ename:VK_QUERY_RESULT_64_BIT indicates the results will be written as an * ename:VK_QUERY_RESULT_64_BIT indicates the results will be written as an
array of 64-bit unsigned integer values. If this bit is not set, the array of 64-bit unsigned integer values. If this bit is not set, the
results will be written as an array of 32-bit unsigned integer values. results will be written as an array of 32-bit unsigned integer values.
* ename:VK_QUERY_RESULT_WAIT_BIT indicates that {apiname} will wait for * ename:VK_QUERY_RESULT_WAIT_BIT indicates that Vulkan will wait for
each query's status to become available before retrieving its results. each query's status to become available before retrieving its results.
* ename:VK_QUERY_RESULT_WITH_AVAILABILITY_BIT indicates that the * ename:VK_QUERY_RESULT_WITH_AVAILABILITY_BIT indicates that the
availability status accompanies the results. availability status accompanies the results.
@ -263,7 +263,7 @@ If ename:VK_QUERY_RESULT_64_BIT is not set and the result overflows a
ename:VK_QUERY_RESULT_64_BIT is set and the result overflows a 64-bit ename:VK_QUERY_RESULT_64_BIT is set and the result overflows a 64-bit
value, the value may: either wrap or saturate. value, the value may: either wrap or saturate.
If ename:VK_QUERY_RESULT_WAIT_BIT is set, {apiname} will wait for each If ename:VK_QUERY_RESULT_WAIT_BIT is set, Vulkan will wait for each
query to be in the available state before retrieving the numerical query to be in the available state before retrieving the numerical
results for that query. In this case, fname:vkGetQueryPoolResults is results for that query. In this case, fname:vkGetQueryPoolResults is
guaranteed to succeed and return ename:VK_SUCCESS if the queries guaranteed to succeed and return ename:VK_SUCCESS if the queries
@ -458,7 +458,7 @@ but still not be visible in a final image.
== Pipeline Statistics Queries == Pipeline Statistics Queries
Pipeline statistics queries allow the application to sample a specified set Pipeline statistics queries allow the application to sample a specified set
of sname:VkPipeline counters. These counters are accumulated by {apiname} of sname:VkPipeline counters. These counters are accumulated by Vulkan
for a set of either draw or dispatch commands while a pipeline statistics for a set of either draw or dispatch commands while a pipeline statistics
query is active. As such, pipeline statistics queries are available on query is active. As such, pipeline statistics queries are available on
queue families supporting either graphics or compute operations. Further, queue families supporting either graphics or compute operations. Further,

View File

@ -758,8 +758,8 @@ include::../structs/VkRenderPassBeginInfo.txt[]
* pname:pClearValues is an array of slink: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. Only elements corresponding to cleared
attachments being unused. attachments are used. Other elements of pname:pClearValues are ignored.
include::../validity/structs/VkRenderPassBeginInfo.txt[] include::../validity/structs/VkRenderPassBeginInfo.txt[]

View File

@ -4,7 +4,7 @@
[[resources]] [[resources]]
= Resource Creation = Resource Creation
{apiname} supports two primary resource types: _buffers_ and _images_. Vulkan supports two primary resource types: _buffers_ and _images_.
Resources are views of memory with associated formatting and dimensionality. Resources are views of memory with associated formatting and dimensionality.
Buffers are essentially unformatted arrays of bytes whereas images contain Buffers are essentially unformatted arrays of bytes whereas images contain
format information, can: be multidimensional and may: have associated format information, can: be multidimensional and may: have associated
@ -449,7 +449,7 @@ pname:depthPitch is defined only for 3D images.
For color formats, the pname:aspectMask member of sname:VkImageSubresource For color formats, the pname:aspectMask member of sname:VkImageSubresource
must: be ename:VK_IMAGE_ASPECT_COLOR_BIT. For depth/stencil formats, must: be ename:VK_IMAGE_ASPECT_COLOR_BIT. For depth/stencil formats,
pname:aspect must: be either ename:VK_IMAGE_ASPECT_DEPTH_BIT or pname:aspectMask must: be either ename:VK_IMAGE_ASPECT_DEPTH_BIT or
ename:VK_IMAGE_ASPECT_STENCIL_BIT. On implementations that store depth and ename:VK_IMAGE_ASPECT_STENCIL_BIT. On implementations that store depth and
stencil aspects separately, querying each of these image subresource layouts stencil aspects separately, querying each of these image subresource layouts
will return a different pname:offset and pname:size representing the region will return a different pname:offset and pname:size representing the region
@ -996,7 +996,7 @@ include::../protos/vkBindBufferMemory.txt[]
include::../validity/protos/vkBindBufferMemory.txt[] include::../validity/protos/vkBindBufferMemory.txt[]
To attach memory to a image object, call: To attach memory to an image object, call:
include::../protos/vkBindImageMemory.txt[] include::../protos/vkBindImageMemory.txt[]

View File

@ -109,7 +109,7 @@ include::../enums/VkBorderColor.txt[]
** The functions mustnot: use offsets. ** The functions mustnot: use offsets.
[NOTE] [NOTE]
.Mapping of OpenGL to {apiname} filter modes .Mapping of OpenGL to Vulkan filter modes
================== ==================
pname:magFilter values of ename:VK_FILTER_NEAREST and ename:VK_FILTER_LINEAR pname:magFilter values of ename:VK_FILTER_NEAREST and ename:VK_FILTER_LINEAR
directly correspond to code:GL_NEAREST and code:GL_LINEAR magnification directly correspond to code:GL_NEAREST and code:GL_LINEAR magnification
@ -120,7 +120,7 @@ ename:VK_FILTER_LINEAR and pname:mipmapMode of
ename:VK_SAMPLER_MIPMAP_MODE_NEAREST correspond to 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 Vulkan 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

View File

@ -40,7 +40,7 @@ _Shader modules_ contain _shader code_ and one or more entry points. Shaders
are selected from a shader module by specifying an entry point as part of are selected from a shader module by specifying an entry point as part of
<<pipelines,pipeline>> creation. The stages of a pipeline can: use shaders <<pipelines,pipeline>> creation. The stages of a pipeline can: use shaders
that come from different modules. The shader code defining a shader module that come from different modules. The shader code defining a shader module
must: be in the SPIR-V format, as described by the <<spirvenv,{apiname} must: be in the SPIR-V format, as described by the <<spirvenv,Vulkan
Environment for SPIR-V>> appendix. Environment for SPIR-V>> appendix.
A shader module is created by calling: A shader module is created by calling:

View File

@ -5,7 +5,7 @@
= Sparse Resources = Sparse Resources
As documented in <<resources-association,Resource Memory Association>>, As documented in <<resources-association,Resource Memory Association>>,
sname:VkBuffer and sname:VkImage resources in {apiname} must: be bound sname:VkBuffer and sname:VkImage resources in Vulkan must: be bound
completely and contiguously to a single sname:VkDeviceMemory object. completely and contiguously to a single sname:VkDeviceMemory object.
This binding must: be done before the resource is used, and the This binding must: be done before the resource is used, and the
binding is immutable for the lifetime of the resource. binding is immutable for the lifetime of the resource.
@ -1027,7 +1027,7 @@ arrayMipTailOffset = imageMipTailOffset + arrayLayer * imageMipTailStride;
and the mip tail can: be bound with code:layerCount slink:VkSparseMemoryBind and the mip tail can: be bound with code:layerCount slink:VkSparseMemoryBind
structures, each using pname:size = pname:imageMipTailSize and structures, each using pname:size = pname:imageMipTailSize and
pname:resourceOffset = pname:arrayMipTailOffset as defined above. pname:resourceOffset = ptext:arrayMipTailOffset as defined above.
Sparse memory binding is handled by the following APIs and related data Sparse memory binding is handled by the following APIs and related data
structures. structures.
@ -1167,7 +1167,7 @@ include::../structs/VkSparseImageMemoryBind.txt[]
* pname:extent is the size in texels of the region within the image * pname:extent is the size in texels of the region within the image
subresource to bind. The extent must: be a multiple of the sparse image subresource to bind. The extent must: be a multiple of the sparse image
block dimensions, except when binding sparse image blocks along the edge block dimensions, except when binding sparse image blocks along the edge
of a image subresource it can: instead be such that any coordinate of of an image subresource it can: instead be such that any coordinate of
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

View File

@ -5,17 +5,17 @@
= Synchronization and Cache Control = Synchronization and Cache Control
Synchronization of access to resources is primarily the responsibility of Synchronization of access to resources is primarily the responsibility of
the application. In {apiname}, there are four forms of concurrency during the application. In Vulkan, there are four forms of concurrency during
execution: between the host and device, between the queues, between execution: between the host and device, between the queues, between
queue submissions, and between commands within a command buffer. queue submissions, and between commands within a command buffer.
{apiname} provides the application with a set of Vulkan provides the application with a set of
synchronization primitives for these purposes. Further, memory caches and synchronization primitives for these purposes. Further, memory caches and
other optimizations mean that the normal flow of command execution does not other optimizations mean that the normal flow of command execution does not
guarantee that all memory transactions from a command are immediately guarantee that all memory transactions from a command are immediately
visible to other agents with views into a given range of memory. {apiname} visible to other agents with views into a given range of memory. Vulkan
also provides barrier operations to ensure this type of synchronization. also provides barrier operations to ensure this type of synchronization.
Four synchronization primitive types are exposed by {apiname}. These are: Four synchronization primitive types are exposed by Vulkan. These are:
* <<synchronization-fences,Fences>> * <<synchronization-fences,Fences>>
* <<synchronization-semaphores,Semaphores>> * <<synchronization-semaphores,Semaphores>>
@ -225,7 +225,7 @@ include::../protos/vkDestroySemaphore.txt[]
include::../validity/protos/vkDestroySemaphore.txt[] include::../validity/protos/vkDestroySemaphore.txt[]
To signal a semaphore from a queue, include it in an element of the array To signal a semaphore from a queue, include it in an element of the array
of slink:VkSubmitInfo structures passed through the pname:pSubmitInfo of slink:VkSubmitInfo structures passed through the pname:pSubmits
parameter to a call to flink:vkQueueSubmit, or in an element of the array parameter to a call to flink:vkQueueSubmit, or in an element of the array
of slink:VkBindSparseInfo structures passed through the pname:pBindInfo of slink:VkBindSparseInfo structures passed through the pname:pBindInfo
parameter to a call to flink:vkQueueBindSparse. parameter to a call to flink:vkQueueBindSparse.
@ -297,7 +297,7 @@ performed in between.
(The primary use case for this example is with the presentation extensions, (The primary use case for this example is with the presentation extensions,
thus the etext:VK_IMAGE_LAYOUT_PRESENT_SRC_KHR token is used even though it thus the etext:VK_IMAGE_LAYOUT_PRESENT_SRC_KHR token is used even though it
is not defined in the core {apiname} specification.) is not defined in the core Vulkan specification.)
==== ====
When a queue signals or waits upon a semaphore, certain When a queue signals or waits upon a semaphore, certain
@ -313,7 +313,7 @@ the host.
Events represent a fine-grained synchronization primitive that can: be used Events represent a fine-grained synchronization primitive that can: be used
to gauge progress through a sequence of commands executed on a queue by to gauge progress through a sequence of commands executed on a queue by
{apiname}. An event is initially in the unsignaled state. It can: be Vulkan. An event is initially in the unsignaled state. It can: be
signaled by a device, using commands inserted into the command buffer, or by signaled by a device, using commands inserted into the command buffer, or by
the host. It can: also be reset to the unsignaled state by a device or the the host. It can: also be reset to the unsignaled state by a device or the
host. The host can: query the state of an event. A device can: wait for one host. The host can: query the state of an event. A device can: wait for one
@ -936,7 +936,7 @@ Enumeration>> and <<devsandqueues-queues,Queues>>.
_Memory barriers_ express the two halves of a memory dependency between an _Memory barriers_ express the two halves of a memory dependency between an
earlier set of memory accesses against a later set of memory accesses. earlier set of memory accesses against a later set of memory accesses.
{apiname} provides three types of memory barriers: global memory, buffer Vulkan provides three types of memory barriers: global memory, buffer
memory, and image memory. memory, and image memory.
@ -1142,7 +1142,7 @@ include::../validity/structs/VkBufferMemoryBarrier.txt[]
The image memory barrier type is specified with an instance of the The image memory barrier type is specified with an instance of the
sname:VkImageMemoryBarrier structure. This type of barrier only applies to sname:VkImageMemoryBarrier structure. This type of barrier only applies to
memory accesses involving a specific image subresource range of the memory accesses involving a specific image subresource range of the
specified image object. That is, a memory dependency formed from a image specified image object. That is, a memory dependency formed from an image
memory barrier is memory barrier is
<<synchronization-execution-and-memory-dependencies-types,scoped>> to the <<synchronization-execution-and-memory-dependencies-types,scoped>> to the
specified image subresources of the image. It is also used to perform a specified image subresources of the image. It is also used to perform a

View File

@ -62,6 +62,6 @@ representatives be liable for any damages, whether direct, indirect, special or
consequential damages for lost revenues, lost profits, or otherwise, arising from or in consequential damages for lost revenues, lost profits, or otherwise, arising from or in
connection with these materials. connection with these materials.
Khronos and {apiname} are trademarks of The Khronos Group Inc. OpenCL is a trademark of Khronos and Vulkan are trademarks of The Khronos Group Inc. OpenCL is a trademark of
Apple Inc. and OpenGL is a registered trademark of Silicon Graphics International, both Apple Inc. and OpenGL is a registered trademark of Silicon Graphics International, both
used under license by Khronos. used under license by Khronos.

View File

@ -25,7 +25,7 @@ pname:pCommandBuffers::
Description Description
----------- -----------
fname::vkAllocateCommandBuffers allocates command buffers from an existing command pool. pname:pAllocateInfo fname:vkAllocateCommandBuffers allocates command buffers from an existing command pool. pname:pAllocateInfo
is a pointer to an instance of the slink:VkCommandBufferAllocateInfo structure which is a pointer to an instance of the slink:VkCommandBufferAllocateInfo structure which
describes the command buffer allocation. The definition of slink:VkCommandBufferAllocateInfo is: describes the command buffer allocation. The definition of slink:VkCommandBufferAllocateInfo is:

View File

@ -39,7 +39,7 @@ the slink:VkBufferCopy structure, whose definition is:
include::../structs/VkBufferCopy.txt[] include::../structs/VkBufferCopy.txt[]
If any two or more regions within pname:pRegions overlap, the resulting data will be If any two or more regions within pname:pRegions overlap, the resulting data will be
undefined. It is recomended, but not required, that the regions given in pname:pRegions undefined. It is recommended, but not required, that the regions given in pname:pRegions
start on multiples of four bytes and have a length which is a multiple of four bytes. start on multiples of four bytes and have a length which is a multiple of four bytes.
include::../validity/protos/vkCmdCopyBuffer.txt[] include::../validity/protos/vkCmdCopyBuffer.txt[]

View File

@ -14,7 +14,7 @@ Parameters
---------- ----------
pname:commandBuffer:: pname:commandBuffer::
Ths command buffer into which the command is to be placed. The command buffer into which the command is to be placed.
pname:srcImage:: pname:srcImage::
The image that is the source of the resolve operation. The image that is the source of the resolve operation.

View File

@ -20,7 +20,7 @@ pname:pCreateInfo::
Pointer to data structure containing information about the object to be created. Pointer to data structure containing information about the object to be created.
pname:pBuffer:: pname:pBuffer::
Pointer to a variable to recieve a handle to the new buffer object. Pointer to a variable to receive a handle to the new buffer object.
Description Description
----------- -----------

View File

@ -66,7 +66,7 @@ to fname:vkCreateComputePipelines.
The parameters pname:basePipelineHandle and pname:basePipelineIndex are ignored The parameters pname:basePipelineHandle and pname:basePipelineIndex are ignored
unless pname:flags has the ename:VK_PIPELINE_CREATE_DERIVATIVE_BIT bit set. If unless pname:flags has the ename:VK_PIPELINE_CREATE_DERIVATIVE_BIT bit set. If
using the pname:basePipelineIndex parameter, the index must refer to a using the pname:basePipelineIndex parameter, the index must refer to a
pname:pCreateInfos parameter pased to vkCreateComputePipelines that appeared pname:pCreateInfos parameter passed to vkCreateComputePipelines that appeared
earlier than the current sname:VkComputePipelineCreateInfo in the list. The 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,

View File

@ -25,7 +25,7 @@ pname:pView::
Description Description
----------- -----------
fname:vkCreateImageView creates a new view of a source image in a compatible format, alowing casting fname:vkCreateImageView creates a new view of a source image in a compatible format, allowing casting
of image data from one format to another. Image views may be bound into descriptor sets to allow them of image data from one format to another. Image views may be bound into descriptor sets to allow them
to be accessed in shaders, or be bound as color attachments. pname:device specifies the device that to be accessed in shaders, or be bound as color attachments. pname:device specifies the device that
is to be used to create the new view. pname:pCreateInfo is a pointer to an instance of the is to be used to create the new view. pname:pCreateInfo is a pointer to an instance of the

View File

@ -20,7 +20,7 @@ pname:pCreateInfo::
A pointer to structure specifying the properties of the new pipeline layout. A pointer to structure specifying the properties of the new pipeline layout.
pname:pPipelineLayout:: pname:pPipelineLayout::
Pointer to a variable to recieve a handle to the new pipeline layout object. Pointer to a variable to receive a handle to the new pipeline layout object.
Description Description
----------- -----------

View File

@ -41,7 +41,7 @@ If pname:pPhysicalDevices is not code:NULL, then pname:pPhysicalDeviceCount shou
to a variable that has been initialized with the size of the array pointed to by pname:pPhysicalDevices. to a variable that has been initialized with the size of the array pointed to by pname:pPhysicalDevices.
No more than this number of physical device handles will be written into the output array. No more than this number of physical device handles will be written into the output array.
The actual number of device handles written into pname:pPhysicalDevices is then written into The actual number of device handles written into pname:pPhysicalDevices is then written into
the variable pointed to pname:pPhysicalDevices. the variable pointed to by pname:pPhysicalDeviceCount.
include::../validity/protos/vkEnumeratePhysicalDevices.txt[] include::../validity/protos/vkEnumeratePhysicalDevices.txt[]

View File

@ -30,7 +30,7 @@ Description
----------- -----------
fname:vkGetImageSubresourceLayout returns information about the memory fname:vkGetImageSubresourceLayout returns information about the memory
layout of a image subresource of an image. pname:device is a handle to the layout of an image subresource of an image. pname:device is a handle to the
device that owns pname:image, which is the image about which to retrieve device that owns pname:image, which is the image about which to retrieve
information. A description of the image subresource is passsed to the information. A description of the image subresource is passsed to the
command through an instance of the slink:VkImageSubresource structure, the command through an instance of the slink:VkImageSubresource structure, the

View File

@ -30,7 +30,7 @@ different values of pname:instance.
If pname:instance is code:NULL, fname:vkGetInstanceProcAddr will return If pname:instance is code:NULL, fname:vkGetInstanceProcAddr will return
non-code:NULL function pointers for the global commands non-code:NULL function pointers for the global commands
fname::vkEnumerateInstanceExtensionProperties, fname:vkEnumerateInstanceExtensionProperties,
fname:vkEnumerateInstanceLayerProperties, and fname:vkCreateInstance. It will fname:vkEnumerateInstanceLayerProperties, and fname:vkCreateInstance. It will
return code:NULL for all other commands, since they may have different return code:NULL for all other commands, since they may have different
implementations in different instances. implementations in different instances.

View File

@ -73,8 +73,8 @@ operations such as binding graphics state and graphics pipelines and executing d
* If a queue's ptext:queueFlags member contains ename:VK_QUEUE_COMPUTE_BIT, then it supports compute * If a queue's ptext:queueFlags member contains ename:VK_QUEUE_COMPUTE_BIT, then it supports compute
operations such as binding compute pipelines and executing compute dispatches. operations such as binding compute pipelines and executing compute dispatches.
* If a queue's ptext:queueFlags member contains ename:VK_QUEUE_TRANSFER_BIT, then it supports transsfer * If a queue's ptext:queueFlags member contains ename:VK_QUEUE_TRANSFER_BIT, then it supports transfer
operations, which include copying data an images. operations, which include copying data and images.
* If a queue's ptext:queueFlags member contains ename:VK_QUEUE_SPARSE_BINDING_BIT, then it supports * If a queue's ptext:queueFlags member contains ename:VK_QUEUE_SPARSE_BINDING_BIT, then it supports
binding memory to sparse buffer and image resources. binding memory to sparse buffer and image resources.

View File

@ -583,6 +583,13 @@ See Gitlab issue #61.
==== ====
=== Terms to Use With Caution
The term _subset_ is sometimes used to refer to a _strict subset_, and
sometimes used to refer to a subset which may be equal to the entire set.
This is particularly likely to come up when describing bitmasks. Make sure
to use either _subset_ or _strict subset_ as appropriate.
=== Terms to Avoid === Terms to Avoid
Don't describe anything in the documentation using vague or wishy-washy Don't describe anything in the documentation using vague or wishy-washy
@ -852,7 +859,7 @@ autogenerated from vk.xml, and included from the `../validity/` directories:
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[]

View File

@ -35,6 +35,7 @@ endif::doctype-manpage[]
* If either of pname:srcImage or pname:dstImage was created with an unsigned integer elink:VkFormat, the other must: also have been created with an unsigned integer elink:VkFormat * If either of pname:srcImage or pname:dstImage was created with an unsigned integer elink:VkFormat, the other must: also have been created with an unsigned integer elink:VkFormat
* If either of pname:srcImage or pname:dstImage was created with a depth/stencil format, the other must: have exactly the same format * If either of pname:srcImage or pname:dstImage was created with a depth/stencil format, the other must: have exactly the same format
* If pname:srcImage was created with a depth/stencil format, pname:filter must: be ename:VK_FILTER_NEAREST * If pname:srcImage was created with a depth/stencil format, pname:filter must: be ename:VK_FILTER_NEAREST
* If pname:filter is ename:VK_FILTER_LINEAR, pname:srcImage 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) returned by fname:vkGetPhysicalDeviceFormatProperties
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -20,7 +20,7 @@ endif::doctype-manpage[]
* pname:image must: have been created with ename:VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag * pname:image must: have been created with ename:VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag
* 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 an image subresource range that is contained within pname:image
* pname:image mustnot: have a compressed or depth/stencil format * pname:image mustnot: have a compressed or depth/stencil format
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************

View File

@ -20,7 +20,7 @@ endif::doctype-manpage[]
* pname:image must: have been created with ename:VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag * pname:image must: have been created with ename:VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag
* 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 an image subresource range that is contained within pname:image
* pname:image must: have a depth/stencil format * pname:image must: have a depth/stencil format
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 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 * Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 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 * Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 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 * Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 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 * Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 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 * Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 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 * Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) returned by fname:vkGetPhysicalDeviceFormatProperties
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -17,6 +17,7 @@ endif::doctype-manpage[]
* Each of pname:commandBuffer and pname:event must: have been created, allocated or retrieved from the same sname:VkDevice * Each of pname:commandBuffer and pname:event must: have been created, allocated or retrieved from the same sname:VkDevice
* If the <<features-features-geometryShader,geometry shaders>> feature is not enabled, pname:stageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT * If the <<features-features-geometryShader,geometry shaders>> feature is not enabled, pname:stageMask mustnot: contain ename:VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
* If the <<features-features-tessellationShader,tessellation shaders>> feature is not enabled, pname:stageMask 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:stageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or ename:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
* When this command executes, pname:event mustnot: be waited on by a fname:vkCmdWaitEvents command that is currently executing
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -11,8 +11,8 @@ endif::doctype-manpage[]
* If pname:submitCount is not `0`, pname:pSubmits must: be a pointer to an array of pname:submitCount valid sname:VkSubmitInfo structures * If pname:submitCount is not `0`, pname:pSubmits must: be a pointer to an array of pname:submitCount valid sname:VkSubmitInfo structures
* If pname:fence is not sname:VK_NULL_HANDLE, pname:fence must: be a valid sname:VkFence handle * If pname:fence is not sname:VK_NULL_HANDLE, pname:fence must: be a valid sname:VkFence handle
* Each of pname:queue and pname:fence that are valid handles must: have been created, allocated or retrieved from the same sname:VkDevice * Each of pname:queue and pname:fence that are valid handles must: have been created, allocated or retrieved from the same sname:VkDevice
* pname:fence must: be unsignalled * If pname:fence is not sname:VK_NULL_HANDLE, pname:fence must: be unsignalled
* pname:fence mustnot: be associated with any other queue command that has not yet completed execution on that queue * If pname:fence is not sname:VK_NULL_HANDLE, pname:fence mustnot: be associated with any other queue command that has not yet completed execution on that queue
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -11,6 +11,7 @@ endif::doctype-manpage[]
* pname:event must: be a valid sname:VkEvent handle * pname:event must: be a valid sname:VkEvent handle
* pname:event must: have been created, allocated or retrieved from pname:device * pname:event must: have been created, allocated or retrieved from pname:device
* Each of pname:device and pname:event must: have been created, allocated or retrieved from the same sname:VkPhysicalDevice * Each of pname:device and pname:event must: have been created, allocated or retrieved from the same sname:VkPhysicalDevice
* pname:event mustnot: be waited on by a fname:vkCmdWaitEvents command that is currently executing
ifndef::doctype-manpage[] ifndef::doctype-manpage[]
******************************************************************************** ********************************************************************************
endif::doctype-manpage[] endif::doctype-manpage[]

View File

@ -16,13 +16,13 @@ endif::doctype-manpage[]
* pname:imageOffset.y and (imageExtent.height + pname:imageOffset.y) must: both be greater than or equal to `0` and less than or equal to the image subresource height * pname:imageOffset.y and (imageExtent.height + pname:imageOffset.y) must: both be greater than or equal to `0` and less than or equal to the image subresource height
* pname:imageOffset.z and (imageExtent.depth + pname:imageOffset.z) must: both be greater than or equal to `0` and less than or equal to the image subresource depth * pname:imageOffset.z and (imageExtent.depth + pname:imageOffset.z) must: both be greater than or equal to `0` and less than or equal to the image subresource depth
* If the calling command's sname:VkImage parameter is a compressed format image: * If the calling command's sname:VkImage parameter is a compressed format image:
* pname:bufferRowLength must: be a multiple of the compressed texel block width ** pname:bufferRowLength must: be a multiple of the compressed texel block width
* pname:bufferImageHeight must: be a multiple of the compressed texel block height ** pname:bufferImageHeight must: be a multiple of the compressed texel block height
* all members of pname:imageOffset must: be a multiple of the corresponding dimensions of the compressed texel block ** all members of pname:imageOffset must: be a multiple of the corresponding dimensions of the compressed texel block
* pname:bufferOffset must: be a multiple of the compressed texel block size in bytes ** pname:bufferOffset must: be a multiple of the compressed texel block size in bytes
* 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 <<devsandqueues-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

View File

@ -15,10 +15,10 @@ endif::doctype-manpage[]
* pname:offset must: be less than the size of pname:buffer * pname:offset must: be less than the size of pname:buffer
* pname:offset must: be a multiple of sname:VkPhysicalDeviceLimits::pname:minTexelBufferOffsetAlignment * pname:offset must: be a multiple of sname:VkPhysicalDeviceLimits::pname:minTexelBufferOffsetAlignment
* If pname:range is not equal to ename:VK_WHOLE_SIZE: * If pname:range is not equal to ename:VK_WHOLE_SIZE:
* pname:range must: be greater than `0` ** pname:range must: be greater than `0`
* pname:range must: be a multiple of the element size of pname:format ** pname:range must: be a multiple of the element size of pname:format
* pname:range divided by the size of an element of pname:format, must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxTexelBufferElements ** pname:range divided by the size of an element of pname:format, must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxTexelBufferElements
* the sum of pname:offset and pname:range must: be less than or equal to the size of pname:buffer ** the sum of pname:offset and pname:range must: be less than or equal to the size of pname:buffer
* pname:buffer must: have been created with a pname:usage value containing at least one of ename:VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT or ename:VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT * pname:buffer must: have been created with a pname:usage value containing at least one of ename:VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT or ename:VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT
* If pname:buffer was created with pname:usage containing ename:VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT, pname:format must: be supported for uniform texel buffers, as specified by the ename:VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT flag in sname:VkFormatProperties::pname:bufferFeatures returned by fname:vkGetPhysicalDeviceFormatProperties * If pname:buffer was created with pname:usage containing ename:VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT, pname:format must: be supported for uniform texel buffers, as specified by the ename:VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT flag in sname:VkFormatProperties::pname:bufferFeatures returned by fname:vkGetPhysicalDeviceFormatProperties
* If pname:buffer was created with pname:usage containing ename:VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT, pname:format must: be supported for storage texel buffers, as specified by the ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT flag in sname:VkFormatProperties::pname:bufferFeatures returned by fname:vkGetPhysicalDeviceFormatProperties * If pname:buffer was created with pname:usage containing ename:VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT, pname:format must: be supported for storage texel buffers, as specified by the ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT flag in sname:VkFormatProperties::pname:bufferFeatures returned by fname:vkGetPhysicalDeviceFormatProperties

View File

@ -21,15 +21,15 @@ endif::doctype-manpage[]
* pname:dstOffset.y and (pname:extent.height + pname:dstOffset.y) must: both be greater than or equal to `0` and less than or equal to the destination image subresource height * pname:dstOffset.y and (pname:extent.height + pname:dstOffset.y) must: both be greater than or equal to `0` and less than or equal to the destination image subresource height
* pname:dstOffset.z and (pname:extent.depth + pname:dstOffset.z) must: both be greater than or equal to `0` and less than or equal to the destination image subresource depth * pname:dstOffset.z and (pname:extent.depth + pname:dstOffset.z) must: both be greater than or equal to `0` and less than or equal to the destination image subresource depth
* If the calling command's pname:srcImage is a compressed format image: * If the calling command's pname:srcImage is a compressed format image:
* all members of pname:srcOffset must: be a multiple of the corresponding dimensions of the compressed texel block ** all members of pname:srcOffset must: be a multiple of the corresponding dimensions of the compressed texel block
* pname:extent.width must: be a multiple of the compressed texel block width or (pname:extent.width + pname:srcOffset.x) must: equal the source image subresource width ** pname:extent.width must: be a multiple of the compressed texel block width or (pname:extent.width + pname:srcOffset.x) must: equal the source image subresource width
* pname:extent.height must: be a multiple of the compressed texel block height or (pname:extent.height + pname:srcOffset.y) must: equal the source image subresource height ** pname:extent.height must: be a multiple of the compressed texel block height or (pname:extent.height + pname:srcOffset.y) must: equal the source image subresource height
* pname:extent.depth must: be a multiple of the compressed texel block depth or (pname:extent.depth + pname:srcOffset.z) must: equal the source image subresource depth ** pname:extent.depth must: be a multiple of the compressed texel block depth or (pname:extent.depth + pname:srcOffset.z) must: equal the source image subresource depth
* If the calling command's pname:dstImage is a compressed format image: * If the calling command's pname:dstImage is a compressed format image:
* all members of pname:dstOffset must: be a multiple of the corresponding dimensions of the compressed texel block ** all members of pname:dstOffset must: be a multiple of the corresponding dimensions of the compressed texel block
* 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 <<devsandqueues-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[]
******************************************************************************** ********************************************************************************

View File

@ -113,7 +113,8 @@ consts['VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR'] = 'VkStructureType'
consts['VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR'] = 'VkStructureType' consts['VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR'] = 'VkStructureType'
consts['VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR'] = 'VkStructureType' consts['VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR'] = 'VkStructureType'
consts['VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT'] = 'VkStructureType' consts['VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT'] = 'VkStructureType'
enums['VkStructureType'] = ['VK_STRUCTURE_TYPE_APPLICATION_INFO', 'VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO', 'VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO', 'VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO', 'VK_STRUCTURE_TYPE_SUBMIT_INFO', 'VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO', 'VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE', 'VK_STRUCTURE_TYPE_BIND_SPARSE_INFO', 'VK_STRUCTURE_TYPE_FENCE_CREATE_INFO', 'VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO', 'VK_STRUCTURE_TYPE_EVENT_CREATE_INFO', 'VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO', 'VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO', 'VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO', 'VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO', 'VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO', 'VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO', 'VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO', 'VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO', 'VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO', 'VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO', 'VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO', 'VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET', 'VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET', 'VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO', 'VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO', 'VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO', 'VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO', 'VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO', 'VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO', 'VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO', 'VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER', 'VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER', 'VK_STRUCTURE_TYPE_MEMORY_BARRIER', 'VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO', 'VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO', 'VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_PRESENT_INFO_KHR', 'VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR', 'VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_XCB_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT'] consts['VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD'] = 'VkStructureType'
enums['VkStructureType'] = ['VK_STRUCTURE_TYPE_APPLICATION_INFO', 'VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO', 'VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO', 'VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO', 'VK_STRUCTURE_TYPE_SUBMIT_INFO', 'VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO', 'VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE', 'VK_STRUCTURE_TYPE_BIND_SPARSE_INFO', 'VK_STRUCTURE_TYPE_FENCE_CREATE_INFO', 'VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO', 'VK_STRUCTURE_TYPE_EVENT_CREATE_INFO', 'VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO', 'VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO', 'VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO', 'VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO', 'VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO', 'VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO', 'VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO', 'VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO', 'VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO', 'VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO', 'VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO', 'VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO', 'VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO', 'VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET', 'VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET', 'VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO', 'VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO', 'VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO', 'VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO', 'VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO', 'VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO', 'VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO', 'VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER', 'VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER', 'VK_STRUCTURE_TYPE_MEMORY_BARRIER', 'VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO', 'VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO', 'VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_PRESENT_INFO_KHR', 'VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR', 'VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_XCB_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR', 'VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT', 'VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD']
# Unprocessed type: void # Unprocessed type: void
# Unprocessed type: uint32_t # Unprocessed type: uint32_t
# Unprocessed type: VkFlags category: basetype # Unprocessed type: VkFlags category: basetype
@ -988,7 +989,7 @@ protos['vkCmdCopyBuffer'] = ['commandBuffer', 'srcBuffer', 'dstBuffer', 'region
structs['VkImageSubresourceLayers'] = ['aspectMask', 'mipLevel', 'baseArrayLayer', 'layerCount'] structs['VkImageSubresourceLayers'] = ['aspectMask', 'mipLevel', 'baseArrayLayer', 'layerCount']
structs['VkImageCopy'] = ['srcSubresource', 'srcOffset', 'dstSubresource', 'dstOffset', 'extent'] structs['VkImageCopy'] = ['srcSubresource', 'srcOffset', 'dstSubresource', 'dstOffset', 'extent']
protos['vkCmdCopyImage'] = ['commandBuffer', 'srcImage', 'srcImageLayout', 'dstImage', 'dstImageLayout', 'regionCount', 'pRegions'] protos['vkCmdCopyImage'] = ['commandBuffer', 'srcImage', 'srcImageLayout', 'dstImage', 'dstImageLayout', 'regionCount', 'pRegions']
structs['VkImageBlit'] = ['srcSubresource', 'srcOffsets[2]', 'dstSubresource', 'dstOffsets[2]'] structs['VkImageBlit'] = ['srcSubresource', 'srcOffsets', 'dstSubresource', 'dstOffsets']
protos['vkCmdBlitImage'] = ['commandBuffer', 'srcImage', 'srcImageLayout', 'dstImage', 'dstImageLayout', 'regionCount', 'pRegions', 'filter'] protos['vkCmdBlitImage'] = ['commandBuffer', 'srcImage', 'srcImageLayout', 'dstImage', 'dstImageLayout', 'regionCount', 'pRegions', 'filter']
structs['VkBufferImageCopy'] = ['bufferOffset', 'bufferRowLength', 'bufferImageHeight', 'imageSubresource', 'imageOffset', 'imageExtent'] structs['VkBufferImageCopy'] = ['bufferOffset', 'bufferRowLength', 'bufferImageHeight', 'imageSubresource', 'imageOffset', 'imageExtent']
protos['vkCmdCopyBufferToImage'] = ['commandBuffer', 'srcBuffer', 'dstImage', 'dstImageLayout', 'regionCount', 'pRegions'] protos['vkCmdCopyBufferToImage'] = ['commandBuffer', 'srcBuffer', 'dstImage', 'dstImageLayout', 'regionCount', 'pRegions']

View File

@ -3,7 +3,7 @@
include::specversion.txt[] include::specversion.txt[]
= {apiname} {apirevision} - A Specification = Vulkan {apirevision} - A Specification
The Khronos Vulkan Working Group The Khronos Vulkan Working Group
:icons: :icons:
:toc2: :toc2:

View File

@ -1745,11 +1745,14 @@ class ValidityOutputGenerator(OutputGenerator):
asciidoc += self.makeParameterName(paramname.text) asciidoc += self.makeParameterName(paramname.text)
validextensionstructs = param.attrib.get('validextensionstructs') validextensionstructs = param.attrib.get('validextensionstructs')
if validextensionstructs is None:
asciidoc += ' must: be `NULL`' asciidoc += ' must: be `NULL`'
if validextensionstructs is not None:
extensionstructs = ['slink:' + x for x in validextensionstructs.split(',')]
asciidoc += ', or a pointer to a valid instance of '
if len(extensionstructs) == 1:
asciidoc += validextensionstructs
else: else:
extensionstructs = validextensionstructs.split(',') asciidoc += (', ').join(extensionstructs[:-1]) + ' or ' + extensionstructs[-1]
asciidoc += ' must: point to one of ' + extensionstructs[:-1].join(', ') + ' or ' + extensionstructs[-1] + 'if the extension that introduced them is enabled '
asciidoc += '\n' asciidoc += '\n'

File diff suppressed because it is too large Load Diff

View File

@ -411,6 +411,9 @@ member.
\paragraph{Attributes of \tag{member} tags} \paragraph{Attributes of \tag{member} tags}
\begin{itemize} \begin{itemize}
\item \attr{validextensionstructs} - only valid on the \code{pNext} member of a
struct. This is a comma-separated list of structures that may be
accepted by \code{pNext} instead of \code{NULL}
\item \attr{len} - if the member is an array, len may be one or more of the \item \attr{len} - if the member is an array, len may be one or more of the
following things, separated by commas (one for each array following things, separated by commas (one for each array
indirection): another member of that struct; ``null-terminated'' for a indirection): another member of that struct; ``null-terminated'' for a
@ -419,9 +422,13 @@ member.
latexmath:[\$} and {\tt \$]}. latexmath:[\$} and {\tt \$]}.
\item \attr{externsync} - denotes that the member should be externally \item \attr{externsync} - denotes that the member should be externally
synchronized when accessed by Vulkan synchronized when accessed by Vulkan
\item \attr{optional} - whether this value can be omitted by providing \item \attr{optional} - a value of 'true' or 'false' determines whether this
\code{NULL} (for pointers), \code{VK_NULL_HANDLE} (for handles) or 0 member can be omitted by providing \code{NULL} (for pointers),
(for bitmasks/values) \code{VK_NULL_HANDLE} (for handles) or 0 (for bitmasks/values). If the
member is a pointer to one of those types, multiple values may be
provided, separated by commas - one for each pointer indirection.
Note that this only affects automatic validity statements - explicit
statements remain unchanged.
\item \attr{noautovalidity} - prevents automatic validity language being \item \attr{noautovalidity} - prevents automatic validity language being
generated for the tagged item. Only suppresses item-specific validity generated for the tagged item. Only suppresses item-specific validity
- parenting issues etc. are still captured. - parenting issues etc. are still captured.
@ -795,9 +802,13 @@ members.
string; ``1'' to indicate it's just a pointer (used for nested string; ``1'' to indicate it's just a pointer (used for nested
pointers); or an equation (a simple expression prefixed with pointers); or an equation (a simple expression prefixed with
``math:'') ``math:'')
\item \attr{optional} - whether this value can be omitted by providing \item \attr{optional} - a value of 'true' or 'false' determines whether this
\code{NULL} (for pointers), \code{VK_NULL_HANDLE} (for handles) or 0 member can be omitted by providing \code{NULL} (for pointers),
(for bitmasks/values) \code{VK_NULL_HANDLE} (for handles) or 0 (for bitmasks/values). If the
member is a pointer to one of those types, multiple values may be
provided, separated by commas - one for each pointer indirection.
Note that this only affects automatic validity statements - explicit
statements remain unchanged.
\item \attr{noautovalidity} - prevents automatic validity language being \item \attr{noautovalidity} - prevents automatic validity language being
generated for the tagged item. Only suppresses item-specific validity generated for the tagged item. Only suppresses item-specific validity
- parenting issues etc. are still captured. - parenting issues etc. are still captured.
@ -918,7 +929,7 @@ When processed into a C header for Vulkan, this results in:
#define VK_MAX_EXTENSION_NAME 256 #define VK_MAX_EXTENSION_NAME 256
#define VK_LOD_CLAMP_NONE MAX_FLOAT #define VK_LOD_CLAMP_NONE MAX_FLOAT
typedef VkResult (VKAPI_PTR *PFN_vkCreateInstance)(const VkInstanceCreateInfo* pCreateInfo, VkInstance* pInstance); typedef VkResult (VKAPI_PTR *PFN_vkCreateInstance)(const VkInstanceCreateInfo* pCreateInfo, VkInstance* pInstance);
#ifdef VK_PROTOTYPES #ifndef VK_NO_PROTOTYPES
VKAPI_ATTR VkResult VKAPI_CALL vkCreateInstance( VKAPI_ATTR VkResult VKAPI_CALL vkCreateInstance(
const VkInstanceCreateInfo* pCreateInfo, const VkInstanceCreateInfo* pCreateInfo,
VkInstance* pInstance); VkInstance* pInstance);
@ -1033,7 +1044,7 @@ typedef VkResult (VKAPI_PTR *PFN_vkCreateSharedSwapchainsKHR)(
const VkAllocationCallbacks* pAllocator, const VkAllocationCallbacks* pAllocator,
VkSwapchainKHR* pSwapchains); VkSwapchainKHR* pSwapchains);
#ifdef VK_PROTOTYPES #ifndef VK_NO_PROTOTYPES
VKAPI_ATTR VkResult VKAPI_CALL vkCreateSharedSwapchainsKHR( VKAPI_ATTR VkResult VKAPI_CALL vkCreateSharedSwapchainsKHR(
VkDevice device, VkDevice device,
uint32_t swapchainCount, uint32_t swapchainCount,
@ -1503,7 +1514,7 @@ VK_DEFINE_DISP_SUBCLASS_HANDLE(VkInstance, VkObject)
#define VK_MAX_PHYSICAL_DEVICE_NAME 256 #define VK_MAX_PHYSICAL_DEVICE_NAME 256
#define VK_MAX_EXTENSION_NAME 256 #define VK_MAX_EXTENSION_NAME 256
typedef VkResult (VKAPI_PTR *PFN_vkCreateInstance)(const VkInstanceCreateInfo* pCreateInfo, VkInstance* pInstance); typedef VkResult (VKAPI_PTR *PFN_vkCreateInstance)(const VkInstanceCreateInfo* pCreateInfo, VkInstance* pInstance);
#ifdef VK_PROTOTYPES #ifndef VK_NO_PROTOTYPES
VKAPI_ATTR VkResult VKAPI_CALL vkCreateInstance( VKAPI_ATTR VkResult VKAPI_CALL vkCreateInstance(
const VkInstanceCreateInfo* pCreateInfo, const VkInstanceCreateInfo* pCreateInfo,
VkInstance* pInstance); VkInstance* pInstance);

View File

@ -298,7 +298,7 @@ Command = element command {
# Each <feature> defines the interface of an API version (e.g. OpenGL 1.2) # Each <feature> defines the interface of an API version (e.g. OpenGL 1.2)
# api - API tag (e.g. 'gl', 'gles2', etc. - used internally, not # api - API tag (e.g. 'gl', 'gles2', etc. - used internally, not
# neccessarily an actual API name # necessarily an actual API name
# name - version name (C preprocessor name, e.g. GL_VERSION_4_2) # name - version name (C preprocessor name, e.g. GL_VERSION_4_2)
# number - version number, e.g. 4.2 # number - version number, e.g. 4.2
# protect - additional #ifdef symbol to place around the feature # protect - additional #ifdef symbol to place around the feature

View File

@ -13,7 +13,7 @@ int main(int ac, const char **av) {
VkStructureType sType; VkStructureType sType;
VkResult result; VkResult result;
// Supress warnings about unused variables // Suppress warnings about unused variables
(void)sType; (void)result; (void)sType; (void)result;
sType = VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR; sType = VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR;

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> 11</type> #define <name>VK_HEADER_VERSION</name> 12</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>
@ -336,6 +336,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<type name="VkDebugReportFlagBitsEXT" category="enum"/> <type name="VkDebugReportFlagBitsEXT" category="enum"/>
<type name="VkDebugReportObjectTypeEXT" category="enum"/> <type name="VkDebugReportObjectTypeEXT" category="enum"/>
<type name="VkDebugReportErrorEXT" category="enum"/> <type name="VkDebugReportErrorEXT" category="enum"/>
<type name="VkRasterizationOrderAMD" category="enum"/>
<!-- The PFN_vk*Function types are used by VkAllocationCallbacks below --> <!-- The PFN_vk*Function types are used by VkAllocationCallbacks below -->
<type category="funcpointer">typedef void (VKAPI_PTR *<name>PFN_vkInternalAllocationNotification</name>)( <type category="funcpointer">typedef void (VKAPI_PTR *<name>PFN_vkInternalAllocationNotification</name>)(
@ -692,11 +693,11 @@ maintained in the master branch of the Khronos Vulkan Github project.
<validity> <validity>
<usage>pname:offset must: be less than the size of pname:buffer</usage> <usage>pname:offset must: be less than the size of pname:buffer</usage>
<usage>pname:offset must: be a multiple of sname:VkPhysicalDeviceLimits::pname:minTexelBufferOffsetAlignment</usage> <usage>pname:offset must: be a multiple of sname:VkPhysicalDeviceLimits::pname:minTexelBufferOffsetAlignment</usage>
<usage>If pname:range is not equal to ename:VK_WHOLE_SIZE:</usage> <usage>If pname:range is not equal to ename:VK_WHOLE_SIZE:
<usage> pname:range must: be greater than `0`</usage> ** pname:range must: be greater than `0`
<usage> pname:range must: be a multiple of the element size of pname:format</usage> ** pname:range must: be a multiple of the element size of pname:format
<usage> pname:range divided by the size of an element of pname:format, must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxTexelBufferElements</usage> ** pname:range divided by the size of an element of pname:format, must: be less than or equal to sname:VkPhysicalDeviceLimits::pname:maxTexelBufferElements
<usage> the sum of pname:offset and pname:range must: be less than or equal to the size of pname:buffer</usage> ** the sum of pname:offset and pname:range must: be less than or equal to the size of pname:buffer</usage>
<usage>pname:buffer must: have been created with a pname:usage value containing at least one of ename:VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT or ename:VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT</usage> <usage>pname:buffer must: have been created with a pname:usage value containing at least one of ename:VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT or ename:VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT</usage>
<usage>If pname:buffer was created with pname:usage containing ename:VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT, pname:format must: be supported for uniform texel buffers, as specified by the ename:VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT flag in sname:VkFormatProperties::pname:bufferFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage> <usage>If pname:buffer was created with pname:usage containing ename:VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT, pname:format must: be supported for uniform texel buffers, as specified by the ename:VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT flag in sname:VkFormatProperties::pname:bufferFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage>
<usage>If pname:buffer was created with pname:usage containing ename:VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT, pname:format must: be supported for storage texel buffers, as specified by the ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT flag in sname:VkFormatProperties::pname:bufferFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage> <usage>If pname:buffer was created with pname:usage containing ename:VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT, pname:format must: be supported for storage texel buffers, as specified by the ename:VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT flag in sname:VkFormatProperties::pname:bufferFeatures returned by fname:vkGetPhysicalDeviceFormatProperties</usage>
@ -977,24 +978,24 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>pname:dstOffset.x and (pname:extent.width + pname:dstOffset.x) must: both be greater than or equal to `0` and less than or equal to the destination image subresource width</usage> <usage>pname:dstOffset.x and (pname:extent.width + pname:dstOffset.x) must: both be greater than or equal to `0` and less than or equal to the destination image subresource width</usage>
<usage>pname:dstOffset.y and (pname:extent.height + pname:dstOffset.y) must: both be greater than or equal to `0` and less than or equal to the destination image subresource height</usage> <usage>pname:dstOffset.y and (pname:extent.height + pname:dstOffset.y) must: both be greater than or equal to `0` and less than or equal to the destination image subresource height</usage>
<usage>pname:dstOffset.z and (pname:extent.depth + pname:dstOffset.z) must: both be greater than or equal to `0` and less than or equal to the destination image subresource depth</usage> <usage>pname:dstOffset.z and (pname:extent.depth + pname:dstOffset.z) must: both be greater than or equal to `0` and less than or equal to the destination image subresource depth</usage>
<usage>If the calling command's pname:srcImage is a compressed format image:</usage> <usage>If the calling command's pname:srcImage is a compressed format image:
<usage> all members of pname:srcOffset must: be a multiple of the corresponding dimensions of the compressed texel block</usage> ** all members of pname:srcOffset must: be a multiple of the corresponding dimensions of the compressed texel block
<usage> pname:extent.width must: be a multiple of the compressed texel block width or (pname:extent.width + pname:srcOffset.x) must: equal the source image subresource width</usage> ** pname:extent.width must: be a multiple of the compressed texel block width or (pname:extent.width + pname:srcOffset.x) must: equal the source image subresource width
<usage> pname:extent.height must: be a multiple of the compressed texel block height or (pname:extent.height + pname:srcOffset.y) must: equal the source image subresource height</usage> ** pname:extent.height must: be a multiple of the compressed texel block height or (pname:extent.height + pname:srcOffset.y) must: equal the source image subresource height
<usage> pname:extent.depth must: be a multiple of the compressed texel block depth or (pname:extent.depth + pname:srcOffset.z) must: equal the source image subresource depth</usage> ** pname:extent.depth must: be a multiple of the compressed texel block depth or (pname:extent.depth + pname:srcOffset.z) must: equal the source image subresource depth</usage>
<usage>If the calling command's pname:dstImage is a compressed format image:</usage> <usage>If the calling command's pname:dstImage is a compressed format image:
<usage> all members of pname:dstOffset must: be a multiple of the corresponding dimensions of the compressed texel block</usage> ** all members of pname:dstOffset must: be a multiple of the corresponding dimensions of the compressed texel block
<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> ** 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> 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> ** 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> 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> ** 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;devsandqueues-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">
<member><type>VkImageSubresourceLayers</type> <name>srcSubresource</name></member> <member><type>VkImageSubresourceLayers</type> <name>srcSubresource</name></member>
<member><type>VkOffset3D</type> <name>srcOffsets[2]</name></member> <!-- Specified in pixels for both compressed and uncompressed images --> <member><type>VkOffset3D</type> <name>srcOffsets</name>[2]</member> <!-- Specified in pixels for both compressed and uncompressed images -->
<member><type>VkImageSubresourceLayers</type> <name>dstSubresource</name></member> <member><type>VkImageSubresourceLayers</type> <name>dstSubresource</name></member>
<member><type>VkOffset3D</type> <name>dstOffsets[2]</name></member> <!-- Specified in pixels for both compressed and uncompressed images --> <member><type>VkOffset3D</type> <name>dstOffsets</name>[2]</member> <!-- Specified in pixels for both compressed and uncompressed images -->
<validity> <validity>
<usage>The pname:aspectMask member of pname:srcSubresource and pname:dstSubresource must: match</usage> <usage>The pname:aspectMask member of pname:srcSubresource and pname:dstSubresource must: match</usage>
<usage>The pname:layerCount member of pname:srcSubresource and pname:dstSubresource must: match</usage> <usage>The pname:layerCount member of pname:srcSubresource and pname:dstSubresource must: match</usage>
@ -1024,14 +1025,14 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>pname:imageOffset.x and (pname:imageExtent.width + pname:imageOffset.x) must: both be greater than or equal to `0` and less than or equal to the image subresource width</usage> <usage>pname:imageOffset.x and (pname:imageExtent.width + pname:imageOffset.x) must: both be greater than or equal to `0` and less than or equal to the image subresource width</usage>
<usage>pname:imageOffset.y and (imageExtent.height + pname:imageOffset.y) must: both be greater than or equal to `0` and less than or equal to the image subresource height</usage> <usage>pname:imageOffset.y and (imageExtent.height + pname:imageOffset.y) must: both be greater than or equal to `0` and less than or equal to the image subresource height</usage>
<usage>pname:imageOffset.z and (imageExtent.depth + pname:imageOffset.z) must: both be greater than or equal to `0` and less than or equal to the image subresource depth</usage> <usage>pname:imageOffset.z and (imageExtent.depth + pname:imageOffset.z) must: both be greater than or equal to `0` and less than or equal to the image subresource depth</usage>
<usage>If the calling command's sname:VkImage parameter is a compressed format image:</usage> <usage>If the calling command's sname:VkImage parameter is a compressed format image:
<usage> pname:bufferRowLength must: be a multiple of the compressed texel block width</usage> ** pname:bufferRowLength must: be a multiple of the compressed texel block width
<usage> pname:bufferImageHeight must: be a multiple of the compressed texel block height</usage> ** pname:bufferImageHeight must: be a multiple of the compressed texel block height
<usage> all members of pname:imageOffset must: be a multiple of the corresponding dimensions of the compressed texel block</usage> ** all members of pname:imageOffset must: be a multiple of the corresponding dimensions of the compressed texel block
<usage> pname:bufferOffset must: be a multiple of the compressed texel block size in bytes</usage> ** pname:bufferOffset must: be a multiple of the compressed texel block size in bytes
<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> ** 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> 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> ** 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> 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> ** 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;devsandqueues-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>
@ -1251,7 +1252,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
</type> </type>
<type category="struct" name="VkPipelineRasterizationStateCreateInfo"> <type category="struct" name="VkPipelineRasterizationStateCreateInfo">
<member><type>VkStructureType</type> <name>sType</name></member> <!-- Must be VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO --> <member><type>VkStructureType</type> <name>sType</name></member> <!-- Must be VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO -->
<member>const <type>void</type>* <name>pNext</name></member> <!-- Pointer to next structure --> <member validextensionstructs="VkPipelineRasterizationStateRasterizationOrderAMD">const <type>void</type>* <name>pNext</name></member> <!-- Pointer to next structure -->
<member optional="true"><type>VkPipelineRasterizationStateCreateFlags</type> <name>flags</name></member> <!-- Reserved --> <member optional="true"><type>VkPipelineRasterizationStateCreateFlags</type> <name>flags</name></member> <!-- Reserved -->
<member><type>VkBool32</type> <name>depthClampEnable</name></member> <member><type>VkBool32</type> <name>depthClampEnable</name></member>
<member><type>VkBool32</type> <name>rasterizerDiscardEnable</name></member> <member><type>VkBool32</type> <name>rasterizerDiscardEnable</name></member>
@ -2129,6 +2130,11 @@ maintained in the master branch of the Khronos Vulkan Github project.
<member><type>PFN_vkDebugReportCallbackEXT</type> <name>pfnCallback</name></member> <!-- Function pointer of a callback function--> <member><type>PFN_vkDebugReportCallbackEXT</type> <name>pfnCallback</name></member> <!-- Function pointer of a callback function-->
<member optional="true"><type>void</type>* <name>pUserData</name></member> <!-- User data provided to callback function --> <member optional="true"><type>void</type>* <name>pUserData</name></member> <!-- User data provided to callback function -->
</type> </type>
<type category="struct" name="VkPipelineRasterizationStateRasterizationOrderAMD">
<member><type>VkStructureType</type> <name>sType</name></member> <!-- Must be VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD -->
<member>const <type>void</type>* <name>pNext</name></member> <!-- Pointer to next structure -->
<member><type>VkRasterizationOrderAMD</type> <name>rasterizationOrder</name></member> <!-- Rasterization order to use for the pipeline -->
</type>
</types> </types>
<!-- SECTION: Vulkan enumerant (token) definitions. --> <!-- SECTION: Vulkan enumerant (token) definitions. -->
@ -2630,12 +2636,12 @@ maintained in the master branch of the Khronos Vulkan Github project.
<enum value="2" name="VK_TIMEOUT" comment="A wait operation has not completed in the specified time"/> <enum value="2" name="VK_TIMEOUT" comment="A wait operation has not completed in the specified time"/>
<enum value="3" name="VK_EVENT_SET" comment="An event is signaled"/> <enum value="3" name="VK_EVENT_SET" comment="An event is signaled"/>
<enum value="4" name="VK_EVENT_RESET" comment="An event is unsignalled"/> <enum value="4" name="VK_EVENT_RESET" comment="An event is unsignalled"/>
<enum value="5" name="VK_INCOMPLETE" comment="A return array was too small for the resul"/> <enum value="5" name="VK_INCOMPLETE" comment="A return array was too small for the result"/>
<!-- Error codes (negative values) --> <!-- Error codes (negative values) -->
<enum value="-1" name="VK_ERROR_OUT_OF_HOST_MEMORY" comment="A host memory allocation has failed"/> <enum value="-1" name="VK_ERROR_OUT_OF_HOST_MEMORY" comment="A host memory allocation has failed"/>
<enum value="-2" name="VK_ERROR_OUT_OF_DEVICE_MEMORY" comment="A device memory allocation has failed"/> <enum value="-2" name="VK_ERROR_OUT_OF_DEVICE_MEMORY" comment="A device memory allocation has failed"/>
<enum value="-3" name="VK_ERROR_INITIALIZATION_FAILED" comment="The logical device has been lost. See &lt;&lt;devsandqueues-lost-device&gt;&gt;"/> <enum value="-3" name="VK_ERROR_INITIALIZATION_FAILED" comment="Initialization of a object has failed"/>
<enum value="-4" name="VK_ERROR_DEVICE_LOST" comment="Initialization of a object has failed"/> <enum value="-4" name="VK_ERROR_DEVICE_LOST" comment="The logical device has been lost. See &lt;&lt;devsandqueues-lost-device&gt;&gt;"/>
<enum value="-5" name="VK_ERROR_MEMORY_MAP_FAILED" comment="Mapping of a memory object has failed"/> <enum value="-5" name="VK_ERROR_MEMORY_MAP_FAILED" comment="Mapping of a memory object has failed"/>
<enum value="-6" name="VK_ERROR_LAYER_NOT_PRESENT" comment="Layer specified does not exist"/> <enum value="-6" name="VK_ERROR_LAYER_NOT_PRESENT" comment="Layer specified does not exist"/>
<enum value="-7" name="VK_ERROR_EXTENSION_NOT_PRESENT" comment="Extension specified does not exist"/> <enum value="-7" name="VK_ERROR_EXTENSION_NOT_PRESENT" comment="Extension specified does not exist"/>
@ -2933,6 +2939,10 @@ maintained in the master branch of the Khronos Vulkan Github project.
<enum value="0" name="VK_DEBUG_REPORT_ERROR_NONE_EXT"/> <!-- Used for INFO & other non-error messages --> <enum value="0" name="VK_DEBUG_REPORT_ERROR_NONE_EXT"/> <!-- Used for INFO & other non-error messages -->
<enum value="1" name="VK_DEBUG_REPORT_ERROR_CALLBACK_REF_EXT"/> <!-- Callbacks were not destroyed prior to calling DestroyInstance --> <enum value="1" name="VK_DEBUG_REPORT_ERROR_CALLBACK_REF_EXT"/> <!-- Callbacks were not destroyed prior to calling DestroyInstance -->
</enums> </enums>
<enums name="VkRasterizationOrderAMD" type="enum">
<enum value="0" name="VK_RASTERIZATION_ORDER_STRICT_AMD"/> <!-- Rasterization order strictly follows API order -->
<enum value="1" name="VK_RASTERIZATION_ORDER_RELAXED_AMD"/> <!-- Rasterization order may not follow API order -->
</enums>
<!-- SECTION: Vulkan command definitions --> <!-- SECTION: Vulkan command definitions -->
<commands> <commands>
@ -3077,8 +3087,8 @@ maintained in the master branch of the Khronos Vulkan Github project.
<param len="submitCount" externsync="pSubmits[].pWaitSemaphores[],pSubmits[].pSignalSemaphores[]">const <type>VkSubmitInfo</type>* <name>pSubmits</name></param> <param len="submitCount" externsync="pSubmits[].pWaitSemaphores[],pSubmits[].pSignalSemaphores[]">const <type>VkSubmitInfo</type>* <name>pSubmits</name></param>
<param optional="true" externsync="true"><type>VkFence</type> <name>fence</name></param> <param optional="true" externsync="true"><type>VkFence</type> <name>fence</name></param>
<validity> <validity>
<usage>pname:fence must: be unsignalled</usage> <usage>If pname:fence is not sname:VK_NULL_HANDLE, pname:fence must: be unsignalled</usage>
<usage>pname:fence mustnot: be associated with any other queue command that has not yet completed execution on that queue</usage> <usage>If pname:fence is not sname:VK_NULL_HANDLE, pname:fence mustnot: be associated with any other queue command that has not yet completed execution on that queue</usage>
</validity> </validity>
</command> </command>
<command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST"> <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST">
@ -3327,6 +3337,9 @@ maintained in the master branch of the Khronos Vulkan Github project.
<proto><type>VkResult</type> <name>vkResetEvent</name></proto> <proto><type>VkResult</type> <name>vkResetEvent</name></proto>
<param><type>VkDevice</type> <name>device</name></param> <param><type>VkDevice</type> <name>device</name></param>
<param externsync="true"><type>VkEvent</type> <name>event</name></param> <param externsync="true"><type>VkEvent</type> <name>event</name></param>
<validity>
<usage>pname:event mustnot: be waited on by a fname:vkCmdWaitEvents command that is currently executing</usage>
</validity>
</command> </command>
<command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY"> <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
<proto><type>VkResult</type> <name>vkCreateQueryPool</name></proto> <proto><type>VkResult</type> <name>vkCreateQueryPool</name></proto>
@ -3918,7 +3931,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 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> <usage>Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 +3957,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 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> <usage>Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 +3987,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 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> <usage>Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 +4017,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 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> <usage>Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 +4039,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 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> <usage>Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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 +4060,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 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> <usage>Any sname:VkImageView 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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">
@ -4118,6 +4131,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>If either of pname:srcImage or pname:dstImage was created with an unsigned integer elink:VkFormat, the other must: also have been created with an unsigned integer elink:VkFormat</usage> <usage>If either of pname:srcImage or pname:dstImage was created with an unsigned integer elink:VkFormat, the other must: also have been created with an unsigned integer elink:VkFormat</usage>
<usage>If either of pname:srcImage or pname:dstImage was created with a depth/stencil format, the other must: have exactly the same format</usage> <usage>If either of pname:srcImage or pname:dstImage was created with a depth/stencil format, the other must: have exactly the same format</usage>
<usage>If pname:srcImage was created with a depth/stencil format, pname:filter must: be ename:VK_FILTER_NEAREST</usage> <usage>If pname:srcImage was created with a depth/stencil format, pname:filter must: be ename:VK_FILTER_NEAREST</usage>
<usage>If pname:filter is ename:VK_FILTER_LINEAR, pname:srcImage 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 (for a linear image) or sname:VkFormatProperties::pname:optimalTilingFeatures(for an optimally tiled image) 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">
@ -4203,7 +4217,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>pname:image must: have been created with ename:VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag</usage> <usage>pname:image must: have been created with ename:VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag</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: 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 an image subresource range that is contained within pname:image</usage>
<usage>pname:image mustnot: have a compressed or depth/stencil format</usage> <usage>pname:image mustnot: have a compressed or depth/stencil format</usage>
</validity> </validity>
</command> </command>
@ -4219,7 +4233,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<usage>pname:image must: have been created with ename:VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag</usage> <usage>pname:image must: have been created with ename:VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag</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: 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 an image subresource range that is contained within pname:image</usage>
<usage>pname:image must: have a depth/stencil format</usage> <usage>pname:image must: have a depth/stencil format</usage>
</validity> </validity>
</command> </command>
@ -4278,6 +4292,7 @@ maintained in the master branch of the Khronos Vulkan Github project.
<validity> <validity>
<usage>If the &lt;&lt;features-features-geometryShader,geometry shaders&gt;&gt; feature is not enabled, pname:stageMask 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:stageMask 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:stageMask 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:stageMask mustnot: contain ename:VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or ename:VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</usage>
<usage>When this command executes, pname:event mustnot: be waited on by a fname:vkCmdWaitEvents command that is currently executing</usage>
</validity> </validity>
</command> </command>
<command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary"> <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
@ -5168,10 +5183,13 @@ maintained in the master branch of the Khronos Vulkan Github project.
<enum value="&quot;VK_AMD_extension_2&quot;" name="VK_AMD_EXTENSION_2_EXTENSION_NAME"/> <enum value="&quot;VK_AMD_extension_2&quot;" name="VK_AMD_EXTENSION_2_EXTENSION_NAME"/>
</require> </require>
</extension> </extension>
<extension name="VK_AMD_extension_3" number="19" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled"> <extension name="VK_AMD_rasterization_order" number="19" author="AMD" contact="Daniel Rakos @aqnuep" supported="vulkan">
<require> <require>
<enum value="0" name="VK_AMD_EXTENSION_3_SPEC_VERSION"/> <enum value="1" name="VK_AMD_RASTERIZATION_ORDER_SPEC_VERSION"/>
<enum value="&quot;VK_AMD_extension_3&quot;" name="VK_AMD_EXTENSION_3_EXTENSION_NAME"/> <enum value="&quot;VK_AMD_rasterization_order&quot;" name="VK_AMD_RASTERIZATION_ORDER_EXTENSION_NAME"/>
<enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD"/>
<type name="VkRasterizationOrderAMD"/>
<type name="VkPipelineRasterizationStateRasterizationOrderAMD"/>
</require> </require>
</extension> </extension>
<extension name="VK_AMD_extension_4" number="20" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled"> <extension name="VK_AMD_extension_4" number="20" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">

View File

@ -43,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 11 #define VK_HEADER_VERSION 12
#define VK_NULL_HANDLE 0 #define VK_NULL_HANDLE 0
@ -210,6 +210,7 @@ typedef enum VkStructureType {
VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR = 1000008000, VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR = 1000008000,
VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR = 1000009000, VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR = 1000009000,
VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT = 1000011000, VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT = 1000011000,
VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD = 1000018000,
VK_STRUCTURE_TYPE_BEGIN_RANGE = VK_STRUCTURE_TYPE_APPLICATION_INFO, VK_STRUCTURE_TYPE_BEGIN_RANGE = VK_STRUCTURE_TYPE_APPLICATION_INFO,
VK_STRUCTURE_TYPE_END_RANGE = VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO, VK_STRUCTURE_TYPE_END_RANGE = VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO,
VK_STRUCTURE_TYPE_RANGE_SIZE = (VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO - VK_STRUCTURE_TYPE_APPLICATION_INFO + 1), VK_STRUCTURE_TYPE_RANGE_SIZE = (VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO - VK_STRUCTURE_TYPE_APPLICATION_INFO + 1),
@ -3828,6 +3829,28 @@ VKAPI_ATTR void VKAPI_CALL vkDebugReportMessageEXT(
#define VK_IMG_FILTER_CUBIC_EXTENSION_NAME "VK_IMG_filter_cubic" #define VK_IMG_FILTER_CUBIC_EXTENSION_NAME "VK_IMG_filter_cubic"
#define VK_AMD_rasterization_order 1
#define VK_AMD_RASTERIZATION_ORDER_SPEC_VERSION 1
#define VK_AMD_RASTERIZATION_ORDER_EXTENSION_NAME "VK_AMD_rasterization_order"
typedef enum VkRasterizationOrderAMD {
VK_RASTERIZATION_ORDER_STRICT_AMD = 0,
VK_RASTERIZATION_ORDER_RELAXED_AMD = 1,
VK_RASTERIZATION_ORDER_BEGIN_RANGE_AMD = VK_RASTERIZATION_ORDER_STRICT_AMD,
VK_RASTERIZATION_ORDER_END_RANGE_AMD = VK_RASTERIZATION_ORDER_RELAXED_AMD,
VK_RASTERIZATION_ORDER_RANGE_SIZE_AMD = (VK_RASTERIZATION_ORDER_RELAXED_AMD - VK_RASTERIZATION_ORDER_STRICT_AMD + 1),
VK_RASTERIZATION_ORDER_MAX_ENUM_AMD = 0x7FFFFFFF
} VkRasterizationOrderAMD;
typedef struct VkPipelineRasterizationStateRasterizationOrderAMD {
VkStructureType sType;
const void* pNext;
VkRasterizationOrderAMD rasterizationOrder;
} VkPipelineRasterizationStateRasterizationOrderAMD;
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif