From: Andreas Krebbel Date: Fri, 18 Mar 2011 17:32:29 +0000 (+0000) Subject: s390.c (s390_delegitimize_address): Handle GOTOFF unspecs. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=e101e12e593fdf3354221e5a02482238e9aad4a6;p=gcc.git s390.c (s390_delegitimize_address): Handle GOTOFF unspecs. 2011-03-18 Andreas Krebbel * config/s390/s390.c (s390_delegitimize_address): Handle GOTOFF unspecs. From-SVN: r171157 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 519ba5d44c8..4dda33c52b2 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2011-03-18 Andreas Krebbel + + * config/s390/s390.c (s390_delegitimize_address): Handle GOTOFF + unspecs. + 2011-03-18 Andreas Krebbel * config/s390/s390.c (s390_chunkify_start): Prevent literal pool diff --git a/gcc/config/s390/s390.c b/gcc/config/s390/s390.c index dcbd4ac5391..53083ae1730 100644 --- a/gcc/config/s390/s390.c +++ b/gcc/config/s390/s390.c @@ -5015,6 +5015,23 @@ s390_delegitimize_address (rtx orig_x) orig_x = delegitimize_mem_from_attrs (orig_x); x = orig_x; + + /* Extract the symbol ref from: + (plus:SI (reg:SI 12 %r12) + (const:SI (unspec:SI [(symbol_ref/f:SI ("*.LC0"))] + UNSPEC_GOTOFF))) */ + if (GET_CODE (x) == PLUS + && REG_P (XEXP (x, 0)) + && REGNO (XEXP (x, 0)) == PIC_OFFSET_TABLE_REGNUM + && GET_CODE (XEXP (x, 1)) == CONST) + { + /* The const operand. */ + y = XEXP (XEXP (x, 1), 0); + if (GET_CODE (y) == UNSPEC + && XINT (y, 1) == UNSPEC_GOTOFF) + return XVECEXP (y, 0, 0); + } + if (GET_CODE (x) != MEM) return orig_x;