vhdx: correctly propagate errors

Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Reviewed-by: Fam Zheng <famz@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
Paolo Bonzini 2014-02-17 14:44:00 +01:00 committed by Kevin Wolf
parent 0fea6b7972
commit 6890aad46b

View File

@ -402,9 +402,10 @@ int vhdx_update_headers(BlockDriverState *bs, BDRVVHDXState *s,
} }
/* opens the specified header block from the VHDX file header section */ /* opens the specified header block from the VHDX file header section */
static int vhdx_parse_header(BlockDriverState *bs, BDRVVHDXState *s) static void vhdx_parse_header(BlockDriverState *bs, BDRVVHDXState *s,
Error **errp)
{ {
int ret = 0; int ret;
VHDXHeader *header1; VHDXHeader *header1;
VHDXHeader *header2; VHDXHeader *header2;
bool h1_valid = false; bool h1_valid = false;
@ -462,7 +463,6 @@ static int vhdx_parse_header(BlockDriverState *bs, BDRVVHDXState *s)
} else if (!h1_valid && h2_valid) { } else if (!h1_valid && h2_valid) {
s->curr_header = 1; s->curr_header = 1;
} else if (!h1_valid && !h2_valid) { } else if (!h1_valid && !h2_valid) {
ret = -EINVAL;
goto fail; goto fail;
} else { } else {
/* If both headers are valid, then we choose the active one by the /* If both headers are valid, then we choose the active one by the
@ -473,27 +473,22 @@ static int vhdx_parse_header(BlockDriverState *bs, BDRVVHDXState *s)
} else if (h2_seq > h1_seq) { } else if (h2_seq > h1_seq) {
s->curr_header = 1; s->curr_header = 1;
} else { } else {
ret = -EINVAL;
goto fail; goto fail;
} }
} }
vhdx_region_register(s, s->headers[s->curr_header]->log_offset, vhdx_region_register(s, s->headers[s->curr_header]->log_offset,
s->headers[s->curr_header]->log_length); s->headers[s->curr_header]->log_length);
ret = 0;
goto exit; goto exit;
fail: fail:
qerror_report(ERROR_CLASS_GENERIC_ERROR, "No valid VHDX header found"); error_setg_errno(errp, -ret, "No valid VHDX header found");
qemu_vfree(header1); qemu_vfree(header1);
qemu_vfree(header2); qemu_vfree(header2);
s->headers[0] = NULL; s->headers[0] = NULL;
s->headers[1] = NULL; s->headers[1] = NULL;
exit: exit:
qemu_vfree(buffer); qemu_vfree(buffer);
return ret;
} }
@ -878,7 +873,7 @@ static int vhdx_open(BlockDriverState *bs, QDict *options, int flags,
int ret = 0; int ret = 0;
uint32_t i; uint32_t i;
uint64_t signature; uint64_t signature;
Error *local_err = NULL;
s->bat = NULL; s->bat = NULL;
s->first_visible_write = true; s->first_visible_write = true;
@ -901,8 +896,10 @@ static int vhdx_open(BlockDriverState *bs, QDict *options, int flags,
* header update */ * header update */
vhdx_guid_generate(&s->session_guid); vhdx_guid_generate(&s->session_guid);
ret = vhdx_parse_header(bs, s); vhdx_parse_header(bs, s, &local_err);
if (ret < 0) { if (local_err != NULL) {
error_propagate(errp, local_err);
ret = -EINVAL;
goto fail; goto fail;
} }