Hash :
2682b5a0
        
        Author :
  
        
        Date :
2019-10-07T15:13:23
        
      
Documentation maintenance. Fixes links in the Vulkan back-end doc. Also includes a link to the Vulkan back-end docs on the main page. Also updates the building code section to mention VS2019 and make the win toolchain varable set more prominent. Bug: angleproject:1944 Change-Id: I8e8f0775daa3643afaa1ddd44429fa7d8e77b19b Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/1846014 Reviewed-by: Jamie Madill <jmadill@chromium.org>
The required Vulkan format support tables do not implement the full set of formats needed for OpenGL conformance with extensions. ANGLE emulates missing formats using format overrides and format fallbacks.
An override implements a missing GL format with a required format in all cases. For example, the
luminance texture format L8_UNORM does not exist in Vulkan. We override L8_UNORM with the
required image format R8_UNORM.
A fallback is one or more non-required formats ANGLE checks for support at runtime. For example,
R8_UNORM is not a required vertex buffer format. Some drivers do support R8_UNORM for vertex
buffers. So at runtime we check for sampled image support and fall back to R32_FLOAT if R8_UNORM
is not supported.
Overrides and fallbacks are implemented in ANGLE’s [Vulkan format
table][../vk_format_table_autogen.cpp]. The table is auto-generated by
gen_vk_format_table.py. We store the mapping from
angle::Format::ID to VkFormat in
vk_format_map.json. The format map also lists the overrides and fallbacks.
To update the tables please modify the format map JSON and then run
scripts/run_code_generation.py.
The vk::Format class describes the information ANGLE needs for a particular
VkFormat. The ‘ANGLE’ format ID is a reference to the front-end format. The ‘Image’ or ‘Buffer’
format are the native Vulkan formats that implement a particular front-end format for VkImages and
VkBuffers. For the above example of R8_UNORM overriding L8_UNORM, L8_UNORM is the ANGLE
format and R8_UNORM is the Image format.
For more information please see the source files.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
# Format Tables and Format Emulation
## Overrides and Fallbacks
The [required Vulkan format support][VulkanRequiredSupport] tables do not implement the full set of
formats needed for OpenGL conformance with extensions. ANGLE emulates missing formats using *format
overrides* and *format fallbacks*.
An *override* implements a missing GL format with a required format in all cases. For example, the
luminance texture format `L8_UNORM` does not exist in Vulkan. We override `L8_UNORM` with the
required image format `R8_UNORM`.
A *fallback* is one or more non-required formats ANGLE checks for support at runtime. For example,
`R8_UNORM` is not a required vertex buffer format. Some drivers do support `R8_UNORM` for vertex
buffers. So at runtime we check for sampled image support and fall back to `R32_FLOAT` if `R8_UNORM`
is not supported.
## The Vulkan Format Table
Overrides and fallbacks are implemented in ANGLE's [Vulkan format
table][../vk_format_table_autogen.cpp]. The table is auto-generated by
[`gen_vk_format_table.py`](../gen_vk_format_table.py). We store the mapping from
[`angle::Format::ID`](../../FormatID_autogen.h) to [VkFormat][VkFormat] in
[`vk_format_map.json`](../vk_format_map.json). The format map also lists the overrides and fallbacks.
To update the tables please modify the format map JSON and then run
[`scripts/run_code_generation.py`][RunCodeGeneration].
The [`vk::Format`](../vk_format_utils.h) class describes the information ANGLE needs for a particular
`VkFormat`. The 'ANGLE' format ID is a reference to the front-end format. The 'Image' or 'Buffer'
format are the native Vulkan formats that implement a particular front-end format for `VkImages` and
`VkBuffers`. For the above example of `R8_UNORM` overriding `L8_UNORM`, `L8_UNORM` is the ANGLE
format and `R8_UNORM` is the Image format.
For more information please see the source files.
[VulkanRequiredSupport]: https://renderdoc.org/vkspec_chunked/chap37.html#features-required-format-support
[VkFormat]: https://renderdoc.org/vkspec_chunked/chap37.html#VkFormat
[RunCodeGeneration]: ../../../../scripts/run_code_generation.py