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-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=533af0314f016b893b80fb2e8325e7fe5826e416;p=binutils-gdb.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 a63f12a4dc6..3f73fc044a7 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 30924790b6e..ef41bdbe725 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); }