diff options
author | Ian Lance Taylor <ian@airs.com> | 1995-11-29 19:14:33 +0000 |
---|---|---|
committer | Ian Lance Taylor <ian@airs.com> | 1995-11-29 19:14:33 +0000 |
commit | 44ef8897daee098e361b279406693bc6849c61e5 (patch) | |
tree | af250e30c84b8bc2239fe857c964abe46ceedeac /bfd | |
parent | 27fb8f2933cd65eb68179a79f0078034f20cfb2c (diff) | |
download | gdb-44ef8897daee098e361b279406693bc6849c61e5.zip gdb-44ef8897daee098e361b279406693bc6849c61e5.tar.gz gdb-44ef8897daee098e361b279406693bc6849c61e5.tar.bz2 |
* elf.c (assign_file_positions_for_segments): Fix case where extra
program headers were allocated.
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 3 | ||||
-rw-r--r-- | bfd/elf.c | 19 |
2 files changed, 11 insertions, 11 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 7e5b694..d9c4856 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,5 +1,8 @@ Wed Nov 29 12:42:36 1995 Ian Lance Taylor <ian@cygnus.com> + * elf.c (assign_file_positions_for_segments): Fix case where extra + program headers were allocated. + * elf.c (_bfd_elf_print_private_bfd_data): New function. * elf-bfd.h (_bfd_elf_print_private_bfd_data): Declare. * elfxx-target.h (bfd_elfNN_bfd_print_private_bfd_data): Define to @@ -1835,13 +1835,15 @@ assign_file_positions_for_segments (abfd) { unsigned int i; asection **secpp; - boolean adjusted; p->p_type = m->p_type; if (m->p_flags_valid) p->p_flags = m->p_flags; + if (p->p_type == PT_LOAD && m->count > 0) + off += (m->sections[0]->vma - off) % bed->maxpagesize; + if (m->count == 0) p->p_vaddr = 0; else @@ -1864,7 +1866,6 @@ assign_file_positions_for_segments (abfd) p->p_filesz = 0; p->p_memsz = 0; - adjusted = false; if (p->p_type == PT_LOAD) { p->p_offset = off; @@ -1890,7 +1891,6 @@ assign_file_positions_for_segments (abfd) p->p_memsz = off; p->p_vaddr -= off; p->p_paddr -= off; - adjusted = true; } if (mi->p_type == PT_PHDR) pi_phdr = pi; @@ -1927,14 +1927,11 @@ assign_file_positions_for_segments (abfd) adjust = (sec->vma - off) % bed->maxpagesize; if (adjust != 0) { - if (i == 0 && ! adjusted) - p->p_offset += adjust; - else - { - p->p_memsz += adjust; - if ((flags & SEC_LOAD) != 0) - p->p_filesz += adjust; - } + if (i == 0) + abort (); + p->p_memsz += adjust; + if ((flags & SEC_LOAD) != 0) + p->p_filesz += adjust; off += adjust; } |