diff options
Diffstat (limited to 'bfd/elfxx-ia64.c')
-rw-r--r-- | bfd/elfxx-ia64.c | 26 |
1 files changed, 13 insertions, 13 deletions
diff --git a/bfd/elfxx-ia64.c b/bfd/elfxx-ia64.c index 37b0d24..74fbfba 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. */ |