QMP: Add QEMU's version to the greeting message

With capability negotiation support clients will only have a chance
to check QEMU's version (ie. issue 'query-version') after the
negotiation procedure is done.

It might be useful to clients to check QEMU's version before
negotiating features, though.

To allow that, this commit adds the QEMU's version object to the
greeting message.

Not really sure this is needed, but doesn't hurt anyway.

Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
Luiz Capitulino 2010-02-04 18:10:04 -02:00 committed by Anthony Liguori
parent 4ab4183d76
commit ca9567e234
3 changed files with 17 additions and 5 deletions

View File

@ -52,9 +52,11 @@ $ telnet localhost 4444
Trying 127.0.0.1... Trying 127.0.0.1...
Connected to localhost. Connected to localhost.
Escape character is '^]'. Escape character is '^]'.
{"QMP": {"capabilities": []}} {"QMP": {"version": {"qemu": "0.12.50", "package": ""}, "capabilities": []}}
{ "execute": "qmp_capabilities" }
{"return": {}}
{ "execute": "query-version" } { "execute": "query-version" }
{"return": {"qemu": "0.11.50", "package": ""}} {"return": {"qemu": "0.12.50", "package": ""}}
Contact Contact
------- -------

View File

@ -48,10 +48,12 @@ waiting for commands.
The format is: The format is:
{ "QMP": { "capabilities": json-array } } { "QMP": { "version": json-object, "capabilities": json-array } }
Where, Where,
- The "version" member contains the Server's version information (the format
is the same of the 'query-version' command)
- The "capabilities" member specify the availability of features beyond the - The "capabilities" member specify the availability of features beyond the
baseline specification baseline specification
@ -152,7 +154,7 @@ This section provides some examples of real QMP usage, in all of them
3.1 Server greeting 3.1 Server greeting
------------------- -------------------
S: {"QMP": {"capabilities": []}} S: {"QMP": {"version": {"qemu": "0.12.50", "package": ""}, "capabilities": []}}
3.2 Simple 'stop' execution 3.2 Simple 'stop' execution
--------------------------- ---------------------------

View File

@ -4368,6 +4368,14 @@ void monitor_resume(Monitor *mon)
readline_show_prompt(mon->rs); readline_show_prompt(mon->rs);
} }
static QObject *get_qmp_greeting(void)
{
QObject *ver;
do_info_version(NULL, &ver);
return qobject_from_jsonf("{'QMP':{'version': %p,'capabilities': []}}",ver);
}
/** /**
* monitor_control_event(): Print QMP gretting * monitor_control_event(): Print QMP gretting
*/ */
@ -4379,7 +4387,7 @@ static void monitor_control_event(void *opaque, int event)
json_message_parser_init(&mon->mc->parser, handle_qmp_command); json_message_parser_init(&mon->mc->parser, handle_qmp_command);
data = qobject_from_jsonf("{ 'QMP': { 'capabilities': [] } }"); data = get_qmp_greeting();
assert(data != NULL); assert(data != NULL);
monitor_json_emitter(mon, data); monitor_json_emitter(mon, data);