Message ID | 755a17f2d8daf7d2a62b23bb8957c114a93ccf12.1486285434.git.ben@skyportsystems.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Sun, 5 Feb 2017 01:12:02 -0800 ben@skyportsystems.com wrote: > From: Igor Mammedov <imammedo@redhat.com> > > Add set-vm-generation-id command to set Virtual Machine > Generation ID counter. > > QMP command example: > { "execute": "set-vm-generation-id", > "arguments": { > "guid": "324e6eaf-d1d1-4bf6-bf41-b9bb6c91fb87" > } > } > > HMP command example: > set-vm-generation-id guid=324e6eaf-d1d1-4bf6-bf41-b9bb6c91fb87 > > Signed-off-by: Igor Mammedov <imammedo@redhat.com> > Reviewed-by: Eric Blake <eblake@redhat.com> > Signed-off-by: Ben Warren <ben@skyportsystems.com> > --- > hmp-commands.hx | 13 +++++++++++++ > hmp.c | 12 ++++++++++++ > hmp.h | 1 + > hw/acpi/vmgenid.c | 12 ++++++++++++ > qapi-schema.json | 11 +++++++++++ > stubs/vmgenid.c | 6 ++++++ > 6 files changed, 55 insertions(+) > > diff --git a/hmp-commands.hx b/hmp-commands.hx > index 8819281..56744aa 100644 > --- a/hmp-commands.hx > +++ b/hmp-commands.hx > @@ -1775,5 +1775,18 @@ ETEXI > }, > > STEXI > +@item set-vm-generation-id @var{uuid} > +Set Virtual Machine Generation ID counter to @var{guid} > +ETEXI > + > + { > + .name = "set-vm-generation-id", > + .args_type = "guid:s", > + .params = "guid", > + .help = "Set Virtual Machine Generation ID counter", > + .cmd = hmp_set_vm_generation_id, > + }, > + > +STEXI > @end table > ETEXI > diff --git a/hmp.c b/hmp.c > index 535613d..39c8965 100644 > --- a/hmp.c > +++ b/hmp.c > @@ -2574,3 +2574,15 @@ void hmp_info_vm_generation_id(Monitor *mon, const QDict *qdict) > } > qapi_free_GuidInfo(info); > } > + > +void hmp_set_vm_generation_id(Monitor *mon, const QDict *qdict) > +{ > + Error *errp = NULL; > + const char *guid = qdict_get_str(qdict, "guid"); > + > + qmp_set_vm_generation_id(guid, &errp); > + if (errp) { > + hmp_handle_error(mon, &errp); > + return; > + } > +} > diff --git a/hmp.h b/hmp.h > index 799fd37..e0ac1e8 100644 > --- a/hmp.h > +++ b/hmp.h > @@ -138,5 +138,6 @@ void hmp_rocker_of_dpa_groups(Monitor *mon, const QDict *qdict); > void hmp_info_dump(Monitor *mon, const QDict *qdict); > void hmp_hotpluggable_cpus(Monitor *mon, const QDict *qdict); > void hmp_info_vm_generation_id(Monitor *mon, const QDict *qdict); > +void hmp_set_vm_generation_id(Monitor *mon, const QDict *qdict); > > #endif > diff --git a/hw/acpi/vmgenid.c b/hw/acpi/vmgenid.c > index e148051..af8b35c 100644 > --- a/hw/acpi/vmgenid.c > +++ b/hw/acpi/vmgenid.c > @@ -224,3 +224,15 @@ GuidInfo *qmp_query_vm_generation_id(Error **errp) > info->guid = qemu_uuid_unparse_strdup(&guid); > return info; > } > + > +void qmp_set_vm_generation_id(const char *guid, Error **errp) > +{ > + Object *obj = find_vmgenid_dev(errp); > + > + if (!obj) { move error_set here from find_vmgenid_dev() > + return; > + } > + > + object_property_set_str(obj, guid, VMGENID_GUID, errp); > + return; > +} > diff --git a/qapi-schema.json b/qapi-schema.json > index 384a7f3..ed2657d 100644 > --- a/qapi-schema.json > +++ b/qapi-schema.json > @@ -6051,3 +6051,14 @@ > # Since 2.9 > ## > { 'command': 'query-vm-generation-id', 'returns': 'GuidInfo' } > + > +## > +# @set-vm-generation-id: > +# > +# Set Virtual Machine Generation ID > +# > +# @guid: new GUID to set as Virtual Machine Generation ID > +# > +# Since 2.9 > +## > +{ 'command': 'set-vm-generation-id', 'data': {'guid': 'str'} } > diff --git a/stubs/vmgenid.c b/stubs/vmgenid.c > index 8c448ac..d25d41b 100644 > --- a/stubs/vmgenid.c > +++ b/stubs/vmgenid.c > @@ -6,3 +6,9 @@ GuidInfo *qmp_query_vm_generation_id(Error **errp) > error_setg(errp, "this command is not currently supported"); > return NULL; > } > + > +void qmp_set_vm_generation_id(const char *guid, Error **errp) > +{ > + error_setg(errp, "this command is not currently supported"); > + return; > +}
On 02/05/17 10:12, ben@skyportsystems.com wrote: > From: Igor Mammedov <imammedo@redhat.com> > > Add set-vm-generation-id command to set Virtual Machine > Generation ID counter. > > QMP command example: > { "execute": "set-vm-generation-id", > "arguments": { > "guid": "324e6eaf-d1d1-4bf6-bf41-b9bb6c91fb87" > } > } > > HMP command example: > set-vm-generation-id guid=324e6eaf-d1d1-4bf6-bf41-b9bb6c91fb87 > > Signed-off-by: Igor Mammedov <imammedo@redhat.com> > Reviewed-by: Eric Blake <eblake@redhat.com> > Signed-off-by: Ben Warren <ben@skyportsystems.com> > --- > hmp-commands.hx | 13 +++++++++++++ > hmp.c | 12 ++++++++++++ > hmp.h | 1 + > hw/acpi/vmgenid.c | 12 ++++++++++++ > qapi-schema.json | 11 +++++++++++ > stubs/vmgenid.c | 6 ++++++ > 6 files changed, 55 insertions(+) > > diff --git a/hmp-commands.hx b/hmp-commands.hx > index 8819281..56744aa 100644 > --- a/hmp-commands.hx > +++ b/hmp-commands.hx > @@ -1775,5 +1775,18 @@ ETEXI > }, > > STEXI > +@item set-vm-generation-id @var{uuid} > +Set Virtual Machine Generation ID counter to @var{guid} > +ETEXI > + > + { > + .name = "set-vm-generation-id", > + .args_type = "guid:s", > + .params = "guid", > + .help = "Set Virtual Machine Generation ID counter", > + .cmd = hmp_set_vm_generation_id, > + }, > + > +STEXI > @end table > ETEXI > diff --git a/hmp.c b/hmp.c > index 535613d..39c8965 100644 > --- a/hmp.c > +++ b/hmp.c > @@ -2574,3 +2574,15 @@ void hmp_info_vm_generation_id(Monitor *mon, const QDict *qdict) > } > qapi_free_GuidInfo(info); > } > + > +void hmp_set_vm_generation_id(Monitor *mon, const QDict *qdict) > +{ > + Error *errp = NULL; > + const char *guid = qdict_get_str(qdict, "guid"); > + > + qmp_set_vm_generation_id(guid, &errp); > + if (errp) { > + hmp_handle_error(mon, &errp); > + return; This return statement is superfluous. > + } > +} > diff --git a/hmp.h b/hmp.h > index 799fd37..e0ac1e8 100644 > --- a/hmp.h > +++ b/hmp.h > @@ -138,5 +138,6 @@ void hmp_rocker_of_dpa_groups(Monitor *mon, const QDict *qdict); > void hmp_info_dump(Monitor *mon, const QDict *qdict); > void hmp_hotpluggable_cpus(Monitor *mon, const QDict *qdict); > void hmp_info_vm_generation_id(Monitor *mon, const QDict *qdict); > +void hmp_set_vm_generation_id(Monitor *mon, const QDict *qdict); > > #endif > diff --git a/hw/acpi/vmgenid.c b/hw/acpi/vmgenid.c > index e148051..af8b35c 100644 > --- a/hw/acpi/vmgenid.c > +++ b/hw/acpi/vmgenid.c > @@ -224,3 +224,15 @@ GuidInfo *qmp_query_vm_generation_id(Error **errp) > info->guid = qemu_uuid_unparse_strdup(&guid); > return info; > } > + > +void qmp_set_vm_generation_id(const char *guid, Error **errp) > +{ > + Object *obj = find_vmgenid_dev(errp); > + > + if (!obj) { > + return; > + } > + > + object_property_set_str(obj, guid, VMGENID_GUID, errp); > + return; This too. > +} > diff --git a/qapi-schema.json b/qapi-schema.json > index 384a7f3..ed2657d 100644 > --- a/qapi-schema.json > +++ b/qapi-schema.json > @@ -6051,3 +6051,14 @@ > # Since 2.9 > ## > { 'command': 'query-vm-generation-id', 'returns': 'GuidInfo' } > + > +## > +# @set-vm-generation-id: > +# > +# Set Virtual Machine Generation ID > +# > +# @guid: new GUID to set as Virtual Machine Generation ID > +# > +# Since 2.9 > +## > +{ 'command': 'set-vm-generation-id', 'data': {'guid': 'str'} } > diff --git a/stubs/vmgenid.c b/stubs/vmgenid.c > index 8c448ac..d25d41b 100644 > --- a/stubs/vmgenid.c > +++ b/stubs/vmgenid.c > @@ -6,3 +6,9 @@ GuidInfo *qmp_query_vm_generation_id(Error **errp) > error_setg(errp, "this command is not currently supported"); > return NULL; > } > + > +void qmp_set_vm_generation_id(const char *guid, Error **errp) > +{ > + error_setg(errp, "this command is not currently supported"); > + return; And this. Thanks, Laszlo > +} >
diff --git a/hmp-commands.hx b/hmp-commands.hx index 8819281..56744aa 100644 --- a/hmp-commands.hx +++ b/hmp-commands.hx @@ -1775,5 +1775,18 @@ ETEXI }, STEXI +@item set-vm-generation-id @var{uuid} +Set Virtual Machine Generation ID counter to @var{guid} +ETEXI + + { + .name = "set-vm-generation-id", + .args_type = "guid:s", + .params = "guid", + .help = "Set Virtual Machine Generation ID counter", + .cmd = hmp_set_vm_generation_id, + }, + +STEXI @end table ETEXI diff --git a/hmp.c b/hmp.c index 535613d..39c8965 100644 --- a/hmp.c +++ b/hmp.c @@ -2574,3 +2574,15 @@ void hmp_info_vm_generation_id(Monitor *mon, const QDict *qdict) } qapi_free_GuidInfo(info); } + +void hmp_set_vm_generation_id(Monitor *mon, const QDict *qdict) +{ + Error *errp = NULL; + const char *guid = qdict_get_str(qdict, "guid"); + + qmp_set_vm_generation_id(guid, &errp); + if (errp) { + hmp_handle_error(mon, &errp); + return; + } +} diff --git a/hmp.h b/hmp.h index 799fd37..e0ac1e8 100644 --- a/hmp.h +++ b/hmp.h @@ -138,5 +138,6 @@ void hmp_rocker_of_dpa_groups(Monitor *mon, const QDict *qdict); void hmp_info_dump(Monitor *mon, const QDict *qdict); void hmp_hotpluggable_cpus(Monitor *mon, const QDict *qdict); void hmp_info_vm_generation_id(Monitor *mon, const QDict *qdict); +void hmp_set_vm_generation_id(Monitor *mon, const QDict *qdict); #endif diff --git a/hw/acpi/vmgenid.c b/hw/acpi/vmgenid.c index e148051..af8b35c 100644 --- a/hw/acpi/vmgenid.c +++ b/hw/acpi/vmgenid.c @@ -224,3 +224,15 @@ GuidInfo *qmp_query_vm_generation_id(Error **errp) info->guid = qemu_uuid_unparse_strdup(&guid); return info; } + +void qmp_set_vm_generation_id(const char *guid, Error **errp) +{ + Object *obj = find_vmgenid_dev(errp); + + if (!obj) { + return; + } + + object_property_set_str(obj, guid, VMGENID_GUID, errp); + return; +} diff --git a/qapi-schema.json b/qapi-schema.json index 384a7f3..ed2657d 100644 --- a/qapi-schema.json +++ b/qapi-schema.json @@ -6051,3 +6051,14 @@ # Since 2.9 ## { 'command': 'query-vm-generation-id', 'returns': 'GuidInfo' } + +## +# @set-vm-generation-id: +# +# Set Virtual Machine Generation ID +# +# @guid: new GUID to set as Virtual Machine Generation ID +# +# Since 2.9 +## +{ 'command': 'set-vm-generation-id', 'data': {'guid': 'str'} } diff --git a/stubs/vmgenid.c b/stubs/vmgenid.c index 8c448ac..d25d41b 100644 --- a/stubs/vmgenid.c +++ b/stubs/vmgenid.c @@ -6,3 +6,9 @@ GuidInfo *qmp_query_vm_generation_id(Error **errp) error_setg(errp, "this command is not currently supported"); return NULL; } + +void qmp_set_vm_generation_id(const char *guid, Error **errp) +{ + error_setg(errp, "this command is not currently supported"); + return; +}