Commit 5df81313 by Jakub Jelinek Committed by Jakub Jelinek

re PR rtl-optimization/56195 (Error: incorrect register `%rdi' used with `l' suffix (at -O2))

	PR rtl-optimization/56195
	* lra-constraints.c (get_reload_reg): Don't reuse regs
	if they have smaller mode than requested, if they have
	wider mode than requested, try to return a SUBREG.

	* gcc.dg/torture/pr56195.c: New test.

From-SVN: r195891
parent 3434c119
2013-02-08 Jakub Jelinek <jakub@redhat.com>
PR rtl-optimization/56195
* lra-constraints.c (get_reload_reg): Don't reuse regs
if they have smaller mode than requested, if they have
wider mode than requested, try to return a SUBREG.
PR tree-optimization/56250
* fold-const.c (extract_muldiv_1) <case NEGATE_EXPR>: Don't optimize
if type is unsigned and code isn't MULT_EXPR.
......
......@@ -421,8 +421,20 @@ get_reload_reg (enum op_type type, enum machine_mode mode, rtx original,
if (rtx_equal_p (curr_insn_input_reloads[i].input, original)
&& in_class_p (curr_insn_input_reloads[i].reg, rclass, &new_class))
{
*result_reg = curr_insn_input_reloads[i].reg;
regno = REGNO (*result_reg);
rtx reg = curr_insn_input_reloads[i].reg;
regno = REGNO (reg);
/* If input is equal to original and both are VOIDmode,
GET_MODE (reg) might be still different from mode.
Ensure we don't return *result_reg with wrong mode. */
if (GET_MODE (reg) != mode)
{
if (GET_MODE_SIZE (GET_MODE (reg)) < GET_MODE_SIZE (mode))
continue;
reg = lowpart_subreg (mode, reg, GET_MODE (reg));
if (reg == NULL_RTX || GET_CODE (reg) != SUBREG)
continue;
}
*result_reg = reg;
if (lra_dump_file != NULL)
{
fprintf (lra_dump_file, " Reuse r%d for reload ", regno);
......
2013-02-08 Jakub Jelinek <jakub@redhat.com>
PR rtl-optimization/56195
* gcc.dg/torture/pr56195.c: New test.
2013-02-08 Mikael Morin <mikael@gcc.gnu.org>
PR fortran/54107
......
/* PR rtl-optimization/56195 */
/* { dg-do assemble } */
int i, a, t, b, c, d, e, f, j, *h;
void
fn (void)
{
if (b)
{
int *p, *q;
char g;
if (f++)
for (;; e++);
lbl:
for (b = 0; b < 2; b++)
t /= d + 1 ? : i || a < c < (d = f) ? : 1 | (j = 2);
*p = g >= *q ^ c != a ^ *p;
if (!e)
{
q = p;
goto lbl;
}
}
if (h++)
goto lbl;
}
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