1// Copyright 2017-2023 The Khronos Group Inc. 2// 3// SPDX-License-Identifier: CC-BY-4.0 4 5include::{generated}/meta/{refprefix}VK_EXT_conservative_rasterization.adoc[] 6 7=== Other Extension Metadata 8 9*Last Modified Date*:: 10 2020-06-09 11*Interactions and External Dependencies*:: 12 - This extension requires 13 {spirv}/EXT/SPV_EXT_fragment_fully_covered.html[`SPV_EXT_fragment_fully_covered`] 14 if the 15 sname:VkPhysicalDeviceConservativeRasterizationPropertiesEXT::pname:fullyCoveredFragmentShaderInputVariable 16 feature is used. 17 - This extension requires 18 {spirv}/KHR/SPV_KHR_post_depth_coverage.html[`SPV_KHR_post_depth_coverage`]if 19 the 20 sname:VkPhysicalDeviceConservativeRasterizationPropertiesEXT::pname:conservativeRasterizationPostDepthCoverage 21 feature is used. 22 - This extension provides API support for 23 {GLregistry}/NV/NV_conservative_raster_underestimation.txt[`GL_NV_conservative_raster_underestimation`] 24 if the 25 sname:VkPhysicalDeviceConservativeRasterizationPropertiesEXT::pname:fullyCoveredFragmentShaderInputVariable 26 feature is used. 27*Contributors*:: 28 - Daniel Koch, NVIDIA 29 - Daniel Rakos, AMD 30 - Jeff Bolz, NVIDIA 31 - Slawomir Grajewski, Intel 32 - Stu Smith, Imagination Technologies 33 34=== Description 35 36This extension adds a new rasterization mode called conservative 37rasterization. 38There are two modes of conservative rasterization; overestimation and 39underestimation. 40 41When overestimation is enabled, if any part of the primitive, including its 42edges, covers any part of the rectangular pixel area, including its sides, 43then a fragment is generated with all coverage samples turned on. 44This extension allows for some variation in implementations by accounting 45for differences in overestimation, where the generating primitive size is 46increased at each of its edges by some sub-pixel amount to further increase 47conservative pixel coverage. 48Implementations can allow the application to specify an extra overestimation 49beyond the base overestimation the implementation already does. 50It also allows implementations to either cull degenerate primitives or 51rasterize them. 52 53When underestimation is enabled, fragments are only generated if the 54rectangular pixel area is fully covered by the generating primitive. 55If supported by the implementation, when a pixel rectangle is fully covered 56the fragment shader input variable builtin called FullyCoveredEXT is set to 57true. 58The shader variable works in either overestimation or underestimation mode. 59 60Implementations can process degenerate triangles and lines by either 61discarding them or generating conservative fragments for them. 62Degenerate triangles are those that end up with zero area after the 63rasterizer quantizes them to the fixed-point pixel grid. 64Degenerate lines are those with zero length after quantization. 65 66include::{generated}/interfaces/VK_EXT_conservative_rasterization.adoc[] 67 68=== New Built-In Variables 69 70 * <<interfaces-builtin-variables-fullycoveredext,FullyCoveredEXT>> 71 72=== New SPIR-V Capabilities 73 74 * <<spirvenv-capabilities-table-FragmentFullyCoveredEXT, 75 FragmentFullyCoveredEXT>> 76 77=== Version History 78 79 * Revision 1.1, 2020-09-06 (Piers Daniell) 80 ** Add missing SPIR-V and GLSL dependencies. 81 82 * Revision 1, 2017-08-28 (Piers Daniell) 83 ** Internal revisions 84