[Mesa-dev] [PATCH] ir_to_mesa: Skip useless comparison instructions.

Ian Romanick idr at freedesktop.org
Wed Dec 16 17:24:28 PST 2015


This looks right.  I haven't tested it on i915, but the CI will soon enough.

Reviewed-by: Ian Romanick <ian.d.romanick at intel.com>

On 12/07/2015 10:50 AM, Matt Turner wrote:
> ---
> With this, we generate the same number of Mesa IR instructions before
> and after my series. all() is the same as well.
> 
>  src/mesa/program/ir_to_mesa.cpp | 8 +++++++-
>  1 file changed, 7 insertions(+), 1 deletion(-)
> 
> diff --git a/src/mesa/program/ir_to_mesa.cpp b/src/mesa/program/ir_to_mesa.cpp
> index 8160f8e..852655d 100644
> --- a/src/mesa/program/ir_to_mesa.cpp
> +++ b/src/mesa/program/ir_to_mesa.cpp
> @@ -1113,7 +1113,13 @@ ir_to_mesa_visitor::visit(ir_expression *ir)
>        if (ir->operands[0]->type->is_vector() ||
>  	  ir->operands[1]->type->is_vector()) {
>  	 src_reg temp = get_temp(glsl_type::vec4_type);
> -	 emit(ir, OPCODE_SNE, dst_reg(temp), op[0], op[1]);
> +         if (ir->operands[0]->type->is_boolean() &&
> +             ir->operands[1]->as_constant() &&
> +             ir->operands[1]->as_constant()->is_zero()) {
> +            temp = op[0];
> +         } else {
> +            emit(ir, OPCODE_SNE, dst_reg(temp), op[0], op[1]);
> +         }
>  
>  	 /* After the dot-product, the value will be an integer on the
>  	  * range [0,4].  Zero stays zero, and positive values become 1.0.
> 



More information about the mesa-dev mailing list