Skip to content

Commit

Permalink
block: Remove bdrv_new() from bdrv_file_open()
Browse files Browse the repository at this point in the history
Change bdrv_file_open() to take a simple pointer to an already existing
BDS instead of an indirect one. The BDS will be created in bdrv_open()
if necessary.

Signed-off-by: Max Reitz <mreitz@redhat.com>
Reviewed-by: Benoit Canet <benoit@irqsave.net>
Reviewed-by: Kevin Wolf <kwolf@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
  • Loading branch information
XanClic authored and kevmw committed Feb 21, 2014
1 parent 5d12aa6 commit d4446ea
Showing 1 changed file with 13 additions and 11 deletions.
24 changes: 13 additions & 11 deletions block.c
Original file line number Diff line number Diff line change
Expand Up @@ -960,10 +960,9 @@ static int bdrv_open_common(BlockDriverState *bs, BlockDriverState *file,
* 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.
*/
static int bdrv_file_open(BlockDriverState **pbs, const char *filename,
static int bdrv_file_open(BlockDriverState *bs, const char *filename,
QDict *options, int flags, Error **errp)
{
BlockDriverState *bs = NULL;
BlockDriver *drv;
const char *drvname;
bool allow_protocol_prefix = false;
Expand All @@ -975,7 +974,6 @@ static int bdrv_file_open(BlockDriverState **pbs, const char *filename,
options = qdict_new();
}

bs = bdrv_new("");
bs->options = options;
options = qdict_clone_shallow(options);

Expand Down Expand Up @@ -1049,15 +1047,13 @@ static int bdrv_file_open(BlockDriverState **pbs, const char *filename,
QDECREF(options);

bs->growable = 1;
*pbs = bs;
return 0;

fail:
QDECREF(options);
if (!bs->drv) {
QDECREF(bs->options);
}
bdrv_unref(bs);
return ret;
}

Expand Down Expand Up @@ -1252,18 +1248,24 @@ int bdrv_open(BlockDriverState **pbs, const char *filename,
return 0;
}

if (flags & BDRV_O_PROTOCOL) {
assert(!drv);
return bdrv_file_open(pbs, filename, options, flags & ~BDRV_O_PROTOCOL,
errp);
}

if (*pbs) {
bs = *pbs;
} else {
bs = bdrv_new("");
}

if (flags & BDRV_O_PROTOCOL) {
assert(!drv);
ret = bdrv_file_open(bs, filename, options, flags & ~BDRV_O_PROTOCOL,
errp);
if (ret && !*pbs) {
bdrv_unref(bs);
} else if (!ret) {
*pbs = bs;
}
return ret;
}

/* NULL means an empty set of options */
if (options == NULL) {
options = qdict_new();
Expand Down

0 comments on commit d4446ea

Please sign in to comment.