diff options
author | Eric W. Biederman <ebiederm@xmission.com> | 2014-07-28 16:26:53 -0700 |
---|---|---|
committer | Ziyan <jaraidaniel@gmail.com> | 2016-10-29 01:34:18 +0200 |
commit | 045b35811978bda95db69acd658956d935ce70dd (patch) | |
tree | f61bd4e0848e94e6032393b700d4073899485392 /fs | |
parent | 6b43c1e526d9ec1bc7ab1692a5620568d8e5e0d4 (diff) | |
download | kernel_samsung_tuna-045b35811978bda95db69acd658956d935ce70dd.zip kernel_samsung_tuna-045b35811978bda95db69acd658956d935ce70dd.tar.gz kernel_samsung_tuna-045b35811978bda95db69acd658956d935ce70dd.tar.bz2 |
mnt: Only change user settable mount flags in remount
commit a6138db815df5ee542d848318e5dae681590fccd upstream.
Kenton Varda <kenton@sandstorm.io> discovered that by remounting a
read-only bind mount read-only in a user namespace the
MNT_LOCK_READONLY bit would be cleared, allowing an unprivileged user
to the remount a read-only mount read-write.
Correct this by replacing the mask of mount flags to preserve
with a mask of mount flags that may be changed, and preserve
all others. This ensures that any future bugs with this mask and
remount will fail in an easy to detect way where new mount flags
simply won't change.
Change-Id: I8ab8bda03a14b9b43e78f1dc6c818bbec048e986
Acked-by: Serge E. Hallyn <serge.hallyn@ubuntu.com>
Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
Cc: Francis Moreau <francis.moro@gmail.com>
Signed-off-by: Zefan Li <lizefan@huawei.com>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/namespace.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/namespace.c b/fs/namespace.c index 8815c8b..be146ad 100644 --- a/fs/namespace.c +++ b/fs/namespace.c @@ -1883,7 +1883,7 @@ static int do_remount(struct path *path, int flags, int mnt_flags, err = do_remount_sb(sb, flags, data, 0); if (!err) { br_write_lock(&vfsmount_lock); - mnt_flags |= path->mnt->mnt_flags & MNT_PROPAGATION_MASK; + mnt_flags |= path->mnt->mnt_flags & ~MNT_USER_SETTABLE_MASK; path->mnt->mnt_flags = mnt_flags; br_write_unlock(&vfsmount_lock); } |