Signed-off-by: Gert Wollny <gert.wollny@collabora.com>
Reviewed-by: Andreas Baierl <ichgeh@imkreisrum.de>
Reviewed-by: Eric Anholt <eric@anholt.net>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/6220>
* gl_FragCoord.xyz = gl_FragCoord_orig.xyz
* gl_FragCoord.w = 1.0 / gl_FragCoord_orig.w
*
- * To trigger the transformation, gl_FragCoord currently has to be treated
- * as a system value with PIPE_CAP_TGSI_FS_POSITION_IS_SYSVAL enabled.
*/
static bool
return false;
nir_intrinsic_instr *intr = nir_instr_as_intrinsic(instr);
- return intr->intrinsic == nir_intrinsic_load_frag_coord;
+ if (intr->intrinsic == nir_intrinsic_load_frag_coord)
+ return true;
+
+ if (intr->intrinsic != nir_intrinsic_load_deref)
+ return false;
+
+ nir_variable *var = nir_intrinsic_get_var(intr, 0);
+ return var->data.location == VARYING_SLOT_POS;
}
static nir_ssa_def *