]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
S390: Save and restore r12 in TLS_IE macro.
authorStefan Liebler <stli@linux.vnet.ibm.com>
Tue, 27 Jun 2017 13:23:43 +0000 (15:23 +0200)
committerStefan Liebler <stli@linux.vnet.ibm.com>
Tue, 27 Jun 2017 13:23:43 +0000 (15:23 +0200)
The testcases elf/tst-tls1-static and elf/tst-tls2-static
are failing on s390 if gcc is configured with --enable-default-pie.

According to binutils, there are only four valid cases for IE -> LE transition:
lg %rx,(0,%ry)    -> sllg %rx,%ry,0
lg %rx,(%ry,0)    -> sllg %rx,%ry,0
lg %rx,(%ry,%r12) -> sllg %rx,%ry,0
lg %rx,(%r12,%ry) -> sllg %rx,%ry,0

Thus I've adjusted the TLS_IE macro in s390 tls-macros.h files in PIC case
in order to use r12 for the address of global offset table.
The adjusted macro definition is not used if gcc is not configured with
--enable-default-pie.

ChangeLog:

* sysdeps/s390/s390-32/tls-macros.h (TLS_IE): Use r12 for GOT address.
* sysdeps/s390/s390-64/tls-macros.h (TLS_IE): Likewise.

ChangeLog
sysdeps/s390/s390-32/tls-macros.h
sysdeps/s390/s390-64/tls-macros.h

index f885eb49948651d0920239713f6a5fc239e0331a..48821c0737adf3f82f156cabe114a27c3d7f3aee 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2017-06-27  Stefan Liebler  <stli@linux.vnet.ibm.com>
+
+       * sysdeps/s390/s390-32/tls-macros.h (TLS_IE): Use r12 for GOT address.
+       * sysdeps/s390/s390-64/tls-macros.h (TLS_IE): Likewise.
+
 2017-06-27  Florian Weimer  <fweimer@redhat.com>
 
        Work around test timeouts with ICMP rate limiting on localhost.
index a4c5fffa33674c432c60740e19a14dfad789228e..153523a4aed744fe4cb331f37374857ca35b785f 100644 (file)
@@ -8,15 +8,17 @@
 
 #ifdef PIC
 # define TLS_IE(x) \
-  ({ unsigned long __offset, __got;                                          \
+  ({ unsigned long __offset, __save12;                                       \
      __asm__ ("bras %0,1f\n"                                                 \
              "0:\t.long _GLOBAL_OFFSET_TABLE_-0b\n\t"                        \
              ".long " #x "@gotntpoff\n"                                      \
-             "1:\tl %1,0(%0)\n\t"                                            \
-             "la %1,0(%1,%0)\n\t"                                            \
+             "1:\tlr %1,%%r12\n\t"                                           \
+             "l %%r12,0(%0)\n\t"                                             \
+             "la %%r12,0(%0,%%r12)\n\t"                                      \
              "l %0,4(%0)\n\t"                                                \
-             "l %0,0(%0,%1):tls_load:" #x "\n"                               \
-             : "=&a" (__offset), "=&a" (__got) : : "cc" );                   \
+             "l %0,0(%0,%%r12):tls_load:" #x "\n\t"                          \
+             "lr %%r12,%1\n"                                                 \
+             : "=&a" (__offset), "=&a" (__save12) : : "cc" );                \
      (int *) (__builtin_thread_pointer() + __offset); })
 #else
 # define TLS_IE(x) \
index d70ea6ce0cb171a0d482b585daf381b05684dded..449a843d6971ab989529540ef7b1d855104a7c42 100644 (file)
@@ -8,13 +8,15 @@
 
 #ifdef PIC
 # define TLS_IE(x) \
-  ({ unsigned long __offset, __got;                                          \
+  ({ unsigned long __offset, __save12;                                       \
      __asm__ ("bras %0,0f\n\t"                                               \
              ".quad " #x "@gotntpoff\n"                                      \
-             "0:\tlarl %1,_GLOBAL_OFFSET_TABLE_\n\t"                         \
+             "0:\tlgr %1,%%r12\n\t"                                          \
+             "larl %%r12,_GLOBAL_OFFSET_TABLE_\n\t"                          \
              "lg %0,0(%0)\n\t"                                               \
-             "lg %0,0(%0,%1):tls_load:" #x     "\n"                          \
-             : "=&a" (__offset), "=&a" (__got) : : "cc" );                   \
+             "lg %0,0(%0,%%r12):tls_load:" #x  "\n\t"                        \
+             "lgr %%r12,%1\n"                                                \
+             : "=&a" (__offset), "=&a" (__save12) : : "cc" );                \
      (int *) (__builtin_thread_pointer() + __offset); })
 #else
 # define TLS_IE(x) \