diff options
author | Ulrich Drepper <drepper@redhat.com> | 2003-01-12 19:22:32 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2003-01-12 19:22:32 +0000 |
commit | a48dbdf0443228064c425d5b9909e75f7b3dee0a (patch) | |
tree | 29f8345f8f42c8fc89520eee39257bee5b369fbc | |
parent | f5e2ab0edb7ca64e3682ae305d0c04ef0eb37f6b (diff) | |
download | glibc-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.h | 22 |
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 } |