Did this patch help anything? On 03/18/2015 11:37 AM, Matt Turner wrote: > Transform this into b2f(or(a, b)). > --- > src/glsl/opt_algebraic.cpp | 12 ++++++++++++ > 1 file changed, 12 insertions(+) > > diff --git a/src/glsl/opt_algebraic.cpp b/src/glsl/opt_algebraic.cpp > index 0d1f3fc..98c852a 100644 > --- a/src/glsl/opt_algebraic.cpp > +++ b/src/glsl/opt_algebraic.cpp > @@ -421,6 +421,18 @@ ir_algebraic_visitor::handle_expression(ir_expression > *ir) > break; > } > > + case ir_unop_saturate: > + if (op_expr[0] && op_expr[0]->operation == ir_binop_add) { > + ir_expression *b2f_0 = op_expr[0]->operands[0]->as_expression(); > + ir_expression *b2f_1 = op_expr[0]->operands[1]->as_expression(); > + > + if (b2f_0 && b2f_0->operation == ir_unop_b2f && > + b2f_1 && b2f_1->operation == ir_unop_b2f) { > + return b2f(logic_or(b2f_0->operands[0], b2f_1->operands[0])); > + } > + } > + break; > + > case ir_binop_add: > if (is_vec_zero(op_const[0])) > return ir->operands[1]; >
_______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/mesa-dev