On a Wednesday in 2022, Peter Krempa wrote:
For now we have only one code path ('vdpa' interface) which
actually
cleans up the fdset after it's done, but there are more device types
using fdsets.
In order to unify the handling of fdsets the removal code will now be
able to remove fdsets based on a prefix of the 'opaque' field, which
we'll always prefix with a device alias or e.g. node name once fdsets
are also used for disk backing.
To keep compatibility with old qemus, retain the possibility for the
QEMUs
VDPA interface to use the path.
Signed-off-by: Peter Krempa <pkrempa(a)redhat.com>
---
src/qemu/qemu_hotplug.c | 19 ++++++++++++-------
1 file changed, 12 insertions(+), 7 deletions(-)
diff --git a/src/qemu/qemu_hotplug.c b/src/qemu/qemu_hotplug.c
index 3264f287c3..03b7ca30de 100644
--- a/src/qemu/qemu_hotplug.c
+++ b/src/qemu/qemu_hotplug.c
@@ -140,18 +140,21 @@ qemuDomainDeleteDevice(virDomainObj *vm,
/**
* qemuHotplugRemoveFDSet:
* @mon: monitor object
- * @fdname: the 'opaque' string used as a name for the FD
+ * @prefix: the prefix of FD names ('opaque' filed) to delete
*field
+ * @alternate: alternate name for FD, for historical usage (may be
NULL)
*
* Looks up the 'fdset' by looking for a fd inside one of the fdsets which
- * has the opaque string set to @fdname. Removes the whole fdset which contains
- * the fd.
+ * has the opaque string starting with @prefix. Removes the whole fdset which
+ * contains the fd. Alternatively if @alternate is specified fdsets having a fd
+ * with that exact 'opaque' string is removed too.
*
* Errors are logged, but this is a best-effort hot-unplug cleanup helper so it's
* pointless to return a value.
*/
static void
qemuHotplugRemoveFDSet(qemuMonitor *mon,
- const char *fdname)
+ const char *prefix,
+ const char *alternate)
{
g_autoptr(qemuMonitorFdsets) fdsets = NULL;
size_t i;
Reviewed-by: Ján Tomko <jtomko(a)redhat.com>
Jano