[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [RFC 00/11]: QMP feature negotiation support
From: |
Luiz Capitulino |
Subject: |
[Qemu-devel] [RFC 00/11]: QMP feature negotiation support |
Date: |
Thu, 21 Jan 2010 19:09:29 -0200 |
Feature negotiation allows clients to enable QMP capabilities they are
interested in using. This allows QMP to envolve without breaking old clients.
A capability is a new QMP feature and/or protocol change which is not part of
the core protocol as defined in the QMP spec.
Feature negotiation is implemented by defining a set of rules and adding
mode-oriented support.
The set of rules are:
o All QMP capabilities are disabled by default
o All QMP capabilities must be advertised in the capabilities array
o Commands to enable/disable capabilities must be provided
NOTE: Asynchronous messages are now considered a capability.
Mode-oriented support adds the following to QMP:
o Two modes: handshake and operational
o By default all QMP Monitors start in handshake mode
o In handshake mode only commands to query/enable/disable QMP capabilities are
allowed (there are few exceptions)
o Clients can switch to the operational mode at any time
o In Operational mode most commands are allowed and QMP capabilities changes
made in handshake mode take effect
Also note that each QMP Monitor has its own mode state and set of capabilities,
this means that if QEMU is started with N QMP Monitors protocol setup done in
one of them doesn't affect the others.
Session example:
"""
{"QMP": {"capabilities": ["async messages"]}}
{ "execute": "query-qmp-mode" }
{"return": {"mode": "handshake"}}
{ "execute": "change", "arguments": { "device": "vnc", "target": "password",
"arg": "1234" } }
{"error": {"class": "QMPInvalidModeCommad", "desc": "The issued command is
invalid in this mode", "data": {}}}
{ "execute": "async_msg_enable", "arguments": { "name": "STOP" } }
{"return": {}}
{ "execute": "qmp_switch_mode", "arguments": { "mode": "operational" } }
{"return": {}}
{ "execute": "query-qmp-mode" }
{"return": {"mode": "operational"}}
{ "execute": "change", "arguments": { "device": "vnc", "target": "password",
"arg": "1234" } }
{"return": {}}
"""
TODO:
- Update the spec
- Test more and fix some known issues
- Improve the changelog a bit
- [Qemu-devel] [RFC 00/11]: QMP feature negotiation support,
Luiz Capitulino <=
- [Qemu-devel] [PATCH 01/11] QMP: Initial mode-oriented bits, Luiz Capitulino, 2010/01/21
- [Qemu-devel] [PATCH 02/11] QMP: Introduce 'query-qmp-mode' command, Luiz Capitulino, 2010/01/21
- [Qemu-devel] [PATCH 03/11] QError: Add QMP mode-oriented errors, Luiz Capitulino, 2010/01/21
- [Qemu-devel] [PATCH 04/11] QMP: Introduce qmp_switch_mode command, Luiz Capitulino, 2010/01/21
- [Qemu-devel] [PATCH 05/11] QMP: advertise asynchronous messages, Luiz Capitulino, 2010/01/21
- [Qemu-devel] [PATCH 06/11] QMP: Array-based async messages, Luiz Capitulino, 2010/01/21
- [Qemu-devel] [PATCH 07/11] QError: New QERR_ASYNC_MSG_NOT_FOUND, Luiz Capitulino, 2010/01/21
- [Qemu-devel] [PATCH 08/11] QMP: Asynchronous messages enable/disable support, Luiz Capitulino, 2010/01/21