qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH v2 1/4] vmdk: fix L1 and L2 table size in vmdk3


From: Kevin Wolf
Subject: Re: [Qemu-devel] [PATCH v2 1/4] vmdk: fix L1 and L2 table size in vmdk3 open
Date: Mon, 19 Aug 2013 11:53:23 +0200
User-agent: Mutt/1.5.21 (2010-09-15)

Am 13.08.2013 um 03:21 hat Fam Zheng geschrieben:
> VMDK3 header has the field l1dir_size, but vmdk_open_vmdk3 hardcoded the
> value. This patch honors the header field.
> 
> And the L2 table size is 4096 according to VMDK spec[1], instead of
> 1 << 9 (512).
> 
> [1]:
> http://www.vmware.com/support/developer/vddk/vmdk_50_technote.pdf?src=vmdk
> 
> Signed-off-by: Fam Zheng <address@hidden>
> ---
>  block/vmdk.c | 16 ++++++++--------
>  1 file changed, 8 insertions(+), 8 deletions(-)
> 
> diff --git a/block/vmdk.c b/block/vmdk.c
> index 346bb5c..1392542 100644
> --- a/block/vmdk.c
> +++ b/block/vmdk.c
> @@ -486,14 +486,14 @@ static int vmdk_open_vmdk3(BlockDriverState *bs,
>      if (ret < 0) {
>          return ret;
>      }
> -
> -    ret = vmdk_add_extent(bs,
> -                             bs->file, false,
> -                             le32_to_cpu(header.disk_sectors),
> -                             le32_to_cpu(header.l1dir_offset) << 9,
> -                             0, 1 << 6, 1 << 9,
> -                             le32_to_cpu(header.granularity),
> -                             &extent);
> +    ret = vmdk_add_extent(bs, file, false,
> +                          le32_to_cpu(header.disk_sectors),
> +                          le32_to_cpu(header.l1dir_offset) << 9,
> +                          0,
> +                          le32_to_cpu(header.l1dir_size),
> +                          4096,
> +                          le32_to_cpu(header.granularity),
> +                          &extent);

You'll want to add a sanity check for header.l1dir_dir, or move the
existing check from vmdk_open_vmdk4() to vmdk_add_extent().

Kevin



reply via email to

[Prev in Thread] Current Thread [Next in Thread]