qapi: introduce new cmd option "allow-oob"

Here "oob" stands for "Out-Of-Band". When "allow-oob" is set, it means
the command allows out-of-band execution.

The "oob" idea is proposed by Markus Armbruster in following thread:

https://lists.gnu.org/archive/html/qemu-devel/2017-09/msg02057.html

This new "allow-oob" boolean will be exposed by "query-qmp-schema" as
well for command entries, so that QMP clients can know which commands
can be used in out-of-band calls. For example the command "migrate"
originally looks like:

{"name": "migrate", "ret-type": "17", "meta-type": "command",
"arg-type": "86"}

And it'll be changed into:

{"name": "migrate", "ret-type": "17", "allow-oob": false,
"meta-type": "command", "arg-type": "86"}

This patch only provides the QMP interface level changes. It does not
contain the real out-of-band execution implementation yet.

Backports commit 876c67512e2af8c05686faa9f9ff49b38d7a392c from qemu
This commit is contained in:
Peter Xu 2018-07-05 11:34:35 -04:00 committed by Lioncash
parent f5f1d9f86b
commit 15819915db
No known key found for this signature in database
GPG key ID: 4E3C3CC1031BA9C7

View file

@ -927,7 +927,8 @@ def check_exprs(exprs):
elif 'command' in expr: elif 'command' in expr:
meta = 'command' meta = 'command'
check_keys(expr_elem, 'command', [], check_keys(expr_elem, 'command', [],
['data', 'returns', 'gen', 'success-response', 'boxed']) ['data', 'returns', 'gen', 'success-response',
'boxed', 'allow-oob'])
elif 'event' in expr: elif 'event' in expr:
meta = 'event' meta = 'event'
check_keys(expr_elem, 'event', [], ['data', 'boxed']) check_keys(expr_elem, 'event', [], ['data', 'boxed'])
@ -1050,7 +1051,7 @@ class QAPISchemaVisitor(object):
pass pass
def visit_command(self, name, info, arg_type, ret_type, def visit_command(self, name, info, arg_type, ret_type,
gen, success_response, boxed): gen, success_response, boxed, allow_oob):
pass pass
def visit_event(self, name, info, arg_type, boxed): def visit_event(self, name, info, arg_type, boxed):
@ -1435,7 +1436,7 @@ class QAPISchemaAlternateType(QAPISchemaType):
class QAPISchemaCommand(QAPISchemaEntity): class QAPISchemaCommand(QAPISchemaEntity):
def __init__(self, name, info, doc, arg_type, ret_type, def __init__(self, name, info, doc, arg_type, ret_type,
gen, success_response, boxed): gen, success_response, boxed, allow_oob):
QAPISchemaEntity.__init__(self, name, info, doc) QAPISchemaEntity.__init__(self, name, info, doc)
assert not arg_type or isinstance(arg_type, str) assert not arg_type or isinstance(arg_type, str)
assert not ret_type or isinstance(ret_type, str) assert not ret_type or isinstance(ret_type, str)
@ -1446,6 +1447,7 @@ class QAPISchemaCommand(QAPISchemaEntity):
self.gen = gen self.gen = gen
self.success_response = success_response self.success_response = success_response
self.boxed = boxed self.boxed = boxed
self.allow_oob = allow_oob
def check(self, schema): def check(self, schema):
if self._arg_type_name: if self._arg_type_name:
@ -1469,7 +1471,8 @@ class QAPISchemaCommand(QAPISchemaEntity):
def visit(self, visitor): def visit(self, visitor):
visitor.visit_command(self.name, self.info, visitor.visit_command(self.name, self.info,
self.arg_type, self.ret_type, self.arg_type, self.ret_type,
self.gen, self.success_response, self.boxed) self.gen, self.success_response,
self.boxed, self.allow_oob)
class QAPISchemaEvent(QAPISchemaEntity): class QAPISchemaEvent(QAPISchemaEntity):
@ -1692,6 +1695,7 @@ class QAPISchema(object):
gen = expr.get('gen', True) gen = expr.get('gen', True)
success_response = expr.get('success-response', True) success_response = expr.get('success-response', True)
boxed = expr.get('boxed', False) boxed = expr.get('boxed', False)
allow_oob = expr.get('allow-oob', False)
if isinstance(data, OrderedDict): if isinstance(data, OrderedDict):
data = self._make_implicit_object_type( data = self._make_implicit_object_type(
name, info, doc, 'arg', self._make_members(data, info)) name, info, doc, 'arg', self._make_members(data, info))
@ -1699,7 +1703,8 @@ class QAPISchema(object):
assert len(rets) == 1 assert len(rets) == 1
rets = self._make_array_type(rets[0], info) rets = self._make_array_type(rets[0], info)
self._def_entity(QAPISchemaCommand(name, info, doc, data, rets, self._def_entity(QAPISchemaCommand(name, info, doc, data, rets,
gen, success_response, boxed)) gen, success_response,
boxed, allow_oob))
def _def_event(self, expr, info, doc): def _def_event(self, expr, info, doc):
name = expr['event'] name = expr['event']