[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v2 2/7] vmdk: clean up open
From: |
Paolo Bonzini |
Subject: |
[Qemu-devel] [PATCH v2 2/7] vmdk: clean up open |
Date: |
Thu, 20 Oct 2011 13:16:20 +0200 |
Move vmdk_parent_open to vmdk_open. There's another path how
vmdk_parent_open can be reached:
vmdk_parse_extents() -> vmdk_open_sparse() -> vmdk_open_vmdk4() ->
vmdk_open_desc_file().
If that can happen, however, the code is bogus. vmdk_parent_open
reads from bs->file:
if (bdrv_pread(bs->file, s->desc_offset, desc, DESC_SIZE) != DESC_SIZE) {
but it is always called with s->desc_offset == 0 and with the same
bs->file. So the data that vmdk_parent_open reads comes always from the
same place, and anyway there is only one place where it can write it,
namely bs->backing_file.
So, if it cannot happen, the patched code is okay.
It is also possible that the recursive call can happen, but only once. In
that case there would still be a bug in vmdk_open_desc_file setting
s->desc_offset = 0, but the patched code is okay.
Finally, in the case where multiple recursive calls can happen the code
would need to be rewritten anyway. It is likely that this would anyway
involve adding several parameters to vmdk_parent_open, and calling it from
vmdk_open_vmdk4.
Signed-off-by: Paolo Bonzini <address@hidden>
---
block/vmdk.c | 37 +++++++++++++++----------------------
1 files changed, 15 insertions(+), 22 deletions(-)
diff --git a/block/vmdk.c b/block/vmdk.c
index ea00938..ace2977 100644
--- a/block/vmdk.c
+++ b/block/vmdk.c
@@ -624,20 +624,7 @@ static int vmdk_open_desc_file(BlockDriverState *bs, int
flags,
return -ENOTSUP;
}
s->desc_offset = 0;
- ret = vmdk_parse_extents(buf, bs, bs->file->filename);
- if (ret) {
- vmdk_free_extents(bs);
- return ret;
- }
-
- /* try to open parent images, if exist */
- ret = vmdk_parent_open(bs);
- if (ret) {
- vmdk_free_extents(bs);
- return ret;
- }
- s->parent_cid = vmdk_read_cid(bs, 1);
- return 0;
+ return vmdk_parse_extents(buf, bs, bs->file->filename);
}
static int vmdk_open(BlockDriverState *bs, int flags)
@@ -647,17 +634,23 @@ static int vmdk_open(BlockDriverState *bs, int flags)
if (vmdk_open_sparse(bs, bs->file, flags) == 0) {
s->desc_offset = 0x200;
- /* try to open parent images, if exist */
- ret = vmdk_parent_open(bs);
+ } else {
+ ret = vmdk_open_desc_file(bs, flags, 0);
if (ret) {
- vmdk_free_extents(bs);
- return ret;
+ goto fail;
}
- s->parent_cid = vmdk_read_cid(bs, 1);
- return 0;
- } else {
- return vmdk_open_desc_file(bs, flags, 0);
}
+ /* try to open parent images, if exist */
+ ret = vmdk_parent_open(bs);
+ if (ret) {
+ goto fail;
+ }
+ s->parent_cid = vmdk_read_cid(bs, 1);
+ return ret;
+
+fail:
+ vmdk_free_extents(bs);
+ return ret;
}
static int get_whole_cluster(BlockDriverState *bs,
--
1.7.6
- [Qemu-devel] [PATCH v2 0/7] finish coroutinization of drivers, Paolo Bonzini, 2011/10/20
- [Qemu-devel] [PATCH v2 1/7] vmdk: fix return values of vmdk_parent_open, Paolo Bonzini, 2011/10/20
- [Qemu-devel] [PATCH v2 2/7] vmdk: clean up open,
Paolo Bonzini <=
- [Qemu-devel] [PATCH v2 3/7] block: add a CoMutex to synchronous read drivers, Paolo Bonzini, 2011/10/20
- [Qemu-devel] [PATCH v2 4/7] block: take lock around bdrv_read implementations, Paolo Bonzini, 2011/10/20
- [Qemu-devel] [PATCH v2 5/7] block: take lock around bdrv_write implementations, Paolo Bonzini, 2011/10/20
- [Qemu-devel] [PATCH v2 6/7] block: change flush to co_flush, Paolo Bonzini, 2011/10/20
- [Qemu-devel] [PATCH v2 7/7] block: change discard to co_discard, Paolo Bonzini, 2011/10/20
- Re: [Qemu-devel] [PATCH v2 0/7] finish coroutinization of drivers, Kevin Wolf, 2011/10/21