vfio: Pass an error object to vfio_get_device

Pass an error object to prepare for migration to VFIO-PCI realize.

In vfio platform vfio_base_device_init we currently just report the
error. Subsequent patches will propagate the error up to the realize
function.

Signed-off-by: Eric Auger <eric.auger@redhat.com>
Reviewed-by: Markus Armbruster <armbru@redhat.com>
Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
This commit is contained in:
Eric Auger 2016-10-17 10:58:00 -06:00 committed by Alex Williamson
parent 1b808d5be0
commit 59f7d6743c
4 changed files with 11 additions and 12 deletions

View File

@ -1211,23 +1211,24 @@ void vfio_put_group(VFIOGroup *group)
} }
int vfio_get_device(VFIOGroup *group, const char *name, int vfio_get_device(VFIOGroup *group, const char *name,
VFIODevice *vbasedev) VFIODevice *vbasedev, Error **errp)
{ {
struct vfio_device_info dev_info = { .argsz = sizeof(dev_info) }; struct vfio_device_info dev_info = { .argsz = sizeof(dev_info) };
int ret, fd; int ret, fd;
fd = ioctl(group->fd, VFIO_GROUP_GET_DEVICE_FD, name); fd = ioctl(group->fd, VFIO_GROUP_GET_DEVICE_FD, name);
if (fd < 0) { if (fd < 0) {
error_report("vfio: error getting device %s from group %d: %m", error_setg_errno(errp, errno, "error getting device from group %d",
name, group->groupid); group->groupid);
error_printf("Verify all devices in group %d are bound to vfio-<bus> " error_append_hint(errp,
"or pci-stub and not already in use\n", group->groupid); "Verify all devices in group %d are bound to vfio-<bus> "
"or pci-stub and not already in use\n", group->groupid);
return fd; return fd;
} }
ret = ioctl(fd, VFIO_DEVICE_GET_INFO, &dev_info); ret = ioctl(fd, VFIO_DEVICE_GET_INFO, &dev_info);
if (ret) { if (ret) {
error_report("vfio: error getting device info: %m"); error_setg_errno(errp, errno, "error getting device info");
close(fd); close(fd);
return ret; return ret;
} }

View File

@ -2578,9 +2578,8 @@ static int vfio_initfn(PCIDevice *pdev)
} }
} }
ret = vfio_get_device(group, vdev->vbasedev.name, &vdev->vbasedev); ret = vfio_get_device(group, vdev->vbasedev.name, &vdev->vbasedev, &err);
if (ret) { if (ret) {
error_setg_errno(&err, -ret, "failed to get device");
vfio_put_group(group); vfio_put_group(group);
goto error; goto error;
} }

View File

@ -607,11 +607,10 @@ static int vfio_base_device_init(VFIODevice *vbasedev)
return -EBUSY; return -EBUSY;
} }
} }
ret = vfio_get_device(group, vbasedev->name, vbasedev); ret = vfio_get_device(group, vbasedev->name, vbasedev, &err);
if (ret) { if (ret) {
error_report("vfio: failed to get device %s", vbasedev->name);
vfio_put_group(group); vfio_put_group(group);
return ret; goto error;
} }
ret = vfio_populate_device(vbasedev); ret = vfio_populate_device(vbasedev);

View File

@ -158,7 +158,7 @@ void vfio_reset_handler(void *opaque);
VFIOGroup *vfio_get_group(int groupid, AddressSpace *as, Error **errp); VFIOGroup *vfio_get_group(int groupid, AddressSpace *as, Error **errp);
void vfio_put_group(VFIOGroup *group); void vfio_put_group(VFIOGroup *group);
int vfio_get_device(VFIOGroup *group, const char *name, int vfio_get_device(VFIOGroup *group, const char *name,
VFIODevice *vbasedev); VFIODevice *vbasedev, Error **errp);
extern const MemoryRegionOps vfio_region_ops; extern const MemoryRegionOps vfio_region_ops;
extern QLIST_HEAD(vfio_group_head, VFIOGroup) vfio_group_list; extern QLIST_HEAD(vfio_group_head, VFIOGroup) vfio_group_list;