mnt: Carefully set CL_UNPRIVILEGED in clone_mnt
[linux-2.6-block.git] / fs / namespace.c
index e8d1ffa7f132e9f32e72092cf0b3b2e97da41002..f87a90b98da2759a2014fc0eab3a51218cdb6e95 100644 (file)
@@ -963,7 +963,8 @@ static struct mount *clone_mnt(struct mount *old, struct dentry *root,
        }
 
        /* Don't allow unprivileged users to reveal what is under a mount */
-       if ((flag & CL_UNPRIVILEGED) && list_empty(&old->mnt_expire))
+       if ((flag & CL_UNPRIVILEGED) &&
+           (!(flag & CL_EXPIRE) || list_empty(&old->mnt_expire)))
                mnt->mnt.mnt_flags |= MNT_LOCKED;
 
        atomic_inc(&sb->s_active);