]> git.baikalelectronics.ru Git - kernel.git/commitdiff
fs: hold writers when changing mount's idmapping
authorChristian Brauner <christian.brauner@ubuntu.com>
Tue, 10 May 2022 09:58:40 +0000 (11:58 +0200)
committerChristian Brauner (Microsoft) <brauner@kernel.org>
Thu, 12 May 2022 08:12:00 +0000 (10:12 +0200)
Hold writers when changing a mount's idmapping to make it more robust.

The vfs layer takes care to retrieve the idmapping of a mount once
ensuring that the idmapping used for vfs permission checking is
identical to the idmapping passed down to the filesystem.

For ioctl codepaths the filesystem itself is responsible for taking the
idmapping into account if they need to. While all filesystems with
FS_ALLOW_IDMAP raised take the same precautions as the vfs we should
enforce it explicitly by making sure there are no active writers on the
relevant mount while changing the idmapping.

This is similar to turning a mount ro with the difference that in
contrast to turning a mount ro changing the idmapping can only ever be
done once while a mount can transition between ro and rw as much as it
wants.

This is a minor user-visible change. But it is extremely unlikely to
matter. The caller must've created a detached mount via OPEN_TREE_CLONE
and then handed that O_PATH fd to another process or thread which then
must've gotten a writable fd for that mount and started creating files
in there while the caller is still changing mount properties. While not
impossible it will be an extremely rare corner-case and should in
general be considered a bug in the application. Consider making a mount
MOUNT_ATTR_NOEXEC or MOUNT_ATTR_NODEV while allowing someone else to
perform lookups or exec'ing in parallel by handing them a copy of the
OPEN_TREE_CLONE fd or another fd beneath that mount.

Link: https://lore.kernel.org/r/20220510095840.152264-1-brauner@kernel.org
Cc: Seth Forshee <seth.forshee@digitalocean.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: linux-fsdevel@vger.kernel.org
Signed-off-by: Christian Brauner (Microsoft) <brauner@kernel.org>
fs/namespace.c

index afe2b64b14f1fa8e8bd9fa1dc1b2726f2df87faf..41461f55c0390294fd0aa571b897e32419878cf5 100644 (file)
@@ -4026,8 +4026,9 @@ static int can_idmap_mount(const struct mount_kattr *kattr, struct mount *mnt)
 static inline bool mnt_allow_writers(const struct mount_kattr *kattr,
                                     const struct mount *mnt)
 {
-       return !(kattr->attr_set & MNT_READONLY) ||
-              (mnt->mnt.mnt_flags & MNT_READONLY);
+       return (!(kattr->attr_set & MNT_READONLY) ||
+               (mnt->mnt.mnt_flags & MNT_READONLY)) &&
+              !kattr->mnt_userns;
 }
 
 static int mount_setattr_prepare(struct mount_kattr *kattr, struct mount *mnt)