From: Markus Armbruster <armbru@redhat.com>
To: qemu-devel@nongnu.org
Subject: [Qemu-devel] [PULL v4 21/24] block: Initial implementation of -blockdev
Date: Tue, 7 Mar 2017 16:20:42 +0100 [thread overview]
Message-ID: <1488900045-26344-22-git-send-email-armbru@redhat.com> (raw)
In-Reply-To: <1488900045-26344-1-git-send-email-armbru@redhat.com>
The new command line option -blockdev works like QMP command
blockdev-add.
The option argument may be given in JSON syntax, exactly as in QMP.
Example usage:
-blockdev '{"node-name": "foo", "driver": "raw", "file": {"driver": "file", "filename": "foo.img"} }'
The JSON argument doesn't exactly blend into the existing option
syntax, so the traditional KEY=VALUE,... syntax is also supported,
using dotted keys to do the nesting:
-blockdev node-name=foo,driver=raw,file.driver=file,file.filename=foo.img
This does not yet support lists, but that will be addressed shortly.
Note that calling qmp_blockdev_add() (say via qmp_marshal_block_add())
right away would crash. We need to stash the configuration for later
instead. This is crudely done, and bypasses QemuOpts, even though
storing configuration is what QemuOpts is for. Need to revamp option
infrastructure to support QAPI types like BlockdevOptions.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Message-Id: <1488317230-26248-22-git-send-email-armbru@redhat.com>
---
qemu-options.hx | 7 +++++++
vl.c | 39 +++++++++++++++++++++++++++++++++++++++
2 files changed, 46 insertions(+)
diff --git a/qemu-options.hx b/qemu-options.hx
index 2292438..8dd8ee3 100644
--- a/qemu-options.hx
+++ b/qemu-options.hx
@@ -550,6 +550,13 @@ Use @var{file} as CD-ROM image (you cannot use @option{-hdc} and
using @file{/dev/cdrom} as filename (@pxref{host_drives}).
ETEXI
+DEF("blockdev", HAS_ARG, QEMU_OPTION_blockdev,
+ "-blockdev [driver=]driver[,node-name=N][,discard=ignore|unmap]\n"
+ " [,cache.direct=on|off][,cache.no-flush=on|off]\n"
+ " [,read-only=on|off][,detect-zeroes=on|off|unmap]\n"
+ " [,driver specific parameters...]\n"
+ " configure a block backend\n", QEMU_ARCH_ALL)
+
DEF("drive", HAS_ARG, QEMU_OPTION_drive,
"-drive [file=file][,if=type][,bus=n][,unit=m][,media=d][,index=i]\n"
" [,cyls=c,heads=h,secs=s[,trans=t]][,snapshot=on|off]\n"
diff --git a/vl.c b/vl.c
index 71b75ef..7f1644a 100644
--- a/vl.c
+++ b/vl.c
@@ -95,6 +95,9 @@ int main(int argc, char **argv)
#include "migration/colo.h"
#include "sysemu/kvm.h"
#include "sysemu/hax.h"
+#include "qapi/qobject-input-visitor.h"
+#include "qapi/qobject-input-visitor.h"
+#include "qapi-visit.h"
#include "qapi/qmp/qjson.h"
#include "qemu/option.h"
#include "qemu/config-file.h"
@@ -2976,6 +2979,13 @@ int main(int argc, char **argv, char **envp)
Error *main_loop_err = NULL;
Error *err = NULL;
bool list_data_dirs = false;
+ typedef struct BlockdevOptions_queue {
+ BlockdevOptions *bdo;
+ Location loc;
+ QSIMPLEQ_ENTRY(BlockdevOptions_queue) entry;
+ } BlockdevOptions_queue;
+ QSIMPLEQ_HEAD(, BlockdevOptions_queue) bdo_queue
+ = QSIMPLEQ_HEAD_INITIALIZER(bdo_queue);
module_call_init(MODULE_INIT_TRACE);
@@ -3118,6 +3128,25 @@ int main(int argc, char **argv, char **envp)
drive_add(IF_DEFAULT, popt->index - QEMU_OPTION_hda, optarg,
HD_OPTS);
break;
+ case QEMU_OPTION_blockdev:
+ {
+ Visitor *v;
+ BlockdevOptions_queue *bdo;
+
+ v = qobject_input_visitor_new_str(optarg, "driver", &err);
+ if (!v) {
+ error_report_err(err);
+ exit(1);
+ }
+
+ bdo = g_new(BlockdevOptions_queue, 1);
+ visit_type_BlockdevOptions(v, NULL, &bdo->bdo,
+ &error_fatal);
+ visit_free(v);
+ loc_save(&bdo->loc);
+ QSIMPLEQ_INSERT_TAIL(&bdo_queue, bdo, entry);
+ break;
+ }
case QEMU_OPTION_drive:
if (drive_def(optarg) == NULL) {
exit(1);
@@ -4451,6 +4480,16 @@ int main(int argc, char **argv, char **envp)
}
/* open the virtual block devices */
+ while (!QSIMPLEQ_EMPTY(&bdo_queue)) {
+ BlockdevOptions_queue *bdo = QSIMPLEQ_FIRST(&bdo_queue);
+
+ QSIMPLEQ_REMOVE_HEAD(&bdo_queue, entry);
+ loc_push_restore(&bdo->loc);
+ qmp_blockdev_add(bdo->bdo, &error_fatal);
+ loc_pop(&bdo->loc);
+ qapi_free_BlockdevOptions(bdo->bdo);
+ g_free(bdo);
+ }
if (snapshot || replay_mode != REPLAY_MODE_NONE) {
qemu_opts_foreach(qemu_find_opts("drive"), drive_enable_snapshot,
NULL, NULL);
--
2.7.4
next prev parent reply other threads:[~2017-03-07 15:20 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-03-07 15:20 [Qemu-devel] [PULL v4 00/24] block: Command line option -blockdev Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 01/24] test-qemu-opts: Cover qemu_opts_parse() of "no" Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 02/24] tests: Fix gcov-files-test-qemu-opts-y, gcov-files-test-logging-y Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 03/24] keyval: New keyval_parse() Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 04/24] qapi: qobject input visitor variant for use with keyval_parse() Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 05/24] test-keyval: Cover use with qobject input visitor Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 06/24] qapi: Factor out common part of qobject input visitor creation Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 07/24] qapi: Factor out common qobject_input_get_keyval() Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 08/24] qobject: Propagate parse errors through qobject_from_jsonv() Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 09/24] libqtest: Fix qmp() & friends to abort on JSON parse errors Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 10/24] qjson: Abort earlier on qobject_from_jsonf() misuse Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 11/24] test-qobject-input-visitor: Abort earlier on bad test input Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 12/24] qobject: Propagate parse errors through qobject_from_json() Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 13/24] block: More detailed syntax error reporting for JSON filenames Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 14/24] check-qjson: Test errors from qobject_from_json() Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 15/24] test-visitor-serialization: Pass &error_abort to qobject_from_json() Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 16/24] monitor: Assert qmp_schema_json[] is sane Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 17/24] test-qapi-util: New, covering qapi/qapi-util.c Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 18/24] qapi: New parse_qapi_name() Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 19/24] keyval: Restrict key components to valid QAPI names Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 20/24] qapi: New qobject_input_visitor_new_str() for convenience Markus Armbruster
2017-03-07 15:20 ` Markus Armbruster [this message]
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 22/24] qapi: Improve how keyval input visitor reports unexpected dicts Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 23/24] docs/qapi-code-gen.txt: Clarify naming rules Markus Armbruster
2017-03-07 15:20 ` [Qemu-devel] [PULL v4 24/24] keyval: Support lists Markus Armbruster
2017-03-07 15:39 ` [Qemu-devel] [PULL v4 00/24] block: Command line option -blockdev no-reply
2017-03-08 9:47 ` Peter Maydell
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=1488900045-26344-22-git-send-email-armbru@redhat.com \
--to=armbru@redhat.com \
--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 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).