mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
do_add_mount()/umount -l races
normally we deal with lock_mount()/umount races by checking that
mountpoint to be is still in our namespace after lock_mount() has
been done. However, do_add_mount() skips that check when called
with MNT_SHRINKABLE in flags (i.e. from finish_automount()). The
reason is that ->mnt_ns may be a temporary namespace created exactly
to contain automounts a-la NFS4 referral handling. It's not the
namespace of the caller, though, so check_mnt() would fail here.
We still need to check that ->mnt_ns is non-NULL in that case,
though.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
(cherry picked from commit 156cacb1d0
)
This commit is contained in:
parent
32d9bbb081
commit
57e87fa69d
1 changed files with 8 additions and 2 deletions
|
@ -1829,8 +1829,14 @@ static int do_add_mount(struct mount *newmnt, struct path *path, int mnt_flags)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
err = -EINVAL;
|
err = -EINVAL;
|
||||||
if (!(mnt_flags & MNT_SHRINKABLE) && !check_mnt(real_mount(path->mnt)))
|
if (unlikely(!check_mnt(real_mount(path->mnt)))) {
|
||||||
|
/* that's acceptable only for automounts done in private ns */
|
||||||
|
if (!(mnt_flags & MNT_SHRINKABLE))
|
||||||
goto unlock;
|
goto unlock;
|
||||||
|
/* ... and for those we'd better have mountpoint still alive */
|
||||||
|
if (!real_mount(path->mnt)->mnt_ns)
|
||||||
|
goto unlock;
|
||||||
|
}
|
||||||
|
|
||||||
/* Refuse the same filesystem on the same mount point */
|
/* Refuse the same filesystem on the same mount point */
|
||||||
err = -EBUSY;
|
err = -EBUSY;
|
||||||
|
|
Loading…
Reference in a new issue