From e7f0a167643f8b3bc72321be3656fa8e35f9e4e6 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Wed, 30 Jun 2004 03:51:25 +0000 Subject: [PATCH] 2004-06-29 H.J. Lu PR 240 * elfxx-ia64.c (elfNN_ia64_relax_section): Don't relax branch in .init/.fini sections. --- bfd/ChangeLog | 6 ++++++ bfd/elfxx-ia64.c | 13 +++++++++++++ 2 files changed, 19 insertions(+) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 3c0e12a8553..78bcea55e35 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2004-06-29 H.J. Lu + + PR 240 + * elfxx-ia64.c (elfNN_ia64_relax_section): Don't relax branch + in .init/.fini sections. + 2004-06-29 Bob Wilson * elf32-xtensa.c (elf_xtensa_relocate_section): Use diff --git a/bfd/elfxx-ia64.c b/bfd/elfxx-ia64.c index 6f0c06e0ab4..d8c4b5761b8 100644 --- a/bfd/elfxx-ia64.c +++ b/bfd/elfxx-ia64.c @@ -943,6 +943,19 @@ 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; -- 2.30.2