Message ID | 20240515082041.556571-7-zhenzhong.duan@intel.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | VFIO: misc cleanups part2 | expand |
On 5/15/24 10:20, Zhenzhong Duan wrote: > This is to follow the coding standand in qapi/error.h to return bool > for bool-valued functions. > > Suggested-by: Cédric Le Goater <clg@redhat.com> > Signed-off-by: Zhenzhong Duan <zhenzhong.duan@intel.com> Reviewed-by: Cédric Le Goater <clg@redhat.com> Thanks, C. > --- > hw/vfio/platform.c | 40 +++++++++++++++++----------------------- > 1 file changed, 17 insertions(+), 23 deletions(-) > > diff --git a/hw/vfio/platform.c b/hw/vfio/platform.c > index e1a32863d9..a85c199c76 100644 > --- a/hw/vfio/platform.c > +++ b/hw/vfio/platform.c > @@ -441,7 +441,7 @@ static int vfio_platform_hot_reset_multi(VFIODevice *vbasedev) > * @errp: error object > * > */ > -static int vfio_populate_device(VFIODevice *vbasedev, Error **errp) > +static bool vfio_populate_device(VFIODevice *vbasedev, Error **errp) > { > VFIOINTp *intp, *tmp; > int i, ret = -1; > @@ -450,7 +450,7 @@ static int vfio_populate_device(VFIODevice *vbasedev, Error **errp) > > if (!(vbasedev->flags & VFIO_DEVICE_FLAGS_PLATFORM)) { > error_setg(errp, "this isn't a platform device"); > - return ret; > + return false; > } > > vdev->regions = g_new0(VFIORegion *, vbasedev->num_regions); > @@ -487,12 +487,11 @@ static int vfio_populate_device(VFIODevice *vbasedev, Error **errp) > irq.flags); > intp = vfio_init_intp(vbasedev, irq, errp); > if (!intp) { > - ret = -1; > goto irq_err; > } > } > } > - return 0; > + return true; > irq_err: > timer_del(vdev->mmap_timer); > QLIST_FOREACH_SAFE(intp, &vdev->intp_list, next, tmp) { > @@ -507,7 +506,7 @@ reg_error: > g_free(vdev->regions[i]); > } > g_free(vdev->regions); > - return ret; > + return false; > } > > /* specialized functions for VFIO Platform devices */ > @@ -527,10 +526,8 @@ static VFIODeviceOps vfio_platform_ops = { > * fd retrieval, resource query. > * Precondition: the device name must be initialized > */ > -static int vfio_base_device_init(VFIODevice *vbasedev, Error **errp) > +static bool vfio_base_device_init(VFIODevice *vbasedev, Error **errp) > { > - int ret; > - > /* @fd takes precedence over @sysfsdev which takes precedence over @host */ > if (vbasedev->fd < 0 && vbasedev->sysfsdev) { > g_free(vbasedev->name); > @@ -538,7 +535,7 @@ static int vfio_base_device_init(VFIODevice *vbasedev, Error **errp) > } else if (vbasedev->fd < 0) { > if (!vbasedev->name || strchr(vbasedev->name, '/')) { > error_setg(errp, "wrong host device name"); > - return -EINVAL; > + return false; > } > > vbasedev->sysfsdev = g_strdup_printf("/sys/bus/platform/devices/%s", > @@ -546,20 +543,20 @@ static int vfio_base_device_init(VFIODevice *vbasedev, Error **errp) > } > > if (!vfio_device_get_name(vbasedev, errp)) { > - return -EINVAL; > + return false; > } > > if (!vfio_attach_device(vbasedev->name, vbasedev, > &address_space_memory, errp)) { > - return -EINVAL; > + return false; > } > > - ret = vfio_populate_device(vbasedev, errp); > - if (ret) { > - vfio_detach_device(vbasedev); > + if (vfio_populate_device(vbasedev, errp)) { > + return true; > } > > - return ret; > + vfio_detach_device(vbasedev); > + return false; > } > > /** > @@ -576,7 +573,7 @@ static void vfio_platform_realize(DeviceState *dev, Error **errp) > VFIOPlatformDevice *vdev = VFIO_PLATFORM_DEVICE(dev); > SysBusDevice *sbdev = SYS_BUS_DEVICE(dev); > VFIODevice *vbasedev = &vdev->vbasedev; > - int i, ret; > + int i; > > qemu_mutex_init(&vdev->intp_mutex); > > @@ -584,9 +581,8 @@ static void vfio_platform_realize(DeviceState *dev, Error **errp) > vbasedev->sysfsdev : vbasedev->name, > vdev->compat); > > - ret = vfio_base_device_init(vbasedev, errp); > - if (ret) { > - goto out; > + if (!vfio_base_device_init(vbasedev, errp)) { > + goto init_err; > } > > if (!vdev->compat) { > @@ -618,11 +614,9 @@ static void vfio_platform_realize(DeviceState *dev, Error **errp) > } > sysbus_init_mmio(sbdev, vdev->regions[i]->mem); > } > -out: > - if (!ret) { > - return; > - } > + return; > > +init_err: > if (vdev->vbasedev.name) { > error_prepend(errp, VFIO_MSG_PREFIX, vdev->vbasedev.name); > } else {
diff --git a/hw/vfio/platform.c b/hw/vfio/platform.c index e1a32863d9..a85c199c76 100644 --- a/hw/vfio/platform.c +++ b/hw/vfio/platform.c @@ -441,7 +441,7 @@ static int vfio_platform_hot_reset_multi(VFIODevice *vbasedev) * @errp: error object * */ -static int vfio_populate_device(VFIODevice *vbasedev, Error **errp) +static bool vfio_populate_device(VFIODevice *vbasedev, Error **errp) { VFIOINTp *intp, *tmp; int i, ret = -1; @@ -450,7 +450,7 @@ static int vfio_populate_device(VFIODevice *vbasedev, Error **errp) if (!(vbasedev->flags & VFIO_DEVICE_FLAGS_PLATFORM)) { error_setg(errp, "this isn't a platform device"); - return ret; + return false; } vdev->regions = g_new0(VFIORegion *, vbasedev->num_regions); @@ -487,12 +487,11 @@ static int vfio_populate_device(VFIODevice *vbasedev, Error **errp) irq.flags); intp = vfio_init_intp(vbasedev, irq, errp); if (!intp) { - ret = -1; goto irq_err; } } } - return 0; + return true; irq_err: timer_del(vdev->mmap_timer); QLIST_FOREACH_SAFE(intp, &vdev->intp_list, next, tmp) { @@ -507,7 +506,7 @@ reg_error: g_free(vdev->regions[i]); } g_free(vdev->regions); - return ret; + return false; } /* specialized functions for VFIO Platform devices */ @@ -527,10 +526,8 @@ static VFIODeviceOps vfio_platform_ops = { * fd retrieval, resource query. * Precondition: the device name must be initialized */ -static int vfio_base_device_init(VFIODevice *vbasedev, Error **errp) +static bool vfio_base_device_init(VFIODevice *vbasedev, Error **errp) { - int ret; - /* @fd takes precedence over @sysfsdev which takes precedence over @host */ if (vbasedev->fd < 0 && vbasedev->sysfsdev) { g_free(vbasedev->name); @@ -538,7 +535,7 @@ static int vfio_base_device_init(VFIODevice *vbasedev, Error **errp) } else if (vbasedev->fd < 0) { if (!vbasedev->name || strchr(vbasedev->name, '/')) { error_setg(errp, "wrong host device name"); - return -EINVAL; + return false; } vbasedev->sysfsdev = g_strdup_printf("/sys/bus/platform/devices/%s", @@ -546,20 +543,20 @@ static int vfio_base_device_init(VFIODevice *vbasedev, Error **errp) } if (!vfio_device_get_name(vbasedev, errp)) { - return -EINVAL; + return false; } if (!vfio_attach_device(vbasedev->name, vbasedev, &address_space_memory, errp)) { - return -EINVAL; + return false; } - ret = vfio_populate_device(vbasedev, errp); - if (ret) { - vfio_detach_device(vbasedev); + if (vfio_populate_device(vbasedev, errp)) { + return true; } - return ret; + vfio_detach_device(vbasedev); + return false; } /** @@ -576,7 +573,7 @@ static void vfio_platform_realize(DeviceState *dev, Error **errp) VFIOPlatformDevice *vdev = VFIO_PLATFORM_DEVICE(dev); SysBusDevice *sbdev = SYS_BUS_DEVICE(dev); VFIODevice *vbasedev = &vdev->vbasedev; - int i, ret; + int i; qemu_mutex_init(&vdev->intp_mutex); @@ -584,9 +581,8 @@ static void vfio_platform_realize(DeviceState *dev, Error **errp) vbasedev->sysfsdev : vbasedev->name, vdev->compat); - ret = vfio_base_device_init(vbasedev, errp); - if (ret) { - goto out; + if (!vfio_base_device_init(vbasedev, errp)) { + goto init_err; } if (!vdev->compat) { @@ -618,11 +614,9 @@ static void vfio_platform_realize(DeviceState *dev, Error **errp) } sysbus_init_mmio(sbdev, vdev->regions[i]->mem); } -out: - if (!ret) { - return; - } + return; +init_err: if (vdev->vbasedev.name) { error_prepend(errp, VFIO_MSG_PREFIX, vdev->vbasedev.name); } else {
This is to follow the coding standand in qapi/error.h to return bool for bool-valued functions. Suggested-by: Cédric Le Goater <clg@redhat.com> Signed-off-by: Zhenzhong Duan <zhenzhong.duan@intel.com> --- hw/vfio/platform.c | 40 +++++++++++++++++----------------------- 1 file changed, 17 insertions(+), 23 deletions(-)