summaryrefslogtreecommitdiff
diff options
authorAlberto Mardegan <alberto.mardegan@canonical.com>2022-05-25 14:08:36 +0300
committerGitHub <noreply@github.com>2022-05-25 14:08:36 +0300
commit84434d9a7333393ecea5c6489af3a2a8b673ad02 (patch)
tree1f0e3209fc76e4dba5bdc00efc5f2499f6240e90
parentace7d44281da0e797adf5cb94f768c6eb88c3fc0 (diff)
parentb93cf4e531c7cadfd926dac9b5da79767d9e3fb8 (diff)
Merge pull request #11786 from mardy/mount-support-cleanups
cmd/snap-confine: mount support cleanups
-rw-r--r--cmd/snap-confine/mount-support-nvidia.c23
-rw-r--r--cmd/snap-confine/mount-support.h10
2 files changed, 20 insertions, 13 deletions
diff --git a/cmd/snap-confine/mount-support-nvidia.c b/cmd/snap-confine/mount-support-nvidia.c
index 64812b1edb..149ecb5dbe 100644
--- a/cmd/snap-confine/mount-support-nvidia.c
+++ b/cmd/snap-confine/mount-support-nvidia.c
@@ -35,17 +35,14 @@
#include "../libsnap-confine-private/cleanup-funcs.h"
#include "../libsnap-confine-private/string-utils.h"
#include "../libsnap-confine-private/utils.h"
+#include "mount-support.h"
#define SC_NVIDIA_DRIVER_VERSION_FILE "/sys/module/nvidia/version"
-// note: if the parent dir changes to something other than
-// the current /var/lib/snapd/lib then sc_mkdir_and_mount_and_bind
-// and sc_mkdir_and_mount_and_bind need updating.
-#define SC_LIB "/var/lib/snapd/lib"
-#define SC_LIBGL_DIR SC_LIB "/gl"
-#define SC_LIBGL32_DIR SC_LIB "/gl32"
-#define SC_VULKAN_DIR SC_LIB "/vulkan"
-#define SC_GLVND_DIR SC_LIB "/glvnd"
+#define SC_LIBGL_DIR SC_EXTRA_LIB_DIR "/gl"
+#define SC_LIBGL32_DIR SC_EXTRA_LIB_DIR "/gl32"
+#define SC_VULKAN_DIR SC_EXTRA_LIB_DIR "/vulkan"
+#define SC_GLVND_DIR SC_EXTRA_LIB_DIR "/glvnd"
#define SC_VULKAN_SOURCE_DIR "/usr/share/vulkan"
#define SC_EGL_VENDOR_SOURCE_DIR "/usr/share/glvnd"
@@ -590,13 +587,13 @@ void sc_mount_nvidia_driver(const char *rootfs_dir, const char *base_snap_name)
}
sc_identity old = sc_set_effective_identity(sc_root_group_identity());
- int res = mkdir(SC_LIB, 0755);
- if (res != 0 && errno != EEXIST) {
- die("cannot create " SC_LIB);
+ int res = sc_nonfatal_mkpath(SC_EXTRA_LIB_DIR, 0755);
+ if (res != 0) {
+ die("cannot create " SC_EXTRA_LIB_DIR);
}
- if (res == 0 && (chown(SC_LIB, 0, 0) < 0)) {
+ if (res == 0 && (chown(SC_EXTRA_LIB_DIR, 0, 0) < 0)) {
// Adjust the ownership only if we created the directory.
- die("cannot change ownership of " SC_LIB);
+ die("cannot change ownership of " SC_EXTRA_LIB_DIR);
}
(void)sc_set_effective_identity(old);
diff --git a/cmd/snap-confine/mount-support.h b/cmd/snap-confine/mount-support.h
index b2a96f3b2b..84f0b6de55 100644
--- a/cmd/snap-confine/mount-support.h
+++ b/cmd/snap-confine/mount-support.h
@@ -22,6 +22,16 @@
#include "snap-confine-invocation.h"
#include <sys/types.h>
+/* Base location where extra libraries might be made available to the snap.
+ * This is currently used for graphics drivers, but could pontentially be used
+ * for other goals as well.
+ *
+ * NOTE: do not bind-mount anything directly onto this directory! This is only
+ * a *base* directory: for exposing drivers and libraries, create a
+ * sub-directory in SC_EXTRA_LIB_DIR and use that one as the bind mount target.
+ */
+#define SC_EXTRA_LIB_DIR "/var/lib/snapd/lib"
+
/**
* Assuming a new mountspace, populate it accordingly.
*