From: Fam Zheng <famz@redhat.com>
To: Eric Blake <eblake@redhat.com>
Cc: Kevin Wolf <kwolf@redhat.com>,
qemu-block@nongnu.org, Jeff Cody <jcody@redhat.com>,
qemu-devel@nongnu.org, qemu-stable@nongnu.org,
Stefan Hajnoczi <stefanha@redhat.com>,
pbonzini@redhat.com, jsnow@redhat.com, wangxiaolong@ucloud.cn
Subject: Re: [Qemu-devel] [PATCH v6 2/8] qmp: Add optional bool "unmap" to drive-mirror
Date: Wed, 3 Jun 2015 15:13:48 +0800 [thread overview]
Message-ID: <20150603071348.GF1533@ad.nay.redhat.com> (raw)
In-Reply-To: <556DE7B2.8020405@redhat.com>
On Tue, 06/02 11:28, Eric Blake wrote:
> On 05/27/2015 11:29 PM, Fam Zheng wrote:
> > If specified as "true", it allows discarding on target sectors where source is
> > not allocated.
> >
> > Signed-off-by: Fam Zheng <famz@redhat.com>
> > ---
>
> > +++ b/qapi/block-core.json
> > @@ -954,6 +954,11 @@
> > # @on-target-error: #optional the action to take on an error on the target,
> > # default 'report' (no limitations, since this applies to
> > # a different block device than @device).
> > +# @unmap: #optional Whether to try to unmap target sectors where source has
> > +# only zero. If true, and target unallocated sectors will read as zero,
> > +# target image sectors will be unmapped; otherwise, zeroes will be
> > +# written. Both will result in identical contents.
> > +# Default is true. (Since 2.4)
>
> Just making sure I understand:
>
> The guest sees identical contents, but with "unmap":true, the host file
> is potentially sparse, while with "unmap":false, the host file is
> fully-allocated.
>
> Also, while the default is now true, this doesn't tell me what the
> behavior was in 2.3. Is this a new default behavior (where in 2.3 you
> could not preserve sparseness), or a new knob (previously you always got
> a sparse copy, and could not request full allocation)? I'm okay either
> way, but I'm trying to understand whether libvirt should advertise this
> knob to higher-level apps, and if so, what libvirt should do when it
> detects qemu 2.3 (that is, should it tell upper-level apps that
> sparseness cannot be preserved, or that full allocation cannot be
> guaranteed, when the "unmap" parameter is not detected).
We always skip sectors which are initially unallocated (at the time of mirror
job starting), actually this even stays true for both unmap=true and
unmap=false now.
The difference is how we handle sectors discarded *after* mirror job starts:
Before, we ignore the *discard*, which means the target remains populated, with
old data before discard.
After, we honor the discard, depending on two factors:
source read as zero unmap RESULT
==========================================================================
Y true write zero with BDRV_REQ_MAY_UNMAP
Y false write zero without BDRV_REQ_MAY_UNMAP
N both discard (note that on some protocols
this may be nop)
In other words, the unmap option only affects sector X if:
1) in the beginning, sector X was allocated
2) drive-mirror starts
3) sector X got discarded at source side
All in all, this is quite advisory.
Fam
next prev parent reply other threads:[~2015-06-03 7:14 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-05-28 5:29 [Qemu-devel] [PATCH v6 0/8] block: Mirror discarded sectors Fam Zheng
2015-05-28 5:29 ` [Qemu-devel] [PATCH v6 1/8] block: Add bdrv_get_block_status_above Fam Zheng
2015-05-28 8:27 ` Paolo Bonzini
2015-05-28 5:29 ` [Qemu-devel] [PATCH v6 2/8] qmp: Add optional bool "unmap" to drive-mirror Fam Zheng
2015-05-28 8:28 ` Paolo Bonzini
2015-06-02 17:28 ` Eric Blake
2015-06-03 7:13 ` Fam Zheng [this message]
2015-05-28 5:29 ` [Qemu-devel] [PATCH v6 3/8] mirror: Do zero write on target if sectors not allocated Fam Zheng
2015-05-28 8:28 ` Paolo Bonzini
2015-05-28 5:29 ` [Qemu-devel] [PATCH v6 4/8] block: Fix dirty bitmap in bdrv_co_discard Fam Zheng
2015-05-28 5:29 ` [Qemu-devel] [PATCH v6 5/8] block: Remove bdrv_reset_dirty Fam Zheng
2015-05-28 5:29 ` [Qemu-devel] [PATCH v6 6/8] qemu-iotests: Make block job methods common Fam Zheng
2015-05-28 5:29 ` [Qemu-devel] [PATCH v6 7/8] qemu-iotests: Add test case for mirror with unmap Fam Zheng
2015-05-28 8:29 ` Paolo Bonzini
2015-05-28 5:29 ` [Qemu-devel] [PATCH v6 8/8] iotests: Use event_wait in wait_ready Fam Zheng
2015-05-28 8:30 ` Paolo Bonzini
2015-06-02 16:02 ` [Qemu-devel] [Qemu-block] [PATCH v6 0/8] block: Mirror discarded sectors Stefan Hajnoczi
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20150603071348.GF1533@ad.nay.redhat.com \
--to=famz@redhat.com \
--cc=eblake@redhat.com \
--cc=jcody@redhat.com \
--cc=jsnow@redhat.com \
--cc=kwolf@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
--cc=qemu-stable@nongnu.org \
--cc=stefanha@redhat.com \
--cc=wangxiaolong@ucloud.cn \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.