From: Iago Toral Quiroga Date: Wed, 22 Jul 2020 06:15:10 +0000 (+0200) Subject: v3d/compiler: request fragment shader clip lowering to be vulkan compatible. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d1677c8f8cdb11cf55db81a511b8bf8802fa2c19;p=mesa.git v3d/compiler: request fragment shader clip lowering to be vulkan compatible. Vulkan allows fragment shaders to read gl_ClipDistance[], in which case the SPIR-V compiler will inject a compact array variable at VARYING_SLOT_CLIP_DIST0. Request the lowering to always work in terms of a compact array variable so we don't have to care about the API in use. Reviewed-by: Alejandro PiƱeiro Part-of: --- diff --git a/src/broadcom/compiler/vir.c b/src/broadcom/compiler/vir.c index 940d3402ec7..749a38f6028 100644 --- a/src/broadcom/compiler/vir.c +++ b/src/broadcom/compiler/vir.c @@ -954,9 +954,15 @@ v3d_nir_lower_fs_late(struct v3d_compile *c) false, NULL); } + /* In OpenGL the fragment shader can't read gl_ClipDistance[], but + * Vulkan allows it, in which case the SPIR-V compiler will declare + * VARING_SLOT_CLIP_DIST0 as compact array variable. Pass true as + * the last parameter to always operate with a compact array in both + * OpenGL and Vulkan so we do't have to care about the API we + * are using. + */ if (c->key->ucp_enables) - NIR_PASS_V(c->s, nir_lower_clip_fs, c->key->ucp_enables, - false); + NIR_PASS_V(c->s, nir_lower_clip_fs, c->key->ucp_enables, true); /* Note: FS input scalarizing must happen after * nir_lower_two_sided_color, which only handles a vec4 at a time.