[Mesa-dev] [PATCH 2/2] anv/gen9: expose VK_EXT_post_depth_coverage
Jason Ekstrand
jason at jlekstrand.net
Fri Jul 20 23:57:10 UTC 2018
The CI system says no regressions
On Fri, Jul 20, 2018 at 3:48 PM Yunchao He <yunchao.he at intel.com> wrote:
> From: Ilia Mirkin <imirkin at alum.mit.edu>
>
> Note that the use of ICMS_INNER_CONSERVATIVE disagrees with the GL driver.
> Perhaps it's more performant than ICMS_NORMAL and is otherwise permitted?
> Not sure, so I left it as-is.
>
> Signed-off-by: Ilia Mirkin <imirkin at alum.mit.edu>
> ---
> src/intel/vulkan/anv_extensions.py | 1 +
> src/intel/vulkan/anv_pipeline.c | 1 +
> src/intel/vulkan/genX_pipeline.c | 10 ++++++++--
> 3 files changed, 10 insertions(+), 2 deletions(-)
>
> diff --git a/src/intel/vulkan/anv_extensions.py
> b/src/intel/vulkan/anv_extensions.py
> index adc1d75898..ea837744b4 100644
> --- a/src/intel/vulkan/anv_extensions.py
> +++ b/src/intel/vulkan/anv_extensions.py
> @@ -124,6 +124,7 @@ EXTENSIONS = [
> Extension('VK_EXT_shader_viewport_index_layer', 1, True),
> Extension('VK_EXT_shader_stencil_export', 1,
> 'device->info.gen >= 9'),
> Extension('VK_EXT_vertex_attribute_divisor', 2, True),
> + Extension('VK_EXT_post_depth_coverage', 1,
> 'device->info.gen >= 9'),
> ]
>
> class VkVersion:
> diff --git a/src/intel/vulkan/anv_pipeline.c
> b/src/intel/vulkan/anv_pipeline.c
> index 95a686f783..e91c146aad 100644
> --- a/src/intel/vulkan/anv_pipeline.c
> +++ b/src/intel/vulkan/anv_pipeline.c
> @@ -155,6 +155,7 @@ anv_shader_compile_to_nir(struct anv_pipeline
> *pipeline,
> .subgroup_vote = true,
> .stencil_export = device->instance->physicalDevice.info.gen >= 9,
> .storage_8bit = device->instance->physicalDevice.info.gen >= 8,
> + .post_depth_coverage = device->instance->physicalDevice.info.gen
> >= 9,
> },
> };
>
> diff --git a/src/intel/vulkan/genX_pipeline.c
> b/src/intel/vulkan/genX_pipeline.c
> index 0821d71c9f..6f6793e122 100644
> --- a/src/intel/vulkan/genX_pipeline.c
> +++ b/src/intel/vulkan/genX_pipeline.c
> @@ -1617,8 +1617,14 @@ emit_3dstate_ps_extra(struct anv_pipeline *pipeline,
> #if GEN_GEN >= 9
> ps.PixelShaderComputesStencil = wm_prog_data->computed_stencil;
> ps.PixelShaderPullsBary = wm_prog_data->pulls_bary;
> - ps.InputCoverageMaskState = wm_prog_data->uses_sample_mask ?
> - ICMS_INNER_CONSERVATIVE : ICMS_NONE;
> +
> + ps.InputCoverageMaskState = ICMS_NONE;
> + if (wm_prog_data->uses_sample_mask) {
> + if (wm_prog_data->post_depth_coverage)
> + ps.InputCoverageMaskState = ICMS_DEPTH_COVERAGE;
> + else
> + ps.InputCoverageMaskState = ICMS_INNER_CONSERVATIVE;
> + }
> #else
> ps.PixelShaderUsesInputCoverageMask =
> wm_prog_data->uses_sample_mask;
> #endif
> --
> 2.17.1
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/mesa-dev
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/mesa-dev/attachments/20180720/d2c24a8f/attachment.html>
More information about the mesa-dev
mailing list