Fix problematic TLS sequences for the Solaris linker
authorEric Botcazou <ebotcazou@gcc.gnu.org>
Fri, 14 Feb 2020 18:21:02 +0000 (19:21 +0100)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Fri, 14 Feb 2020 18:24:33 +0000 (19:24 +0100)
This is an old thinko pertaining to the interaction between TLS
sequences and delay slot filling: the compiler knows that it cannot
put instructions with TLS relocations into delay slots with the
original Sun TLS model, but it tests TARGET_SUN_TLS in this context,
which depends only on the assembler.  So if the compiler is configured
with the GNU assembler and the Solaris linker, then TARGET_GNU_TLS is
set instead and the limitation is not enforced.

PR target/93704
* config/sparc/sparc.c (eligible_for_call_delay): Test HAVE_GNU_LD
in conjunction with TARGET_GNU_TLS in early return.

gcc/ChangeLog
gcc/config/sparc/sparc.c

index 2080b738fb653923756209dd5236c9e89c1f69dd..e6eb6ab4c21f76e72fb934fd8c6187bb10d2e3e9 100644 (file)
@@ -1,3 +1,9 @@
+2020-02-14  Eric Botcazou  <ebotcazou@adacore.com>
+
+       PR target/93704
+       * config/sparc/sparc.c (eligible_for_call_delay): Test HAVE_GNU_LD in
+       conjunction with TARGET_GNU_TLS in early return.
+
 2020-02-14  Alexander Monakov  <amonakov@ispras.ru>
 
        * rtlanal.c (rtx_cost): Handle a SET up front. Avoid division if
index 7e05e1a6f82a12832a88d55e079266368a47b211..aefced85fe142885b1b31fa878a0ff0dfd4e921a 100644 (file)
@@ -3959,11 +3959,8 @@ eligible_for_call_delay (rtx_insn *trial)
   if (get_attr_in_branch_delay (trial) == IN_BRANCH_DELAY_FALSE)
     return 0;
 
-  /* Binutils allows
-       call __tls_get_addr, %tgd_call (foo)
-        add %l7, %o0, %o0, %tgd_add (foo)
-     while Sun as/ld does not.  */
-  if (TARGET_GNU_TLS || !TARGET_TLS)
+  /* The only problematic cases are TLS sequences with Sun as/ld.  */
+  if ((TARGET_GNU_TLS && HAVE_GNU_LD) || !TARGET_TLS)
     return 1;
 
   pat = PATTERN (trial);