aboutsummaryrefslogtreecommitdiff
path: root/gas/config
diff options
context:
space:
mode:
authorHans-Peter Nilsson <hp@axis.com>2000-10-30 20:26:42 +0000
committerHans-Peter Nilsson <hp@axis.com>2000-10-30 20:26:42 +0000
commit1308f14c9723e587a736812b15fa1421675bc534 (patch)
treea8ad4aea067c8abb7c37c27cb2a11a4e8d550de8 /gas/config
parentd8374dcd8a7b20b0c54a7fbc255609d488348fb5 (diff)
downloadgdb-1308f14c9723e587a736812b15fa1421675bc534.zip
gdb-1308f14c9723e587a736812b15fa1421675bc534.tar.gz
gdb-1308f14c9723e587a736812b15fa1421675bc534.tar.bz2
* config/tc-sh.c (md_apply_fix): For ELF, do not "adjust back" VAL
for weak symbols.
Diffstat (limited to 'gas/config')
-rw-r--r--gas/config/tc-sh.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/gas/config/tc-sh.c b/gas/config/tc-sh.c
index 65ae551..645397e 100644
--- a/gas/config/tc-sh.c
+++ b/gas/config/tc-sh.c
@@ -2767,8 +2767,17 @@ md_apply_fix (fixP, val)
/* The function adjust_reloc_syms won't convert a reloc against a weak
symbol into a reloc against a section, but bfd_install_relocation
will screw up if the symbol is defined, so we have to adjust val here
- to avoid the screw up later. */
- if (fixP->fx_addsy != NULL
+ to avoid the screw up later.
+
+ For ordinary relocs, this does not happen for ELF, since for ELF,
+ bfd_install_relocation uses the "special function" field of the
+ howto, and does not execute the code that needs to be undone, as long
+ as the special function does not return bfd_reloc_continue.
+ It can happen for GOT- and PLT-type relocs the way they are
+ described in elf32-sh.c as they use bfd_elf_generic_reloc, but it
+ doesn't matter here since those relocs don't use VAL; see below. */
+ if (OUTPUT_FLAVOR != bfd_target_elf_flavour
+ && fixP->fx_addsy != NULL
&& S_IS_WEAK (fixP->fx_addsy))
val -= S_GET_VALUE (fixP->fx_addsy);
#endif