From: Pavel Hrdina Date: Sun, 15 Feb 2026 18:28:16 +0000 (+0100) Subject: qemu: Convert vfioDeviceFd to qemuFDPassDirect X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=4611f227c7882c8b9237da5e2fab21932ef6bd51;p=thirdparty%2Flibvirt.git qemu: Convert vfioDeviceFd to qemuFDPassDirect This cleans up creating QEMU command line and makes it easier when adding hotplug support. Signed-off-by: Pavel Hrdina Reviewed-by: Michal Privoznik --- diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c index 204fdf152b..91eb3cb27d 100644 --- a/src/qemu/qemu_command.c +++ b/src/qemu/qemu_command.c @@ -4818,12 +4818,10 @@ qemuBuildPCIHostdevDevProps(const virDomainDef *def, pcisrc->driver.iommufd == VIR_TRISTATE_BOOL_YES) { qemuDomainHostdevPrivate *hostdevPriv = QEMU_DOMAIN_HOSTDEV_PRIVATE(dev); - if (hostdevPriv->vfioDeviceFd != -1) { - g_autofree char *fdstr = g_strdup_printf("%d", hostdevPriv->vfioDeviceFd); - if (virJSONValueObjectAdd(&props, "S:fd", fdstr, NULL) < 0) - return NULL; - hostdevPriv->vfioDeviceFd = -1; - } + if (virJSONValueObjectAdd(&props, + "S:fd", qemuFDPassDirectGetPath(hostdevPriv->vfioDeviceFd), + NULL) < 0) + return NULL; } if (qemuBuildDeviceAddressProps(props, def, dev->info) < 0) @@ -5273,10 +5271,7 @@ qemuBuildHostdevCommandLine(virCommand *cmd, if (subsys->u.pci.driver.iommufd == VIR_TRISTATE_BOOL_YES) { qemuDomainHostdevPrivate *hostdevPriv = QEMU_DOMAIN_HOSTDEV_PRIVATE(hostdev); - if (hostdevPriv->vfioDeviceFd != -1) { - virCommandPassFD(cmd, hostdevPriv->vfioDeviceFd, - VIR_COMMAND_PASS_FD_CLOSE_PARENT); - } + qemuFDPassDirectTransferCommand(hostdevPriv->vfioDeviceFd, cmd); } if (!(devprops = qemuBuildPCIHostdevDevProps(def, hostdev))) diff --git a/src/qemu/qemu_domain.c b/src/qemu/qemu_domain.c index d9cd9324e0..ada9d3431c 100644 --- a/src/qemu/qemu_domain.c +++ b/src/qemu/qemu_domain.c @@ -1245,7 +1245,7 @@ qemuDomainHostdevPrivateDispose(void *obj) { qemuDomainHostdevPrivate *priv = obj; - VIR_FORCE_CLOSE(priv->vfioDeviceFd); + g_clear_pointer(&priv->vfioDeviceFd, qemuFDPassDirectFree); } @@ -1271,7 +1271,7 @@ qemuDomainHostdevPrivateNew(void) if (!(priv = virObjectNew(qemuDomainHostdevPrivateClass))) return NULL; - priv->vfioDeviceFd = -1; + priv->vfioDeviceFd = NULL; return (virObject *) priv; } diff --git a/src/qemu/qemu_domain.h b/src/qemu/qemu_domain.h index c6430b1bfb..fa7d4ab40f 100644 --- a/src/qemu/qemu_domain.h +++ b/src/qemu/qemu_domain.h @@ -463,7 +463,7 @@ struct _qemuDomainHostdevPrivate { virObject parent; /* VFIO device file descriptor for iommufd passthrough */ - int vfioDeviceFd; + qemuFDPassDirect *vfioDeviceFd; }; diff --git a/src/qemu/qemu_process.c b/src/qemu/qemu_process.c index c814f992bb..fc7e7bc980 100644 --- a/src/qemu/qemu_process.c +++ b/src/qemu/qemu_process.c @@ -7714,10 +7714,14 @@ qemuProcessOpenVfioDeviceFd(virDomainHostdevDef *hostdev) { qemuDomainHostdevPrivate *hostdevPriv = QEMU_DOMAIN_HOSTDEV_PRIVATE(hostdev); virDomainHostdevSubsysPCI *pci = &hostdev->source.subsys.u.pci; + g_autofree char *name = g_strdup_printf("hostdev-%s-fd", hostdev->info->alias); + int vfioDeviceFd; - if ((hostdevPriv->vfioDeviceFd = virPCIDeviceOpenVfioFd(&pci->addr)) < 0) + if ((vfioDeviceFd = virPCIDeviceOpenVfioFd(&pci->addr)) < 0) return -1; + hostdevPriv->vfioDeviceFd = qemuFDPassDirectNew(name, &vfioDeviceFd); + return 0; } diff --git a/tests/qemuxmlconftest.c b/tests/qemuxmlconftest.c index 13055eef84..d2ab4a71b5 100644 --- a/tests/qemuxmlconftest.c +++ b/tests/qemuxmlconftest.c @@ -357,8 +357,10 @@ testQemuPrepareHostdevPCI(virDomainHostdevDef *hostdev) qemuDomainHostdevPrivate *hostdevPriv = QEMU_DOMAIN_HOSTDEV_PRIVATE(hostdev); if (virHostdevIsPCIDeviceWithIOMMUFD(hostdev)) { + g_autofree char *name = g_strdup_printf("hostdev-%s-fd", hostdev->info->alias); /* Use a placeholder FD value for tests */ - hostdevPriv->vfioDeviceFd = 0; + int vfioDeviceFD = 0; + hostdevPriv->vfioDeviceFd = qemuFDPassDirectNew(name, &vfioDeviceFD); } }