diff options
author | Jason Eckhardt <jle@rice.edu> | 2000-08-21 23:26:19 +0000 |
---|---|---|
committer | Jason Eckhardt <jle@rice.edu> | 2000-08-21 23:26:19 +0000 |
commit | ded0649cd504e9895ab37f7ffae110d00ebbaaef (patch) | |
tree | 20ad6a27c89278c0940a7aa85e1dba3076e8e229 /bfd/elf32-i860.c | |
parent | c8c5888ebc7925fcc631e3a7be075ad6c5cc2ad1 (diff) | |
download | gdb-ded0649cd504e9895ab37f7ffae110d00ebbaaef.zip gdb-ded0649cd504e9895ab37f7ffae110d00ebbaaef.tar.gz gdb-ded0649cd504e9895ab37f7ffae110d00ebbaaef.tar.bz2 |
2000-08-21 Jason Eckhardt <jle@cygnus.com>
bfd:
* elf32-i860.c (elf32_i860_relocate_pc16): Just write the immediate
field with the newly relocated value instead of adding it to the
existing immediate field.
(elf32_i860_relocate_splitn): Likewise.
(elf32_i860_relocate_highadj): Likewise.
gas:
* config/tc-i860.c (md_apply_fix3): Do not insert the immediate
if the fixup resulted in a relocation.
Diffstat (limited to 'bfd/elf32-i860.c')
-rw-r--r-- | bfd/elf32-i860.c | 23 |
1 files changed, 6 insertions, 17 deletions
diff --git a/bfd/elf32-i860.c b/bfd/elf32-i860.c index bc10093..08c2e16 100644 --- a/bfd/elf32-i860.c +++ b/bfd/elf32-i860.c @@ -709,20 +709,15 @@ elf32_i860_relocate_splitn (input_bfd, rello, contents, value) bfd_byte *contents; bfd_vma value; { - bfd_vma insn, t; + bfd_vma insn; reloc_howto_type *howto; howto = lookup_howto (ELF32_R_TYPE (rello->r_info)); insn = bfd_get_32 (input_bfd, contents + rello->r_offset); - /* Remove encode bits and intervening bits. Then concatenate the - two fields into one 16-bit quantity. */ - t = (insn & howto->src_mask); - t = ((t >> 5) & 0xf8) | (t & 0x7ff); - /* Relocate. */ - value += (rello->r_addend + t); + value += rello->r_addend; - /* Separate the fields and re-insert. */ + /* Separate the fields and insert. */ value = (((value & 0xf8) << 5) | (value & 0x7ff)) & howto->dst_mask; insn = (insn & ~howto->dst_mask) | value; @@ -742,7 +737,7 @@ elf32_i860_relocate_pc16 (input_bfd, input_section, rello, contents, value) bfd_byte *contents; bfd_vma value; { - bfd_vma insn, t; + bfd_vma insn; reloc_howto_type *howto; howto = lookup_howto (ELF32_R_TYPE (rello->r_info)); insn = bfd_get_32 (input_bfd, contents + rello->r_offset); @@ -752,15 +747,10 @@ elf32_i860_relocate_pc16 (input_bfd, input_section, rello, contents, value) + input_section->output_offset); value -= rello->r_offset; - /* Remove encode bits and intervening bits. Then concatenate the - two fields into one 16-bit quantity. */ - t = (insn & howto->src_mask); - t = ((t >> 5) & 0xf8) | (t & 0x7ff); - /* Relocate. */ - value += (rello->r_addend + t); + value += rello->r_addend; - /* Separate the fields and re-insert. */ + /* Separate the fields and insert. */ value = (((value & 0xf8) << 5) | (value & 0x7ff)) & howto->dst_mask; insn = (insn & ~howto->dst_mask) | value; @@ -785,7 +775,6 @@ elf32_i860_relocate_highadj (input_bfd, rel, contents, value) value += ((rel->r_addend & 0x8000) << 1); value += rel->r_addend; value = ((value >> 16) & 0xffff); - value = (value + (insn & 0xffff)) & 0xffff; insn = (insn & 0xffff0000) | value; |