aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2019-10-23 17:40:51 +1030
committerAlan Modra <amodra@gmail.com>2019-10-25 13:30:05 +1030
commit30fe183248b2523ecff9da36853e2f893c4c4b91 (patch)
tree3f65ea3d49d3ed120a2ed8ef92e4ef8657321a25 /include
parentc0c121b01c8a9408ae22ee9007dd0273f4c8d0be (diff)
downloadgdb-30fe183248b2523ecff9da36853e2f893c4c4b91.zip
gdb-30fe183248b2523ecff9da36853e2f893c4c4b91.tar.gz
gdb-30fe183248b2523ecff9da36853e2f893c4c4b91.tar.bz2
PR4499, assign file positions assumes segment offsets increasing
This rewrites much of assign_file_positions_for_non_load_sections to allow objcopy and strip to handle cases like that in PR4499 where program headers were not in their usual position immediately after the ELF file header, and PT_LOAD headers were not sorted by paddr. PR 4499 include/ * elf/internal.h (struct elf_segment_map): Delete header_size. Add no_sort_lma and idx. bfd/ * elf-nacl.c (nacl_modify_segment_map): Set no_sort_lma for all PT_LOAD segments. * elf32-spu.c (spu_elf_modify_segment_map): Likewise on overlay PT_LOAD segments. * elf.c (elf_sort_segments): New function. (assign_file_positions_except_relocs): Use shortcuts to elfheader and elf_tdata. Seek to e_phoff not sizeof_ehdr to write program headers. Move PT_PHDR check.. (assign_file_positions_for_non_load_sections): ..and code setting PT_PHDR p_vaddr and p_paddr, and code setting __ehdr_start value.. (assign_file_positions_for_load_sections): ..to here. Sort PT_LOAD headers. Delete header_pad code. Use actual number of headers rather than allocated in calculating size for program headers. Don't assume program headers follow ELF file header. Simplify pt_load_count code. Only set "off" for PT_LOAD or PT_NOTE in cores. (rewrite_elf_program_header): Set p_vaddr_offset for segments that include file and program headers. (copy_elf_program_header): Likewise, replacing header_size code.
Diffstat (limited to 'include')
-rw-r--r--include/ChangeLog6
-rw-r--r--include/elf/internal.h9
2 files changed, 13 insertions, 2 deletions
diff --git a/include/ChangeLog b/include/ChangeLog
index 412d714..1b3a519 100644
--- a/include/ChangeLog
+++ b/include/ChangeLog
@@ -1,3 +1,9 @@
+2019-10-25 Alan Modra <amodra@gmail.com>
+
+ PR 4499
+ * elf/internal.h (struct elf_segment_map): Delete header_size.
+ Add no_sort_lma and idx.
+
2019-10-16 Alan Modra <amodra@gmail.com>
PR 13616
diff --git a/include/elf/internal.h b/include/elf/internal.h
index 59e3ede..794c168 100644
--- a/include/elf/internal.h
+++ b/include/elf/internal.h
@@ -273,8 +273,6 @@ struct elf_segment_map
bfd_vma p_align;
/* Segment size in file and memory */
bfd_vma p_size;
- /* Required size of filehdr + phdrs, if non-zero */
- bfd_vma header_size;
/* Whether the p_flags field is valid; if not, the flags are based
on the section flags. */
unsigned int p_flags_valid : 1;
@@ -291,6 +289,13 @@ struct elf_segment_map
unsigned int includes_filehdr : 1;
/* Whether this segment includes the program headers. */
unsigned int includes_phdrs : 1;
+ /* Assume this PT_LOAD header has an lma of zero when sorting
+ headers before assigning file offsets. PT_LOAD headers with this
+ flag set are placed after one with includes_filehdr set, and
+ before PT_LOAD headers without this flag set. */
+ unsigned int no_sort_lma : 1;
+ /* Index holding original order before sorting segments. */
+ unsigned int idx;
/* Number of sections (may be 0). */
unsigned int count;
/* Sections. Actual number of elements is in count field. */