]> git.ipfire.org Git - thirdparty/util-linux.git/commitdiff
libmount: improve EPERM interpretation
authorKarel Zak <kzak@redhat.com>
Thu, 3 Aug 2023 11:06:30 +0000 (13:06 +0200)
committerKarel Zak <kzak@redhat.com>
Thu, 3 Aug 2023 11:11:28 +0000 (13:11 +0200)
In some cases mount(2)/open_tree(2) returns EPERM for root user. In
this case libmount reports it as "mount point is not a directory".

It does not makes sense for bind mount where target could be a
regular file.

This patch is not ideal, the error handler is generic, but semantic
for new mount API and mount(2) is different. For example now it checks
for regular file, but the new API supports bind over symlinks, so
proper fix will require lstat() and S_ISLNK(), etc. We need to move
error messages to hook_mount.c and mount_mount_legacy.c to make it
more specific.

Fixes: https://github.com/util-linux/util-linux/issues/2413
Signed-off-by: Karel Zak <kzak@redhat.com>
libmount/src/context_mount.c

index 07971708bc8ff141330b1a3ff62d6dd057b4bf8a..dcc5eb97fbbf808284e2df881118a513a4bfe2ed 100644 (file)
@@ -1580,10 +1580,13 @@ int mnt_context_get_mount_excode(
                if (!buf)
                        break;
                if (geteuid() == 0) {
-                       if (mnt_safe_stat(tgt, &st) || !S_ISDIR(st.st_mode))
-                               snprintf(buf, bufsz, _("mount point is not a directory"));
-                       else
+
+                       if (mnt_safe_stat(tgt, &st) == 0
+                           && ((mflags & MS_BIND && S_ISREG(st.st_mode))
+                               || S_ISDIR(st.st_mode)))
                                snprintf(buf, bufsz, _("permission denied"));
+                       else
+                               snprintf(buf, bufsz, _("mount point is not a directory"));
                } else
                        snprintf(buf, bufsz, _("must be superuser to use mount"));
                break;