ac/nir: use nir_is_shared_access

Signed-off-by: Alyssa Rosenzweig <alyssa.rosenzweig@intel.com>
Reviewed-by: Timur Kristóf <timur.kristof@gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/39219>
This commit is contained in:
Alyssa Rosenzweig 2026-01-08 14:49:58 -05:00 committed by Marge Bot
parent 00e705add1
commit 235e868ef7

View file

@ -917,18 +917,9 @@ ac_nir_lower_phis_to_scalar_cb(const nir_instr *instr, const void *_)
bool
ac_nir_allow_offset_wrap_cb(nir_intrinsic_instr *instr, const void *data)
{
/* GFX6 uses a 16-bit adder and can't handle unsigned wrap. */
enum amd_gfx_level gfx_level = *(enum amd_gfx_level *)data;
switch (instr->intrinsic) {
case nir_intrinsic_load_shared:
case nir_intrinsic_store_shared:
case nir_intrinsic_shared_atomic:
case nir_intrinsic_shared_atomic_swap:
case nir_intrinsic_load_shared2_amd:
case nir_intrinsic_store_shared2_amd:
/* GFX6 uses a 16-bit adder and can't handle unsigned wrap. */
return gfx_level >= GFX7;
default: return false;
}
return nir_is_shared_access(instr) && gfx_level >= GFX7;
}
/* This only applies to ACO, not LLVM, but it's not part of ACO because it's used by this shared