On 26/04/16 06:39, Jason Ekstrand wrote: > --- > src/compiler/nir/nir_opt_algebraic.py | 5 ++++- > src/compiler/nir/nir_search.c | 14 ++++++++++++++ > 2 files changed, 18 insertions(+), 1 deletion(-) > > diff --git a/src/compiler/nir/nir_opt_algebraic.py > b/src/compiler/nir/nir_opt_algebraic.py > index fa7d7c7..fc439f0 100644 > --- a/src/compiler/nir/nir_opt_algebraic.py > +++ b/src/compiler/nir/nir_opt_algebraic.py > @@ -56,7 +56,10 @@ d = 'd' > # > # All expression types can have a bit-size specified. For opcodes, this > # looks like "op@32", for variables it is "a@32" or "a@uint32" to specify a > -# type and size, and for literals, you can write "2.0@32". > +# type and size, and for literals, you can write "2.0@32". In the search > half > +# of the expression this indicates that it should only match that particular > +# bit-size. In the replace half of the expression this indicates that the > +# constructed value should have that bit-size. > > optimizations = [ > (('fneg', ('fneg', a)), a), > diff --git a/src/compiler/nir/nir_search.c b/src/compiler/nir/nir_search.c > index dc53a90..af1da34 100644 > --- a/src/compiler/nir/nir_search.c > +++ b/src/compiler/nir/nir_search.c > @@ -88,6 +88,11 @@ match_value(const nir_search_value *value, nir_alu_instr > *instr, unsigned src, > for (unsigned i = 0; i < num_components; ++i) > new_swizzle[i] = instr->src[src].swizzle[swizzle[i]]; > > + /* If the value has a spefic bit size and it doesn't match, bail */
specific Other than that, Reviewed-by: Samuel Iglesias Gonsálvez <sigles...@igalia.com> Sam > + if (value->bit_size && > + nir_src_bit_size(instr->src[src].src) != value->bit_size) > + return false; > + > switch (value->type) { > case nir_search_value_expression: > if (!instr->src[src].src.is_ssa) > @@ -243,6 +248,10 @@ match_expression(const nir_search_expression *expr, > nir_alu_instr *instr, > > assert(instr->dest.dest.is_ssa); > > + if (expr->value.bit_size && > + instr->dest.dest.ssa.bit_size != expr->value.bit_size) > + return false; > + > state->inexact_match = expr->inexact || state->inexact_match; > state->has_exact_alu = instr->exact || state->has_exact_alu; > if (state->inexact_match && state->has_exact_alu) > @@ -353,6 +362,11 @@ build_bitsize_tree(void *mem_ctx, struct match_state > *state, > } > } > > + if (value->bit_size) { > + assert(!tree->is_dest_sized || tree->dest_size == value->bit_size); > + tree->common_size = value->bit_size; > + } > + > return tree; > } > > _______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/mesa-dev