[libvirt] [Qemu-devel] [PATCH v2] qmp: access the local QemuOptsLists for drive option
Amos Kong
akong at redhat.com
Sat Nov 9 03:19:50 UTC 2013
On Fri, Nov 08, 2013 at 05:18:02PM +0800, Fam Zheng wrote:
> Looks good to me. Two small comments below.
>
> On Wed, 11/06 13:16, Amos Kong wrote:
> > Currently we have three QemuOptsList (qemu_common_drive_opts,
> > qemu_legacy_drive_opts, and qemu_drive_opts), only qemu_drive_opts
> > is added to vm_config_groups[].
> >
> > This patch changes query-command-line-options to access three local
> > QemuOptsLists for drive option, and merge the description items
> > together.
> >
> > Signed-off-by: Amos Kong <akong at redhat.com>
> > ---
> > V2: access local QemuOptsLists for drive (kevin)
> > ---
> > blockdev.c | 1 -
> > include/qemu/config-file.h | 1 +
> > include/sysemu/sysemu.h | 2 ++
> > util/qemu-config.c | 77 +++++++++++++++++++++++++++++++++++++++++++++-
> > vl.c | 3 ++
> > 5 files changed, 82 insertions(+), 2 deletions(-)
> >
> > diff --git a/blockdev.c b/blockdev.c
> > index b260477..f09f991 100644
> > --- a/blockdev.c
> > +++ b/blockdev.c
> > @@ -47,7 +47,6 @@
> > #include "sysemu/arch_init.h"
> >
> > static QTAILQ_HEAD(drivelist, DriveInfo) drives = QTAILQ_HEAD_INITIALIZER(drives);
> > -extern QemuOptsList qemu_common_drive_opts;
> >
> > static const char *const if_name[IF_COUNT] = {
> > [IF_NONE] = "none",
> > diff --git a/include/qemu/config-file.h b/include/qemu/config-file.h
> > index ad4a9e5..508428f 100644
> > --- a/include/qemu/config-file.h
> > +++ b/include/qemu/config-file.h
> > @@ -8,6 +8,7 @@
> > QemuOptsList *qemu_find_opts(const char *group);
> > QemuOptsList *qemu_find_opts_err(const char *group, Error **errp);
> > void qemu_add_opts(QemuOptsList *list);
> > +void qemu_add_drive_opts(QemuOptsList *list);
>
> This can be static. Do you plan to use it outside qemu-config.c?
It's used in vl.c
> > int qemu_set_option(const char *str);
> > int qemu_global_option(const char *str);
> > void qemu_add_globals(void);
> > diff --git a/include/sysemu/sysemu.h b/include/sysemu/sysemu.h
> > index cd5791e..495dae8 100644
> > --- a/include/sysemu/sysemu.h
> > +++ b/include/sysemu/sysemu.h
> > @@ -193,6 +193,8 @@ QemuOpts *qemu_get_machine_opts(void);
> >
> > bool usb_enabled(bool default_usb);
> >
> > +extern QemuOptsList qemu_legacy_drive_opts;
> > +extern QemuOptsList qemu_common_drive_opts;
> > extern QemuOptsList qemu_drive_opts;
> > extern QemuOptsList qemu_chardev_opts;
> > extern QemuOptsList qemu_device_opts;
> > diff --git a/util/qemu-config.c b/util/qemu-config.c
> > index a59568d..867fb4b 100644
> > --- a/util/qemu-config.c
> > +++ b/util/qemu-config.c
> > @@ -8,6 +8,7 @@
> > #include "qmp-commands.h"
> >
> > static QemuOptsList *vm_config_groups[32];
> > +static QemuOptsList *drive_config_groups[4];
> >
> > static QemuOptsList *find_list(QemuOptsList **lists, const char *group,
> > Error **errp)
> > @@ -77,6 +78,59 @@ static CommandLineParameterInfoList *query_option_descs(const QemuOptDesc *desc)
> > return param_list;
> > }
> >
> > +/* remove repeated entry from the info list */
> > +static void cleanup_infolist(CommandLineParameterInfoList *head)
> > +{
> > + CommandLineParameterInfoList *pre_entry, *cur, *del_entry;
> > +
> > + cur = head;
> > + while (cur->next) {
> > + pre_entry = head;
> > + while (pre_entry != cur->next) {
> > + if (!strcmp(pre_entry->value->name, cur->next->value->name)) {
> > + del_entry = cur->next;
> > + cur->next = cur->next->next;
> > + g_free(del_entry);
> > + break;
> > + }
> > + pre_entry = pre_entry->next;
> > + }
> > + cur = cur->next;
> > + }
> > +}
> > +
> > +/* merge the description items of two parameter infolists */
> > +static void connect_infolist(CommandLineParameterInfoList *head,
> > + CommandLineParameterInfoList *new)
> > +{
> > + CommandLineParameterInfoList *cur;
> > +
> > + cur = head;
> > + while (cur->next) {
> > + cur = cur->next;
> > + }
> > + cur->next = new;
> > +}
> > +
> > +/* access all the local QemuOptsLists for drive option */
> > +static CommandLineParameterInfoList *get_drive_infolist(void)
> > +{
> > + CommandLineParameterInfoList *head = NULL, *cur;
> > + int i;
> > +
> > + for (i = 0; drive_config_groups[i] != NULL; i++) {
> > + if (!head) {
> > + head = query_option_descs(drive_config_groups[i]->desc);
> > + } else {
> > + cur = query_option_descs(drive_config_groups[i]->desc);
> > + connect_infolist(head, cur);
> > + }
> > + }
> > + cleanup_infolist(head);
> > +
> > + return head;
> > +}
> > +
> > CommandLineOptionInfoList *qmp_query_command_line_options(bool has_option,
> > const char *option,
> > Error **errp)
> > @@ -89,7 +143,12 @@ CommandLineOptionInfoList *qmp_query_command_line_options(bool has_option,
> > if (!has_option || !strcmp(option, vm_config_groups[i]->name)) {
> > info = g_malloc0(sizeof(*info));
> > info->option = g_strdup(vm_config_groups[i]->name);
> > - info->parameters = query_option_descs(vm_config_groups[i]->desc);
> > + if (!strcmp("drive", vm_config_groups[i]->name)) {
> > + info->parameters = get_drive_infolist();
> > + } else {
>
> Misaligned line.
Thanks for the catch.
> Fam
>
> > + info->parameters =
> > + query_option_descs(vm_config_groups[i]->desc);
> > + }
> > entry = g_malloc0(sizeof(*entry));
> > entry->value = info;
> > entry->next = conf_list;
> > @@ -109,6 +168,22 @@ QemuOptsList *qemu_find_opts_err(const char *group, Error **errp)
> > return find_list(vm_config_groups, group, errp);
> > }
> >
> > +void qemu_add_drive_opts(QemuOptsList *list)
> > +{
> > + int entries, i;
> > +
> > + entries = ARRAY_SIZE(drive_config_groups);
> > + entries--; /* keep list NULL terminated */
> > + for (i = 0; i < entries; i++) {
> > + if (drive_config_groups[i] == NULL) {
> > + drive_config_groups[i] = list;
> > + return;
> > + }
> > + }
> > + fprintf(stderr, "ran out of space in drive_config_groups");
> > + abort();
> > +}
> > +
> > void qemu_add_opts(QemuOptsList *list)
> > {
> > int entries, i;
> > diff --git a/vl.c b/vl.c
> > index efbff65..341d7b5 100644
> > --- a/vl.c
> > +++ b/vl.c
> > @@ -2869,6 +2869,9 @@ int main(int argc, char **argv, char **envp)
> > module_call_init(MODULE_INIT_QOM);
> >
> > qemu_add_opts(&qemu_drive_opts);
> > + qemu_add_drive_opts(&qemu_legacy_drive_opts);
> > + qemu_add_drive_opts(&qemu_common_drive_opts);
> > + qemu_add_drive_opts(&qemu_drive_opts);
> > qemu_add_opts(&qemu_chardev_opts);
> > qemu_add_opts(&qemu_device_opts);
> > qemu_add_opts(&qemu_netdev_opts);
--
Amos.
More information about the libvir-list
mailing list