diff options
author | Nick Clifton <nickc@redhat.com> | 2004-01-09 13:59:55 +0000 |
---|---|---|
committer | Nick Clifton <nickc@redhat.com> | 2004-01-09 13:59:55 +0000 |
commit | 44e889528372ba167099ed14fdf7192b4cebe1b3 (patch) | |
tree | bc3c062fd1660060e76d623932113a9ccc59183f /bfd | |
parent | ef11303ebfb711b2a4f53b5c2fe29cf59484f5e6 (diff) | |
download | gdb-44e889528372ba167099ed14fdf7192b4cebe1b3.zip gdb-44e889528372ba167099ed14fdf7192b4cebe1b3.tar.gz gdb-44e889528372ba167099ed14fdf7192b4cebe1b3.tar.bz2 |
Remainder of fixes for ARM WINCE support
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 12 | ||||
-rw-r--r-- | bfd/coff-arm.c | 14 |
2 files changed, 22 insertions, 4 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 94aa94d..1fada0c 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,15 @@ +2004-01-09 Dmitry Semyonov <Dmitry.Semyonov@oktet.ru> + + * coff-arm.c (aoutarm_std_reloc_howto): [ARM_WINCE] Synchronize ARM_26D + relocation howto with ARM_26 one for consistency. + (coff_arm_relocate_section): Set partial_inplace for ARM_26 relocations + that will be converted to ARM_26D ones, since we always want 'done' + relocations to be reflected in section's data. + (coff_arm_relocate_section): [ARM_WINCE] Quick fix for BL instruction + offset. + (_bfd_final_link_relocate): Do not modify "inplace" data, if not + requested. + 2004-01-08 Dmitry Semyonov <Dmitry.Semyonov@oktet.ru> * coff-arm.c (coff_arm_relocate_section): Do not alter relocs that diff --git a/bfd/coff-arm.c b/bfd/coff-arm.c index 79bae59..e51d07d 100644 --- a/bfd/coff-arm.c +++ b/bfd/coff-arm.c @@ -268,7 +268,7 @@ static reloc_howto_type aoutarm_std_reloc_howto[] = 2, 2, 24, - FALSE, + TRUE, 0, complain_overflow_dont, aoutarm_fix_pcrel_26_done, @@ -276,7 +276,7 @@ static reloc_howto_type aoutarm_std_reloc_howto[] = FALSE, 0x00ffffff, 0x0, - FALSE), + PCRELOFFSET), HOWTO (ARM_32, 0, 2, @@ -1250,7 +1250,8 @@ coff_arm_relocate_section (output_bfd, info, input_bfd, input_section, when doing a relocatable link. However, we want to convert ARM_26 to ARM_26D relocs if possible. We return a fake howto in this case without pcrel_offset set, and adjust the addend to - compensate. */ + compensate. 'partial_inplace' is also set, since we want 'done' + relocations to be reflected in section's data. */ if (rel->r_type == ARM_26 && h != NULL && info->relocatable @@ -1269,12 +1270,17 @@ coff_arm_relocate_section (output_bfd, info, input_bfd, input_section, complain_overflow_signed, aoutarm_fix_pcrel_26 , "ARM_26", - FALSE, + TRUE, 0x00ffffff, 0x00ffffff, FALSE); addend -= rel->r_vaddr - input_section->vma; +#ifdef ARM_WINCE + /* FIXME: I don't know why, but the hack is necessary for correct + generation of bl's instruction offset. */ + addend -= 8; +#endif howto = &fake_arm26_reloc; } |