Commit e62bb796 by Segher Boessenkool Committed by Segher Boessenkool

re PR rtl-optimization/66706 (Redundant bitmask instruction on x >> (n & 32))

	PR rtl-optimization/66706
	* combine.c (make_compound_operation): If an AND of SUBREG of
	LSHIFTRT does not simplify, see if just the AND of SUBREG does.

From-SVN: r225344
parent 54e37851
2015-07-02 Segher Boessenkool <segher@kernel.crashing.org>
PR rtl-optimization/66706
* combine.c (make_compound_operation): If an AND of SUBREG of
LSHIFTRT does not simplify, see if just the AND of SUBREG does.
2015-07-02 Alan Lawrence <alan.lawrence@arm.com>
* tree-pass.h (make_pass_ch_vect): New.
......
......@@ -7893,6 +7893,15 @@ make_compound_operation (rtx x, enum rtx_code in_code)
new_rtx = make_extraction (GET_MODE (SUBREG_REG (XEXP (x, 0))), new_rtx, 0,
XEXP (SUBREG_REG (XEXP (x, 0)), 1), i, 1,
0, in_code == COMPARE);
/* If that didn't give anything, see if the AND simplifies on
its own. */
if (!new_rtx && i >= 0)
{
new_rtx = make_compound_operation (XEXP (x, 0), next_code);
new_rtx = make_extraction (mode, new_rtx, 0, NULL_RTX, i, 1,
0, in_code == COMPARE);
}
}
/* Same as previous, but for (xor/ior (lshiftrt...) (lshiftrt...)). */
else if ((GET_CODE (XEXP (x, 0)) == XOR
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment