attach_recursive_mnt() needs to hold vfsmount_lock over set_mnt_shared()
authorAl Viro <viro@zeniv.linux.org.uk>
Sat, 16 Jan 2010 17:57:40 +0000 (12:57 -0500)
committerAl Viro <viro@zeniv.linux.org.uk>
Sat, 16 Jan 2010 17:57:40 +0000 (12:57 -0500)
race in mnt_flags update

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/namespace.c

index 461090a..4de493e 100644 (file)
@@ -1354,12 +1354,12 @@ static int attach_recursive_mnt(struct vfsmount *source_mnt,
        if (err)
                goto out_cleanup_ids;
 
+       spin_lock(&vfsmount_lock);
+
        if (IS_MNT_SHARED(dest_mnt)) {
                for (p = source_mnt; p; p = next_mnt(p, source_mnt))
                        set_mnt_shared(p);
        }
-
-       spin_lock(&vfsmount_lock);
        if (parent_path) {
                detach_mnt(source_mnt, parent_path);
                attach_mnt(source_mnt, path);