diff options
author | H.J. Lu <hjl@lucon.org> | 2004-07-09 19:27:15 +0000 |
---|---|---|
committer | H.J. Lu <hjl@lucon.org> | 2004-07-09 19:27:15 +0000 |
commit | ed741060d63182d72b283385a8f98bbf160dcf80 (patch) | |
tree | 3b77733e13c9177022aa2929fb0356ae61f636d3 /bfd | |
parent | c222a7fd8f4f32c6dc29e19579a138a9d4934924 (diff) | |
download | gdb-ed741060d63182d72b283385a8f98bbf160dcf80.tar.gz |
2004-07-09 H.J. Lu <hongjiu.lu@intel.com>
PR 240
* elfxx-ia64.c (elfNN_ia64_relax_section): Only warn br in
.init/.fini sections when trying to relax it.
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 6 | ||||
-rw-r--r-- | bfd/elfxx-ia64.c | 26 |
2 files changed, 19 insertions, 13 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 7d8efdd6e2d..b300f86917b 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2004-07-09 H.J. Lu <hongjiu.lu@intel.com> + + PR 240 + * elfxx-ia64.c (elfNN_ia64_relax_section): Only warn br in + .init/.fini sections when trying to relax it. + 2004-07-09 Jie Zhang <zhangjie@magima.com.cn> * elf.c (assign_file_positions_for_segments): Make sure the diff --git a/bfd/elfxx-ia64.c b/bfd/elfxx-ia64.c index 37b0d24ade3..74fbfbad887 100644 --- a/bfd/elfxx-ia64.c +++ b/bfd/elfxx-ia64.c @@ -943,19 +943,6 @@ elfNN_ia64_relax_section (abfd, sec, link_info, again) { bfd_signed_vma offset; - /* We can't put a trampoline in a .init/.fini section. Issue - an error. */ - if (strcmp (sec->output_section->name, ".init") == 0 - || strcmp (sec->output_section->name, ".fini") == 0) - { - (*_bfd_error_handler) - (_("%s: Can't relax br at 0x%lx in section `%s'. Please use brl or indirect branch."), - bfd_archive_filename (sec->owner), - (unsigned long) roff, sec->name); - bfd_set_error (bfd_error_bad_value); - goto error_return; - } - reladdr = (sec->output_section->vma + sec->output_offset + roff) & (bfd_vma) -4; @@ -984,6 +971,19 @@ elfNN_ia64_relax_section (abfd, sec, link_info, again) else if (r_type == R_IA64_PCREL60B) continue; + /* We can't put a trampoline in a .init/.fini section. Issue + an error. */ + if (strcmp (sec->output_section->name, ".init") == 0 + || strcmp (sec->output_section->name, ".fini") == 0) + { + (*_bfd_error_handler) + (_("%s: Can't relax br at 0x%lx in section `%s'. Please use brl or indirect branch."), + bfd_archive_filename (sec->owner), + (unsigned long) roff, sec->name); + bfd_set_error (bfd_error_bad_value); + goto error_return; + } + /* If the branch and target are in the same section, you've got one honking big section and we can't help you. You'll get an error message later. */ |