diff options
author | Nick Clifton <nickc@redhat.com> | 2010-05-04 16:21:07 +0000 |
---|---|---|
committer | Nick Clifton <nickc@redhat.com> | 2010-05-04 16:21:07 +0000 |
commit | 1fc5d88e4ba59db7a934cb63503a78a8655c9e53 (patch) | |
tree | f3e2ef9da1eb52fb1aacc3893c67bdbb04fb3547 | |
parent | 63b4f126d12867bff0f4e8dd37e4c11129f1ba87 (diff) | |
download | binutils-1fc5d88e4ba59db7a934cb63503a78a8655c9e53.zip binutils-1fc5d88e4ba59db7a934cb63503a78a8655c9e53.tar.gz binutils-1fc5d88e4ba59db7a934cb63503a78a8655c9e53.tar.bz2 |
* write.c (fixup_segment): Revert previous delta.
* config/tc-arm.h (TC_FORCE_RELOCATION_LOCAL): Also force the
generation of relocations for fixups against weak symbols.
-rw-r--r-- | gas/ChangeLog | 6 | ||||
-rw-r--r-- | gas/config/tc-arm.h | 1 | ||||
-rw-r--r-- | gas/write.c | 4 |
3 files changed, 8 insertions, 3 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog index c2b3faa..d8bfcd0 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,9 @@ +2010-05-04 Nick Clifton <nickc@redhat.com> + + * write.c (fixup_segment): Revert previous delta. + * config/tc-arm.h (TC_FORCE_RELOCATION_LOCAL): Also force the + generation of relocations for fixups against weak symbols. + 2010-04-29 Nathan Sidwell <nathan@codesourcery.com> * write.c (fixup_segment): Do not assume we know the section a diff --git a/gas/config/tc-arm.h b/gas/config/tc-arm.h index dacb342..702e405 100644 --- a/gas/config/tc-arm.h +++ b/gas/config/tc-arm.h @@ -183,6 +183,7 @@ void arm_copy_symbol_attributes (symbolS *, symbolS *); (!(FIX)->fx_pcrel \ || (FIX)->fx_r_type == BFD_RELOC_ARM_GOT32 \ || (FIX)->fx_r_type == BFD_RELOC_32 \ + || ((FIX)->fx_addsy != NULL && S_IS_WEAK ((FIX)->fx_addsy)) \ || TC_FORCE_RELOCATION (FIX)) /* Force output of R_ARM_REL32 relocations against thumb function symbols. diff --git a/gas/write.c b/gas/write.c index b50b0d4..a148b24 100644 --- a/gas/write.c +++ b/gas/write.c @@ -992,9 +992,7 @@ fixup_segment (fixS *fixP, segT this_segment) if (fixP->fx_addsy) { - if (S_IS_WEAK (fixP->fx_addsy)) - ; // even if it is defined, it might be overridden later - else if (add_symbol_segment == this_segment + if (add_symbol_segment == this_segment && !TC_FORCE_RELOCATION_LOCAL (fixP)) { /* This fixup was made when the symbol's segment was |