mirror of
https://gitlab.com/qemu-project/qemu
synced 2024-11-05 20:35:44 +00:00
qom: Make all interface types abstract
"qom-list-types abstract=false" currently returns all interface types, as if they were not abstract. Fix this by making sure all interface types are abstract. All interface types have instance_size == 0, so we can use it to set abstract=true on type_initialize(). Signed-off-by: Eduardo Habkost <ehabkost@redhat.com> Message-Id: <1481567461-2341-1-git-send-email-ehabkost@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
765a707000
commit
1c6d75d5f7
2 changed files with 63 additions and 3 deletions
|
@ -272,6 +272,12 @@ static void type_initialize(TypeImpl *ti)
|
|||
|
||||
ti->class_size = type_class_get_size(ti);
|
||||
ti->instance_size = type_object_get_size(ti);
|
||||
/* Any type with zero instance_size is implicitly abstract.
|
||||
* This means interface types are all abstract.
|
||||
*/
|
||||
if (ti->instance_size == 0) {
|
||||
ti->abstract = true;
|
||||
}
|
||||
|
||||
ti->class = g_malloc0(ti->class_size);
|
||||
|
||||
|
|
|
@ -20,18 +20,24 @@
|
|||
#include "qemu/osdep.h"
|
||||
#include "qemu-common.h"
|
||||
#include "qapi/qmp/qstring.h"
|
||||
#include "qapi/qmp/qbool.h"
|
||||
#include "qapi/qmp/qdict.h"
|
||||
#include "libqtest.h"
|
||||
|
||||
const char common_args[] = "-nodefaults -machine none";
|
||||
|
||||
static QList *device_type_list(bool abstract)
|
||||
static QList *qom_list_types(const char *implements, bool abstract)
|
||||
{
|
||||
QDict *resp;
|
||||
QList *ret;
|
||||
QDict *args = qdict_new();
|
||||
|
||||
qdict_put(args, "abstract", qbool_from_bool(abstract));
|
||||
if (implements) {
|
||||
qdict_put(args, "implements", qstring_from_str(implements));
|
||||
}
|
||||
resp = qmp("{'execute': 'qom-list-types',"
|
||||
" 'arguments': {'implements': 'device', 'abstract': %i}}",
|
||||
abstract);
|
||||
" 'arguments': %p }", args);
|
||||
g_assert(qdict_haskey(resp, "return"));
|
||||
ret = qdict_get_qlist(resp, "return");
|
||||
QINCREF(ret);
|
||||
|
@ -39,6 +45,11 @@ static QList *device_type_list(bool abstract)
|
|||
return ret;
|
||||
}
|
||||
|
||||
static QList *device_type_list(bool abstract)
|
||||
{
|
||||
return qom_list_types("device", abstract);
|
||||
}
|
||||
|
||||
static void test_one_device(const char *type)
|
||||
{
|
||||
QDict *resp;
|
||||
|
@ -110,6 +121,48 @@ static void test_device_intro_concrete(void)
|
|||
qtest_end();
|
||||
}
|
||||
|
||||
static void test_abstract_interfaces(void)
|
||||
{
|
||||
QList *all_types;
|
||||
QList *obj_types;
|
||||
QListEntry *ae;
|
||||
|
||||
qtest_start(common_args);
|
||||
/* qom-list-types implements=interface would return any type
|
||||
* that implements _any_ interface (not just interface types),
|
||||
* so use a trick to find the interface type names:
|
||||
* - list all object types
|
||||
* - list all types, and look for items that are not
|
||||
* on the first list
|
||||
*/
|
||||
all_types = qom_list_types(NULL, false);
|
||||
obj_types = qom_list_types("object", false);
|
||||
|
||||
QLIST_FOREACH_ENTRY(all_types, ae) {
|
||||
QDict *at = qobject_to_qdict(qlist_entry_obj(ae));
|
||||
const char *aname = qdict_get_str(at, "name");
|
||||
QListEntry *oe;
|
||||
const char *found = NULL;
|
||||
|
||||
QLIST_FOREACH_ENTRY(obj_types, oe) {
|
||||
QDict *ot = qobject_to_qdict(qlist_entry_obj(oe));
|
||||
const char *oname = qdict_get_str(ot, "name");
|
||||
if (!strcmp(aname, oname)) {
|
||||
found = oname;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* Using g_assert_cmpstr() will give more useful failure
|
||||
* messages than g_assert(found) */
|
||||
g_assert_cmpstr(aname, ==, found);
|
||||
}
|
||||
|
||||
QDECREF(all_types);
|
||||
QDECREF(obj_types);
|
||||
qtest_end();
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
g_test_init(&argc, &argv, NULL);
|
||||
|
@ -118,6 +171,7 @@ int main(int argc, char **argv)
|
|||
qtest_add_func("device/introspect/none", test_device_intro_none);
|
||||
qtest_add_func("device/introspect/abstract", test_device_intro_abstract);
|
||||
qtest_add_func("device/introspect/concrete", test_device_intro_concrete);
|
||||
qtest_add_func("device/introspect/abstract-interfaces", test_abstract_interfaces);
|
||||
|
||||
return g_test_run();
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue