ac/nir: Move ac_nir_lower_bit_size_callback to ac_nir.c
ac_shader_util should not concern itself with NIR stuff. Reviewed-by: Marek Olšák <marek.olsak@amd.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/32966>
This commit is contained in:
@@ -2275,3 +2275,71 @@ ac_nir_optimize_uniform_atomics(nir_shader *nir)
|
||||
|
||||
return progress;
|
||||
}
|
||||
|
||||
unsigned
|
||||
ac_nir_lower_bit_size_callback(const nir_instr *instr, void *data)
|
||||
{
|
||||
enum amd_gfx_level chip = *(enum amd_gfx_level *)data;
|
||||
|
||||
if (instr->type != nir_instr_type_alu)
|
||||
return 0;
|
||||
nir_alu_instr *alu = nir_instr_as_alu(instr);
|
||||
|
||||
/* If an instruction is not scalarized by this point,
|
||||
* it can be emitted as packed instruction */
|
||||
if (alu->def.num_components > 1)
|
||||
return 0;
|
||||
|
||||
if (alu->def.bit_size & (8 | 16)) {
|
||||
unsigned bit_size = alu->def.bit_size;
|
||||
switch (alu->op) {
|
||||
case nir_op_bitfield_select:
|
||||
case nir_op_imul_high:
|
||||
case nir_op_umul_high:
|
||||
case nir_op_uadd_carry:
|
||||
case nir_op_usub_borrow:
|
||||
return 32;
|
||||
case nir_op_iabs:
|
||||
case nir_op_imax:
|
||||
case nir_op_umax:
|
||||
case nir_op_imin:
|
||||
case nir_op_umin:
|
||||
case nir_op_ishr:
|
||||
case nir_op_ushr:
|
||||
case nir_op_ishl:
|
||||
case nir_op_isign:
|
||||
case nir_op_uadd_sat:
|
||||
case nir_op_usub_sat:
|
||||
return (bit_size == 8 || !(chip >= GFX8 && alu->def.divergent)) ? 32 : 0;
|
||||
case nir_op_iadd_sat:
|
||||
case nir_op_isub_sat:
|
||||
return bit_size == 8 || !alu->def.divergent ? 32 : 0;
|
||||
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
if (nir_src_bit_size(alu->src[0].src) & (8 | 16)) {
|
||||
unsigned bit_size = nir_src_bit_size(alu->src[0].src);
|
||||
switch (alu->op) {
|
||||
case nir_op_bit_count:
|
||||
case nir_op_find_lsb:
|
||||
case nir_op_ufind_msb:
|
||||
return 32;
|
||||
case nir_op_ilt:
|
||||
case nir_op_ige:
|
||||
case nir_op_ieq:
|
||||
case nir_op_ine:
|
||||
case nir_op_ult:
|
||||
case nir_op_uge:
|
||||
case nir_op_bitz:
|
||||
case nir_op_bitnz:
|
||||
return (bit_size == 8 || !(chip >= GFX8 && alu->def.divergent)) ? 32 : 0;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Reference in New Issue
Block a user