Commit 56038245 by Steven Bosscher Committed by Steven Bosscher

patch for PR rtl-optimization/25130

gcc/
        * postreload-gcse.c (record_last_set_info): Notice stack pointer
        changes in push insns without REG_INC notes.

testsuite/
        * gcc.dg/pr25130.c: New test.

From-SVN: r108906
parent 46833406
2005-12-21 Steven Bosscher <stevenb@suse.de>
PR rtl-optimization/25130
* postreload-gcse.c (record_last_set_info): Notice stack pointer
changes in push insns without REG_INC notes.
2005-12-21 Kazu Hirata <kazu@codesourcery.com> 2005-12-21 Kazu Hirata <kazu@codesourcery.com>
PR tree-optimization/25382. PR tree-optimization/25382.
......
...@@ -671,10 +671,18 @@ record_last_set_info (rtx dest, rtx setter ATTRIBUTE_UNUSED, void *data) ...@@ -671,10 +671,18 @@ record_last_set_info (rtx dest, rtx setter ATTRIBUTE_UNUSED, void *data)
if (REG_P (dest)) if (REG_P (dest))
record_last_reg_set_info (last_set_insn, REGNO (dest)); record_last_reg_set_info (last_set_insn, REGNO (dest));
else if (MEM_P (dest) else if (MEM_P (dest))
/* Ignore pushes, they clobber nothing. */ {
&& ! push_operand (dest, GET_MODE (dest))) /* Ignore pushes, they don't clobber memory. They may still
record_last_mem_set_info (last_set_insn); clobber the stack pointer though. Some targets do argument
pushes without adding REG_INC notes. See e.g. PR25196,
where a pushsi2 on i386 doesn't have REG_INC notes. Note
such changes here too. */
if (! push_operand (dest, GET_MODE (dest)))
record_last_mem_set_info (last_set_insn);
else
record_last_reg_set_info (last_set_insn, STACK_POINTER_REGNUM);
}
} }
......
2005-12-21 Steven Bosscher <stevenb@suse.de>
PR rtl-optimization/25130
* gcc.dg/pr25130.c: New test.
2005-12-21 Erik Edelmann <eedelman@gcc.gnu.org> 2005-12-21 Erik Edelmann <eedelman@gcc.gnu.org>
PR fortran/25423 PR fortran/25423
/* { dg-do run { target i?86-*-* x86_64-*-* } } */
/* { dg-require-effective-target ilp32 } */
/* { dg-options "-march=i386 -O3 -fomit-frame-pointer" } */
/* For this test case, we used to do an invalid load motion after
reload, because we missed autoincrements of the stack pointer. */
extern void abort (void);
static int j;
static void __attribute__((noinline))
f1 (int a, int b, int c, int d, int e)
{
j = a;
}
int __attribute__((noinline))
f2 (int a, int b, int c, int d, int e)
{
if ((b & 0x1111) != 1)
f1 (a, b, c, d, e);
return 0;
}
int
main (void)
{
f2 (123, 0, 0, 0, 0);
if (j != 123)
abort ();
return 0;
}
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