ab7a78
From edca5497554ccf8016681884aa732156a9773061 Mon Sep 17 00:00:00 2001
ab7a78
Message-Id: <edca5497554ccf8016681884aa732156a9773061@dist-git>
ab7a78
From: Michal Privoznik <mprivozn@redhat.com>
ab7a78
Date: Tue, 6 Sep 2022 13:43:58 +0200
ab7a78
Subject: [PATCH] qemu_namespace: Introduce qemuDomainNamespaceSetupPath()
ab7a78
ab7a78
Sometimes it may come handy to just bind mount a directory/file
ab7a78
into domain's namespace. Implement a thin wrapper over
ab7a78
qemuNamespaceMknodPaths() which has all the logic we need.
ab7a78
ab7a78
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
ab7a78
Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
ab7a78
(cherry picked from commit 5853d707189005a4ea5b2215e80853867b822fd9)
ab7a78
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2132177
ab7a78
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
ab7a78
---
ab7a78
 src/qemu/qemu_namespace.c | 19 +++++++++++++++++++
ab7a78
 src/qemu/qemu_namespace.h |  4 ++++
ab7a78
 2 files changed, 23 insertions(+)
ab7a78
ab7a78
diff --git a/src/qemu/qemu_namespace.c b/src/qemu/qemu_namespace.c
ab7a78
index fc286ab0be..74ffd6fb90 100644
ab7a78
--- a/src/qemu/qemu_namespace.c
ab7a78
+++ b/src/qemu/qemu_namespace.c
ab7a78
@@ -1398,6 +1398,25 @@ qemuNamespaceUnlinkPaths(virDomainObj *vm,
ab7a78
 }
ab7a78
 
ab7a78
 
ab7a78
+int
ab7a78
+qemuDomainNamespaceSetupPath(virDomainObj *vm,
ab7a78
+                             const char *path,
ab7a78
+                             bool *created)
ab7a78
+{
ab7a78
+    g_autoptr(virGSListString) paths = NULL;
ab7a78
+
ab7a78
+    if (!qemuDomainNamespaceEnabled(vm, QEMU_DOMAIN_NS_MOUNT))
ab7a78
+        return 0;
ab7a78
+
ab7a78
+    paths = g_slist_prepend(paths, g_strdup(path));
ab7a78
+
ab7a78
+    if (qemuNamespaceMknodPaths(vm, paths, created) < 0)
ab7a78
+        return -1;
ab7a78
+
ab7a78
+    return 0;
ab7a78
+}
ab7a78
+
ab7a78
+
ab7a78
 int
ab7a78
 qemuDomainNamespaceSetupDisk(virDomainObj *vm,
ab7a78
                              virStorageSource *src,
ab7a78
diff --git a/src/qemu/qemu_namespace.h b/src/qemu/qemu_namespace.h
ab7a78
index 020aca13d8..1ab9322061 100644
ab7a78
--- a/src/qemu/qemu_namespace.h
ab7a78
+++ b/src/qemu/qemu_namespace.h
ab7a78
@@ -49,6 +49,10 @@ void qemuDomainDestroyNamespace(virQEMUDriver *driver,
ab7a78
 
ab7a78
 bool qemuDomainNamespaceAvailable(qemuDomainNamespace ns);
ab7a78
 
ab7a78
+int qemuDomainNamespaceSetupPath(virDomainObj *vm,
ab7a78
+                                 const char *path,
ab7a78
+                                 bool *created);
ab7a78
+
ab7a78
 int qemuDomainNamespaceSetupDisk(virDomainObj *vm,
ab7a78
                                  virStorageSource *src,
ab7a78
                                  bool *created);
ab7a78
-- 
ab7a78
2.37.2
ab7a78