If the filename is not prefixed by "blkverify:" in blkverify_parse_filename(), the blkverify driver was not selected through that protocol prefix, but by an explicit command line option (like file.driver=blkverify). Contrary to the current reaction, this is not really a problem; the whole filename just has to be stored (in the x-image option) and the user has to manually specify the x-raw option.
Signed-off-by: Max Reitz <mre...@redhat.com> --- The x-raw option is undocumented and may be removed at any point in time; but I don't see a reason why this should happen. Passing the reference filename through an option maybe was a bit dirty in the past; but by “exposing” it in the way this patch does, it becomes probably the only clean solution. The only problem I can see right now is the naming of the option, but we should always be able to leave it as an alias, if necessary. --- block/blkverify.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/block/blkverify.c b/block/blkverify.c index 3c63528..bdbdd68 100644 --- a/block/blkverify.c +++ b/block/blkverify.c @@ -78,7 +78,9 @@ static void blkverify_parse_filename(const char *filename, QDict *options, /* Parse the blkverify: prefix */ if (!strstart(filename, "blkverify:", &filename)) { - error_setg(errp, "File name string must start with 'blkverify:'"); + /* There was no prefix; therefore, all options have to be already + present in the QDict (except for the filename) */ + qdict_put(options, "x-image", qstring_from_str(filename)); return; } -- 1.8.4.2