nir: scalarize masked_swizzle_amd created from shuffle_xor
Reviewed-by: Rhys Perry <pendingchaos02@gmail.com>
Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/9901
Fixes: 0ef87f148d
("nir/lower_subgroups: Don't do multiple lowerings at once")
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/25468>
This commit is contained in:
@@ -842,6 +842,13 @@ lower_subgroups_instr(nir_builder *b, nir_instr *instr, void *_options)
|
|||||||
return lower_subgroup_op_to_32bit(b, intrin);
|
return lower_subgroup_op_to_32bit(b, intrin);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case nir_intrinsic_masked_swizzle_amd:
|
||||||
|
if (options->lower_to_scalar && intrin->num_components > 1) {
|
||||||
|
return lower_subgroup_op_to_scalar(b, intrin);
|
||||||
|
} else if (options->lower_shuffle_to_32bit && intrin->src[0].ssa->bit_size == 64) {
|
||||||
|
return lower_subgroup_op_to_32bit(b, intrin);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
Reference in New Issue
Block a user