From 0a88ad8f274042ca7da575818da46e5ee0d989db Mon Sep 17 00:00:00 2001 From: Richard Sandiford Date: Tue, 14 Dec 2004 09:48:10 +0000 Subject: [PATCH] * elfxx-mips.c (mips_elf_calculate_relocation): Don't report an overflow for calls to undefined weak symbols. --- bfd/ChangeLog | 5 +++++ bfd/elfxx-mips.c | 3 ++- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index f61fd226a2..e0d5f86e83 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2004-12-14 Richard Sandiford + + * elfxx-mips.c (mips_elf_calculate_relocation): Don't report an + overflow for calls to undefined weak symbols. + 2004-12-11 Alan Modra * elfcode.h (elf_slurp_symbol_table): Use bfd_elf_sym_name so that diff --git a/bfd/elfxx-mips.c b/bfd/elfxx-mips.c index ef4650b1eb..9ec9c86dcb 100644 --- a/bfd/elfxx-mips.c +++ b/bfd/elfxx-mips.c @@ -3352,7 +3352,8 @@ mips_elf_calculate_relocation (bfd *abfd, bfd *input_bfd, else { value = (_bfd_mips_elf_sign_extend (addend, 28) + symbol) >> 2; - overflowed_p = (value >> 26) != ((p + 4) >> 28); + if (h->root.root.type != bfd_link_hash_undefweak) + overflowed_p = (value >> 26) != ((p + 4) >> 28); } value &= howto->dst_mask; break; -- 2.11.0