qemu-devel
[Top][All Lists]
Advanced

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

Re: [Qemu-devel] [PATCH V9 00/14] qmp/hmp interfaces for internal snapsh


From: Wenchao Xia
Subject: Re: [Qemu-devel] [PATCH V9 00/14] qmp/hmp interfaces for internal snapshot info
Date: Mon, 18 Mar 2013 18:30:03 +0800
User-agent: Mozilla/5.0 (Windows NT 5.1; rv:17.0) Gecko/20130307 Thunderbird/17.0.4

于 2013-3-15 16:07, Kevin Wolf 写道:
Am 15.03.2013 um 07:07 hat Wenchao Xia geschrieben:
于 2013-3-13 20:40, Stefan Hajnoczi 写道:
The same applies for VMDK where one .vmdk can reference multiple extent
files.

   I'd like to confirm: This means a block device can have multiple
images at top level, but one image can still have only one backing
image at most? If my understanding is correct,following should be the
case:

1 device hda have two active images: a.qcow2 and b.qcow2(maybe vmdk
format now, just an example)
2 a.qcow2 file's backing file will be a_base0.qcow2, never a_base0.qcow2
and a_base1.qcow2.

I don't think this describes exactly what happens. Each qemu block
device refers to one BlockDriverState, let's say top.vmdk for the top
level image. This may refer to a backing file, backing.vmdk for example.

Now top.vmdk nd back.vmdk could both be split images, and the former
refers to its extents top_0.vmdk and top_1.vmdk, which contain the
actual data of the image, and the latter may refer to backing_0.vmdk,
backing_1.vmdk and backing_2.vmdk.

So this can happen in any position in the BlockDriverState graph.

  Thank u for the detailed explaination. Currently BlockDriverState
have only one file name, so if my understanding is correct, the multiple
referred disk is actually an internal data struct in VMDK now. Qemu main
block layer only saw "main" disk in each layer.

an case:
BlockDriverState:
     |
top.vmdk<-----------------------------------ref_top.vmdk
     |                                            |
backing_top.vmdk<---ref_backing_top.vmdk  backing_ref_top.vmdk

  This seems hard to be reflected in the structure I defined before,
and hard to get in currently block.c's API. what I can think is
improve ImageInfo:

{ 'type': 'ImageInfo',
   'data': {'filename': 'str', 'format': 'str', '*dirty-flag': 'bool',
            '*actual-size': 'int', 'virtual-size': 'int',
            '*cluster-size': 'int', '*encrypted': 'bool',
            '*backing-filename': 'str', '*full-backing-filename': 'str',
            '*backing-filename-format': 'str',
            '*backing-image": 'ImageInfo',
            '*ref-images": '[ImageInfo]',
            '*snapshots': ['SnapshotInfo'] } }

  Backing-image reflect that one image can have one main backing file,
and one image can have multiple referenced images. Do you think this
structure is good enough?


   Since ImageInfo already have key 'backing-filename', which stands for
the information got in this image, not from the backing image,
add a new key 'bakcing-image' for recursive linking:

{ 'type': 'ImageInfo',
   'data': {'filename': 'str', 'format': 'str', '*dirty-flag': 'bool',
            '*actual-size': 'int', 'virtual-size': 'int',
            '*cluster-size': 'int', '*encrypted': 'bool',
            '*backing-filename': 'str', '*full-backing-filename': 'str',
            '*backing-filename-format': 'str',
            '*backing-image": 'ImageInfo',
            '*snapshots': ['SnapshotInfo'] } }

   Then insert ImageInfo into BlockDeviceInfo, with key 'images', since
'file' is already used which may break compatibility if we change it.
'images' uses an array for the case when multiple images exist in
top level, not for backing chain.

{ 'type': 'BlockDeviceInfo',
   'data': { 'file': 'str', 'ro': 'bool', 'drv': 'str',
             '*backing_file': 'str', 'backing_file_depth': 'int',
             'encrypted': 'bool', 'encryption_key_missing': 'bool',
             'bps': 'int', 'bps_rd': 'int', 'bps_wr': 'int',
             'iops': 'int', 'iops_rd': 'int', 'iops_wr': 'int',
             'images': ['ImageInfo']} }}

Yes, I think this is what Stefan meant (at least it looks like what I
was thinking of).

Kevin



--
Best Regards

Wenchao Xia




reply via email to

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