mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-09 14:35:25 +00:00
qemuDomainDetachDeviceUnlink: Unlink paths in one go
Simirarly to qemuDomainAttachDeviceMknodHelper() which was modified just a couple of commits ago, modify the unlink helper which is called on device detach so that it can unlink multiple files in one go instead of forking off for every single one of them. Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
parent
a83a2041eb
commit
5c86fbb72d
@ -1282,10 +1282,14 @@ qemuNamespaceMknodPaths(virDomainObjPtr vm G_GNUC_UNUSED,
|
|||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
qemuDomainDetachDeviceUnlinkHelper(pid_t pid G_GNUC_UNUSED,
|
qemuNamespaceUnlinkHelper(pid_t pid G_GNUC_UNUSED,
|
||||||
void *opaque)
|
void *opaque)
|
||||||
{
|
{
|
||||||
const char *path = opaque;
|
char **paths = opaque;
|
||||||
|
size_t i;
|
||||||
|
|
||||||
|
for (i = 0; paths[i]; i++) {
|
||||||
|
const char *path = paths[i];
|
||||||
|
|
||||||
VIR_DEBUG("Unlinking %s", path);
|
VIR_DEBUG("Unlinking %s", path);
|
||||||
if (unlink(path) < 0 && errno != ENOENT) {
|
if (unlink(path) < 0 && errno != ENOENT) {
|
||||||
@ -1293,36 +1297,9 @@ qemuDomainDetachDeviceUnlinkHelper(pid_t pid G_GNUC_UNUSED,
|
|||||||
_("Unable to remove device %s"), path);
|
_("Unable to remove device %s"), path);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static int
|
|
||||||
qemuDomainDetachDeviceUnlink(virQEMUDriverPtr driver G_GNUC_UNUSED,
|
|
||||||
virDomainObjPtr vm,
|
|
||||||
const char *file,
|
|
||||||
char * const *devMountsPath,
|
|
||||||
size_t ndevMountsPath)
|
|
||||||
{
|
|
||||||
size_t i;
|
|
||||||
|
|
||||||
if (STRPREFIX(file, QEMU_DEVPREFIX)) {
|
|
||||||
for (i = 0; i < ndevMountsPath; i++) {
|
|
||||||
if (STREQ(devMountsPath[i], "/dev"))
|
|
||||||
continue;
|
|
||||||
if (STRPREFIX(file, devMountsPath[i]))
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (i == ndevMountsPath) {
|
|
||||||
if (virProcessRunInMountNamespace(vm->pid,
|
|
||||||
qemuDomainDetachDeviceUnlinkHelper,
|
|
||||||
(void *)file) < 0)
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
g_strfreev(paths);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1335,6 +1312,7 @@ qemuDomainNamespaceUnlinkPaths(virDomainObjPtr vm,
|
|||||||
qemuDomainObjPrivatePtr priv = vm->privateData;
|
qemuDomainObjPrivatePtr priv = vm->privateData;
|
||||||
virQEMUDriverPtr driver = priv->driver;
|
virQEMUDriverPtr driver = priv->driver;
|
||||||
g_autoptr(virQEMUDriverConfig) cfg = NULL;
|
g_autoptr(virQEMUDriverConfig) cfg = NULL;
|
||||||
|
VIR_AUTOSTRINGLIST unlinkPaths = NULL;
|
||||||
char **devMountsPath = NULL;
|
char **devMountsPath = NULL;
|
||||||
size_t ndevMountsPath = 0;
|
size_t ndevMountsPath = 0;
|
||||||
size_t i;
|
size_t i;
|
||||||
@ -1351,11 +1329,28 @@ qemuDomainNamespaceUnlinkPaths(virDomainObjPtr vm,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
for (i = 0; i < npaths; i++) {
|
for (i = 0; i < npaths; i++) {
|
||||||
if (qemuDomainDetachDeviceUnlink(driver, vm, paths[i],
|
const char *file = paths[i];
|
||||||
devMountsPath, ndevMountsPath) < 0)
|
|
||||||
goto cleanup;
|
if (STRPREFIX(file, QEMU_DEVPREFIX)) {
|
||||||
|
for (i = 0; i < ndevMountsPath; i++) {
|
||||||
|
if (STREQ(devMountsPath[i], "/dev"))
|
||||||
|
continue;
|
||||||
|
if (STRPREFIX(file, devMountsPath[i]))
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (i == ndevMountsPath &&
|
||||||
|
virStringListAdd(&unlinkPaths, file) < 0)
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (unlinkPaths &&
|
||||||
|
virProcessRunInMountNamespace(vm->pid,
|
||||||
|
qemuNamespaceUnlinkHelper,
|
||||||
|
unlinkPaths) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
cleanup:
|
cleanup:
|
||||||
virStringListFreeCount(devMountsPath, ndevMountsPath);
|
virStringListFreeCount(devMountsPath, ndevMountsPath);
|
||||||
|
Loading…
Reference in New Issue
Block a user