From: Matt Turner Date: Sun, 26 Oct 2014 17:31:21 +0000 (-0700) Subject: i965/vec4: Perform CSE on MAD instructions with final arguments switched. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=601a134180f4b0c5b02f6866dddc3ab220feb831;p=mesa.git i965/vec4: Perform CSE on MAD instructions with final arguments switched. Reviewed-by: Kenneth Graunke --- diff --git a/src/mesa/drivers/dri/i965/brw_vec4_cse.cpp b/src/mesa/drivers/dri/i965/brw_vec4_cse.cpp index 28c69ca69d1..630d3357a3f 100644 --- a/src/mesa/drivers/dri/i965/brw_vec4_cse.cpp +++ b/src/mesa/drivers/dri/i965/brw_vec4_cse.cpp @@ -104,7 +104,11 @@ is_expression_commutative(enum opcode op) static bool operands_match(enum opcode op, src_reg *xs, src_reg *ys) { - if (!is_expression_commutative(op)) { + if (op == BRW_OPCODE_MAD) { + return xs[0].equals(ys[0]) && + ((xs[1].equals(ys[1]) && xs[2].equals(ys[2])) || + (xs[2].equals(ys[1]) && xs[1].equals(ys[2]))); + } else if (!is_expression_commutative(op)) { return xs[0].equals(ys[0]) && xs[1].equals(ys[1]) && xs[2].equals(ys[2]); } else { return (xs[0].equals(ys[0]) && xs[1].equals(ys[1])) ||