| Index: bfd/elfcore.h
|
| diff --git a/bfd/elfcore.h b/bfd/elfcore.h
|
| index 81980c0fecc49a5fb1a353971ea69c6ae9b9fdf0..429c09c758e5771fbcfb5362d96a29cf5cf09a20 100644
|
| --- a/bfd/elfcore.h
|
| +++ b/bfd/elfcore.h
|
| @@ -22,19 +22,19 @@
|
| char*
|
| elf_core_file_failing_command (bfd *abfd)
|
| {
|
| - return elf_tdata (abfd)->core_command;
|
| + return elf_tdata (abfd)->core->command;
|
| }
|
|
|
| int
|
| elf_core_file_failing_signal (bfd *abfd)
|
| {
|
| - return elf_tdata (abfd)->core_signal;
|
| + return elf_tdata (abfd)->core->signal;
|
| }
|
|
|
| int
|
| elf_core_file_pid (bfd *abfd)
|
| {
|
| - return elf_tdata (abfd)->core_pid;
|
| + return elf_tdata (abfd)->core->pid;
|
| }
|
|
|
| bfd_boolean
|
| @@ -51,7 +51,7 @@ elf_core_file_matches_executable_p (bfd *core_bfd, bfd *exec_bfd)
|
| }
|
|
|
| /* See if the name in the corefile matches the executable name. */
|
| - corename = elf_tdata (core_bfd)->core_program;
|
| + corename = elf_tdata (core_bfd)->core->program;
|
| if (corename != NULL)
|
| {
|
| const char* execname = strrchr (exec_bfd->filename, '/');
|
| @@ -84,11 +84,8 @@ elf_core_file_p (bfd *abfd)
|
| Elf_Internal_Phdr *i_phdrp; /* Elf program header, internal form. */
|
| unsigned int phindex;
|
| const struct elf_backend_data *ebd;
|
| - struct bfd_preserve preserve;
|
| bfd_size_type amt;
|
|
|
| - preserve.marker = NULL;
|
| -
|
| /* Read in the ELF header in external format. */
|
| if (bfd_bread (&x_ehdr, sizeof (x_ehdr), abfd) != sizeof (x_ehdr))
|
| {
|
| @@ -123,13 +120,9 @@ elf_core_file_p (bfd *abfd)
|
| goto wrong;
|
| }
|
|
|
| - if (!bfd_preserve_save (abfd, &preserve))
|
| - goto fail;
|
| -
|
| /* Give abfd an elf_obj_tdata. */
|
| if (! (*abfd->xvec->_bfd_set_format[bfd_core]) (abfd))
|
| goto fail;
|
| - preserve.marker = elf_tdata (abfd);
|
|
|
| /* Swap in the rest of the header, now that we have the byte order. */
|
| i_ehdrp = elf_elfheader (abfd);
|
| @@ -294,7 +287,7 @@ elf_core_file_p (bfd *abfd)
|
| {
|
| bfd_size_type high = 0;
|
| struct stat statbuf;
|
| - for (phindex = 0; phindex < i_ehdrp->e_phnum; ++phindex)
|
| + for (phindex = 0; phindex < i_ehdrp->e_phnum; ++phindex)
|
| {
|
| Elf_Internal_Phdr *p = i_phdrp + phindex;
|
| if (p->p_filesz)
|
| @@ -315,27 +308,13 @@ elf_core_file_p (bfd *abfd)
|
| }
|
| }
|
| }
|
| -
|
| +
|
| /* Save the entry point from the ELF header. */
|
| bfd_get_start_address (abfd) = i_ehdrp->e_entry;
|
| -
|
| - bfd_preserve_finish (abfd, &preserve);
|
| return abfd->xvec;
|
|
|
| wrong:
|
| - /* There is way too much undoing of half-known state here. The caller,
|
| - bfd_check_format_matches, really shouldn't iterate on live bfd's to
|
| - check match/no-match like it does. We have to rely on that a call to
|
| - bfd_default_set_arch_mach with the previously known mach, undoes what
|
| - was done by the first bfd_default_set_arch_mach (with mach 0) here.
|
| - For this to work, only elf-data and the mach may be changed by the
|
| - target-specific elf_backend_object_p function. Note that saving the
|
| - whole bfd here and restoring it would be even worse; the first thing
|
| - you notice is that the cached bfd file position gets out of sync. */
|
| bfd_set_error (bfd_error_wrong_format);
|
| -
|
| fail:
|
| - if (preserve.marker != NULL)
|
| - bfd_preserve_restore (abfd, &preserve);
|
| return NULL;
|
| }
|
|
|