diff options
author | Alan Modra <amodra@gmail.com> | 2003-02-08 08:18:41 +0000 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2003-02-08 08:18:41 +0000 |
commit | 00b28bb047a8304ba4f00433072b8f1bd8f35e60 (patch) | |
tree | 51c9d6becacbbf224b2842ccd7c6ba897024d5c3 | |
parent | acc990f282141b0857da1b22b0fa4b0f7c06c4f5 (diff) | |
download | binutils-gdb-00b28bb047a8304ba4f00433072b8f1bd8f35e60.tar.gz |
* elf32-hppa.c (group_sections): Don't share a stub section if
stubs are for a large section.
-rw-r--r-- | bfd/ChangeLog | 3 | ||||
-rw-r--r-- | bfd/elf32-hppa.c | 10 |
2 files changed, 11 insertions, 2 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 02cebf48582..2033f639575 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,5 +1,8 @@ 2003-02-08 Alan Modra <amodra@bigpond.net.au> + * elf32-hppa.c (group_sections): Don't share a stub section if + stubs are for a large section. + * elf32-hppa.c (elf32_hppa_size_stubs): Double the size left for stubs if !stubs_always_before_branch. diff --git a/bfd/elf32-hppa.c b/bfd/elf32-hppa.c index 69ead0dbf45..80e8b1861c1 100644 --- a/bfd/elf32-hppa.c +++ b/bfd/elf32-hppa.c @@ -2686,12 +2686,15 @@ group_sections (htab, stub_group_size, stubs_always_before_branch) asection *curr; asection *prev; bfd_size_type total; + bfd_boolean big_sec; curr = tail; if (tail->_cooked_size) total = tail->_cooked_size; else total = tail->_raw_size; + big_sec = total >= stub_group_size; + while ((prev = PREV_SEC (curr)) != NULL && ((total += curr->output_offset - prev->output_offset) < stub_group_size)) @@ -2719,8 +2722,11 @@ group_sections (htab, stub_group_size, stubs_always_before_branch) while (tail != curr && (tail = prev) != NULL); /* But wait, there's more! Input sections up to 240000 - bytes before the stub section can be handled by it too. */ - if (!stubs_always_before_branch) + bytes before the stub section can be handled by it too. + Don't do this if we have a really large section after the + stubs, as adding more stubs increases the chance that + branches may not reach into the stub section. */ + if (!stubs_always_before_branch && !big_sec) { total = 0; while (prev != NULL |