Skip to content

Commit

Permalink
qmp: Merge ObjectPropertyInfo and DevicePropertyInfo
Browse files Browse the repository at this point in the history
ObjectPropertyInfo is more generic and only missing @description.
This adds a description to ObjectPropertyInfo and removes
DevicePropertyInfo so the resulting ObjectPropertyInfo can be used
elsewhere.

Signed-off-by: Alexey Kardashevskiy <[email protected]>
Message-Id: <[email protected]>
Signed-off-by: Paolo Bonzini <[email protected]>
  • Loading branch information
aik authored and bonzini committed Mar 6, 2018
1 parent f29d445 commit 35f6376
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 31 deletions.
23 changes: 5 additions & 18 deletions qapi/misc.json
Original file line number Diff line number Diff line change
Expand Up @@ -1285,10 +1285,12 @@
# 3) A link type in the form 'link<subtype>' where subtype is a qdev
# device type name. Link properties form the device model graph.
#
# @description: if specified, the description of the property.
#
# Since: 1.2
##
{ 'struct': 'ObjectPropertyInfo',
'data': { 'name': 'str', 'type': 'str' } }
'data': { 'name': 'str', 'type': 'str', '*description': 'str' } }

##
# @qom-list:
Expand Down Expand Up @@ -1443,35 +1445,20 @@
'data': { '*implements': 'str', '*abstract': 'bool' },
'returns': [ 'ObjectTypeInfo' ] }

##
# @DevicePropertyInfo:
#
# Information about device properties.
#
# @name: the name of the property
# @type: the typename of the property
# @description: if specified, the description of the property.
# (since 2.2)
#
# Since: 1.2
##
{ 'struct': 'DevicePropertyInfo',
'data': { 'name': 'str', 'type': 'str', '*description': 'str' } }

##
# @device-list-properties:
#
# List properties associated with a device.
#
# @typename: the type name of a device
#
# Returns: a list of DevicePropertyInfo describing a devices properties
# Returns: a list of ObjectPropertyInfo describing a devices properties
#
# Since: 1.2
##
{ 'command': 'device-list-properties',
'data': { 'typename': 'str'},
'returns': [ 'DevicePropertyInfo' ] }
'returns': [ 'ObjectPropertyInfo' ] }

##
# @xen-set-global-dirty-log:
Expand Down
6 changes: 3 additions & 3 deletions qdev-monitor.c
Original file line number Diff line number Diff line change
Expand Up @@ -258,8 +258,8 @@ int qdev_device_help(QemuOpts *opts)
{
Error *local_err = NULL;
const char *driver;
DevicePropertyInfoList *prop_list;
DevicePropertyInfoList *prop;
ObjectPropertyInfoList *prop_list;
ObjectPropertyInfoList *prop;

driver = qemu_opt_get(opts, "driver");
if (driver && is_help_option(driver)) {
Expand Down Expand Up @@ -295,7 +295,7 @@ int qdev_device_help(QemuOpts *opts)
}
}

qapi_free_DevicePropertyInfoList(prop_list);
qapi_free_ObjectPropertyInfoList(prop_list);
return 1;

error:
Expand Down
20 changes: 10 additions & 10 deletions qmp.c
Original file line number Diff line number Diff line change
Expand Up @@ -465,12 +465,12 @@ ObjectTypeInfoList *qmp_qom_list_types(bool has_implements,
*
* The caller must free the return value.
*/
static DevicePropertyInfo *make_device_property_info(ObjectClass *klass,
const char *name,
const char *default_type,
const char *description)
static ObjectPropertyInfo *make_device_property_info(ObjectClass *klass,
const char *name,
const char *default_type,
const char *description)
{
DevicePropertyInfo *info;
ObjectPropertyInfo *info;
Property *prop;

do {
Expand Down Expand Up @@ -510,14 +510,14 @@ static DevicePropertyInfo *make_device_property_info(ObjectClass *klass,
return info;
}

DevicePropertyInfoList *qmp_device_list_properties(const char *typename,
Error **errp)
ObjectPropertyInfoList *qmp_device_list_properties(const char *typename,
Error **errp)
{
ObjectClass *klass;
Object *obj;
ObjectProperty *prop;
ObjectPropertyIterator iter;
DevicePropertyInfoList *prop_list = NULL;
ObjectPropertyInfoList *prop_list = NULL;

klass = object_class_by_name(typename);
if (klass == NULL) {
Expand All @@ -542,8 +542,8 @@ DevicePropertyInfoList *qmp_device_list_properties(const char *typename,

object_property_iter_init(&iter, obj);
while ((prop = object_property_iter_next(&iter))) {
DevicePropertyInfo *info;
DevicePropertyInfoList *entry;
ObjectPropertyInfo *info;
ObjectPropertyInfoList *entry;

/* Skip Object and DeviceState properties */
if (strcmp(prop->name, "type") == 0 ||
Expand Down

0 comments on commit 35f6376

Please sign in to comment.