mirror of
https://github.com/status-im/Vulkan-Docs.git
synced 2025-02-14 23:37:21 +00:00
* Bump API patch number and header version number to 61 for this update. Github Issues: * Provide alternate length attributes (altlen=) in the XML schema, for those using length attributes to generate code instead of documentation (public issue 555). * Fix erroneous references to `latex:` being used for asciidoc math markup, rather than `latexmath:` (public pull request 556). * Add author ID to XML for Kazan software renderer (public pull request 557). Internal Issues: * Add the <<fundamentals-abi,Application Binary Interface>> section describing platform ABI requirements and recommendations, add examples of function and function pointer declarations to the <<boilerplate-platform-specific-calling-conventions, Platform-Specific Calling Conventions>> section, and remove related language that existed elsewhere in the specification (internal issue 64). * Describe where to document valid usage interactions of chained structures in the style guide, and fix one case now appearing in slink:VkBufferCreateInfo instead of the child slink:VkDedicatedAllocationBufferCreateInfoNV structure (internal issue 715). * Add example to the style guide of describing enumerated types which are empty when the spec is built without relevant extensions enabled, and apply it to existing examples for elink:VkDescriptorSetLayoutCreateFlagBits and elink:VkSubpassDescriptionFlagBits (internal issue 864). * Add a note to the <<fundamentals-validusage-enums, Valid Usage for Enumerated Types>> section that the special values suffixed with etext:_BEGIN_RANGE, etext:_END_RANGE, etext:_RANGE_SIZE and etext:_MAX_ENUM are not part of the API and should: not be used by applications (internal issue 872). * Added note to flink:vkCmdUpdateBuffers explaining the performance penalty for copies done in this way, and why the upper copy limit is what it is (internal issue 952). * Update `VK_KHX_device_group` to split some functionality into the new `VK_KHR_bind_memory2` extension, and rename that functionality (internal issue 969). * Remove *Status* fields from extension appendices, since they are by definition published and complete by the time they reach the public github repository (internal issue 973). Other Issues: * Update Data Format specification dependency to version 1.2 and change references to DF sections accordingly. * Update XML to make the pname:pAllocator parameter of flink:vkRegisterDeviceEventEXT and flink:vkRegisterDisplayEventEXT in the `VK_EXT_display_control` extension as optional. New Extensions: * `VK_KHR_bind_memory2` * `VK_KHR_image_format_list` * `VK_KHR_maintenance2` * `VK_KHR_sampler_ycbcr_conversion`
103 lines
3.0 KiB
Plaintext
103 lines
3.0 KiB
Plaintext
// Copyright (c) 2016-2017 Khronos Group. This work is licensed under a
|
|
// Creative Commons Attribution 4.0 International License; see
|
|
// http://creativecommons.org/licenses/by/4.0/
|
|
|
|
include::meta/VK_KHR_shader_draw_parameters.txt[]
|
|
|
|
*Last Modified Date*::
|
|
2016-10-05
|
|
*IP Status*::
|
|
No known IP claims.
|
|
*Interactions and External Dependencies*::
|
|
- Requires the
|
|
https://www.khronos.org/registry/spir-v/extensions/KHR/SPV_KHR_shader_draw_parameters.html[+SPV_KHR_shader_draw_parameters+]
|
|
SPIR-V extension.
|
|
- Requires
|
|
https://www.khronos.org/registry/OpenGL/extensions/ARB/ARB_shader_draw_parameters.txt[+GL_ARB_shader_draw_parameters+]
|
|
for GLSL source languages.
|
|
*Contributors*::
|
|
- Daniel Koch, NVIDIA Corporation
|
|
- Jeff Bolz, NVIDIA
|
|
- Daniel Rakos, AMD
|
|
- Jan-Harald Fredriksen, ARM
|
|
- John Kessenich, Google
|
|
- Stuart Smith, IMG
|
|
|
|
This extension adds support for the following SPIR-V extension in Vulkan:
|
|
|
|
* +SPV_KHR_shader_draw_parameters+
|
|
|
|
The extension provides access to three additional built-in shader variables
|
|
in Vulkan:
|
|
|
|
* code:BaseInstance, which contains the firstInstance parameter passed to
|
|
draw commands,
|
|
* code:BaseVertex, which contains the firstVertex/vertexOffset parameter
|
|
passed to draw commands, and
|
|
* code:DrawIndex, which contains the index of the draw call currently
|
|
being processed from an indirect draw call.
|
|
|
|
When using GLSL source-based shader languages, the following variables from
|
|
+GL_ARB_shader_draw_parameters+ can map to these SPIR-V built-in
|
|
decorations:
|
|
|
|
* in int gl_BaseInstanceARB; -> code:BaseInstance,
|
|
* in int gl_BaseVertexARB -> code:BaseVertex, and
|
|
* in int gl_DrawIDARB; -> code:DrawIndex.
|
|
|
|
=== New Object Types
|
|
|
|
None.
|
|
|
|
=== New Enum Constants
|
|
|
|
None.
|
|
|
|
=== New Enums
|
|
|
|
None.
|
|
|
|
=== New Structures
|
|
|
|
None.
|
|
|
|
=== New Functions
|
|
|
|
None.
|
|
|
|
=== New Built-In Variables
|
|
|
|
* <<interfaces-builtin-variables-baseinstance,code:BaseInstance>>
|
|
* <<interfaces-builtin-variables-basevertex,code:BaseVertex>>
|
|
* <<interfaces-builtin-variables-drawindex,code:DrawIndex>>
|
|
|
|
=== New SPIR-V Capabilities
|
|
|
|
* <<spirvenv-capabilities-table-drawparameters,DrawParameters>>
|
|
|
|
=== Issues
|
|
|
|
1) Is this the same functionality as +GL_ARB_shader_draw_parameters+?
|
|
|
|
*RESOLVED*: It's actually a superset as it also adds in support for arrayed
|
|
drawing commands.
|
|
|
|
In GL for +GL_ARB_shader_draw_parameters+, code:gl_BaseVertexARB holds the
|
|
integer value passed to the parameter to the command that resulted in the
|
|
current shader invocation.
|
|
In the case where the command has no baseVertex parameter, the value of
|
|
code:gl_BaseVertexARB is zero.
|
|
This means that code:gl_BaseVertexARB = baseVertex (for code:glDrawElements
|
|
commands with baseVertex) or 0.
|
|
In particular there are no code:glDrawArrays commands that take a baseVertex
|
|
parameter.
|
|
|
|
Now in Vulkan, we have *BaseVertex* = _vertexOffset_ (for indexed drawing
|
|
commands) or _firstVertex_ (for arrayed drawing commands), and so Vulkan's
|
|
version is really a superset of GL functionality.
|
|
|
|
=== Version History
|
|
|
|
* Revision 1, 2016-10-05 (Daniel Koch)
|
|
- Internal revisions
|