Commit b3519e7c by H.J. Lu

re PR target/30961 (redundant reg/mem stores/moves)

gcc/

2007-11-06  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>

	PR target/30961
	* reload1.c (find_reloads): Also check in_reg when handling a
	simple move with an input reload and a destination of a hard
	register.

gcc/testsuite/

2007-11-06  H.J. Lu  <hongjiu.lu@intel.com>

	PR target/30961
	* gcc.target/i386/pr30961-1.c: New.

From-SVN: r129943
parent b8c96320
2007-11-06 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
PR target/30961
* reload1.c (find_reloads): Also check in_reg when handling a
simple move with an input reload and a destination of a hard
register.
2007-11-06 Maxim Kuvyrkov <maxim@codesourcery.com> 2007-11-06 Maxim Kuvyrkov <maxim@codesourcery.com>
* config/m68k/m68k.c (sched-int.h, insn-codes.h): New includes. * config/m68k/m68k.c (sched-int.h, insn-codes.h): New includes.
...@@ -4462,7 +4462,8 @@ find_reloads (rtx insn, int replace, int ind_levels, int live_known, ...@@ -4462,7 +4462,8 @@ find_reloads (rtx insn, int replace, int ind_levels, int live_known,
if (rld[i].when_needed == RELOAD_FOR_INPUT if (rld[i].when_needed == RELOAD_FOR_INPUT
&& GET_CODE (PATTERN (insn)) == SET && GET_CODE (PATTERN (insn)) == SET
&& REG_P (SET_DEST (PATTERN (insn))) && REG_P (SET_DEST (PATTERN (insn)))
&& SET_SRC (PATTERN (insn)) == rld[i].in && (SET_SRC (PATTERN (insn)) == rld[i].in
|| SET_SRC (PATTERN (insn)) == rld[i].in_reg)
&& !elimination_target_reg_p (SET_DEST (PATTERN (insn)))) && !elimination_target_reg_p (SET_DEST (PATTERN (insn))))
{ {
rtx dest = SET_DEST (PATTERN (insn)); rtx dest = SET_DEST (PATTERN (insn));
......
2007-11-06 H.J. Lu <hongjiu.lu@intel.com>
PR target/30961
* gcc.target/i386/pr30961-1.c: New.
2007-11-06 Tom Tromey <tromey@redhat.com> 2007-11-06 Tom Tromey <tromey@redhat.com>
PR c++/32368: PR c++/32368:
/* { dg-do compile } */
/* { dg-require-effective-target lp64 } */
/* { dg-options "-O2" } */
double
convert (long long in)
{
double f;
__builtin_memcpy( &f, &in, sizeof( in ) );
return f;
}
/* { dg-final { scan-assembler-not "movapd" } } */
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