error: Eliminate error_propagate() manually

When all we do with an Error we receive into a local variable is
propagating to somewhere else, we can just as well receive it there
right away.  The previous two commits did that for sufficiently simple
cases with Coccinelle.  Do it for several more manually.

Signed-off-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Message-Id: <20200707160613.848843-37-armbru@redhat.com>
This commit is contained in:
Markus Armbruster 2020-07-07 18:06:04 +02:00
parent af175e85f9
commit 992861fb1e
18 changed files with 67 additions and 149 deletions

View File

@ -367,7 +367,6 @@ static void reopen_backing_file(BlockDriverState *bs, bool writable,
{ {
BDRVReplicationState *s = bs->opaque; BDRVReplicationState *s = bs->opaque;
BlockReopenQueue *reopen_queue = NULL; BlockReopenQueue *reopen_queue = NULL;
Error *local_err = NULL;
if (writable) { if (writable) {
s->orig_hidden_read_only = bdrv_is_read_only(s->hidden_disk->bs); s->orig_hidden_read_only = bdrv_is_read_only(s->hidden_disk->bs);
@ -392,8 +391,7 @@ static void reopen_backing_file(BlockDriverState *bs, bool writable,
} }
if (reopen_queue) { if (reopen_queue) {
bdrv_reopen_multiple(reopen_queue, &local_err); bdrv_reopen_multiple(reopen_queue, errp);
error_propagate(errp, local_err);
} }
bdrv_subtree_drained_end(s->hidden_disk->bs); bdrv_subtree_drained_end(s->hidden_disk->bs);

View File

@ -793,7 +793,6 @@ DriveInfo *drive_new(QemuOpts *all_opts, BlockInterfaceType block_default_type,
bool read_only = false; bool read_only = false;
bool copy_on_read; bool copy_on_read;
const char *filename; const char *filename;
Error *local_err = NULL;
int i; int i;
/* Change legacy command line options into QMP ones */ /* Change legacy command line options into QMP ones */
@ -1003,13 +1002,10 @@ DriveInfo *drive_new(QemuOpts *all_opts, BlockInterfaceType block_default_type,
} }
/* Actual block device init: Functionality shared with blockdev-add */ /* Actual block device init: Functionality shared with blockdev-add */
blk = blockdev_init(filename, bs_opts, &local_err); blk = blockdev_init(filename, bs_opts, errp);
bs_opts = NULL; bs_opts = NULL;
if (!blk) { if (!blk) {
error_propagate(errp, local_err);
goto fail; goto fail;
} else {
assert(!local_err);
} }
/* Create legacy DriveInfo */ /* Create legacy DriveInfo */
@ -3141,9 +3137,8 @@ void qmp_drive_mirror(DriveMirror *arg, Error **errp)
arg->has_copy_mode, arg->copy_mode, arg->has_copy_mode, arg->copy_mode,
arg->has_auto_finalize, arg->auto_finalize, arg->has_auto_finalize, arg->auto_finalize,
arg->has_auto_dismiss, arg->auto_dismiss, arg->has_auto_dismiss, arg->auto_dismiss,
&local_err); errp);
bdrv_unref(target_bs); bdrv_unref(target_bs);
error_propagate(errp, local_err);
out: out:
aio_context_release(aio_context); aio_context_release(aio_context);
} }
@ -3171,7 +3166,6 @@ void qmp_blockdev_mirror(bool has_job_id, const char *job_id,
AioContext *aio_context; AioContext *aio_context;
AioContext *old_context; AioContext *old_context;
BlockMirrorBackingMode backing_mode = MIRROR_LEAVE_BACKING_CHAIN; BlockMirrorBackingMode backing_mode = MIRROR_LEAVE_BACKING_CHAIN;
Error *local_err = NULL;
bool zero_target; bool zero_target;
int ret; int ret;
@ -3213,8 +3207,7 @@ void qmp_blockdev_mirror(bool has_job_id, const char *job_id,
has_copy_mode, copy_mode, has_copy_mode, copy_mode,
has_auto_finalize, auto_finalize, has_auto_finalize, auto_finalize,
has_auto_dismiss, auto_dismiss, has_auto_dismiss, auto_dismiss,
&local_err); errp);
error_propagate(errp, local_err);
out: out:
aio_context_release(aio_context); aio_context_release(aio_context);
} }
@ -3433,8 +3426,7 @@ void qmp_change_backing_file(const char *device,
} }
if (ro) { if (ro) {
bdrv_reopen_set_read_only(image_bs, true, &local_err); bdrv_reopen_set_read_only(image_bs, true, errp);
error_propagate(errp, local_err);
} }
out: out:

View File

@ -303,15 +303,13 @@ static void device_set_bootindex(Object *obj, Visitor *v, const char *name,
/* check whether bootindex is present in fw_boot_order list */ /* check whether bootindex is present in fw_boot_order list */
check_boot_index(boot_index, &local_err); check_boot_index(boot_index, &local_err);
if (local_err) { if (local_err) {
goto out; error_propagate(errp, local_err);
return;
} }
/* change bootindex to a new one */ /* change bootindex to a new one */
*prop->bootindex = boot_index; *prop->bootindex = boot_index;
add_boot_device_path(*prop->bootindex, prop->dev, prop->suffix); add_boot_device_path(*prop->bootindex, prop->dev, prop->suffix);
out:
error_propagate(errp, local_err);
} }
static void property_release_bootindex(Object *obj, const char *name, static void property_release_bootindex(Object *obj, const char *name,

View File

@ -1031,14 +1031,11 @@ out:
static void write_dump_header(DumpState *s, Error **errp) static void write_dump_header(DumpState *s, Error **errp)
{ {
Error *local_err = NULL;
if (s->dump_info.d_class == ELFCLASS32) { if (s->dump_info.d_class == ELFCLASS32) {
create_header32(s, &local_err); create_header32(s, errp);
} else { } else {
create_header64(s, &local_err); create_header64(s, errp);
} }
error_propagate(errp, local_err);
} }
static size_t dump_bitmap_get_bufsize(DumpState *s) static size_t dump_bitmap_get_bufsize(DumpState *s)

View File

@ -2528,7 +2528,7 @@ static void fdctrl_connect_drives(FDCtrl *fdctrl, DeviceState *fdc_dev,
FDrive *drive; FDrive *drive;
DeviceState *dev; DeviceState *dev;
BlockBackend *blk; BlockBackend *blk;
Error *local_err = NULL; bool ok;
const char *fdc_name, *drive_suffix; const char *fdc_name, *drive_suffix;
for (i = 0; i < MAX_FD; i++) { for (i = 0; i < MAX_FD; i++) {
@ -2567,11 +2567,9 @@ static void fdctrl_connect_drives(FDCtrl *fdctrl, DeviceState *fdc_dev,
blk_ref(blk); blk_ref(blk);
blk_detach_dev(blk, fdc_dev); blk_detach_dev(blk, fdc_dev);
fdctrl->qdev_for_drives[i].blk = NULL; fdctrl->qdev_for_drives[i].blk = NULL;
qdev_prop_set_drive_err(dev, "drive", blk, &local_err); ok = qdev_prop_set_drive_err(dev, "drive", blk, errp);
blk_unref(blk); blk_unref(blk);
if (!ok) {
if (local_err) {
error_propagate(errp, local_err);
return; return;
} }

View File

@ -456,40 +456,33 @@ void parse_numa_hmat_cache(MachineState *ms, NumaHmatCacheOptions *node,
void set_numa_options(MachineState *ms, NumaOptions *object, Error **errp) void set_numa_options(MachineState *ms, NumaOptions *object, Error **errp)
{ {
Error *err = NULL;
if (!ms->numa_state) { if (!ms->numa_state) {
error_setg(errp, "NUMA is not supported by this machine-type"); error_setg(errp, "NUMA is not supported by this machine-type");
goto end; return;
} }
switch (object->type) { switch (object->type) {
case NUMA_OPTIONS_TYPE_NODE: case NUMA_OPTIONS_TYPE_NODE:
parse_numa_node(ms, &object->u.node, &err); parse_numa_node(ms, &object->u.node, errp);
if (err) {
goto end;
}
break; break;
case NUMA_OPTIONS_TYPE_DIST: case NUMA_OPTIONS_TYPE_DIST:
parse_numa_distance(ms, &object->u.dist, &err); parse_numa_distance(ms, &object->u.dist, errp);
if (err) {
goto end;
}
break; break;
case NUMA_OPTIONS_TYPE_CPU: case NUMA_OPTIONS_TYPE_CPU:
if (!object->u.cpu.has_node_id) { if (!object->u.cpu.has_node_id) {
error_setg(&err, "Missing mandatory node-id property"); error_setg(errp, "Missing mandatory node-id property");
goto end; return;
} }
if (!ms->numa_state->nodes[object->u.cpu.node_id].present) { if (!ms->numa_state->nodes[object->u.cpu.node_id].present) {
error_setg(&err, "Invalid node-id=%" PRId64 ", NUMA node must be " error_setg(errp, "Invalid node-id=%" PRId64 ", NUMA node must be "
"defined with -numa node,nodeid=ID before it's used with " "defined with -numa node,nodeid=ID before it's used with "
"-numa cpu,node-id=ID", object->u.cpu.node_id); "-numa cpu,node-id=ID", object->u.cpu.node_id);
goto end; return;
} }
machine_set_cpu_numa_node(ms, qapi_NumaCpuOptions_base(&object->u.cpu), machine_set_cpu_numa_node(ms,
&err); qapi_NumaCpuOptions_base(&object->u.cpu),
errp);
break; break;
case NUMA_OPTIONS_TYPE_HMAT_LB: case NUMA_OPTIONS_TYPE_HMAT_LB:
if (!ms->numa_state->hmat_enabled) { if (!ms->numa_state->hmat_enabled) {
@ -499,10 +492,7 @@ void set_numa_options(MachineState *ms, NumaOptions *object, Error **errp)
return; return;
} }
parse_numa_hmat_lb(ms->numa_state, &object->u.hmat_lb, &err); parse_numa_hmat_lb(ms->numa_state, &object->u.hmat_lb, errp);
if (err) {
goto end;
}
break; break;
case NUMA_OPTIONS_TYPE_HMAT_CACHE: case NUMA_OPTIONS_TYPE_HMAT_CACHE:
if (!ms->numa_state->hmat_enabled) { if (!ms->numa_state->hmat_enabled) {
@ -512,17 +502,11 @@ void set_numa_options(MachineState *ms, NumaOptions *object, Error **errp)
return; return;
} }
parse_numa_hmat_cache(ms, &object->u.hmat_cache, &err); parse_numa_hmat_cache(ms, &object->u.hmat_cache, errp);
if (err) {
goto end;
}
break; break;
default: default:
abort(); abort();
} }
end:
error_propagate(errp, err);
} }
static int parse_numa(void *opaque, QemuOpts *opts, Error **errp) static int parse_numa(void *opaque, QemuOpts *opts, Error **errp)

View File

@ -118,17 +118,15 @@ uint32_t x86_cpu_apic_id_from_index(X86MachineState *x86ms,
void x86_cpu_new(X86MachineState *x86ms, int64_t apic_id, Error **errp) void x86_cpu_new(X86MachineState *x86ms, int64_t apic_id, Error **errp)
{ {
Error *local_err = NULL;
Object *cpu = object_new(MACHINE(x86ms)->cpu_type); Object *cpu = object_new(MACHINE(x86ms)->cpu_type);
if (!object_property_set_uint(cpu, "apic-id", apic_id, &local_err)) { if (!object_property_set_uint(cpu, "apic-id", apic_id, errp)) {
goto out; goto out;
} }
qdev_realize(DEVICE(cpu), NULL, &local_err); qdev_realize(DEVICE(cpu), NULL, errp);
out: out:
object_unref(cpu); object_unref(cpu);
error_propagate(errp, local_err);
} }
void x86_cpus_init(X86MachineState *x86ms, int default_cpu_version) void x86_cpus_init(X86MachineState *x86ms, int default_cpu_version)

View File

@ -757,7 +757,6 @@ static const TypeInfo xive_tctx_info = {
Object *xive_tctx_create(Object *cpu, XivePresenter *xptr, Error **errp) Object *xive_tctx_create(Object *cpu, XivePresenter *xptr, Error **errp)
{ {
Error *local_err = NULL;
Object *obj; Object *obj;
obj = object_new(TYPE_XIVE_TCTX); obj = object_new(TYPE_XIVE_TCTX);
@ -765,17 +764,12 @@ Object *xive_tctx_create(Object *cpu, XivePresenter *xptr, Error **errp)
object_unref(obj); object_unref(obj);
object_property_set_link(obj, "cpu", cpu, &error_abort); object_property_set_link(obj, "cpu", cpu, &error_abort);
object_property_set_link(obj, "presenter", OBJECT(xptr), &error_abort); object_property_set_link(obj, "presenter", OBJECT(xptr), &error_abort);
if (!qdev_realize(DEVICE(obj), NULL, &local_err)) { if (!qdev_realize(DEVICE(obj), NULL, errp)) {
goto error;
}
return obj;
error:
object_unparent(obj); object_unparent(obj);
error_propagate(errp, local_err);
return NULL; return NULL;
} }
return obj;
}
void xive_tctx_destroy(XiveTCTX *tctx) void xive_tctx_destroy(XiveTCTX *tctx)
{ {

View File

@ -239,8 +239,8 @@ static void spapr_realize_vcpu(PowerPCCPU *cpu, SpaprMachineState *spapr,
CPUState *cs = CPU(cpu); CPUState *cs = CPU(cpu);
Error *local_err = NULL; Error *local_err = NULL;
if (!qdev_realize(DEVICE(cpu), NULL, &local_err)) { if (!qdev_realize(DEVICE(cpu), NULL, errp)) {
goto error; return;
} }
/* Set time-base frequency to 512 MHz */ /* Set time-base frequency to 512 MHz */
@ -250,20 +250,14 @@ static void spapr_realize_vcpu(PowerPCCPU *cpu, SpaprMachineState *spapr,
kvmppc_set_papr(cpu); kvmppc_set_papr(cpu);
if (spapr_irq_cpu_intc_create(spapr, cpu, &local_err) < 0) { if (spapr_irq_cpu_intc_create(spapr, cpu, &local_err) < 0) {
goto error_intc_create; cpu_remove_sync(CPU(cpu));
return;
} }
if (!sc->pre_3_0_migration) { if (!sc->pre_3_0_migration) {
vmstate_register(NULL, cs->cpu_index, &vmstate_spapr_cpu_state, vmstate_register(NULL, cs->cpu_index, &vmstate_spapr_cpu_state,
cpu->machine_data); cpu->machine_data);
} }
return;
error_intc_create:
cpu_remove_sync(CPU(cpu));
error:
error_propagate(errp, local_err);
} }
static PowerPCCPU *spapr_create_vcpu(SpaprCpuCore *sc, int i, Error **errp) static PowerPCCPU *spapr_create_vcpu(SpaprCpuCore *sc, int i, Error **errp)

View File

@ -743,7 +743,6 @@ static void s390_pcihost_realize(DeviceState *dev, Error **errp)
BusState *bus; BusState *bus;
PCIHostState *phb = PCI_HOST_BRIDGE(dev); PCIHostState *phb = PCI_HOST_BRIDGE(dev);
S390pciState *s = S390_PCI_HOST_BRIDGE(dev); S390pciState *s = S390_PCI_HOST_BRIDGE(dev);
Error *local_err = NULL;
DPRINTF("host_init\n"); DPRINTF("host_init\n");
@ -767,8 +766,7 @@ static void s390_pcihost_realize(DeviceState *dev, Error **errp)
QTAILQ_INIT(&s->zpci_devs); QTAILQ_INIT(&s->zpci_devs);
css_register_io_adapters(CSS_IO_ADAPTER_PCI, true, false, css_register_io_adapters(CSS_IO_ADAPTER_PCI, true, false,
S390_ADAPTER_SUPPRESSIBLE, &local_err); S390_ADAPTER_SUPPRESSIBLE, errp);
error_propagate(errp, local_err);
} }
static int s390_pci_msix_init(S390PCIBusDevice *pbdev) static int s390_pci_msix_init(S390PCIBusDevice *pbdev)

View File

@ -68,20 +68,18 @@ static S390CPU *s390x_new_cpu(const char *typename, uint32_t core_id,
Error **errp) Error **errp)
{ {
S390CPU *cpu = S390_CPU(object_new(typename)); S390CPU *cpu = S390_CPU(object_new(typename));
Error *err = NULL;
S390CPU *ret = NULL; S390CPU *ret = NULL;
if (!object_property_set_int(OBJECT(cpu), "core-id", core_id, &err)) { if (!object_property_set_int(OBJECT(cpu), "core-id", core_id, errp)) {
goto out; goto out;
} }
if (!qdev_realize(DEVICE(cpu), NULL, &err)) { if (!qdev_realize(DEVICE(cpu), NULL, errp)) {
goto out; goto out;
} }
ret = cpu; ret = cpu;
out: out:
object_unref(OBJECT(cpu)); object_unref(OBJECT(cpu));
error_propagate(errp, err);
return ret; return ret;
} }

View File

@ -329,7 +329,6 @@ static void sclp_realize(DeviceState *dev, Error **errp)
{ {
MachineState *machine = MACHINE(qdev_get_machine()); MachineState *machine = MACHINE(qdev_get_machine());
SCLPDevice *sclp = SCLP(dev); SCLPDevice *sclp = SCLP(dev);
Error *err = NULL;
uint64_t hw_limit; uint64_t hw_limit;
int ret; int ret;
@ -338,20 +337,17 @@ static void sclp_realize(DeviceState *dev, Error **errp)
* as we can't find a fitting bus via the qom tree, we have to add the * as we can't find a fitting bus via the qom tree, we have to add the
* event facility to the sysbus, so e.g. a sclp console can be created. * event facility to the sysbus, so e.g. a sclp console can be created.
*/ */
if (!sysbus_realize(SYS_BUS_DEVICE(sclp->event_facility), &err)) { if (!sysbus_realize(SYS_BUS_DEVICE(sclp->event_facility), errp)) {
goto out; return;
} }
ret = s390_set_memory_limit(machine->maxram_size, &hw_limit); ret = s390_set_memory_limit(machine->maxram_size, &hw_limit);
if (ret == -E2BIG) { if (ret == -E2BIG) {
error_setg(&err, "host supports a maximum of %" PRIu64 " GB", error_setg(errp, "host supports a maximum of %" PRIu64 " GB",
hw_limit / GiB); hw_limit / GiB);
} else if (ret) { } else if (ret) {
error_setg(&err, "setting the guest size failed"); error_setg(errp, "setting the guest size failed");
} }
out:
error_propagate(errp, err);
} }
static void sclp_memory_init(SCLPDevice *sclp) static void sclp_memory_init(SCLPDevice *sclp)

View File

@ -723,15 +723,13 @@ static bool usb_get_attached(Object *obj, Error **errp)
static void usb_set_attached(Object *obj, bool value, Error **errp) static void usb_set_attached(Object *obj, bool value, Error **errp)
{ {
USBDevice *dev = USB_DEVICE(obj); USBDevice *dev = USB_DEVICE(obj);
Error *err = NULL;
if (dev->attached == value) { if (dev->attached == value) {
return; return;
} }
if (value) { if (value) {
usb_device_attach(dev, &err); usb_device_attach(dev, errp);
error_propagate(errp, err);
} else { } else {
usb_device_detach(dev); usb_device_detach(dev);
} }

View File

@ -600,7 +600,6 @@ DeviceState *qdev_device_add(QemuOpts *opts, Error **errp)
const char *driver, *path; const char *driver, *path;
DeviceState *dev = NULL; DeviceState *dev = NULL;
BusState *bus = NULL; BusState *bus = NULL;
Error *err = NULL;
bool hide; bool hide;
driver = qemu_opt_get(opts, "driver"); driver = qemu_opt_get(opts, "driver");
@ -655,15 +654,13 @@ DeviceState *qdev_device_add(QemuOpts *opts, Error **errp)
dev = qdev_new(driver); dev = qdev_new(driver);
/* Check whether the hotplug is allowed by the machine */ /* Check whether the hotplug is allowed by the machine */
if (qdev_hotplug && !qdev_hotplug_allowed(dev, &err)) { if (qdev_hotplug && !qdev_hotplug_allowed(dev, errp)) {
/* Error must be set in the machine hook */
assert(err);
goto err_del_dev; goto err_del_dev;
} }
if (!bus && qdev_hotplug && !qdev_get_machine_hotplug_handler(dev)) { if (!bus && qdev_hotplug && !qdev_get_machine_hotplug_handler(dev)) {
/* No bus, no machine hotplug handler --> device is not hotpluggable */ /* No bus, no machine hotplug handler --> device is not hotpluggable */
error_setg(&err, "Device '%s' can not be hotplugged on this machine", error_setg(errp, "Device '%s' can not be hotplugged on this machine",
driver); driver);
goto err_del_dev; goto err_del_dev;
} }
@ -671,19 +668,18 @@ DeviceState *qdev_device_add(QemuOpts *opts, Error **errp)
qdev_set_id(dev, qemu_opts_id(opts)); qdev_set_id(dev, qemu_opts_id(opts));
/* set properties */ /* set properties */
if (qemu_opt_foreach(opts, set_property, dev, &err)) { if (qemu_opt_foreach(opts, set_property, dev, errp)) {
goto err_del_dev; goto err_del_dev;
} }
dev->opts = opts; dev->opts = opts;
if (!qdev_realize(DEVICE(dev), bus, &err)) { if (!qdev_realize(DEVICE(dev), bus, errp)) {
dev->opts = NULL; dev->opts = NULL;
goto err_del_dev; goto err_del_dev;
} }
return dev; return dev;
err_del_dev: err_del_dev:
error_propagate(errp, err);
if (dev) { if (dev) {
object_unparent(OBJECT(dev)); object_unparent(OBJECT(dev));
object_unref(OBJECT(dev)); object_unref(OBJECT(dev));

View File

@ -1552,13 +1552,12 @@ static int run_process_child(const char *command[], Error **errp)
static bool systemd_supports_mode(SuspendMode mode, Error **errp) static bool systemd_supports_mode(SuspendMode mode, Error **errp)
{ {
Error *local_err = NULL;
const char *systemctl_args[3] = {"systemd-hibernate", "systemd-suspend", const char *systemctl_args[3] = {"systemd-hibernate", "systemd-suspend",
"systemd-hybrid-sleep"}; "systemd-hybrid-sleep"};
const char *cmd[4] = {"systemctl", "status", systemctl_args[mode], NULL}; const char *cmd[4] = {"systemctl", "status", systemctl_args[mode], NULL};
int status; int status;
status = run_process_child(cmd, &local_err); status = run_process_child(cmd, errp);
/* /*
* systemctl status uses LSB return codes so we can expect * systemctl status uses LSB return codes so we can expect
@ -1572,7 +1571,6 @@ static bool systemd_supports_mode(SuspendMode mode, Error **errp)
return true; return true;
} }
error_propagate(errp, local_err);
return false; return false;
} }

View File

@ -549,7 +549,6 @@ bool object_initialize_child_with_propsv(Object *parentobj,
const char *type, const char *type,
Error **errp, va_list vargs) Error **errp, va_list vargs)
{ {
Error *local_err = NULL;
bool ok = false; bool ok = false;
Object *obj; Object *obj;
UserCreatable *uc; UserCreatable *uc;
@ -565,7 +564,7 @@ bool object_initialize_child_with_propsv(Object *parentobj,
uc = (UserCreatable *)object_dynamic_cast(obj, TYPE_USER_CREATABLE); uc = (UserCreatable *)object_dynamic_cast(obj, TYPE_USER_CREATABLE);
if (uc) { if (uc) {
if (!user_creatable_complete(uc, &local_err)) { if (!user_creatable_complete(uc, errp)) {
object_unparent(obj); object_unparent(obj);
goto out; goto out;
} }
@ -583,8 +582,6 @@ out:
* the reference taken by object_property_add_child(). * the reference taken by object_property_add_child().
*/ */
object_unref(obj); object_unref(obj);
error_propagate(errp, local_err);
return ok; return ok;
} }
@ -737,7 +734,6 @@ Object *object_new_with_propv(const char *typename,
{ {
Object *obj; Object *obj;
ObjectClass *klass; ObjectClass *klass;
Error *local_err = NULL;
UserCreatable *uc; UserCreatable *uc;
klass = object_class_by_name(typename); klass = object_class_by_name(typename);
@ -762,7 +758,7 @@ Object *object_new_with_propv(const char *typename,
uc = (UserCreatable *)object_dynamic_cast(obj, TYPE_USER_CREATABLE); uc = (UserCreatable *)object_dynamic_cast(obj, TYPE_USER_CREATABLE);
if (uc) { if (uc) {
if (!user_creatable_complete(uc, &local_err)) { if (!user_creatable_complete(uc, errp)) {
if (id != NULL) { if (id != NULL) {
object_unparent(obj); object_unparent(obj);
} }
@ -774,7 +770,6 @@ Object *object_new_with_propv(const char *typename,
return obj; return obj;
error: error:
error_propagate(errp, local_err);
object_unref(obj); object_unref(obj);
return NULL; return NULL;
} }
@ -2326,36 +2321,34 @@ static void property_get_tm(Object *obj, Visitor *v, const char *name,
prop->get(obj, &value, &err); prop->get(obj, &value, &err);
if (err) { if (err) {
goto out; error_propagate(errp, err);
return;
} }
if (!visit_start_struct(v, name, NULL, 0, &err)) { if (!visit_start_struct(v, name, NULL, 0, errp)) {
goto out; return;
} }
if (!visit_type_int32(v, "tm_year", &value.tm_year, &err)) { if (!visit_type_int32(v, "tm_year", &value.tm_year, errp)) {
goto out_end; goto out_end;
} }
if (!visit_type_int32(v, "tm_mon", &value.tm_mon, &err)) { if (!visit_type_int32(v, "tm_mon", &value.tm_mon, errp)) {
goto out_end; goto out_end;
} }
if (!visit_type_int32(v, "tm_mday", &value.tm_mday, &err)) { if (!visit_type_int32(v, "tm_mday", &value.tm_mday, errp)) {
goto out_end; goto out_end;
} }
if (!visit_type_int32(v, "tm_hour", &value.tm_hour, &err)) { if (!visit_type_int32(v, "tm_hour", &value.tm_hour, errp)) {
goto out_end; goto out_end;
} }
if (!visit_type_int32(v, "tm_min", &value.tm_min, &err)) { if (!visit_type_int32(v, "tm_min", &value.tm_min, errp)) {
goto out_end; goto out_end;
} }
if (!visit_type_int32(v, "tm_sec", &value.tm_sec, &err)) { if (!visit_type_int32(v, "tm_sec", &value.tm_sec, errp)) {
goto out_end; goto out_end;
} }
visit_check_struct(v, &err); visit_check_struct(v, errp);
out_end: out_end:
visit_end_struct(v, NULL); visit_end_struct(v, NULL);
out:
error_propagate(errp, err);
} }
static void property_release_tm(Object *obj, const char *name, static void property_release_tm(Object *obj, const char *name,

View File

@ -34,15 +34,12 @@ QObject *object_property_get_qobject(Object *obj, const char *name,
Error **errp) Error **errp)
{ {
QObject *ret = NULL; QObject *ret = NULL;
Error *local_err = NULL;
Visitor *v; Visitor *v;
v = qobject_output_visitor_new(&ret); v = qobject_output_visitor_new(&ret);
object_property_get(obj, name, v, &local_err); if (object_property_get(obj, name, v, errp)) {
if (!local_err) {
visit_complete(v, &ret); visit_complete(v, &ret);
} }
error_propagate(errp, local_err);
visit_free(v); visit_free(v);
return ret; return ret;
} }

View File

@ -5260,16 +5260,13 @@ static void x86_cpu_to_dict_full(X86CPU *cpu, QDict *props)
static void object_apply_props(Object *obj, QDict *props, Error **errp) static void object_apply_props(Object *obj, QDict *props, Error **errp)
{ {
const QDictEntry *prop; const QDictEntry *prop;
Error *err = NULL;
for (prop = qdict_first(props); prop; prop = qdict_next(props, prop)) { for (prop = qdict_first(props); prop; prop = qdict_next(props, prop)) {
if (!object_property_set_qobject(obj, qdict_entry_key(prop), if (!object_property_set_qobject(obj, qdict_entry_key(prop),
qdict_entry_value(prop), &err)) { qdict_entry_value(prop), errp)) {
break; break;
} }
} }
error_propagate(errp, err);
} }
/* Create X86CPU object according to model+props specification */ /* Create X86CPU object according to model+props specification */
@ -6327,19 +6324,18 @@ static void x86_cpu_expand_features(X86CPU *cpu, Error **errp)
FeatureWord w; FeatureWord w;
int i; int i;
GList *l; GList *l;
Error *local_err = NULL;
for (l = plus_features; l; l = l->next) { for (l = plus_features; l; l = l->next) {
const char *prop = l->data; const char *prop = l->data;
if (!object_property_set_bool(OBJECT(cpu), prop, true, &local_err)) { if (!object_property_set_bool(OBJECT(cpu), prop, true, errp)) {
goto out; return;
} }
} }
for (l = minus_features; l; l = l->next) { for (l = minus_features; l; l = l->next) {
const char *prop = l->data; const char *prop = l->data;
if (!object_property_set_bool(OBJECT(cpu), prop, false, &local_err)) { if (!object_property_set_bool(OBJECT(cpu), prop, false, errp)) {
goto out; return;
} }
} }
@ -6437,11 +6433,6 @@ static void x86_cpu_expand_features(X86CPU *cpu, Error **errp)
if (env->cpuid_xlevel2 == UINT32_MAX) { if (env->cpuid_xlevel2 == UINT32_MAX) {
env->cpuid_xlevel2 = env->cpuid_min_xlevel2; env->cpuid_xlevel2 = env->cpuid_min_xlevel2;
} }
out:
if (local_err != NULL) {
error_propagate(errp, local_err);
}
} }
/* /*