Commit c1d82215 authored by Alexander Mikhalitsyn's avatar Alexander Mikhalitsyn Committed by Miklos Szeredi

fuse: support idmapped ->permission inode op

We only cover the case when "default_permissions" flag
is used. A reason for that is that otherwise all the permission
checks are done in the userspace and we have to deal with
VFS idmapping in the userspace (which is bad), alternatively
we have to provide the userspace with idmapped req->in.h.uid/req->in.h.gid
which is also not align with VFS idmaps philosophy.
Signed-off-by: default avatarAlexander Mikhalitsyn <aleksandr.mikhalitsyn@canonical.com>
Reviewed-by: default avatarChristian Brauner <brauner@kernel.org>
Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
parent 2a8c810d
...@@ -1545,7 +1545,7 @@ static int fuse_permission(struct mnt_idmap *idmap, ...@@ -1545,7 +1545,7 @@ static int fuse_permission(struct mnt_idmap *idmap,
} }
if (fc->default_permissions) { if (fc->default_permissions) {
err = generic_permission(&nop_mnt_idmap, inode, mask); err = generic_permission(idmap, inode, mask);
/* If permission is denied, try to refresh file /* If permission is denied, try to refresh file
attributes. This is also needed, because the root attributes. This is also needed, because the root
...@@ -1553,7 +1553,7 @@ static int fuse_permission(struct mnt_idmap *idmap, ...@@ -1553,7 +1553,7 @@ static int fuse_permission(struct mnt_idmap *idmap,
if (err == -EACCES && !refreshed) { if (err == -EACCES && !refreshed) {
err = fuse_perm_getattr(inode, mask); err = fuse_perm_getattr(inode, mask);
if (!err) if (!err)
err = generic_permission(&nop_mnt_idmap, err = generic_permission(idmap,
inode, mask); inode, mask);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment