@@ -128,8 +128,6 @@ enum {
OPTION_OBJECT,
};
-extern QemuOptsList qemu_chardev_opts;
-
static QemuOptsList qemu_object_opts = {
.name = "object",
.implied_opt_name = "qom-type",
@@ -207,18 +205,15 @@ static void process_options(int argc, char *argv[])
}
case OPTION_CHARDEV:
{
- /* TODO This interface is not stable until we QAPIfy it */
- QemuOpts *opts = qemu_opts_parse_noisily(&qemu_chardev_opts,
- optarg, true);
- if (opts == NULL) {
- exit(EXIT_FAILURE);
- }
+ ChardevOptions *options;
- if (!qemu_chr_new_from_opts(opts, NULL, &error_fatal)) {
- /* No error, but NULL returned means help was printed */
+ options = qemu_chr_parse_cli_str(optarg, &error_fatal);
+ if (!options) {
+ /* Help was printed */
exit(EXIT_SUCCESS);
}
- qemu_opts_del(opts);
+ qemu_chr_new_cli(options, &error_fatal);
+ qapi_free_ChardevOptions(options);
break;
}
case OPTION_EXPORT:
Make use of the QAPIfied command line interface of the chardev subsystem. With this, --chardev supports QMP-like syntax (i.e. chardev-add mapped to the command line) as well as the legacy syntax that it already supported and which is shared with the system emulator. Signed-off-by: Kevin Wolf <kwolf@redhat.com> --- storage-daemon/qemu-storage-daemon.c | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-)