> On Feb 15, 2017, at 7:36 AM, Laszlo Ersek <ler...@redhat.com> wrote: > > Two questions: > > On 02/15/17 07:15, b...@skyportsystems.com <mailto:b...@skyportsystems.com> > wrote: >> From: Igor Mammedov <imamm...@redhat.com> >> >> Add commands to query Virtual Machine Generation ID counter. >> >> QMP command example: >> { "execute": "query-vm-generation-id" } >> >> HMP command example: >> info vm-generation-id >> >> Signed-off-by: Igor Mammedov <imamm...@redhat.com> >> Reviewed-by: Eric Blake <ebl...@redhat.com> >> Signed-off-by: Ben Warren <b...@skyportsystems.com> >> --- >> hmp-commands-info.hx | 13 +++++++++++++ >> hmp.c | 9 +++++++++ >> hmp.h | 1 + >> hw/acpi/vmgenid.c | 16 ++++++++++++++++ >> qapi-schema.json | 20 ++++++++++++++++++++ >> stubs/Makefile.objs | 1 + >> stubs/vmgenid.c | 8 ++++++++ >> 7 files changed, 68 insertions(+) >> create mode 100644 stubs/vmgenid.c >> >> diff --git a/hmp-commands-info.hx b/hmp-commands-info.hx >> index b0f35e6..f3df793 100644 >> --- a/hmp-commands-info.hx >> +++ b/hmp-commands-info.hx >> @@ -802,6 +802,19 @@ Show information about hotpluggable CPUs >> ETEXI >> >> STEXI >> +@item info vm-generation-id > > (1) Don't we need some kind of @findex here, for consistency with the > rest of the file? > >> +Show Virtual Machine Generation ID >> +ETEXI >> + >> + { >> + .name = "vm-generation-id", >> + .args_type = "", >> + .params = "", >> + .help = "Show Virtual Machine Generation ID", >> + .cmd = hmp_info_vm_generation_id, >> + }, >> + >> +STEXI >> @end table >> ETEXI >> >> diff --git a/hmp.c b/hmp.c >> index 2bc4f06..535613d 100644 >> --- a/hmp.c >> +++ b/hmp.c >> @@ -2565,3 +2565,12 @@ void hmp_hotpluggable_cpus(Monitor *mon, const QDict >> *qdict) >> >> qapi_free_HotpluggableCPUList(saved); >> } >> + >> +void hmp_info_vm_generation_id(Monitor *mon, const QDict *qdict) >> +{ >> + GuidInfo *info = qmp_query_vm_generation_id(NULL); >> + if (info) { >> + monitor_printf(mon, "%s\n", info->guid); >> + } >> + qapi_free_GuidInfo(info); >> +} >> diff --git a/hmp.h b/hmp.h >> index 05daf7c..799fd37 100644 >> --- a/hmp.h >> +++ b/hmp.h >> @@ -137,5 +137,6 @@ void hmp_rocker_of_dpa_flows(Monitor *mon, const QDict >> *qdict); >> 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); >> >> #endif >> diff --git a/hw/acpi/vmgenid.c b/hw/acpi/vmgenid.c >> index b1b7b32..c159c76 100644 >> --- a/hw/acpi/vmgenid.c >> +++ b/hw/acpi/vmgenid.c >> @@ -235,3 +235,19 @@ static void vmgenid_register_types(void) >> } >> >> type_init(vmgenid_register_types) >> + >> +GuidInfo *qmp_query_vm_generation_id(Error **errp) >> +{ >> + GuidInfo *info; >> + VmGenIdState *vms; >> + Object *obj = find_vmgenid_dev(); >> + >> + if (!obj) { >> + return NULL; >> + } >> + vms = VMGENID(obj); >> + >> + info = g_malloc0(sizeof(*info)); >> + info->guid = qemu_uuid_unparse_strdup(&vms->guid); >> + return info; >> +} >> diff --git a/qapi-schema.json b/qapi-schema.json >> index 61151f3..5e2a47f 100644 >> --- a/qapi-schema.json >> +++ b/qapi-schema.json >> @@ -6051,3 +6051,23 @@ >> # >> ## >> { 'command': 'query-hotpluggable-cpus', 'returns': ['HotpluggableCPU'] } >> + >> +## >> +# @GuidInfo: >> +# >> +# GUID information. >> +# >> +# @guid: the globally unique identifier >> +# >> +# Since: 2.9 >> +## >> +{ 'struct': 'GuidInfo', 'data': {'guid': 'str'} } >> + >> +## >> +# @query-vm-generation-id: >> +# >> +# Show Virtual Machine Generation ID >> +# >> +# Since 2.9 >> +## >> +{ 'command': 'query-vm-generation-id', 'returns': 'GuidInfo' } >> diff --git a/stubs/Makefile.objs b/stubs/Makefile.objs >> index a187295..0bffca6 100644 >> --- a/stubs/Makefile.objs >> +++ b/stubs/Makefile.objs >> @@ -35,3 +35,4 @@ stub-obj-y += qmp_pc_dimm_device_list.o >> stub-obj-y += target-monitor-defs.o >> stub-obj-y += target-get-monitor-def.o >> stub-obj-y += pc_madt_cpu_entry.o >> +stub-obj-y += vmgenid.o >> diff --git a/stubs/vmgenid.c b/stubs/vmgenid.c >> new file mode 100644 >> index 0000000..8c448ac >> --- /dev/null >> +++ b/stubs/vmgenid.c >> @@ -0,0 +1,8 @@ >> +#include "qemu/osdep.h" >> +#include "qmp-commands.h" >> + >> +GuidInfo *qmp_query_vm_generation_id(Error **errp) >> +{ >> + error_setg(errp, "this command is not currently supported"); >> + return NULL; >> +} >> > > (2) Don't we usually employ QERR_UNSUPPORTED for the format string in > such cases? > > With or without updates: > > Reviewed-by: Laszlo Ersek <ler...@redhat.com <mailto:ler...@redhat.com>> > Both items changed. Thanks! > Thanks > Laszlo
smime.p7s
Description: S/MIME cryptographic signature