summaryrefslogtreecommitdiff
path: root/bfd/vms-alpha.c
diff options
context:
space:
mode:
authorTristan Gingold <gingold@adacore.com>2010-05-14 07:45:02 +0000
committerTristan Gingold <gingold@adacore.com>2010-05-14 07:45:02 +0000
commit928ba46ea7ecff1b56458bbe52d159302ec44564 (patch)
treea81f9c2fa79427f6412e9b288e17a86ed1268325 /bfd/vms-alpha.c
parent7ead9a68ee8d32f2dede21aa84f422fe78ba3e4f (diff)
downloadbinutils-redhat-928ba46ea7ecff1b56458bbe52d159302ec44564.tar.gz
2010-05-14 Tristan Gingold <gingold@adacore.com>
* vms-alpha.c (alpha_vms_object_p): Accept header size of 0. (_bfd_vms_get_object_record): Handle align byte only in the foreign case.
Diffstat (limited to 'bfd/vms-alpha.c')
-rw-r--r--bfd/vms-alpha.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/bfd/vms-alpha.c b/bfd/vms-alpha.c
index 5ae54c245a..c4e4c9cc72 100644
--- a/bfd/vms-alpha.c
+++ b/bfd/vms-alpha.c
@@ -759,7 +759,7 @@ _bfd_vms_get_object_record (bfd *abfd)
vms_debug2 ((8, "_bfd_vms_get_obj_record\n"));
/* Skip alignment byte if the current position is odd. */
- if (bfd_tell (abfd) & 1)
+ if (PRIV (recrd.file_format) == FF_FOREIGN && (bfd_tell (abfd) & 1))
{
if (bfd_bread (PRIV (recrd.buf), 1, abfd) != 1)
{
@@ -2450,6 +2450,10 @@ alpha_vms_object_p (bfd *abfd)
/* Extract the header size. */
PRIV (recrd.rec_size) = bfd_getl32 (buf + EIHD__L_SIZE);
+ /* The header size is 0 for DSF files. */
+ if (PRIV (recrd.rec_size) == 0)
+ PRIV (recrd.rec_size) = sizeof (struct vms_eihd);
+
if (PRIV (recrd.rec_size) > PRIV (recrd.buf_size))
{
buf = bfd_realloc_or_free (buf, PRIV (recrd.rec_size));