All of lore.kernel.org
 help / color / mirror / Atom feed
From: Ari Sundholm <ari@tuxera.com>
To: Max Reitz <mreitz@redhat.com>, qemu-block@nongnu.org
Cc: Kevin Wolf <kwolf@redhat.com>, qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [Qemu-block] [PATCH v9 00/31] block: Fix some filename generation issues
Date: Thu, 19 Jul 2018 15:53:14 +0300	[thread overview]
Message-ID: <2387faca-e90b-7ff4-437f-e56c2fcf4459@tuxera.com> (raw)
In-Reply-To: <86ba537d-3b77-c7d1-ac46-c85f18faf5ca@redhat.com>

On 07/13/2018 12:49 PM, Max Reitz wrote:
> Ping – any thoughts on the design, Kevin?
> 
> 
> (Continuing to see how much of a mess our backing filename handling is
> (half of the time, bs->backing_file is seen as a value in the image
> header (so relative paths are interpreted relatively to the overlay),
> half of the time it is seen as a cache of bs->backing->bs->filename (so
> relative paths are given relatively to qemu)), I am nearly inclined to
> move off the first part of this series that deals with detecting changed
> backing files until later, when I try to tackle that bs->backing_file
> issue.)
> 

I'm not Kevin, but it seems this series needs updating to accommodate 
the recent addition of the blklogwrites block driver.

Best regards,
Ari Sundholm
ari@tuxera.com

> 
> On 2018-06-28 02:07, Max Reitz wrote:
>> Once more, I’ll spare both me and you another iteration of the cover
>> letter, so see here:
>>
>> http://lists.nongnu.org/archive/html/qemu-block/2017-09/msg01030.html
>>
>> (Although this series no longer includes a @base-directory option.)
>>
>> In regards to the last version, the biggest change is that I dropped
>> backing_overridden and instead try to compare the filename from the
>> image header with the filename of the actual backing BDS to find out
>> whether the backing file has been overridden.
>>
>> In order that this doesn’t break whenever the header contains a slightly
>> unusual (“non-canonical”) backing filename (e.g. “file:foo.qcow2” or
>> “nbd:localhost:10809” instead of “nbd://localhost:10809”, i.e. something
>> different from what bdrv_refresh_filename() would generate), when the
>> reference filename in the BDS (auto_backing_file) is used to open the
>> backing file, it is updated from the backing BDS's resulting filename.
>>
>>
>> All (I hope) changes in v9:
>> - Rebase (warranting an NVME patch)
>>
>> - Dropped backing_overridden, switched to the comparison described above
>>    (and dealt with the fallout, for example test 191 can now stay
>>    unchanged)
>>
>> - Removed all existing bdrv_refresh_filename() calls and moved them to
>>    the users of BDS.filename (first patch) -- otherwise, I got iotest
>>    failure (because it's hard to reflect all graph changes properly with
>>    a “pushing” bdrv_refresh_filename()), and I don't even want to
>>    remember how 191 broke without this change.
>>
>> - Renamed “significant options” to “strong options”
>>
>> - Implicit nodes should be completely skipped in
>>    bdrv_refresh_filename(), including setting of bs->full_open_options
>>    (patch 3)
>>
>> - vmdk_gather_child_options() failed to set backing=null when the image
>>    header asked for a backing file, but the user forbid its use
>>
>> - Added the penultimate patch which makes json:{} filenames for explicit
>>    internal nodes kind of working?
>>    (When you specify @filter-node e.g. for block-commit, the node should
>>    be visible, so it may appear in a json:{} filename; but creating that
>>    node did not take a real options QDict, so it was lacking the @driver
>>    option, and that was a bit sad.)
>>
>> - Dropped a superfluous “suspend.” in blkdebug
>>
>> - Dropped the first patch of v8
>>
>> - Restyled some comments (“/*” on its own line where “*/” is on its own
>>    line)
>>
>> - Fixed mention of "NBD" in the NFS patch (18)
>>
>>
>> git-backport-diff against v8:
>>
>> Key:
>> [----] : patches are identical
>> [####] : number of functional differences between upstream/downstream patch
>> [down] : patch is downstream-only
>> The flags [FC] indicate (F)unctional and (C)ontextual differences, respectively
>>
>> 001/31:[down] 'block: Use bdrv_refresh_filename() to pull'
>> 002/31:[----] [--] 'block: Use children list in bdrv_refresh_filename'
>> 003/31:[down] 'block: Skip implicit nodes for filename info'
>> 004/31:[down] 'block: Add BDS.auto_backing_file'
>> 005/31:[0052] [FC] 'block: Respect backing bs in bdrv_refresh_filename'
>> 006/31:[down] 'iotests.py: Add filter_imgfmt()'
>> 007/31:[down] 'iotests.py: Add node_info()'
>> 008/31:[down] 'iotests: Add test for backing file overrides'
>> 009/31:[----] [--] 'block: Make path_combine() return the path'
>> 010/31:[0016] [FC] 'block: bdrv_get_full_backing_filename_from_...'s ret. val.'
>> 011/31:[0001] [FC] 'block: bdrv_get_full_backing_filename's ret. val.'
>> 012/31:[0022] [FC] 'block: Add bdrv_make_absolute_filename()'
>> 013/31:[0003] [FC] 'block: Fix bdrv_find_backing_image()'
>> 014/31:[0001] [FC] 'block: Add bdrv_dirname()'
>> 015/31:[----] [--] 'blkverify: Make bdrv_dirname() return NULL'
>> 016/31:[----] [-C] 'quorum: Make bdrv_dirname() return NULL'
>> 017/31:[----] [-C] 'block/nbd: Make bdrv_dirname() return NULL'
>> 018/31:[0003] [FC] 'block/nfs: Implement bdrv_dirname()'
>> 019/31:[0014] [FC] 'block: Use bdrv_dirname() for relative filenames'
>> 020/31:[----] [--] 'iotests: Add quorum case to test 110'
>> 021/31:[down] 'block: Add strong_runtime_opts to BlockDriver'
>> 022/31:[0037] [FC] 'block: Add BlockDriver.bdrv_gather_child_options'
>> 023/31:[0084] [FC] 'block: Generically refresh runtime options'
>> 024/31:[0076] [FC] 'block: Purify .bdrv_refresh_filename()'
>> 025/31:[0005] [FC] 'block: Do not copy exact_filename from format file'
>> 026/31:[down] 'block/nvme: Fix bdrv_refresh_filename()'
>> 027/31:[----] [--] 'block/curl: Harmonize option defaults'
>> 028/31:[----] [-C] 'block/curl: Implement bdrv_refresh_filename()'
>> 029/31:[----] [--] 'block/null: Generate filename even with latency-ns'
>> 030/31:[down] 'block: BDS options may lack the "driver" option'
>> 031/31:[down] 'iotests: Test json:{} filenames of internal BDSs'
>>
>>
>> Max Reitz (31):
>>    block: Use bdrv_refresh_filename() to pull
>>    block: Use children list in bdrv_refresh_filename
>>    block: Skip implicit nodes for filename info
>>    block: Add BDS.auto_backing_file
>>    block: Respect backing bs in bdrv_refresh_filename
>>    iotests.py: Add filter_imgfmt()
>>    iotests.py: Add node_info()
>>    iotests: Add test for backing file overrides
>>    block: Make path_combine() return the path
>>    block: bdrv_get_full_backing_filename_from_...'s ret. val.
>>    block: bdrv_get_full_backing_filename's ret. val.
>>    block: Add bdrv_make_absolute_filename()
>>    block: Fix bdrv_find_backing_image()
>>    block: Add bdrv_dirname()
>>    blkverify: Make bdrv_dirname() return NULL
>>    quorum: Make bdrv_dirname() return NULL
>>    block/nbd: Make bdrv_dirname() return NULL
>>    block/nfs: Implement bdrv_dirname()
>>    block: Use bdrv_dirname() for relative filenames
>>    iotests: Add quorum case to test 110
>>    block: Add strong_runtime_opts to BlockDriver
>>    block: Add BlockDriver.bdrv_gather_child_options
>>    block: Generically refresh runtime options
>>    block: Purify .bdrv_refresh_filename()
>>    block: Do not copy exact_filename from format file
>>    block/nvme: Fix bdrv_refresh_filename()
>>    block/curl: Harmonize option defaults
>>    block/curl: Implement bdrv_refresh_filename()
>>    block/null: Generate filename even with latency-ns
>>    block: BDS options may lack the "driver" option
>>    iotests: Test json:{} filenames of internal BDSs
>>
>>   include/block/block.h         |  16 +-
>>   include/block/block_int.h     |  48 +++-
>>   block.c                       | 505 ++++++++++++++++++++++------------
>>   block/blkdebug.c              |  70 ++---
>>   block/blkverify.c             |  29 +-
>>   block/commit.c                |   3 +-
>>   block/crypto.c                |   8 +
>>   block/curl.c                  |  55 +++-
>>   block/gluster.c               |  19 ++
>>   block/iscsi.c                 |  18 ++
>>   block/mirror.c                |   3 +-
>>   block/nbd.c                   |  46 ++--
>>   block/nfs.c                   |  54 ++--
>>   block/null.c                  |  32 ++-
>>   block/nvme.c                  |  27 +-
>>   block/qapi.c                  |  16 +-
>>   block/qcow.c                  |  14 +-
>>   block/qcow2.c                 |  17 +-
>>   block/qed.c                   |   7 +-
>>   block/quorum.c                |  71 +++--
>>   block/raw-format.c            |  11 +-
>>   block/rbd.c                   |  14 +
>>   block/replication.c           |  10 +-
>>   block/sheepdog.c              |  12 +
>>   block/ssh.c                   |  12 +
>>   block/throttle.c              |   7 +
>>   block/vhdx-log.c              |   1 +
>>   block/vmdk.c                  |  43 ++-
>>   block/vpc.c                   |  11 +-
>>   block/vvfat.c                 |  12 +
>>   block/vxhs.c                  |  11 +
>>   blockdev.c                    |   8 +
>>   qemu-img.c                    |  12 +-
>>   tests/qemu-iotests/051.out    |   8 +-
>>   tests/qemu-iotests/051.pc.out |   8 +-
>>   tests/qemu-iotests/110        |  29 +-
>>   tests/qemu-iotests/110.out    |   9 +-
>>   tests/qemu-iotests/223        | 235 ++++++++++++++++
>>   tests/qemu-iotests/223.out    |  84 ++++++
>>   tests/qemu-iotests/224        | 139 ++++++++++
>>   tests/qemu-iotests/224.out    |  18 ++
>>   tests/qemu-iotests/group      |   2 +
>>   tests/qemu-iotests/iotests.py |  10 +
>>   43 files changed, 1374 insertions(+), 390 deletions(-)
>>   create mode 100755 tests/qemu-iotests/223
>>   create mode 100644 tests/qemu-iotests/223.out
>>   create mode 100755 tests/qemu-iotests/224
>>   create mode 100644 tests/qemu-iotests/224.out
>>
> 
> 

      reply	other threads:[~2018-07-19 13:04 UTC|newest]

Thread overview: 52+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-06-28  0:07 [Qemu-devel] [PATCH v9 00/31] block: Fix some filename generation issues Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 01/31] block: Use bdrv_refresh_filename() to pull Max Reitz
2018-06-28 21:48   ` Eric Blake
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 02/31] block: Use children list in bdrv_refresh_filename Max Reitz
2018-07-19 12:47   ` [Qemu-devel] [Qemu-block] " Ari Sundholm
2018-07-21 21:14     ` Max Reitz
2018-07-23 12:15       ` Ari Sundholm
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 03/31] block: Skip implicit nodes for filename info Max Reitz
2018-06-28 21:49   ` Eric Blake
2018-08-07 14:31   ` [Qemu-devel] [Qemu-block] " Alberto Garcia
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 04/31] block: Add BDS.auto_backing_file Max Reitz
2018-06-28 21:55   ` Eric Blake
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 05/31] block: Respect backing bs in bdrv_refresh_filename Max Reitz
2018-06-28 21:58   ` Eric Blake
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 06/31] iotests.py: Add filter_imgfmt() Max Reitz
2018-06-28 21:59   ` Eric Blake
2018-08-07 15:15   ` [Qemu-devel] [Qemu-block] " Alberto Garcia
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 07/31] iotests.py: Add node_info() Max Reitz
2018-08-07 14:49   ` [Qemu-devel] [Qemu-block] " Alberto Garcia
2018-08-09 17:53     ` Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 08/31] iotests: Add test for backing file overrides Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 09/31] block: Make path_combine() return the path Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 10/31] block: bdrv_get_full_backing_filename_from_...'s ret. val Max Reitz
2018-08-07 15:03   ` [Qemu-devel] [Qemu-block] " Alberto Garcia
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 11/31] block: bdrv_get_full_backing_filename's " Max Reitz
2018-08-07 15:07   ` [Qemu-devel] [Qemu-block] " Alberto Garcia
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 12/31] block: Add bdrv_make_absolute_filename() Max Reitz
2018-08-07 15:07   ` [Qemu-devel] [Qemu-block] " Alberto Garcia
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 13/31] block: Fix bdrv_find_backing_image() Max Reitz
2018-08-07 15:10   ` [Qemu-devel] [Qemu-block] " Alberto Garcia
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 14/31] block: Add bdrv_dirname() Max Reitz
2018-08-07 15:11   ` [Qemu-devel] [Qemu-block] " Alberto Garcia
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 15/31] blkverify: Make bdrv_dirname() return NULL Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 16/31] quorum: " Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 17/31] block/nbd: " Max Reitz
2018-06-28 22:05   ` Eric Blake
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 18/31] block/nfs: Implement bdrv_dirname() Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 19/31] block: Use bdrv_dirname() for relative filenames Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 20/31] iotests: Add quorum case to test 110 Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 21/31] block: Add strong_runtime_opts to BlockDriver Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 22/31] block: Add BlockDriver.bdrv_gather_child_options Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 23/31] block: Generically refresh runtime options Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 24/31] block: Purify .bdrv_refresh_filename() Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 25/31] block: Do not copy exact_filename from format file Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 26/31] block/nvme: Fix bdrv_refresh_filename() Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 27/31] block/curl: Harmonize option defaults Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 28/31] block/curl: Implement bdrv_refresh_filename() Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 29/31] block/null: Generate filename even with latency-ns Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 30/31] block: BDS options may lack the "driver" option Max Reitz
2018-06-28  0:07 ` [Qemu-devel] [PATCH v9 31/31] iotests: Test json:{} filenames of internal BDSs Max Reitz
2018-07-13  9:49 ` [Qemu-devel] [PATCH v9 00/31] block: Fix some filename generation issues Max Reitz
2018-07-19 12:53   ` Ari Sundholm [this message]

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=2387faca-e90b-7ff4-437f-e56c2fcf4459@tuxera.com \
    --to=ari@tuxera.com \
    --cc=kwolf@redhat.com \
    --cc=mreitz@redhat.com \
    --cc=qemu-block@nongnu.org \
    --cc=qemu-devel@nongnu.org \
    /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.