* elf.c (elf_fake_sections): Formatting.
(assign_file_positions_for_load_sections): Only add SEC_ALLOC sections to p_memsz. Remove hack for PT_NOTE sections. Allow section alignment to increase p_align for PT_LOAD. (assign_file_positions_for_non_load_sections): Remove ARM BPABI hack for PT_DYNAMIC. Instead, set p_filesz for all segments other than PT_LOAD, and PT_NOTE in core.
This commit is contained in:
parent
e8fb7a4998
commit
1ea63fd215
2 changed files with 39 additions and 28 deletions
|
@ -1,3 +1,13 @@
|
||||||
|
2006-05-19 Alan Modra <amodra@bigpond.net.au>
|
||||||
|
|
||||||
|
* elf.c (elf_fake_sections): Formatting.
|
||||||
|
(assign_file_positions_for_load_sections): Only add SEC_ALLOC
|
||||||
|
sections to p_memsz. Remove hack for PT_NOTE sections. Allow
|
||||||
|
section alignment to increase p_align for PT_LOAD.
|
||||||
|
(assign_file_positions_for_non_load_sections): Remove ARM BPABI
|
||||||
|
hack for PT_DYNAMIC. Instead, set p_filesz for all segments
|
||||||
|
other than PT_LOAD, and PT_NOTE in core.
|
||||||
|
|
||||||
2006-05-17 Alan Modra <amodra@bigpond.net.au>
|
2006-05-17 Alan Modra <amodra@bigpond.net.au>
|
||||||
|
|
||||||
* elf.c (assign_file_positions_for_segments): Split into..
|
* elf.c (assign_file_positions_for_segments): Split into..
|
||||||
|
|
53
bfd/elf.c
53
bfd/elf.c
|
@ -4379,6 +4379,11 @@ assign_file_positions_for_load_sections (bfd *abfd,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Set up p_filesz, p_memsz, p_align and p_flags from the section
|
||||||
|
maps. Set filepos for sections in PT_LOAD segments, and in
|
||||||
|
core files, for sections in PT_NOTE segments.
|
||||||
|
assign_file_positions_for_non_load_sections will set filepos
|
||||||
|
for other sections and update p_filesz for other segments. */
|
||||||
for (i = 0, secpp = m->sections; i < m->count; i++, secpp++)
|
for (i = 0, secpp = m->sections; i < m->count; i++, secpp++)
|
||||||
{
|
{
|
||||||
asection *sec;
|
asection *sec;
|
||||||
|
@ -4410,8 +4415,9 @@ assign_file_positions_for_load_sections (bfd *abfd,
|
||||||
}
|
}
|
||||||
/* .tbss is special. It doesn't contribute to p_memsz of
|
/* .tbss is special. It doesn't contribute to p_memsz of
|
||||||
normal segments. */
|
normal segments. */
|
||||||
else if ((flags & SEC_THREAD_LOCAL) == 0
|
else if ((flags & SEC_ALLOC) != 0
|
||||||
|| p->p_type == PT_TLS)
|
&& ((flags & SEC_THREAD_LOCAL) == 0
|
||||||
|
|| p->p_type == PT_TLS))
|
||||||
{
|
{
|
||||||
/* The section VMA must equal the file position
|
/* The section VMA must equal the file position
|
||||||
modulo the page size. */
|
modulo the page size. */
|
||||||
|
@ -4475,16 +4481,12 @@ assign_file_positions_for_load_sections (bfd *abfd,
|
||||||
p->p_filesz += sec->size;
|
p->p_filesz += sec->size;
|
||||||
p->p_memsz += sec->size;
|
p->p_memsz += sec->size;
|
||||||
}
|
}
|
||||||
/* PR ld/594: Sections in note segments which are not loaded
|
|
||||||
contribute to the file size but not the in-memory size. */
|
|
||||||
else if (p->p_type == PT_NOTE
|
|
||||||
&& (flags & SEC_HAS_CONTENTS) != 0)
|
|
||||||
p->p_filesz += sec->size;
|
|
||||||
|
|
||||||
/* .tbss is special. It doesn't contribute to p_memsz of
|
/* .tbss is special. It doesn't contribute to p_memsz of
|
||||||
normal segments. */
|
normal segments. */
|
||||||
else if ((flags & SEC_THREAD_LOCAL) == 0
|
else if ((flags & SEC_ALLOC) != 0
|
||||||
|| p->p_type == PT_TLS)
|
&& ((flags & SEC_THREAD_LOCAL) == 0
|
||||||
|
|| p->p_type == PT_TLS))
|
||||||
p->p_memsz += sec->size;
|
p->p_memsz += sec->size;
|
||||||
|
|
||||||
if (p->p_type == PT_TLS
|
if (p->p_type == PT_TLS
|
||||||
|
@ -4497,7 +4499,9 @@ assign_file_positions_for_load_sections (bfd *abfd,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (align > p->p_align
|
if (align > p->p_align
|
||||||
&& (p->p_type != PT_LOAD || (abfd->flags & D_PAGED) == 0))
|
&& (p->p_type != PT_LOAD
|
||||||
|
|| (abfd->flags & D_PAGED) == 0
|
||||||
|
|| ((p->p_vaddr - p->p_offset) & (align - 1)) == 0))
|
||||||
p->p_align = align;
|
p->p_align = align;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4624,27 +4628,24 @@ assign_file_positions_for_non_load_sections (bfd *abfd,
|
||||||
m != NULL;
|
m != NULL;
|
||||||
m = m->next, p++)
|
m = m->next, p++)
|
||||||
{
|
{
|
||||||
if (p->p_type != PT_LOAD && m->count > 0)
|
if (m->count != 0)
|
||||||
{
|
{
|
||||||
|
if (p->p_type != PT_LOAD
|
||||||
|
&& (p->p_type != PT_NOTE || bfd_get_format (abfd) != bfd_core))
|
||||||
|
{
|
||||||
|
Elf_Internal_Shdr *hdr;
|
||||||
BFD_ASSERT (!m->includes_filehdr && !m->includes_phdrs);
|
BFD_ASSERT (!m->includes_filehdr && !m->includes_phdrs);
|
||||||
/* If the section has not yet been assigned a file position,
|
|
||||||
do so now. The ARM BPABI requires that .dynamic section
|
|
||||||
not be marked SEC_ALLOC because it is not part of any
|
|
||||||
PT_LOAD segment, so it will not be processed above. */
|
|
||||||
if (p->p_type == PT_DYNAMIC && m->sections[0]->filepos == 0)
|
|
||||||
{
|
|
||||||
Elf_Internal_Shdr ** const i_shdrpp = elf_elfsections (abfd);
|
|
||||||
|
|
||||||
i = 1;
|
hdr = &elf_section_data (m->sections[m->count - 1])->this_hdr;
|
||||||
while (i_shdrpp[i]->bfd_section != m->sections[0])
|
p->p_filesz = (m->sections[m->count - 1]->filepos
|
||||||
++i;
|
- m->sections[0]->filepos);
|
||||||
off = (_bfd_elf_assign_file_position_for_section
|
if (hdr->sh_type != SHT_NOBITS)
|
||||||
(i_shdrpp[i], off, TRUE));
|
p->p_filesz += hdr->sh_size;
|
||||||
p->p_filesz = m->sections[0]->size;
|
|
||||||
}
|
|
||||||
p->p_offset = m->sections[0]->filepos;
|
p->p_offset = m->sections[0]->filepos;
|
||||||
}
|
}
|
||||||
if (m->count == 0)
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
if (m->includes_filehdr)
|
if (m->includes_filehdr)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue