aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2005-01-05 21:29:06 +0100
committerRichard Henderson <rth@gcc.gnu.org>2005-01-05 12:29:06 -0800
commitd2ad2c8a9cea5cc01db606f39b73b1cbfd0622d6 (patch)
tree0afab63e815744564a65ada194bc5bd5d65e5f3f
parent2cdb31489836779b7316f60cb49c5eb83de88adb (diff)
downloadgcc-d2ad2c8a9cea5cc01db606f39b73b1cbfd0622d6.zip
gcc-d2ad2c8a9cea5cc01db606f39b73b1cbfd0622d6.tar.gz
gcc-d2ad2c8a9cea5cc01db606f39b73b1cbfd0622d6.tar.bz2
re PR target/18910 (unrecognisable insn in regclass on x86/amd64)
PR target/18910 * config/i386/i386.c (ix86_expand_move): Handle tls symbols with an offset. Co-Authored-By: Richard Henderson <rth@redhat.com> From-SVN: r92968
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/config/i386/i386.c31
-rw-r--r--gcc/testsuite/gcc.dg/tls/opt-8.c13
3 files changed, 45 insertions, 6 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 08b41f5..7797ffc 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2005-01-05 Jan Hubicka <jh@suse.cz>
+ Richard Henderson <rth@redhat.com>
+
+ PR target/18910
+ * config/i386/i386.c (ix86_expand_move): Handle tls symbols
+ with an offset.
+
2005-01-05 Richard Henderson <rth@redhat.com>
PR target/12902
diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c
index 51d36f1..ca1f1f7 100644
--- a/gcc/config/i386/i386.c
+++ b/gcc/config/i386/i386.c
@@ -7472,13 +7472,32 @@ ix86_expand_move (enum machine_mode mode, rtx operands[])
op0 = operands[0];
op1 = operands[1];
- model = GET_CODE (op1) == SYMBOL_REF ? SYMBOL_REF_TLS_MODEL (op1) : 0;
- if (model)
+ if (GET_CODE (op1) == SYMBOL_REF)
{
- op1 = legitimize_tls_address (op1, model, true);
- op1 = force_operand (op1, op0);
- if (op1 == op0)
- return;
+ model = SYMBOL_REF_TLS_MODEL (op1);
+ if (model)
+ {
+ op1 = legitimize_tls_address (op1, model, true);
+ op1 = force_operand (op1, op0);
+ if (op1 == op0)
+ return;
+ }
+ }
+ else if (GET_CODE (op1) == CONST
+ && GET_CODE (XEXP (op1, 0)) == PLUS
+ && GET_CODE (XEXP (XEXP (op1, 0), 0)) == SYMBOL_REF)
+ {
+ model = SYMBOL_REF_TLS_MODEL (XEXP (XEXP (op1, 0), 0));
+ if (model)
+ {
+ rtx addend = XEXP (XEXP (op1, 0), 1);
+ op1 = legitimize_tls_address (XEXP (XEXP (op1, 0), 0), model, true);
+ op1 = force_operand (op1, NULL);
+ op1 = expand_simple_binop (Pmode, PLUS, op1, addend,
+ op0, 1, OPTAB_DIRECT);
+ if (op1 == op0)
+ return;
+ }
}
if (flag_pic && mode == Pmode && symbolic_operand (op1, Pmode))
diff --git a/gcc/testsuite/gcc.dg/tls/opt-8.c b/gcc/testsuite/gcc.dg/tls/opt-8.c
new file mode 100644
index 0000000..dec0eab
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/tls/opt-8.c
@@ -0,0 +1,13 @@
+/* PR 18910 */
+/* { dg-do compile } */
+/* { dg-options "-O2" } */
+
+static __thread void *foo [2];
+void
+test1 (void)
+{
+ unsigned int s;
+
+ for (s = 0; s < 2; ++s)
+ foo [s] = &foo[s];
+}