diff options
author | Jan W. Jagersma <jwjagersma@gmail.com> | 2020-04-02 14:31:43 +0100 |
---|---|---|
committer | Nick Clifton <nickc@redhat.com> | 2020-04-02 14:31:43 +0100 |
commit | 4d095f5b5e57584133f85df42da2123e20834aec (patch) | |
tree | d7368d31a7417cb1295596aa0e89567c15a0af63 /bfd/bfdio.c | |
parent | 0dd7b52ede3de7c5e43cc7c0a52a4e2f2b4297b7 (diff) | |
download | gdb-4d095f5b5e57584133f85df42da2123e20834aec.zip gdb-4d095f5b5e57584133f85df42da2123e20834aec.tar.gz gdb-4d095f5b5e57584133f85df42da2123e20834aec.tar.bz2 |
coff-go32-exe: support variable-length stubs
The stub size in GO32 executables has historically been fixed at 2048
bytes, due to hardcoded limitations in bfd. Recent patches to djgpp by
Stas Sergeev (CC'd) have pushed the stub right up to this limit, so if
any further expansion is desired, this must first be patched in bfd.
This series includes three patches: The first changes the meaning of
the bfd->origin field slightly, so that target code can use this to
specify an offset into the file where the actual bfd is located.
The second patch then uses this to enable support for variable-sized
stubs in the coff-go32-exe format.
The final patch is only a cleanup, it normalizes function and variable
names in coff-stgo32.c so that they all begin with the same prefix.
bfd * bfdio.c (bfd_bread, bfd_tell, bfd_seek, bfd_mmap): Always add
bfd->origin to file offset.
* bfdwin.c (bfd_get_file_window): Likewise.
* bfd.c: Clarify the use of the bfd->origin field.
* bfd-in2.h: Regenerate.
* coff-i386.c: Don't include go32exe.h. Allow overriding
coff_write_object_contents via COFF_WRITE_CONTENTS.
* coff-stgo32.c (go32exe_cleanup, go32exe_mkobject)
(go32exe_write_object_contents): New functions.
(go32exe_temp_stub, go32exe_temp_stub_size): New static globals.
(COFF_WRITE_CONTENTS, GO32EXE_DEFAULT_STUB_SIZE): Define.
(create_go32_stub): Remove check for 2k size limit. Read stub
from go32exe_temp_stub if present.
(go32_stubbed_coff_bfd_copy_private_bfd_data): Allocate and
copy variable-length stub.
(go32_check_format): Read stub to go32exe_temp_stub, set
origin, return go32exe_cleanup.
(adjust_filehdr_in_post, adjust_filehdr_out_pre)
(adjust_filehdr_out_post, adjust_scnhdr_in_post)
(adjust_scnhdr_out_pre, adjust_scnhdr_out_post)
(adjust_aux_in_post, adjust_aux_out_pre, adjust_aux_out_post):
Remove functions and their associated #defines.
* coffcode.h (coff_mkobject_hook): Remove stub copying code.
* libcoff-in.h: (struct coff_tdata): New field stub_size.
Rename field go32stub to stub.
* libcoff.h: Regenerate.
* coff-stgo32.c (go32_check_format): Rename to...
(go32exe_check_format): ...this.
(go32_stubbed_coff_bfd_copy_private_bfd_data): Rename to...
(go32exe_copy_private_bfd_data): ...this.
(stub_bytes): Rename to...
(go32exe_default_stub): ...this.
(create_go32_stub): Rename to...
(go32exe_create_stub): ...this.
* coff-stgo32.c (go32exe_copy_private_bfd_data): Avoid realloc
when possible.
include * coff/go32exe.h: Remove file.
* coff/internal.h (struct internal_filehdr): Remove field
go32stub. Remove flag F_GO32STUB.
Diffstat (limited to 'bfd/bfdio.c')
-rw-r--r-- | bfd/bfdio.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/bfd/bfdio.c b/bfd/bfdio.c index 9e88f5b..29834d9 100644 --- a/bfd/bfdio.c +++ b/bfd/bfdio.c @@ -201,6 +201,7 @@ bfd_bread (void *ptr, bfd_size_type size, bfd *abfd) offset += abfd->origin; abfd = abfd->my_archive; } + offset += abfd->origin; /* If this is an archive element, don't read past the end of this element. */ @@ -270,6 +271,7 @@ bfd_tell (bfd *abfd) offset += abfd->origin; abfd = abfd->my_archive; } + offset += abfd->origin; if (abfd->iovec == NULL) return 0; @@ -330,6 +332,7 @@ bfd_seek (bfd *abfd, file_ptr position, int direction) offset += abfd->origin; abfd = abfd->my_archive; } + offset += abfd->origin; if (abfd->iovec == NULL) { @@ -522,6 +525,7 @@ bfd_mmap (bfd *abfd, void *addr, bfd_size_type len, offset += abfd->origin; abfd = abfd->my_archive; } + offset += abfd->origin; if (abfd->iovec == NULL) { |