提交 d11ff15f 编写于 作者: M Markus Armbruster 提交者: Michael Roth

qom: Do not reuse errp after a possible error

The argument for an Error **errp parameter must point to a null
pointer.  If it doesn't, and an error happens, error_set() fails its
assertion.

Instead of

    foo(foos, errp);
    bar(bars, errp);

you need to do something like

    Error *err = NULL;

    foo(foos, &err);
    if (err) {
        error_propagate(errp, err);
        goto out;
    }

    bar(bars, errp);
out:

Screwed up in commit 0e558843 (v1.3.0): property_get_bool().

Screwed up in commit 1f21772d (v2.1.0): object_property_get_enum() and
object_property_get_uint16List().

Screwed up in commit a8e3fbed (v2.4.0): property_get_enum(),
property_set_enum().

Found by inspection, no actual crashes observed.

Fix them up.

Cc: Anthony Liguori <anthony@codemonkey.ws>
Cc: Hu Tao <hutao@cn.fujitsu.com>
Cc: Daniel P. Berrange <berrange@redhat.com>
Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
Reviewed-by: NDaniel P. Berrange <berrange@redhat.com>
Cc: qemu-stable@nongnu.org
Signed-off-by: NAndreas Färber <afaerber@suse.de>
(cherry picked from commit 4715d42e)
Signed-off-by: NMichael Roth <mdroth@linux.vnet.ibm.com>
上级 1b8e1f7a
...@@ -1079,6 +1079,7 @@ typedef struct EnumProperty { ...@@ -1079,6 +1079,7 @@ typedef struct EnumProperty {
int object_property_get_enum(Object *obj, const char *name, int object_property_get_enum(Object *obj, const char *name,
const char *typename, Error **errp) const char *typename, Error **errp)
{ {
Error *err = NULL;
StringOutputVisitor *sov; StringOutputVisitor *sov;
StringInputVisitor *siv; StringInputVisitor *siv;
char *str; char *str;
...@@ -1100,7 +1101,12 @@ int object_property_get_enum(Object *obj, const char *name, ...@@ -1100,7 +1101,12 @@ int object_property_get_enum(Object *obj, const char *name,
enumprop = prop->opaque; enumprop = prop->opaque;
sov = string_output_visitor_new(false); sov = string_output_visitor_new(false);
object_property_get(obj, string_output_get_visitor(sov), name, errp); object_property_get(obj, string_output_get_visitor(sov), name, &err);
if (err) {
error_propagate(errp, err);
string_output_visitor_cleanup(sov);
return 0;
}
str = string_output_get_string(sov); str = string_output_get_string(sov);
siv = string_input_visitor_new(str); siv = string_input_visitor_new(str);
string_output_visitor_cleanup(sov); string_output_visitor_cleanup(sov);
...@@ -1116,21 +1122,27 @@ int object_property_get_enum(Object *obj, const char *name, ...@@ -1116,21 +1122,27 @@ int object_property_get_enum(Object *obj, const char *name,
void object_property_get_uint16List(Object *obj, const char *name, void object_property_get_uint16List(Object *obj, const char *name,
uint16List **list, Error **errp) uint16List **list, Error **errp)
{ {
Error *err = NULL;
StringOutputVisitor *ov; StringOutputVisitor *ov;
StringInputVisitor *iv; StringInputVisitor *iv;
char *str; char *str;
ov = string_output_visitor_new(false); ov = string_output_visitor_new(false);
object_property_get(obj, string_output_get_visitor(ov), object_property_get(obj, string_output_get_visitor(ov),
name, errp); name, &err);
if (err) {
error_propagate(errp, err);
goto out;
}
str = string_output_get_string(ov); str = string_output_get_string(ov);
iv = string_input_visitor_new(str); iv = string_input_visitor_new(str);
visit_type_uint16List(string_input_get_visitor(iv), visit_type_uint16List(string_input_get_visitor(iv),
list, NULL, errp); list, NULL, errp);
g_free(str); g_free(str);
string_output_visitor_cleanup(ov);
string_input_visitor_cleanup(iv); string_input_visitor_cleanup(iv);
out:
string_output_visitor_cleanup(ov);
} }
void object_property_parse(Object *obj, const char *string, void object_property_parse(Object *obj, const char *string,
...@@ -1646,8 +1658,14 @@ static void property_get_bool(Object *obj, Visitor *v, void *opaque, ...@@ -1646,8 +1658,14 @@ static void property_get_bool(Object *obj, Visitor *v, void *opaque,
{ {
BoolProperty *prop = opaque; BoolProperty *prop = opaque;
bool value; bool value;
Error *err = NULL;
value = prop->get(obj, &err);
if (err) {
error_propagate(errp, err);
return;
}
value = prop->get(obj, errp);
visit_type_bool(v, &value, name, errp); visit_type_bool(v, &value, name, errp);
} }
...@@ -1701,8 +1719,14 @@ static void property_get_enum(Object *obj, Visitor *v, void *opaque, ...@@ -1701,8 +1719,14 @@ static void property_get_enum(Object *obj, Visitor *v, void *opaque,
{ {
EnumProperty *prop = opaque; EnumProperty *prop = opaque;
int value; int value;
Error *err = NULL;
value = prop->get(obj, &err);
if (err) {
error_propagate(errp, err);
return;
}
value = prop->get(obj, errp);
visit_type_enum(v, &value, prop->strings, NULL, name, errp); visit_type_enum(v, &value, prop->strings, NULL, name, errp);
} }
...@@ -1711,8 +1735,13 @@ static void property_set_enum(Object *obj, Visitor *v, void *opaque, ...@@ -1711,8 +1735,13 @@ static void property_set_enum(Object *obj, Visitor *v, void *opaque,
{ {
EnumProperty *prop = opaque; EnumProperty *prop = opaque;
int value; int value;
Error *err = NULL;
visit_type_enum(v, &value, prop->strings, NULL, name, errp); visit_type_enum(v, &value, prop->strings, NULL, name, &err);
if (err) {
error_propagate(errp, err);
return;
}
prop->set(obj, value, errp); prop->set(obj, value, errp);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册