From: Ulrich Drepper Date: Sun, 12 Oct 1997 03:41:56 +0000 (+0000) Subject: (elf_machine_rela): Fix last change. X-Git-Tag: glibc-2.16-ports-before-merge~3401 X-Git-Url: https://sourceware.org/git/?a=commitdiff_plain;h=989166429cd61139380236fcc053e18b6fd64f4f;p=glibc.git (elf_machine_rela): Fix last change. The R_68K_GLOB_DAT and R_68K_JMP_SLOT relocations really ignore the addend, Richard. (elf_machine_fixup_plt): Don't add the addend. (elf_machine_plt_value): New function. --- diff --git a/sysdeps/m68k/dl-machine.h b/sysdeps/m68k/dl-machine.h index cc0fb56189..1d2045dd87 100644 --- a/sysdeps/m68k/dl-machine.h +++ b/sysdeps/m68k/dl-machine.h @@ -223,7 +223,16 @@ static inline void elf_machine_fixup_plt (struct link_map *map, const Elf32_Rela *reloc, Elf32_Addr *reloc_addr, Elf32_Addr value) { - *reloc_addr = value + reloc->r_addend; + *reloc_addr = value; +} + +/* Return the final value of a plt relocation. On the m68k the JMP_SLOT + relocation ignores the addend. */ +static inline Elf32_Addr +elf_machine_plt_value (struct link_map *map, const Elf32_Rela *reloc, + Elf32_Addr value) +{ + return value; } #endif /* !dl_machine_h */ @@ -272,7 +281,7 @@ elf_machine_rela (struct link_map *map, const Elf32_Rela *reloc, break; case R_68K_GLOB_DAT: case R_68K_JMP_SLOT: - *reloc_addr = value + reloc->r_addend; + *reloc_addr = value; break; case R_68K_8: *(char *) reloc_addr = value + reloc->r_addend;