Skip to content

Commit

Permalink
block: Introduce .bdrv_parse_filename callback
Browse files Browse the repository at this point in the history
If a driver needs structured data and not just a string, it can provide
a .bdrv_parse_filename callback now that parses the command line string
into separate options. Keeping this separate from .bdrv_open_filename
ensures that the preferred way of directly specifying the options always
works as well if parsing the string works.

Signed-off-by: Kevin Wolf <[email protected]>
Reviewed-by: Eric Blake <[email protected]>
  • Loading branch information
kevmw committed Mar 22, 2013
1 parent f53a1fe commit 6963a30
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 16 deletions.
11 changes: 11 additions & 0 deletions block.c
Original file line number Diff line number Diff line change
Expand Up @@ -770,6 +770,17 @@ int bdrv_file_open(BlockDriverState **pbs, const char *filename,
bs->options = options;
options = qdict_clone_shallow(options);

if (drv->bdrv_parse_filename) {
Error *local_err = NULL;
drv->bdrv_parse_filename(filename, options, &local_err);
if (error_is_set(&local_err)) {
qerror_report_err(local_err);
error_free(local_err);
ret = -EINVAL;
goto fail;
}
}

ret = bdrv_open_common(bs, NULL, filename, options, flags, drv);
if (ret < 0) {
goto fail;
Expand Down
29 changes: 13 additions & 16 deletions block/nbd.c
Original file line number Diff line number Diff line change
Expand Up @@ -143,17 +143,20 @@ static int nbd_parse_uri(const char *filename, QDict *options)
return ret;
}

static int nbd_parse_filename(const char *filename, QDict *options)
static void nbd_parse_filename(const char *filename, QDict *options,
Error **errp)
{
char *file;
char *export_name;
const char *host_spec;
const char *unixpath;
int ret = -EINVAL;
Error *local_err = NULL;

if (strstr(filename, "://")) {
return nbd_parse_uri(filename, options);
int ret = nbd_parse_uri(filename, options);
if (ret < 0) {
error_setg(errp, "No valid URL specified");
}
return;
}

file = g_strdup(filename);
Expand All @@ -171,11 +174,11 @@ static int nbd_parse_filename(const char *filename, QDict *options)

/* extract the host_spec - fail if it's not nbd:... */
if (!strstart(file, "nbd:", &host_spec)) {
error_setg(errp, "File name string for NBD must start with 'nbd:'");
goto out;
}

if (!*host_spec) {
ret = 1;
goto out;
}

Expand All @@ -185,10 +188,8 @@ static int nbd_parse_filename(const char *filename, QDict *options)
} else {
InetSocketAddress *addr = NULL;

addr = inet_parse(host_spec, &local_err);
if (local_err != NULL) {
qerror_report_err(local_err);
error_free(local_err);
addr = inet_parse(host_spec, errp);
if (error_is_set(errp)) {
goto out;
}

Expand All @@ -197,10 +198,8 @@ static int nbd_parse_filename(const char *filename, QDict *options)
qapi_free_InetSocketAddress(addr);
}

ret = 1;
out:
g_free(file);
return ret;
}

static int nbd_config(BDRVNBDState *s, QDict *options)
Expand Down Expand Up @@ -437,11 +436,6 @@ static int nbd_open(BlockDriverState *bs, const char* filename,
qemu_co_mutex_init(&s->free_sema);

/* Pop the config into our state object. Exit if invalid. */
result = nbd_parse_filename(filename, options);
if (result < 0) {
return result;
}

result = nbd_config(s, options);
if (result != 0) {
return result;
Expand Down Expand Up @@ -622,6 +616,7 @@ static BlockDriver bdrv_nbd = {
.format_name = "nbd",
.protocol_name = "nbd",
.instance_size = sizeof(BDRVNBDState),
.bdrv_parse_filename = nbd_parse_filename,
.bdrv_file_open = nbd_open,
.bdrv_co_readv = nbd_co_readv,
.bdrv_co_writev = nbd_co_writev,
Expand All @@ -635,6 +630,7 @@ static BlockDriver bdrv_nbd_tcp = {
.format_name = "nbd",
.protocol_name = "nbd+tcp",
.instance_size = sizeof(BDRVNBDState),
.bdrv_parse_filename = nbd_parse_filename,
.bdrv_file_open = nbd_open,
.bdrv_co_readv = nbd_co_readv,
.bdrv_co_writev = nbd_co_writev,
Expand All @@ -648,6 +644,7 @@ static BlockDriver bdrv_nbd_unix = {
.format_name = "nbd",
.protocol_name = "nbd+unix",
.instance_size = sizeof(BDRVNBDState),
.bdrv_parse_filename = nbd_parse_filename,
.bdrv_file_open = nbd_open,
.bdrv_co_readv = nbd_co_readv,
.bdrv_co_writev = nbd_co_writev,
Expand Down
1 change: 1 addition & 0 deletions include/block/block_int.h
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ struct BlockDriver {
int instance_size;
int (*bdrv_probe)(const uint8_t *buf, int buf_size, const char *filename);
int (*bdrv_probe_device)(const char *filename);
void (*bdrv_parse_filename)(const char *filename, QDict *options, Error **errp);

/* For handling image reopen for split or non-split files */
int (*bdrv_reopen_prepare)(BDRVReopenState *reopen_state,
Expand Down

0 comments on commit 6963a30

Please sign in to comment.