From: Ian Lance Taylor Date: Fri, 19 Nov 1993 19:51:52 +0000 (+0000) Subject: * coff-a29k.c (a29k_reloc): For R_IREL, don't left shift X-Git-Tag: gdb-4_18~16493 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=533af0314f016b893b80fb2e8325e7fe5826e416;p=platform%2Fupstream%2Fbinutils.git * coff-a29k.c (a29k_reloc): For R_IREL, don't left shift signed_value before sign extending it. Don't subtract out reloc_entry->address. This makes it compatible with what gas is generating. Fixes PR 3790. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index a63f12a..3f73fc0 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,5 +1,10 @@ Fri Nov 19 14:34:04 1993 Ian Lance Taylor (ian@tweedledumb.cygnus.com) + * coff-a29k.c (a29k_reloc): For R_IREL, don't left shift + signed_value before sign extending it. Don't subtract out + reloc_entry->address. This makes it compatible with what gas is + generating. + * elfcode.h (elf_fake_sections): Accept .sbss as the name for a SHT_NOBITS sections. (map_program_segments): Don't leave the loop after the first diff --git a/bfd/coff-a29k.c b/bfd/coff-a29k.c index 3092479..ef41bdb 100644 --- a/bfd/coff-a29k.c +++ b/bfd/coff-a29k.c @@ -117,8 +117,9 @@ DEFUN(a29k_reloc,(abfd, reloc_entry, symbol_in, data, input_section, output_bfd) case R_IREL: insn = bfd_get_32(abfd, hit_data); /* Take the value in the field and sign extend it */ - signed_value = EXTRACT_HWORD(insn) << 2; + signed_value = EXTRACT_HWORD(insn); signed_value = SIGN_EXTEND_HWORD(signed_value); + signed_value <<= 2; signed_value += sym_value + reloc_entry->addend; if ((signed_value&~0x3ffff) == 0) { /* Absolute jmp/call */ @@ -129,9 +130,8 @@ DEFUN(a29k_reloc,(abfd, reloc_entry, symbol_in, data, input_section, output_bfd) { /* Relative jmp/call, so subtract from the value the address of the place we're coming from */ - signed_value -= reloc_entry->address + - input_section->output_section->vma + - input_section->output_offset; + signed_value -= (input_section->output_section->vma + + input_section->output_offset); if (signed_value>0x1ffff || signed_value<-0x20000) return(bfd_reloc_outofrange); }