intel/fs: teach ubo range analysis pass about resource_intel
Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com> Reviewed-by: Kenneth Graunke <kenneth@whitecape.org> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/21645>
This commit is contained in:

committed by
Marge Bot

parent
12540dfb6b
commit
86e9943b00
@@ -103,6 +103,64 @@ struct brw_nir_compiler_opts {
|
||||
unsigned input_vertices;
|
||||
};
|
||||
|
||||
/* UBO surface index can come in 2 flavors :
|
||||
* - nir_intrinsic_resource_intel
|
||||
* - anything else
|
||||
*
|
||||
* In the first case, checking that the surface index is const requires
|
||||
* checking resource_intel::src[1]. In any other case it's a simple
|
||||
* nir_src_is_const().
|
||||
*
|
||||
* This function should only be called on src[0] of load_ubo intrinsics.
|
||||
*/
|
||||
static inline bool
|
||||
brw_nir_ubo_surface_index_is_pushable(nir_src src)
|
||||
{
|
||||
nir_intrinsic_instr *intrin = src.is_ssa &&
|
||||
src.ssa->parent_instr->type == nir_instr_type_intrinsic ?
|
||||
nir_instr_as_intrinsic(src.ssa->parent_instr) : NULL;
|
||||
|
||||
if (intrin && intrin->intrinsic == nir_intrinsic_resource_intel) {
|
||||
return (nir_intrinsic_resource_access_intel(intrin) &
|
||||
nir_resource_intel_pushable) &&
|
||||
nir_src_is_const(intrin->src[1]);
|
||||
}
|
||||
|
||||
return nir_src_is_const(src);
|
||||
}
|
||||
|
||||
static inline unsigned
|
||||
brw_nir_ubo_surface_index_get_push_block(nir_src src)
|
||||
{
|
||||
if (nir_src_is_const(src))
|
||||
return nir_src_as_uint(src);
|
||||
|
||||
if (!brw_nir_ubo_surface_index_is_pushable(src))
|
||||
return UINT32_MAX;
|
||||
|
||||
assert(src.ssa->parent_instr->type == nir_instr_type_intrinsic);
|
||||
|
||||
nir_intrinsic_instr *intrin = nir_instr_as_intrinsic(src.ssa->parent_instr);
|
||||
assert(intrin->intrinsic == nir_intrinsic_resource_intel);
|
||||
|
||||
return nir_intrinsic_resource_block_intel(intrin);
|
||||
}
|
||||
|
||||
static inline unsigned
|
||||
brw_nir_ubo_surface_index_get_bti(nir_src src)
|
||||
{
|
||||
if (nir_src_is_const(src))
|
||||
return nir_src_as_uint(src);
|
||||
|
||||
assert(src.ssa->parent_instr->type == nir_instr_type_intrinsic);
|
||||
|
||||
nir_intrinsic_instr *intrin = nir_instr_as_intrinsic(src.ssa->parent_instr);
|
||||
assert(intrin->intrinsic == nir_intrinsic_resource_intel);
|
||||
assert(nir_src_is_const(intrin->src[1]));
|
||||
|
||||
return nir_src_as_uint(intrin->src[1]);
|
||||
}
|
||||
|
||||
void brw_preprocess_nir(const struct brw_compiler *compiler,
|
||||
nir_shader *nir,
|
||||
const struct brw_nir_compiler_opts *opts);
|
||||
|
Reference in New Issue
Block a user