summaryrefslogtreecommitdiff
path: root/bfd/som.c
diff options
context:
space:
mode:
authorDave Anglin <dave.anglin@nrc.ca>2004-07-28 22:23:53 +0000
committerDave Anglin <dave.anglin@nrc.ca>2004-07-28 22:23:53 +0000
commit404ed0cf486cc61956570a0fe4291abf28a013d7 (patch)
tree0deb5b38b6dde9b09c65fa2e98e92f66b1c0a657 /bfd/som.c
parent0dea24683af9a708125ba1fa06e2a3a296d390a8 (diff)
downloadbinutils-gdb-404ed0cf486cc61956570a0fe4291abf28a013d7.tar.gz
PR 273
* som.c (setup_sections): Improve estimation of space sizes in relocatable objects.
Diffstat (limited to 'bfd/som.c')
-rw-r--r--bfd/som.c28
1 files changed, 23 insertions, 5 deletions
diff --git a/bfd/som.c b/bfd/som.c
index 4b40f1bf12a..c35b344f1d0 100644
--- a/bfd/som.c
+++ b/bfd/som.c
@@ -1913,6 +1913,7 @@ setup_sections (abfd, file_hdr, current_offset)
struct som_subspace_dictionary_record subspace, save_subspace;
unsigned int subspace_index;
asection *space_asect;
+ bfd_size_type space_size = 0;
char *newname;
/* Read the space dictionary element. */
@@ -2104,6 +2105,9 @@ setup_sections (abfd, file_hdr, current_offset)
subspace_asect->alignment_power = exact_log2 (subspace.alignment);
if (subspace_asect->alignment_power == (unsigned) -1)
goto error_return;
+
+ /* Keep track of the accumulated sizes of the sections. */
+ space_size += subspace.subspace_length;
}
/* This can happen for a .o which defines symbols in otherwise
@@ -2111,11 +2115,25 @@ setup_sections (abfd, file_hdr, current_offset)
if (!save_subspace.file_loc_init_value)
space_asect->size = 0;
else
- /* Setup the size for the space section based upon the info in the
- last subspace of the space. */
- space_asect->size = (save_subspace.subspace_start
- - space_asect->vma
- + save_subspace.subspace_length);
+ {
+ if (file_hdr->a_magic != RELOC_MAGIC)
+ {
+ /* Setup the size for the space section based upon the info
+ in the last subspace of the space. */
+ space_asect->size = (save_subspace.subspace_start
+ - space_asect->vma
+ + save_subspace.subspace_length);
+ }
+ else
+ {
+ /* The subspace_start field is not initialised in relocatable
+ only objects, so it cannot be used for length calculations.
+ Instead we use the space_size value which we have been
+ accumulating. This isn't an accurate estimate since it
+ ignores alignment and ordering issues. */
+ space_asect->size = space_size;
+ }
+ }
}
/* Now that we've read in all the subspace records, we need to assign
a target index to each subspace. */