aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2003-01-12 19:22:32 +0000
committerUlrich Drepper <drepper@redhat.com>2003-01-12 19:22:32 +0000
commita48dbdf0443228064c425d5b9909e75f7b3dee0a (patch)
tree29f8345f8f42c8fc89520eee39257bee5b369fbc
parentf5e2ab0edb7ca64e3682ae305d0c04ef0eb37f6b (diff)
downloadglibc-a48dbdf0443228064c425d5b9909e75f7b3dee0a.tar
glibc-a48dbdf0443228064c425d5b9909e75f7b3dee0a.tar.gz
glibc-a48dbdf0443228064c425d5b9909e75f7b3dee0a.tar.bz2
glibc-a48dbdf0443228064c425d5b9909e75f7b3dee0a.zip
(elf_machine_rela): Compute DTPREL64 and TPREL64 without loadbase applied.
-rw-r--r--sysdeps/alpha/dl-machine.h22
1 files changed, 16 insertions, 6 deletions
diff --git a/sysdeps/alpha/dl-machine.h b/sysdeps/alpha/dl-machine.h
index 3a182ca99f..5016f1353e 100644
--- a/sysdeps/alpha/dl-machine.h
+++ b/sysdeps/alpha/dl-machine.h
@@ -544,15 +544,25 @@ elf_machine_rela (struct link_map *map,
else
{
Elf64_Addr sym_value;
+ Elf64_Addr sym_raw_value;
#if defined USE_TLS && !defined RTLD_BOOTSTRAP
struct link_map *sym_map = RESOLVE_MAP (&sym, version, r_type);
- sym_value = sym ? sym_map->l_addr + sym->st_value : 0;
+ sym_raw_value = sym_value = reloc->r_addend;
+ if (sym)
+ {
+ sym_raw_value += sym->st_value;
+ sym_value = sym_raw_value + sym_map->l_addr;
+ }
#else
Elf64_Addr loadbase = RESOLVE (&sym, version, r_type);
- sym_value = sym ? loadbase + sym->st_value : 0;
+ sym_raw_value = sym_value = reloc->r_addend;
+ if (sym)
+ {
+ sym_raw_value += sym->st_value;
+ sym_value = sym_raw_value + loadbase;
+ }
#endif
- sym_value += reloc->r_addend;
if (r_type == R_ALPHA_GLOB_DAT)
*reloc_addr = sym_value;
@@ -600,18 +610,18 @@ elf_machine_rela (struct link_map *map,
#ifndef RTLD_BOOTSTRAP
/* During relocation all TLS symbols are defined and used.
Therefore the offset is already correct. */
- *reloc_addr = sym_value;
+ *reloc_addr = sym_raw_value;
#endif
}
else if (r_type == R_ALPHA_TPREL64)
{
#ifdef RTLD_BOOTSTRAP
- *reloc_addr = sym_value - map->l_tls_offset;
+ *reloc_addr = sym_raw_value - map->l_tls_offset;
#else
if (sym_map)
{
CHECK_STATIC_TLS (map, sym_map);
- *reloc_addr = sym_value - sym_map->l_tls_offset;
+ *reloc_addr = sym_raw_value - sym_map->l_tls_offset;
}
#endif
}