target/8087: sparc-sun-solaris2.7 C testsuite failures in execute/20020720-1.c w/-m64 or on sparcv9/sparc64
Richard Henderson
rth@redhat.com
Mon Oct 7 11:38:00 GMT 2002
On Mon, Oct 07, 2002 at 12:04:10PM -0600, Roger Sayle wrote:
> (mem/u/f:DF (lo_sum:DI (reg/f:DI 110)
> (symbol_ref/u:DI ("*.LLC0"))) [2 S8 A64]
>
> The problem is that the code in "avoid_constant_pool_reference"
> in simplify-rtx.c (line 149), assumes that constant pool references
> are of the form "(mem (symbol_ref ...))". Indeed the macro
> CONSTANT_POOL_ADDRESS_P assumes that it is always passed a naked
> symbol_ref.
*That* is a bug. The lo_sum is a perfectly respectable way
to do this.
> + if (GET_CODE (addr) == LO_SUM
> + && GET_CODE (XEXP (addr, 1)) == SYMBOL_REF)
> + addr = XEXP (addr, 1);
Yes, this is reasonable. You don't even need the SYMBOL_REF
check here, since that'll get handled ...
> if (GET_CODE (addr) != SYMBOL_REF
> || ! CONSTANT_POOL_ADDRESS_P (addr))
... here.
r~
More information about the Gcc-bugs
mailing list