aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--sysdeps/i386/dl-machine.h11
-rw-r--r--sysdeps/x86_64/dl-machine.h11
3 files changed, 11 insertions, 18 deletions
diff --git a/ChangeLog b/ChangeLog
index 581a926..01517c5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
2017-10-03 H.J. Lu <hongjiu.lu@intel.com>
+ * sysdeps/i386/dl-machine.h (elf_machine_load_address): Don't
+ allow undefined _DYNAMIC in PIE libc.a.
+ * sysdeps/x86_64/dl-machine.h (elf_machine_load_address):
+ Likewse.
+
+2017-10-03 H.J. Lu <hongjiu.lu@intel.com>
+
* sysdeps/mips/dl-machine.h (elf_machine_load_address): Don't
check _DYNAMIC.
diff --git a/sysdeps/i386/dl-machine.h b/sysdeps/i386/dl-machine.h
index 242c692..2e17eba 100644
--- a/sysdeps/i386/dl-machine.h
+++ b/sysdeps/i386/dl-machine.h
@@ -54,15 +54,8 @@ elf_machine_load_address (void)
/* Compute the difference between the runtime address of _DYNAMIC as seen
by a GOTOFF reference, and the link-time address found in the special
unrelocated first GOT entry. */
-#ifndef SHARED
- extern Elf32_Dyn _DYNAMIC[] __attribute__((weak, visibility ("hidden")));
- if (!_DYNAMIC)
- return 0;
-#endif
- /* The address of dynamic must be taken as non-weak to avoid dynamic
- relocation. */
- extern Elf32_Dyn dynamic[] asm ("_DYNAMIC") attribute_hidden;
- return (Elf32_Addr) &dynamic - elf_machine_dynamic ();
+ extern Elf32_Dyn bygotoff[] asm ("_DYNAMIC") attribute_hidden;
+ return (Elf32_Addr) &bygotoff - elf_machine_dynamic ();
}
/* Set up the loaded object described by L so its unrelocated PLT
diff --git a/sysdeps/x86_64/dl-machine.h b/sysdeps/x86_64/dl-machine.h
index a79e5ca..6a04cbc 100644
--- a/sysdeps/x86_64/dl-machine.h
+++ b/sysdeps/x86_64/dl-machine.h
@@ -55,15 +55,8 @@ elf_machine_load_address (void)
/* Compute the difference between the runtime address of _DYNAMIC as seen
by an IP-relative reference, and the link-time address found in the
special unrelocated first GOT entry. */
-#ifndef SHARED
- extern ElfW(Dyn) _DYNAMIC[] __attribute__((weak, visibility ("hidden")));
- if (!_DYNAMIC)
- return 0;
-#endif
- /* The address of dynamic must be taken as non-weak to avoid dynamic
- relocation. */
- extern ElfW(Dyn) dynamic[] asm ("_DYNAMIC") attribute_hidden;
- return (ElfW(Addr)) &dynamic - elf_machine_dynamic ();
+ extern ElfW(Dyn) _DYNAMIC[] attribute_hidden;
+ return (ElfW(Addr)) &_DYNAMIC - elf_machine_dynamic ();
}
/* Set up the loaded object described by L so its unrelocated PLT