summaryrefslogtreecommitdiff
path: root/bfd/plugin.c
diff options
context:
space:
mode:
authorH.J. Lu <hjl.tools@gmail.com>2010-09-15 17:12:53 +0000
committerH.J. Lu <hjl.tools@gmail.com>2010-09-15 17:12:53 +0000
commitbaec46a3c4d983ed7268b03cc8ecbeaa0fccf751 (patch)
treef903a0f8caee0dd744c73e3fe9a547229ed89a98 /bfd/plugin.c
parentae2adb9b2cc7f2e0645867627d0a95aaee8d92d9 (diff)
downloadbinutils-redhat-baec46a3c4d983ed7268b03cc8ecbeaa0fccf751.tar.gz
Handle NULL iostream in bfd_plugin_object_p.
2010-09-15 H.J. Lu <hongjiu.lu@intel.com> PR binutils/12004 * plugin.c (bfd_plugin_object_p): Handle NULL iostream.
Diffstat (limited to 'bfd/plugin.c')
-rw-r--r--bfd/plugin.c25
1 files changed, 15 insertions, 10 deletions
diff --git a/bfd/plugin.c b/bfd/plugin.c
index 4c24a7f6a2..a46bf905c9 100644
--- a/bfd/plugin.c
+++ b/bfd/plugin.c
@@ -233,26 +233,31 @@ bfd_plugin_object_p (bfd *abfd)
int claimed = 0;
int t = load_plugin ();
struct ld_plugin_input_file file;
+ bfd *iobfd;
+
if (!t)
return NULL;
file.name = abfd->filename;
- if (abfd->iostream)
+ if (abfd->my_archive)
{
- file.fd = fileno ((FILE *) abfd->iostream);
- file.offset = 0;
- file.filesize = 0; /*FIXME*/
+ iobfd = abfd->my_archive;
+ file.offset = abfd->origin;
+ file.filesize = arelt_size (abfd);
}
else
{
- bfd *archive = abfd->my_archive;
- BFD_ASSERT (archive);
- file.fd = fileno ((FILE *) archive->iostream);
- file.offset = abfd->origin;
- file.filesize = arelt_size (abfd);
-
+ iobfd = abfd;
+ file.offset = 0;
+ file.filesize = 0; /*FIXME*/
}
+
+ if (!iobfd->iostream && !bfd_open_file (iobfd))
+ return NULL;
+
+ file.fd = fileno ((FILE *) iobfd->iostream);
+
file.handle = abfd;
claim_file (&file, &claimed);
if (!claimed)