qapi: allow freeing partially-allocated objects

Objects going through the dealloc visitor can be only partially allocated.
Detect the situation and avoid a segfault.  This also helps with the
input visitor, when there are errors.

Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Reviewed-by: Anthony Liguori <aliguori@us.ibm.com>
Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
This commit is contained in:
Paolo Bonzini 2012-03-22 12:51:07 +01:00 committed by Luiz Capitulino
parent b6f0474fc0
commit 69b50071d8

View file

@ -65,6 +65,9 @@ def generate_visit_struct(name, members):
return;
}
visit_start_struct(m, (void **)obj, "%(name)s", name, sizeof(%(name)s), errp);
if (obj && !*obj) {
goto end;
}
''',
name=name)
push_indent()
@ -72,6 +75,7 @@ def generate_visit_struct(name, members):
pop_indent()
ret += mcgen('''
end:
visit_end_struct(m, errp);
}
''')
@ -122,6 +126,9 @@ def generate_visit_union(name, members):
return;
}
visit_start_struct(m, (void **)obj, "%(name)s", name, sizeof(%(name)s), &err);
if (obj && !*obj) {
goto end;
}
visit_type_%(name)sKind(m, &(*obj)->kind, "type", &err);
if (err) {
error_propagate(errp, err);