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; |
} |