[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v8 12/17] libxl_qmp: Store advertised QEMU version in libxl__ev_qmp
This will be used in a later patch. Signed-off-by: Anthony PERARD <anthony.perard@xxxxxxxxxx> Acked-by: Ian Jackson <ian.jackson@xxxxxxxxxxxxx> --- Notes: v8: Acked v7: Add do{}while around the MACRO. formating nits changes. v6: new local macro GRAB_VERSION better definition of qemu_version field in libxl_internal.h v5: initialise qemu_version struct in libxl__ev_qmp_init tools/libxl/libxl_internal.h | 8 ++++++++ tools/libxl/libxl_qmp.c | 25 +++++++++++++++++++++++++ 2 files changed, 33 insertions(+) diff --git a/tools/libxl/libxl_internal.h b/tools/libxl/libxl_internal.h index 87a58b3ac3..62492e13d7 100644 --- a/tools/libxl/libxl_internal.h +++ b/tools/libxl/libxl_internal.h @@ -439,6 +439,14 @@ struct libxl__ev_qmp { libxl__ev_qmp_callback *callback; int payload_fd; /* set to send a fd with the command, -1 otherwise */ + /* read-only when Connected + * and not to be accessed by the caller otherwise */ + struct { + int major; + int minor; + int micro; + } qemu_version; + /* * remaining fields are private to libxl_ev_qmp_* */ diff --git a/tools/libxl/libxl_qmp.c b/tools/libxl/libxl_qmp.c index f2ab08620a..9b4a07d622 100644 --- a/tools/libxl/libxl_qmp.c +++ b/tools/libxl/libxl_qmp.c @@ -1829,6 +1829,27 @@ static int qmp_ev_handle_message(libxl__egc *egc, return ERROR_PROTOCOL_ERROR_QMP; } + /* + * Store advertised QEMU version + * { "QMP": { "version": { + * "qemu": { "major": int, "minor": int, "micro": int } } } } + */ + o = libxl__json_map_get("QMP", resp, JSON_MAP); + o = libxl__json_map_get("version", o, JSON_MAP); + o = libxl__json_map_get("qemu", o, JSON_MAP); +#define GRAB_VERSION(level) do { \ + ev->qemu_version.level = libxl__json_object_get_integer( \ + libxl__json_map_get(#level, o, JSON_INTEGER)); \ + } while (0) + GRAB_VERSION(major); + GRAB_VERSION(minor); + GRAB_VERSION(micro); +#undef GRAB_VERSION + LOGD(DEBUG, ev->domid, "QEMU version: %d.%d.%d", + ev->qemu_version.major, + ev->qemu_version.minor, + ev->qemu_version.micro); + /* Prepare next message to send */ assert(!ev->tx_buf); ev->id = ev->next_id++; @@ -1991,6 +2012,10 @@ void libxl__ev_qmp_init(libxl__ev_qmp *ev) ev->msg = NULL; ev->msg_id = 0; + + ev->qemu_version.major = -1; + ev->qemu_version.minor = -1; + ev->qemu_version.micro = -1; } int libxl__ev_qmp_send(libxl__gc *unused_gc, libxl__ev_qmp *ev, -- Anthony PERARD _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |