From: Max Reitz <mreitz@redhat.com>
To: Kevin Wolf <kwolf@redhat.com>
Cc: qemu-devel@nongnu.org, Stefan Hajnoczi <stefanha@redhat.com>
Subject: Re: [Qemu-devel] [PATCH 03/10] block: Make bdrv_file_open() static
Date: Fri, 31 Jan 2014 21:20:43 +0100 [thread overview]
Message-ID: <52EC059B.10209@redhat.com> (raw)
In-Reply-To: <20140129132605.GG2726@dhcp-200-207.str.redhat.com>
On 29.01.2014 14:26, Kevin Wolf wrote:
> Am 26.01.2014 um 20:02 hat Max Reitz geschrieben:
>> Add the bdrv_open() option BDRV_O_PROTOCOL which results in passing the
>> call to bdrv_file_open(). Additionally, make bdrv_file_open() static and
>> therefore bdrv_open() the only way to call it.
>>
>> Consequently, all existing calls to bdrv_file_open() have to be adjusted
>> to use bdrv_open() with the BDRV_O_PROTOCOL flag instead.
>>
>> Signed-off-by: Max Reitz <mreitz@redhat.com>
>> ---
>> block.c | 17 ++++++++++++-----
>> block/cow.c | 6 +++---
>> block/qcow.c | 6 +++---
>> block/qcow2.c | 5 +++--
>> block/qed.c | 5 +++--
>> block/sheepdog.c | 8 +++++---
>> block/vhdx.c | 5 +++--
>> block/vmdk.c | 11 +++++++----
>> include/block/block.h | 5 ++---
>> qemu-io.c | 4 +++-
>> 10 files changed, 44 insertions(+), 28 deletions(-)
>>
>> diff --git a/block.c b/block.c
>> index f9923bb..0fb7892 100644
>> --- a/block.c
>> +++ b/block.c
>> @@ -947,9 +947,9 @@ free_and_fail:
>> * after the call (even on failure), so if the caller intends to reuse the
>> * dictionary, it needs to use QINCREF() before calling bdrv_file_open.
>> */
>> -int bdrv_file_open(BlockDriverState **pbs, const char *filename,
>> - const char *reference, QDict *options, int flags,
>> - Error **errp)
>> +static int bdrv_file_open(BlockDriverState **pbs, const char *filename,
>> + const char *reference, QDict *options, int flags,
>> + Error **errp)
>> {
>> BlockDriverState *bs = NULL;
>> BlockDriver *drv;
>> @@ -1196,8 +1196,9 @@ int bdrv_open_image(BlockDriverState **pbs, const char *filename,
>> *pbs = NULL;
>> ret = bdrv_open(pbs, filename, NULL, image_options, flags, NULL, errp);
>> } else {
>> - ret = bdrv_file_open(pbs, filename, reference, image_options, flags,
>> - errp);
>> + *pbs = NULL;
>> + ret = bdrv_open(pbs, filename, reference, image_options,
>> + flags | BDRV_O_PROTOCOL, NULL, errp);
>> }
>>
>> done:
>> @@ -1227,6 +1228,12 @@ int bdrv_open(BlockDriverState **pbs, const char *filename,
>> const char *drvname;
>> Error *local_err = NULL;
>>
>> + if (flags & BDRV_O_PROTOCOL) {
>> + assert(!drv);
>> + return bdrv_file_open(pbs, filename, reference, options,
>> + flags & ~BDRV_O_PROTOCOL, errp);
>> + }
>> +
>> /* NULL means an empty set of options */
>> if (options == NULL) {
>> options = qdict_new();
>> diff --git a/block/cow.c b/block/cow.c
>> index 7fc0b12..f0748a2 100644
>> --- a/block/cow.c
>> +++ b/block/cow.c
>> @@ -332,7 +332,7 @@ static int cow_create(const char *filename, QEMUOptionParameter *options,
>> const char *image_filename = NULL;
>> Error *local_err = NULL;
>> int ret;
>> - BlockDriverState *cow_bs;
>> + BlockDriverState *cow_bs = NULL;
>>
>> /* Read out options */
>> while (options && options->name) {
>> @@ -351,8 +351,8 @@ static int cow_create(const char *filename, QEMUOptionParameter *options,
>> return ret;
>> }
>>
>> - ret = bdrv_file_open(&cow_bs, filename, NULL, NULL, BDRV_O_RDWR,
>> - &local_err);
>> + ret = bdrv_open(&cow_bs, filename, NULL, NULL,
>> + BDRV_O_RDWR | BDRV_O_PROTOCOL, NULL, &local_err);
>> if (ret < 0) {
>> qerror_report_err(local_err);
>> error_free(local_err);
>> diff --git a/block/qcow.c b/block/qcow.c
>> index 948b0c5..4881d84 100644
>> --- a/block/qcow.c
>> +++ b/block/qcow.c
>> @@ -670,7 +670,7 @@ static int qcow_create(const char *filename, QEMUOptionParameter *options,
>> int flags = 0;
>> Error *local_err = NULL;
>> int ret;
>> - BlockDriverState *qcow_bs;
>> + BlockDriverState *qcow_bs = NULL;
>>
>> /* Read out options */
>> while (options && options->name) {
>> @@ -691,8 +691,8 @@ static int qcow_create(const char *filename, QEMUOptionParameter *options,
>> return ret;
>> }
>>
>> - ret = bdrv_file_open(&qcow_bs, filename, NULL, NULL, BDRV_O_RDWR,
>> - &local_err);
>> + ret = bdrv_open(&qcow_bs, filename, NULL, NULL,
>> + BDRV_O_RDWR | BDRV_O_PROTOCOL, NULL, &local_err);
>> if (ret < 0) {
>> qerror_report_err(local_err);
>> error_free(local_err);
>> diff --git a/block/qcow2.c b/block/qcow2.c
>> index 7202a26..40b957b 100644
>> --- a/block/qcow2.c
>> +++ b/block/qcow2.c
>> @@ -1479,7 +1479,7 @@ static int qcow2_create2(const char *filename, int64_t total_size,
>> * 2 GB for 64k clusters, and we don't want to have a 2 GB initial file
>> * size for any qcow2 image.
>> */
>> - BlockDriverState* bs;
>> + BlockDriverState *bs = NULL;
>> QCowHeader *header;
>> uint8_t* refcount_table;
>> Error *local_err = NULL;
>> @@ -1491,7 +1491,8 @@ static int qcow2_create2(const char *filename, int64_t total_size,
>> return ret;
>> }
>>
>> - ret = bdrv_file_open(&bs, filename, NULL, NULL, BDRV_O_RDWR, &local_err);
>> + ret = bdrv_open(&bs, filename, NULL, NULL, BDRV_O_RDWR | BDRV_O_PROTOCOL,
>> + NULL, &local_err);
>> if (ret < 0) {
>> error_propagate(errp, local_err);
>> return ret;
>> diff --git a/block/qed.c b/block/qed.c
>> index 694e6e2..dee2e61 100644
>> --- a/block/qed.c
>> +++ b/block/qed.c
>> @@ -571,8 +571,9 @@ static int qed_create(const char *filename, uint32_t cluster_size,
>> return ret;
>> }
>>
>> - ret = bdrv_file_open(&bs, filename, NULL, NULL,
>> - BDRV_O_RDWR | BDRV_O_CACHE_WB, &local_err);
>> + ret = bdrv_open(&bs, filename, NULL, NULL,
>> + BDRV_O_RDWR | BDRV_O_CACHE_WB | BDRV_O_PROTOCOL, NULL,
>> + &local_err);
>> if (ret < 0) {
>> qerror_report_err(local_err);
>> error_free(local_err);
>> diff --git a/block/sheepdog.c b/block/sheepdog.c
>> index 672b9c9..6f2ec57 100644
>> --- a/block/sheepdog.c
>> +++ b/block/sheepdog.c
>> @@ -1534,7 +1534,8 @@ static int sd_prealloc(const char *filename)
>> Error *local_err = NULL;
>> int ret;
>>
>> - ret = bdrv_file_open(&bs, filename, NULL, NULL, BDRV_O_RDWR, &local_err);
>> + ret = bdrv_open(&bs, filename, NULL, NULL, BDRV_O_RDWR | BDRV_O_PROTOCOL,
>> + NULL, &local_err);
>> if (ret < 0) {
>> qerror_report_err(local_err);
>> error_free(local_err);
>> @@ -1683,7 +1684,7 @@ static int sd_create(const char *filename, QEMUOptionParameter *options,
>> }
>>
>> if (backing_file) {
>> - BlockDriverState *bs;
>> + BlockDriverState *bs = NULL;
>> BDRVSheepdogState *base;
>> BlockDriver *drv;
>>
>> @@ -1695,7 +1696,8 @@ static int sd_create(const char *filename, QEMUOptionParameter *options,
>> goto out;
>> }
>>
>> - ret = bdrv_file_open(&bs, backing_file, NULL, NULL, 0, &local_err);
>> + ret = bdrv_open(&bs, backing_file, NULL, NULL, BDRV_O_PROTOCOL, NULL,
>> + &local_err);
>> if (ret < 0) {
>> qerror_report_err(local_err);
>> error_free(local_err);
>> diff --git a/block/vhdx.c b/block/vhdx.c
>> index 9ee0a61..13513b4 100644
>> --- a/block/vhdx.c
>> +++ b/block/vhdx.c
>> @@ -1724,7 +1724,7 @@ static int vhdx_create(const char *filename, QEMUOptionParameter *options,
>>
>> gunichar2 *creator = NULL;
>> glong creator_items;
>> - BlockDriverState *bs;
>> + BlockDriverState *bs = NULL;
>> const char *type = NULL;
>> VHDXImageType image_type;
>> Error *local_err = NULL;
>> @@ -1797,7 +1797,8 @@ static int vhdx_create(const char *filename, QEMUOptionParameter *options,
>> goto exit;
>> }
>>
>> - ret = bdrv_file_open(&bs, filename, NULL, NULL, BDRV_O_RDWR, &local_err);
>> + ret = bdrv_open(&bs, filename, NULL, NULL, BDRV_O_RDWR | BDRV_O_PROTOCOL,
>> + NULL, &local_err);
>> if (ret < 0) {
>> error_propagate(errp, local_err);
>> goto exit;
>> diff --git a/block/vmdk.c b/block/vmdk.c
>> index 37b2bc8..d2a69d5 100644
>> --- a/block/vmdk.c
>> +++ b/block/vmdk.c
>> @@ -776,8 +776,9 @@ static int vmdk_parse_extents(const char *desc, BlockDriverState *bs,
>>
>> path_combine(extent_path, sizeof(extent_path),
>> desc_file_path, fname);
>> - ret = bdrv_file_open(&extent_file, extent_path, NULL, NULL,
>> - bs->open_flags, errp);
>> + extent_file = NULL;
>> + ret = bdrv_open(&extent_file, extent_path, NULL, NULL,
>> + bs->open_flags | BDRV_O_PROTOCOL, NULL, errp);
>> if (ret) {
>> return ret;
>> }
>> @@ -1493,7 +1494,8 @@ static int vmdk_create_extent(const char *filename, int64_t filesize,
>> goto exit;
>> }
>>
>> - ret = bdrv_file_open(&bs, filename, NULL, NULL, BDRV_O_RDWR, &local_err);
>> + ret = bdrv_open(&bs, filename, NULL, NULL, BDRV_O_RDWR | BDRV_O_PROTOCOL,
>> + NULL, &local_err);
>> if (ret < 0) {
>> error_propagate(errp, local_err);
>> goto exit;
>> @@ -1831,7 +1833,8 @@ static int vmdk_create(const char *filename, QEMUOptionParameter *options,
>> goto exit;
>> }
>> }
>> - ret = bdrv_file_open(&new_bs, filename, NULL, NULL, BDRV_O_RDWR, &local_err);
>> + ret = bdrv_open(&new_bs, filename, NULL, NULL,
>> + BDRV_O_RDWR | BDRV_O_PROTOCOL, NULL, &local_err);
>> if (ret < 0) {
>> error_setg_errno(errp, -ret, "Could not write description");
>> goto exit;
>> diff --git a/include/block/block.h b/include/block/block.h
>> index a421041..396f9ed 100644
>> --- a/include/block/block.h
>> +++ b/include/block/block.h
>> @@ -102,6 +102,8 @@ typedef enum {
>> #define BDRV_O_CHECK 0x1000 /* open solely for consistency check */
>> #define BDRV_O_ALLOW_RDWR 0x2000 /* allow reopen to change from r/o to r/w */
>> #define BDRV_O_UNMAP 0x4000 /* execute guest UNMAP/TRIM operations */
>> +#define BDRV_O_PROTOCOL 0x8000 /* open the file using a protocol instead of
>> + a block driver */
> Protocol drivers are a subset of block drivers, so this description
> doesn't make sense.
Hm, technically they probably are but it always seemed to me that
bdrv_open() would never directly use a protocol, instead using raw as
the format if no format was found.
More importantly, it is actually possible to use a non-protocol block
driver with BDRV_O_PROTOCOL; it just needs to be explicitly specified.
> I guess we need to list the differences between bdrv_open() and
> bdrv_file_open() in order to define what this flag really changes. I
> think this includes:
>
> - Disables format probing
> - BDRV_O_SNAPSHOT is ignored
> - No backing files are opened
> - Probably a few more
So, to me, the main difference is that bdrv_open() always uses some
non-protocol block driver, whereas bdrv_file_open() only probes for
protocol block drivers (if a non-protocol driver should be used, it has
to be explicitly specified).
The current comment for bdrv_file_open() doesn't help much, either:
“Opens a file using a protocol”. Therefore, the easiest way would just
be to state “behaves like the old bdrv_file_open()”, but that would not
be very helpful. Perhaps we could formulate it like “Opens a single file
(no backing chain, etc.) using only a protocol driver deduced from the
filename, if not explicitly specified otherwise.”
Max
next prev parent reply other threads:[~2014-01-31 20:19 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-01-26 19:02 [Qemu-devel] [PATCH 00/10] block: Integrate bdrv_file_open() into bdrv_open() Max Reitz
2014-01-26 19:02 ` [Qemu-devel] [PATCH 01/10] block: Change BDS parameter of bdrv_open() to ** Max Reitz
2014-01-27 2:38 ` Benoît Canet
2014-01-27 18:51 ` Max Reitz
2014-01-27 19:31 ` Jeff Cody
2014-01-27 19:35 ` Max Reitz
2014-01-29 11:50 ` Kevin Wolf
2014-01-31 20:07 ` Max Reitz
2014-02-03 9:49 ` Kevin Wolf
2014-01-26 19:02 ` [Qemu-devel] [PATCH 02/10] block: Add reference parameter to bdrv_open() Max Reitz
2014-01-26 19:02 ` [Qemu-devel] [PATCH 03/10] block: Make bdrv_file_open() static Max Reitz
2014-01-27 2:51 ` Benoît Canet
2014-01-29 13:26 ` Kevin Wolf
2014-01-31 20:20 ` Max Reitz [this message]
2014-02-03 10:05 ` Kevin Wolf
2014-01-26 19:02 ` [Qemu-devel] [PATCH 04/10] block: Reuse NULL options check from bdrv_open() Max Reitz
2014-01-27 2:52 ` Benoît Canet
2014-01-26 19:02 ` [Qemu-devel] [PATCH 05/10] block: Reuse reference handling " Max Reitz
2014-01-27 2:56 ` Benoît Canet
2014-01-26 19:02 ` [Qemu-devel] [PATCH 06/10] block: Remove bdrv_new() from bdrv_file_open() Max Reitz
2014-01-27 3:04 ` Benoît Canet
2014-01-29 13:35 ` Kevin Wolf
2014-01-31 20:21 ` Max Reitz
2014-01-26 19:02 ` [Qemu-devel] [PATCH 07/10] block: Reuse fail path from bdrv_open() Max Reitz
2014-01-27 3:10 ` Benoît Canet
2014-01-27 18:58 ` Max Reitz
2014-01-29 13:40 ` Kevin Wolf
2014-01-26 19:02 ` [Qemu-devel] [PATCH 08/10] block: Reuse bs->options setting " Max Reitz
2014-01-27 3:13 ` Benoît Canet
2014-01-29 13:45 ` Kevin Wolf
2014-01-31 20:25 ` Max Reitz
2014-01-26 19:02 ` [Qemu-devel] [PATCH 09/10] block: Reuse success path " Max Reitz
2014-01-27 17:44 ` Jeff Cody
2014-01-27 19:06 ` Max Reitz
2014-01-26 19:02 ` [Qemu-devel] [PATCH 10/10] block: Remove bdrv_open_image()'s force_raw option Max Reitz
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=52EC059B.10209@redhat.com \
--to=mreitz@redhat.com \
--cc=kwolf@redhat.com \
--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).