about summary refs log tree commit diff
path: root/elf
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>2002-08-12 06:25:47 +0000
committerRoland McGrath <roland@gnu.org>2002-08-12 06:25:47 +0000
commite6f526809dbca3e772147b7bdedc3ebca8aff30e (patch)
tree8d01638a6124709150e9dd99bdd2073c1da27378 /elf
parent7a8bdff02c8bc80d5068eadf83302595d11f46d4 (diff)
downloadglibc-e6f526809dbca3e772147b7bdedc3ebca8aff30e.tar.gz
glibc-e6f526809dbca3e772147b7bdedc3ebca8aff30e.tar.xz
glibc-e6f526809dbca3e772147b7bdedc3ebca8aff30e.zip
* elf/tst-tlsmod4.c (in_dso): Insert a random library call before use
	of the TLS macros, otherwise the compiler might not have initialized
	the PIC register yet when we use the PLT via asm.
	* elf/tst-tlsmod3.c (in_dso2): Likewise.
	* elf/tst-tlsmod2.c (in_dso): Likewise.
Diffstat (limited to 'elf')
-rw-r--r--elf/tst-tlsmod2.c6
-rw-r--r--elf/tst-tlsmod3.c9
-rw-r--r--elf/tst-tlsmod4.c6
3 files changed, 17 insertions, 4 deletions
diff --git a/elf/tst-tlsmod2.c b/elf/tst-tlsmod2.c
index 6aec8120c0..1a4c73b8a0 100644
--- a/elf/tst-tlsmod2.c
+++ b/elf/tst-tlsmod2.c
@@ -12,9 +12,13 @@ COMMON_INT_DEF(foo);
 int
 in_dso (int n, int *caller_foop)
 {
-  int *foop = TLS_GD (foo);
+  int *foop;
   int result = 0;
 
+  puts ("foo");			/* Make sure PLT is used before macros.  */
+
+  foop = TLS_GD (foo);
+
   if (caller_foop != NULL && foop != caller_foop)
     {
       printf ("callers address of foo differs: %p vs %p\n", caller_foop, foop);
diff --git a/elf/tst-tlsmod3.c b/elf/tst-tlsmod3.c
index 087c11b7a0..6b7fbccf4e 100644
--- a/elf/tst-tlsmod3.c
+++ b/elf/tst-tlsmod3.c
@@ -15,10 +15,15 @@ COMMON_INT_DEF(comm_n);
 int
 in_dso2 (void)
 {
-  int *foop = TLS_GD (foo);
+  int *foop;
   int result = 0;
   static int n;
-  int *np = TLS_GD (comm_n);
+  int *np;
+
+  puts ("foo");			/* Make sure PLT is used before macros.  */
+
+  foop = TLS_GD (foo);
+  np = TLS_GD (comm_n);
 
   if (n != *np)
     {
diff --git a/elf/tst-tlsmod4.c b/elf/tst-tlsmod4.c
index d40b3fdf61..c536303b47 100644
--- a/elf/tst-tlsmod4.c
+++ b/elf/tst-tlsmod4.c
@@ -12,9 +12,13 @@ COMMON_INT_DEF(baz);
 int
 in_dso (int n, int *caller_bazp)
 {
-  int *bazp = TLS_GD (baz);
+  int *bazp;
   int result = 0;
 
+  puts ("foo");			/* Make sure PLT is used before macros.  */
+
+  bazp = TLS_GD (baz);
+
   if (caller_bazp != NULL && bazp != caller_bazp)
     {
       printf ("callers address of baz differs: %p vs %p\n", caller_bazp, bazp);