qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Kevin Wolf <kwolf@redhat.com>
To: Max Reitz <mreitz@redhat.com>
Cc: berto@igalia.com, qemu-block@nongnu.org, jcody@redhat.com,
	qemu-devel@nongnu.org, armbru@redhat.com, stefanha@redhat.com
Subject: Re: [Qemu-devel] [PATCH 13/16] block: Implement bdrv_append() without bdrv_swap()
Date: Tue, 29 Sep 2015 15:51:51 +0200	[thread overview]
Message-ID: <20150929135151.GK3930@noname.str.redhat.com> (raw)
In-Reply-To: <5602D522.5030905@redhat.com>

[-- Attachment #1: Type: text/plain, Size: 4337 bytes --]

Am 23.09.2015 um 18:36 hat Max Reitz geschrieben:
> On 17.09.2015 15:48, Kevin Wolf wrote:
> > Remember all parent nodes and just change the pointers there instead of
> > swapping the contents of the BlockDriverState.
> > 
> > Handling of snapshot=on must be moved further down in bdrv_open()
> > because *pbs (which is the bs pointer in the BlockBackend) must already
> > be set before bdrv_append() is called. Otherwise bdrv_append() changes
> > the BB's pointer to the temporary snapshot, but bdrv_open() overwrites
> > it with the read-only original image.
> > 
> > Signed-off-by: Kevin Wolf <kwolf@redhat.com>

> > @@ -2155,6 +2157,42 @@ void bdrv_swap(BlockDriverState *bs_new, BlockDriverState *bs_old)
> >      bdrv_rebind(bs_old);
> >  }
> >  
> > +static void change_parent_backing_link(BlockDriverState *from,
> > +                                       BlockDriverState *to)
> > +{
> > +    BdrvChild *c, *next;
> > +
> > +    QLIST_FOREACH_SAFE(c, &from->parents, next_parent, next) {
> > +        assert(c->role != &child_backing);
> > +        c->bs = to;
> > +        QLIST_REMOVE(c, next_parent);
> > +        QLIST_INSERT_HEAD(&to->parents, c, next_parent);
> 
> This drops a reference from the parent BDS to @from, and adds a new one
> from the parent BDS to @to. However, this is not reflected here.

You mean bdrv_ref(to); bdrv_unref(from); ?

> > +    }
> > +    if (from->blk) {
> > +        blk_set_bs(from->blk, to);
> > +        if (!to->device_list.tqe_prev) {
> > +            QTAILQ_INSERT_BEFORE(from, to, device_list);
> > +        }
> > +        QTAILQ_REMOVE(&bdrv_states, from, device_list);
> > +    }
> > +}
> > +
> > +static void swap_feature_fields(BlockDriverState *bs_top,
> > +                                BlockDriverState *bs_new)
> > +{
> > +    BlockDriverState tmp;
> > +
> > +    bdrv_move_feature_fields(&tmp, bs_top);
> > +    bdrv_move_feature_fields(bs_top, bs_new);
> > +    bdrv_move_feature_fields(bs_new, &tmp);
> > +
> > +    assert(!bs_new->io_limits_enabled);
> > +    if (bs_top->io_limits_enabled) {
> > +        bdrv_io_limits_enable(bs_new, throttle_group_get_name(bs_top));
> > +        bdrv_io_limits_disable(bs_top);
> > +    }
> > +}
> > +
> >  /*
> >   * Add new bs contents at the top of an image chain while the chain is
> >   * live, while keeping required fields on the top layer.
> > @@ -2165,14 +2203,29 @@ void bdrv_swap(BlockDriverState *bs_new, BlockDriverState *bs_old)
> >   * bs_new must not be attached to a BlockBackend.
> >   *
> >   * This function does not create any image files.
> > + *
> > + * bdrv_append() takes ownership of a bs_new reference and unrefs it because
> > + * that's what the callers commonly need. bs_new will be referenced by the old
> > + * parents of bs_top after bdrv_append() returns. If the caller needs to keep a
> > + * reference of its own, it must call bdrv_ref().
> >   */
> >  void bdrv_append(BlockDriverState *bs_new, BlockDriverState *bs_top)
> >  {
> > -    bdrv_swap(bs_new, bs_top);
> > +    assert(!bdrv_requests_pending(bs_top));
> > +    assert(!bdrv_requests_pending(bs_new));
> > +
> > +    bdrv_ref(bs_top);
> > +    change_parent_backing_link(bs_top, bs_new);
> > +
> > +    /* Some fields always stay on top of the backing file chain */
> > +    swap_feature_fields(bs_top, bs_new);
> > +
> > +    bdrv_set_backing_hd(bs_new, bs_top);
> > +    bdrv_unref(bs_top);
> >  
> > -    /* The contents of 'tmp' will become bs_top, as we are
> > -     * swapping bs_new and bs_top contents. */
> > -    bdrv_set_backing_hd(bs_top, bs_new);
> > +    /* bs_new is now referenced by its new parents, we don't need the
> > +     * additional reference any more. */
> > +    bdrv_unref(bs_new);
> >  }
> 
> Before, all pointers to @bs_new were moved to @bs_top. Now, they stay at
> @bs_new. I suppose we are assuming there are no pointers to @bs_new,
> should we assert that, and/or point it out in the documentation?

How would you assert something like this? Also, I think it's currently
true, but there's no reason why it should stay so. The important part is
just that it's true while applying the patch because the semantics
changes. Once it's applied, we have sane behaviour and can make use of
it.

Kevin

[-- Attachment #2: Type: application/pgp-signature, Size: 836 bytes --]

  reply	other threads:[~2015-09-29 13:52 UTC|newest]

Thread overview: 68+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-09-17 13:48 [Qemu-devel] [PATCH 00/16] block: Get rid of bdrv_swap() Kevin Wolf
2015-09-17 13:48 ` [Qemu-devel] [PATCH 01/16] block: Introduce BDS.file_child Kevin Wolf
2015-09-22 17:14   ` Max Reitz
2015-09-22 17:17     ` Max Reitz
2015-09-23 14:26   ` Alberto Garcia
2015-09-17 13:48 ` [Qemu-devel] [PATCH 02/16] vmdk: Use BdrvChild instead of BDS for references to extents Kevin Wolf
2015-09-22 17:45   ` Max Reitz
2015-09-23 13:23   ` Alberto Garcia
2015-09-17 13:48 ` [Qemu-devel] [PATCH 03/16] blkverify: Convert s->test_file to BdrvChild Kevin Wolf
2015-09-22 17:51   ` Max Reitz
2015-09-23 13:01   ` Alberto Garcia
2015-09-23 13:58     ` Kevin Wolf
2015-09-23 14:05       ` Alberto Garcia
2015-09-23 14:11   ` Alberto Garcia
2015-09-17 13:48 ` [Qemu-devel] [PATCH 04/16] quorum: Convert " Kevin Wolf
2015-09-22 17:57   ` Max Reitz
2015-09-23 12:48   ` Alberto Garcia
2015-09-17 13:48 ` [Qemu-devel] [PATCH 05/16] block: Convert bs->file " Kevin Wolf
2015-09-22 18:36   ` Max Reitz
2015-09-23 13:13     ` Kevin Wolf
2015-09-23 14:54   ` Alberto Garcia
2015-09-25 14:09   ` Alberto Garcia
2015-09-17 13:48 ` [Qemu-devel] [PATCH 06/16] block: Remove bdrv_open_image() Kevin Wolf
2015-09-22 18:38   ` Max Reitz
2015-09-23 13:10   ` Alberto Garcia
2015-09-17 13:48 ` [Qemu-devel] [PATCH 07/16] block: Convert bs->backing_hd to BdrvChild Kevin Wolf
2015-09-22 19:21   ` Max Reitz
2015-09-17 13:48 ` [Qemu-devel] [PATCH 08/16] block: Manage backing file references in bdrv_set_backing_hd() Kevin Wolf
2015-09-23 15:22   ` Max Reitz
2015-09-28 12:29   ` Alberto Garcia
2015-09-17 13:48 ` [Qemu-devel] [PATCH 09/16] block: Split bdrv_move_feature_fields() Kevin Wolf
2015-09-23 16:36   ` Max Reitz
2015-09-29 13:37     ` Kevin Wolf
2015-09-30 14:51   ` Max Reitz
2015-09-17 13:48 ` [Qemu-devel] [PATCH 10/16] block/io: Make bdrv_requests_pending() public Kevin Wolf
2015-09-23 15:40   ` Max Reitz
2015-09-29 12:29     ` Kevin Wolf
2015-09-28 12:32   ` Alberto Garcia
2015-09-17 13:48 ` [Qemu-devel] [PATCH 11/16] block-backend: Add blk_set_bs() Kevin Wolf
2015-09-23 15:46   ` Max Reitz
2015-09-23 15:51     ` Kevin Wolf
2015-09-17 13:48 ` [Qemu-devel] [PATCH 12/16] block: Introduce parents list Kevin Wolf
2015-09-23 16:39   ` Max Reitz
2015-09-28 13:09   ` Alberto Garcia
2015-09-29 12:21     ` Kevin Wolf
2015-09-29 14:00       ` Alberto Garcia
2015-09-17 13:48 ` [Qemu-devel] [PATCH 13/16] block: Implement bdrv_append() without bdrv_swap() Kevin Wolf
2015-09-18 11:45   ` Alberto Garcia
2015-09-18 12:24     ` Kevin Wolf
2015-09-18 13:31       ` Alberto Garcia
2015-09-18 14:23         ` Kevin Wolf
2015-09-23 16:36   ` Max Reitz
2015-09-29 13:51     ` Kevin Wolf [this message]
2015-09-30 14:45       ` Max Reitz
2015-09-30 15:33         ` Kevin Wolf
2015-09-17 13:48 ` [Qemu-devel] [PATCH 14/16] blockjob: Store device name at job creation Kevin Wolf
2015-09-23 16:46   ` Max Reitz
2015-09-17 13:48 ` [Qemu-devel] [PATCH 15/16] block: Add and use bdrv_replace_in_backing_chain() Kevin Wolf
2015-09-23 17:08   ` Max Reitz
2015-09-29 15:22     ` Kevin Wolf
2015-09-30 14:50       ` Max Reitz
2015-09-30 14:50   ` Max Reitz
2015-09-17 13:48 ` [Qemu-devel] [PATCH 16/16] block: Remove bdrv_swap() Kevin Wolf
2015-09-23 17:09   ` Max Reitz
2015-09-28 13:24   ` Alberto Garcia
2015-09-18 11:03 ` [Qemu-devel] [PATCH 00/16] block: Get rid of bdrv_swap() Alberto Garcia
2015-09-22 10:07   ` Kevin Wolf
2015-09-24 18:32 ` Alberto Garcia

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=20150929135151.GK3930@noname.str.redhat.com \
    --to=kwolf@redhat.com \
    --cc=armbru@redhat.com \
    --cc=berto@igalia.com \
    --cc=jcody@redhat.com \
    --cc=mreitz@redhat.com \
    --cc=qemu-block@nongnu.org \
    --cc=qemu-devel@nongnu.org \
    --cc=stefanha@redhat.com \
    /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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).